Add support for login with Google. Note that this CL is not complete
This commit is contained in:
		
							parent
							
								
									b9c6c4c2f2
								
							
						
					
					
						commit
						2597bcef3f
					
				
					 10 changed files with 231 additions and 83 deletions
				
			
		
							
								
								
									
										17
									
								
								static/directives/external-login-button.html
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										17
									
								
								static/directives/external-login-button.html
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,17 @@ | |||
| <span class="external-login-button-element"> | ||||
|   <span ng-if="provider == 'github'"> | ||||
|     <a href="javascript:void(0)" class="btn btn-primary btn-block" quay-require="['GITHUB_LOGIN']" ng-click="startSignin('github')" style="margin-bottom: 10px"> | ||||
|       <i class="fa fa-github fa-lg"></i>  | ||||
|       <span ng-if="action != 'attach'">Sign In with GitHub</span> | ||||
|       <span ng-if="action == 'attach'">Attach to GitHub Account</span> | ||||
|     </a> | ||||
|   </span> | ||||
|    | ||||
|   <span ng-if="provider == 'google'"> | ||||
|     <a href="javascript:void(0)" class="btn btn-primary btn-block" quay-require="['GOOGLE_LOGIN']"  ng-click="startSignin('google')"> | ||||
|       <i class="fa fa-google fa-lg"></i>  | ||||
|       <span ng-if="action != 'attach'">Sign In with Google</span> | ||||
|       <span ng-if="action == 'attach'">Attach to Google Account</span> | ||||
|     </a> | ||||
|   </span> | ||||
| </span> | ||||
|  | @ -11,10 +11,8 @@ | |||
|       <span class="inner-text">OR</span> | ||||
|     </span> | ||||
| 
 | ||||
|     <a id="github-signin-link" class="btn btn-primary btn-lg btn-block" href="javascript:void(0)" ng-click="showGithub()" | ||||
|        quay-require="['GITHUB_LOGIN']"> | ||||
|       <i class="fa fa-github fa-lg"></i> Sign In with GitHub | ||||
|     </a> | ||||
|     <div class="external-login-button" provider="github" redirect-url="redirectUrl" sign-in-started="markStarted()"></div> | ||||
|     <div class="external-login-button" provider="google" redirect-url="redirectUrl" sign-in-started="markStarted()"></div> | ||||
|   </form>  | ||||
| 
 | ||||
|   <div class="alert alert-danger" ng-show="invalidCredentials">Invalid username or password.</div> | ||||
|  |  | |||
|  | @ -18,10 +18,8 @@ | |||
|         <i class="fa fa-circle"></i> | ||||
|         <span class="inner-text">OR</span> | ||||
|       </span> | ||||
|       <a href="https://github.com/login/oauth/authorize?client_id={{ githubClientId }}&scope=user:email{{ github_state_clause }}" | ||||
|          class="btn btn-primary btn-block" quay-require="['GITHUB_LOGIN']"> | ||||
|         <i class="fa fa-github fa-lg"></i> Sign In with GitHub | ||||
|       </a> | ||||
|       <div class="external-login-button" provider="github"></div> | ||||
|       <div class="external-login-button" provider="google"></div> | ||||
|       <p class="help-block" quay-require="['BILLING']">No credit card required.</p> | ||||
|     </div> | ||||
|   </form> | ||||
|  |  | |||
							
								
								
									
										100
									
								
								static/js/app.js
									
										
									
									
									
								
							
							
						
						
									
										100
									
								
								static/js/app.js
									
										
									
									
									
								
							|  | @ -1278,10 +1278,41 @@ quayApp = angular.module('quay', quayDependencies, function($provide, cfpLoading | |||
|       var keyService = {} | ||||
| 
 | ||||
|       keyService['stripePublishableKey'] = Config['STRIPE_PUBLISHABLE_KEY']; | ||||
| 
 | ||||
|       keyService['githubClientId'] = Config['GITHUB_CLIENT_ID']; | ||||
|       keyService['githubLoginClientId'] = Config['GITHUB_LOGIN_CLIENT_ID']; | ||||
|       keyService['githubRedirectUri'] = Config.getUrl('/oauth2/github/callback'); | ||||
| 
 | ||||
|       keyService['googleLoginClientId'] = Config['GOOGLE_LOGIN_CLIENT_ID']; | ||||
|       keyService['googleRedirectUri'] = Config.getUrl('/oauth2/google/callback'); | ||||
| 
 | ||||
|       keyService['googleLoginUrl'] = 'https://accounts.google.com/o/oauth2/auth?response_type=code&'; | ||||
|       keyService['githubLoginUrl'] = 'https://github.com/login/oauth/authorize?'; | ||||
| 
 | ||||
|       keyService['googleLoginScope'] = 'openid email'; | ||||
|       keyService['githubLoginScope'] = 'user:email'; | ||||
| 
 | ||||
|       keyService.getExternalLoginUrl = function(service, action) { | ||||
|         var state_clause = ''; | ||||
|         if (Config.MIXPANEL_KEY && window.mixpanel) { | ||||
|           if (mixpanel.get_distinct_id !== undefined) { | ||||
|             state_clause = "&state=" + encodeURIComponent(mixpanel.get_distinct_id()); | ||||
|           } | ||||
|         } | ||||
| 
 | ||||
|         var client_id = keyService[service + 'LoginClientId']; | ||||
|         var scope = keyService[service + 'LoginScope']; | ||||
|         var redirect_uri = keyService[service + 'RedirectUri']; | ||||
|         if (action == 'attach') { | ||||
|           redirect_uri += '/attach'; | ||||
|         } | ||||
| 
 | ||||
|         var url = keyService[service + 'LoginUrl'] + 'client_id=' + client_id + '&scope=' + scope + | ||||
|           '&redirect_uri=' + redirect_uri + state_clause; | ||||
| 
 | ||||
|         return url; | ||||
|       }; | ||||
| 
 | ||||
|       return keyService; | ||||
|     }]); | ||||
|    | ||||
|  | @ -2150,6 +2181,41 @@ quayApp.directive('userSetup', function () { | |||
| }); | ||||
| 
 | ||||
| 
 | ||||
| quayApp.directive('externalLoginButton', function () { | ||||
|   var directiveDefinitionObject = { | ||||
|     priority: 0, | ||||
|     templateUrl: '/static/directives/external-login-button.html', | ||||
|     replace: false, | ||||
|     transclude: true, | ||||
|     restrict: 'C', | ||||
|     scope: { | ||||
|       'signInStarted': '&signInStarted', | ||||
|       'redirectUrl': '=redirectUrl', | ||||
|       'provider': '@provider', | ||||
|       'action': '@action' | ||||
|     }, | ||||
|     controller: function($scope, $location, $timeout, ApiService, KeyService, UserService, CookieService, Features, Config) { | ||||
|       $scope.startSignin = function(service) { | ||||
|         $scope.signInStarted({'service': service}); | ||||
| 
 | ||||
|         var url = KeyService.getExternalLoginUrl(service, $scope.action || 'login'); | ||||
|          | ||||
|         // Save the redirect URL in a cookie so that we can redirect back after the service returns to us.
 | ||||
|         var redirectURL = $scope.redirectUrl || window.location.toString(); | ||||
|         CookieService.putPermanent('quay.redirectAfterLoad', redirectURL); | ||||
| 
 | ||||
|         // Needed to ensure that UI work done by the started callback is finished before the location
 | ||||
|         // changes.
 | ||||
|         $timeout(function() { | ||||
|           document.location = url; | ||||
|         }, 250); | ||||
|       }; | ||||
|     } | ||||
|   }; | ||||
|   return directiveDefinitionObject; | ||||
| }); | ||||
| 
 | ||||
| 
 | ||||
| quayApp.directive('signinForm', function () { | ||||
|   var directiveDefinitionObject = { | ||||
|     priority: 0, | ||||
|  | @ -2163,29 +2229,6 @@ quayApp.directive('signinForm', function () { | |||
|       'signedIn': '&signedIn' | ||||
|     }, | ||||
|     controller: function($scope, $location, $timeout, ApiService, KeyService, UserService, CookieService, Features, Config) { | ||||
|       $scope.showGithub = function() { | ||||
|         if (!Features.GITHUB_LOGIN) { return; } | ||||
| 
 | ||||
|         $scope.markStarted(); | ||||
| 
 | ||||
|         var mixpanelDistinctIdClause = ''; | ||||
|         if (Config.MIXPANEL_KEY && mixpanel.get_distinct_id !== undefined) { | ||||
|           $scope.mixpanelDistinctIdClause = "&state=" + encodeURIComponent(mixpanel.get_distinct_id()); | ||||
|         } | ||||
| 
 | ||||
|         // Save the redirect URL in a cookie so that we can redirect back after GitHub returns to us.
 | ||||
|         var redirectURL = $scope.redirectUrl || window.location.toString(); | ||||
|         CookieService.putPermanent('quay.redirectAfterLoad', redirectURL); | ||||
|          | ||||
|         // Needed to ensure that UI work done by the started callback is finished before the location
 | ||||
|         // changes.
 | ||||
|         $timeout(function() { | ||||
|           var url = 'https://github.com/login/oauth/authorize?client_id=' + encodeURIComponent(KeyService.githubLoginClientId) + | ||||
|                 '&scope=user:email' + mixpanelDistinctIdClause; | ||||
|           document.location = url; | ||||
|         }, 250); | ||||
|       }; | ||||
| 
 | ||||
|       $scope.markStarted = function() { | ||||
|        if ($scope.signInStarted != null) { | ||||
|          $scope.signInStarted(); | ||||
|  | @ -2235,18 +2278,9 @@ quayApp.directive('signupForm', function () { | |||
|     scope: { | ||||
| 
 | ||||
|     }, | ||||
|     controller: function($scope, $location, $timeout, ApiService, KeyService, UserService, Config, UIService) {       | ||||
|     controller: function($scope, $location, $timeout, ApiService, KeyService, UserService, Config, UIService) {    | ||||
|       $('.form-signup').popover(); | ||||
| 
 | ||||
|       if (Config.MIXPANEL_KEY) { | ||||
|         angulartics.waitForVendorApi(mixpanel, 500, function(loadedMixpanel) { | ||||
|           var mixpanelId = loadedMixpanel.get_distinct_id(); | ||||
|           $scope.github_state_clause = '&state=' + mixpanelId;     | ||||
|         }); | ||||
|       } | ||||
| 
 | ||||
|       $scope.githubClientId = KeyService.githubLoginClientId; | ||||
| 
 | ||||
|       $scope.awaitingConfirmation = false; | ||||
|       $scope.registering = false; | ||||
| 
 | ||||
|  |  | |||
|  | @ -1681,6 +1681,10 @@ function UserAdminCtrl($scope, $timeout, $location, ApiService, PlanService, Use | |||
|             $scope.githubLogin = resp.login; | ||||
|           }); | ||||
|         } | ||||
| 
 | ||||
|         if ($scope.cuser.logins[i].service == 'google') { | ||||
|           $scope.hasGoogleLogin = true; | ||||
|         } | ||||
|       } | ||||
|     } | ||||
|   }); | ||||
|  | @ -1697,7 +1701,6 @@ function UserAdminCtrl($scope, $timeout, $location, ApiService, PlanService, Use | |||
|   $scope.convertStep = 0; | ||||
|   $scope.org = {}; | ||||
|   $scope.githubRedirectUri = KeyService.githubRedirectUri; | ||||
|   $scope.githubClientId = KeyService.githubLoginClientId; | ||||
|   $scope.authorizedApps = null; | ||||
| 
 | ||||
|   $scope.logsShown = 0; | ||||
|  |  | |||
|  | @ -33,7 +33,7 @@ | |||
|         <li quay-classes="{'!Features.BILLING': 'active'}"><a href="javascript:void(0)" data-toggle="tab" data-target="#email">Account E-mail</a></li> | ||||
|         <li><a href="javascript:void(0)" data-toggle="tab" data-target="#robots">Robot Accounts</a></li> | ||||
|         <li><a href="javascript:void(0)" data-toggle="tab" data-target="#password">Change Password</a></li> | ||||
|         <li><a href="javascript:void(0)" data-toggle="tab" data-target="#github" quay-require="['GITHUB_LOGIN']">GitHub Login</a></li> | ||||
|         <li><a href="javascript:void(0)" data-toggle="tab" data-target="#external" quay-show="Features.GITHUB_LOGIN || Features.GOOGLE_LOGIN">External Logins</a></li> | ||||
|         <li><a href="javascript:void(0)" data-toggle="tab" data-target="#authorized" ng-click="loadAuthedApps()">Authorized Applications</a></li> | ||||
|         <li quay-show="Features.USER_LOG_ACCESS || hasPaidBusinessPlan"> | ||||
|           <a href="javascript:void(0)" data-toggle="tab" data-target="#logs" ng-click="loadLogs()">Usage Logs</a> | ||||
|  | @ -162,12 +162,14 @@ | |||
|           </div> | ||||
|         </div> | ||||
| 
 | ||||
|         <!-- Github tab --> | ||||
|         <div id="github" class="tab-pane" quay-require="['GITHUB_LOGIN']"> | ||||
|         <!-- External Login tab --> | ||||
|         <div id="external" class="tab-pane" quay-show="Features.GITHUB_LOGIN || Features.GOOGLE_LOGIN"> | ||||
|           <div class="loading" ng-show="!cuser"> | ||||
|             <div class="quay-spinner 3x"></div> | ||||
|           </div> | ||||
|           <div class="row" ng-show="cuser"> | ||||
|            | ||||
|           <!-- Github --> | ||||
|           <div class="row" quay-show="cuser && Features.GITHUB_LOGIN"> | ||||
|             <div class="panel"> | ||||
|               <div class="panel-title">GitHub Login:</div> | ||||
|               <div class="panel-body"> | ||||
|  | @ -175,12 +177,28 @@ | |||
|                   <i class="fa fa-github fa-lg" style="margin-right: 6px;" data-title="GitHub" bs-tooltip="tooltip.title"></i> | ||||
|                   <b><a href="https://github.com/{{githubLogin}}" target="_blank">{{githubLogin}}</a></b> | ||||
|                 </div> | ||||
|                 <div ng-show="!githubLogin" class="col-md-8"> | ||||
|                   <a href="https://github.com/login/oauth/authorize?client_id={{ githubClientId }}&scope=user:email{{ github_state_clause }}&redirect_uri={{ githubRedirectUri }}/attach" class="btn btn-primary"><i class="fa fa-github fa-lg"></i> Connect with GitHub</a> | ||||
|                 <div ng-show="!githubLogin" class="col-md-4"> | ||||
|                   <span class="external-login-button" provider="github" action="attach"></span> | ||||
|                 </div> | ||||
|               </div> | ||||
|             </div> | ||||
|           </div> | ||||
| 
 | ||||
|           <!-- Google --> | ||||
|           <div class="row" quay-show="cuser && Features.GOOGLE_LOGIN"> | ||||
|             <div class="panel"> | ||||
|               <div class="panel-title">Google Login:</div> | ||||
|               <div class="panel-body"> | ||||
|                 <div ng-show="hasGoogleLogin" class="lead col-md-8"> | ||||
|                   Account tied to your Google account. | ||||
|                 </div> | ||||
|                 <div ng-show="!hasGoogleLogin" class="col-md-4"> | ||||
|                   <span class="external-login-button" provider="google" action="attach"></span> | ||||
|                 </div> | ||||
|               </div> | ||||
|             </div> | ||||
|           </div> | ||||
| 
 | ||||
|         </div> | ||||
|          | ||||
|         <!-- Robot accounts tab --> | ||||
|  |  | |||
		Reference in a new issue