mirror of
				https://gitcode.com/gitea/gitea.git
				synced 2025-10-25 20:35:50 +08:00 
			
		
		
		
	OAuth2 auto-register (#5123)
* Refactored handleOAuth2SignIn in routers/user/auth.go The function handleOAuth2SignIn was called twice but some code path could only be reached by one of the invocations. Moved the unnecessary code path out of handleOAuth2SignIn. * Refactored user creation There was common code to create a user and display the correct error message. And after the creation the only user should be an admin and if enabled a confirmation email should be sent. This common code is now abstracted into two functions and a helper function to call both. * Added auto-register for OAuth2 users If enabled new OAuth2 users will be registered with their OAuth2 details. The UserID, Name and Email fields from the gothUser are used. Therefore the OpenID Connect provider needs additional scopes to return the coresponding claims. * Added error for missing fields in OAuth2 response * Linking and auto linking on oauth2 registration * Set default username source to nickname * Add automatic oauth2 scopes for github and google * Add hint to change the openid connect scopes if fields are missing * Extend info about auto linking security risk Co-authored-by: Viktor Kuzmin <kvaster@gmail.com> Signed-off-by: Martin Michaelis <code@mgjm.de>
This commit is contained in:
		| @ -157,7 +157,11 @@ func createProvider(providerName, providerType, clientID, clientSecret, openIDCo | ||||
| 				emailURL = customURLMapping.EmailURL | ||||
| 			} | ||||
| 		} | ||||
| 		provider = github.NewCustomisedURL(clientID, clientSecret, callbackURL, authURL, tokenURL, profileURL, emailURL) | ||||
| 		scopes := []string{} | ||||
| 		if setting.OAuth2Client.EnableAutoRegistration { | ||||
| 			scopes = append(scopes, "user:email") | ||||
| 		} | ||||
| 		provider = github.NewCustomisedURL(clientID, clientSecret, callbackURL, authURL, tokenURL, profileURL, emailURL, scopes...) | ||||
| 	case "gitlab": | ||||
| 		authURL := gitlab.AuthURL | ||||
| 		tokenURL := gitlab.TokenURL | ||||
| @ -175,9 +179,13 @@ func createProvider(providerName, providerType, clientID, clientSecret, openIDCo | ||||
| 		} | ||||
| 		provider = gitlab.NewCustomisedURL(clientID, clientSecret, callbackURL, authURL, tokenURL, profileURL, "read_user") | ||||
| 	case "gplus": // named gplus due to legacy gplus -> google migration (Google killed Google+). This ensures old connections still work | ||||
| 		provider = google.New(clientID, clientSecret, callbackURL) | ||||
| 		scopes := []string{"email"} | ||||
| 		if setting.OAuth2Client.UpdateAvatar || setting.OAuth2Client.EnableAutoRegistration { | ||||
| 			scopes = append(scopes, "profile") | ||||
| 		} | ||||
| 		provider = google.New(clientID, clientSecret, callbackURL, scopes...) | ||||
| 	case "openidConnect": | ||||
| 		if provider, err = openidConnect.New(clientID, clientSecret, callbackURL, openIDConnectAutoDiscoveryURL); err != nil { | ||||
| 		if provider, err = openidConnect.New(clientID, clientSecret, callbackURL, openIDConnectAutoDiscoveryURL, setting.OAuth2Client.OpenIDConnectScopes...); err != nil { | ||||
| 			log.Warn("Failed to create OpenID Connect Provider with name '%s' with url '%s': %v", providerName, openIDConnectAutoDiscoveryURL, err) | ||||
| 		} | ||||
| 	case "twitter": | ||||
|  | ||||
		Reference in New Issue
	
	Block a user
	 Martin Michaelis
					Martin Michaelis