Add e-mail authorization to the repository notification flow. Also validates the creation of the other notification methods.
This commit is contained in:
		
							parent
							
								
									56fec63fcd
								
							
						
					
					
						commit
						34fc279092
					
				
					 15 changed files with 483 additions and 34 deletions
				
			
		|  | @ -4758,12 +4758,13 @@ quayApp.directive('createExternalNotificationDialog', function () { | |||
|       'counter': '=counter', | ||||
|       'notificationCreated': '¬ificationCreated' | ||||
|     }, | ||||
|     controller: function($scope, $element, ExternalNotificationData, ApiService) { | ||||
|     controller: function($scope, $element, ExternalNotificationData, ApiService, $timeout) { | ||||
|       $scope.currentEvent = null; | ||||
|       $scope.currentMethod = null; | ||||
|       $scope.creating = false; | ||||
|       $scope.status = ''; | ||||
|       $scope.currentConfig = {}; | ||||
|       $scope.clearCounter = 0; | ||||
|       $scope.unauthorizedEmail = false; | ||||
| 
 | ||||
|       $scope.events = ExternalNotificationData.getSupportedEvents(); | ||||
|       $scope.methods = ExternalNotificationData.getSupportedMethods(); | ||||
|  | @ -4775,10 +4776,35 @@ quayApp.directive('createExternalNotificationDialog', function () { | |||
|       $scope.setMethod = function(method) { | ||||
|         $scope.currentConfig = {}; | ||||
|         $scope.currentMethod = method; | ||||
|         $scope.unauthorizedEmail = false; | ||||
|       }; | ||||
| 
 | ||||
|       $scope.createNotification = function() { | ||||
|         $scope.creating = true; | ||||
|         if (!$scope.currentConfig.email) { | ||||
|           $scope.performCreateNotification(); | ||||
|           return; | ||||
|         } | ||||
| 
 | ||||
|         $scope.status = 'checking-email'; | ||||
|         $scope.checkEmailAuthorization(); | ||||
|       }; | ||||
| 
 | ||||
|       $scope.checkEmailAuthorization = function() { | ||||
|         var params = { | ||||
|           'repository': $scope.repository.namespace + '/' + $scope.repository.name, | ||||
|           'email': $scope.currentConfig.email | ||||
|         }; | ||||
| 
 | ||||
|         ApiService.checkRepoEmailAuthorized(null, params).then(function(resp) { | ||||
|           $scope.handleEmailCheck(resp.confirmed); | ||||
|         }, function(resp) { | ||||
|           $scope.handleEmailCheck(false); | ||||
|         }); | ||||
|       }; | ||||
| 
 | ||||
|       $scope.performCreateNotification = function() { | ||||
|         $scope.status = 'creating'; | ||||
| 
 | ||||
|         var params = { | ||||
|           'repository': $scope.repository.namespace + '/' + $scope.repository.name | ||||
|         }; | ||||
|  | @ -4790,21 +4816,58 @@ quayApp.directive('createExternalNotificationDialog', function () { | |||
|         }; | ||||
| 
 | ||||
|         ApiService.createRepoNotification(data, params).then(function(resp) { | ||||
|           $scope.creating = false; | ||||
|           $scope.status = ''; | ||||
|           $scope.notificationCreated({'notification': resp}); | ||||
|           $('#createNotificationModal').modal('hide'); | ||||
|         }); | ||||
|       }; | ||||
| 
 | ||||
|       $scope.handleEmailCheck = function(isAuthorized) { | ||||
|         if (isAuthorized) { | ||||
|           $scope.performCreateNotification(); | ||||
|           return;  | ||||
|         } | ||||
| 
 | ||||
|         if ($scope.status == 'authorizing-email-sent') { | ||||
|           $scope.watchEmail(); | ||||
|         } else { | ||||
|           $scope.status = 'unauthorized-email'; | ||||
|         } | ||||
| 
 | ||||
|         $scope.unauthorizedEmail = true; | ||||
|       }; | ||||
| 
 | ||||
|       $scope.sendAuthEmail = function() { | ||||
|         $scope.status = 'authorizing-email'; | ||||
| 
 | ||||
|         var params = { | ||||
|           'repository': $scope.repository.namespace + '/' + $scope.repository.name, | ||||
|           'email': $scope.currentConfig.email | ||||
|         }; | ||||
| 
 | ||||
|         ApiService.sendAuthorizeRepoEmail(null, params).then(function(resp) { | ||||
|           $scope.status = 'authorizing-email-sent'; | ||||
|           $scope.watchEmail(); | ||||
|         }); | ||||
|       }; | ||||
| 
 | ||||
|       $scope.watchEmail = function() { | ||||
|         // TODO: change this to SSE?
 | ||||
|         $timeout(function() { | ||||
|           $scope.checkEmailAuthorization(); | ||||
|         }, 1000); | ||||
|       }; | ||||
| 
 | ||||
|       $scope.$watch('counter', function(counter) { | ||||
|         if (counter) { | ||||
|           $scope.clearCounter++; | ||||
|           $scope.creating = false; | ||||
|           $scope.status = ''; | ||||
|           $scope.currentEvent = null; | ||||
|           $scope.currentMethod = null; | ||||
|           $scope.unauthorizedEmail = false; | ||||
|           $('#createNotificationModal').modal({}); | ||||
|         } | ||||
|       }); | ||||
|       });       | ||||
|     } | ||||
|   }; | ||||
|   return directiveDefinitionObject; | ||||
|  |  | |||
		Reference in a new issue