mirror of
				https://github.com/langgenius/dify.git
				synced 2025-10-25 07:58:40 +00:00 
			
		
		
		
	Feat/change user email freezes limit (#22900)
This commit is contained in:
		
							parent
							
								
									061d4c8ea0
								
							
						
					
					
						commit
						6ac06486e3
					
				| @ -113,3 +113,9 @@ class MemberNotInTenantError(BaseHTTPException): | |||||||
|     error_code = "member_not_in_tenant" |     error_code = "member_not_in_tenant" | ||||||
|     description = "The member is not in the workspace." |     description = "The member is not in the workspace." | ||||||
|     code = 400 |     code = 400 | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | class AccountInFreezeError(BaseHTTPException): | ||||||
|  |     error_code = "account_in_freeze" | ||||||
|  |     description = "This email is temporarily unavailable." | ||||||
|  |     code = 400 | ||||||
|  | |||||||
| @ -9,6 +9,7 @@ from configs import dify_config | |||||||
| from constants.languages import supported_language | from constants.languages import supported_language | ||||||
| from controllers.console import api | from controllers.console import api | ||||||
| from controllers.console.auth.error import ( | from controllers.console.auth.error import ( | ||||||
|  |     AccountInFreezeError, | ||||||
|     EmailAlreadyInUseError, |     EmailAlreadyInUseError, | ||||||
|     EmailChangeLimitError, |     EmailChangeLimitError, | ||||||
|     EmailCodeError, |     EmailCodeError, | ||||||
| @ -479,15 +480,18 @@ class ChangeEmailResetApi(Resource): | |||||||
|         parser.add_argument("token", type=str, required=True, nullable=False, location="json") |         parser.add_argument("token", type=str, required=True, nullable=False, location="json") | ||||||
|         args = parser.parse_args() |         args = parser.parse_args() | ||||||
| 
 | 
 | ||||||
|  |         if AccountService.is_account_in_freeze(args["new_email"]): | ||||||
|  |             raise AccountInFreezeError() | ||||||
|  | 
 | ||||||
|  |         if not AccountService.check_email_unique(args["new_email"]): | ||||||
|  |             raise EmailAlreadyInUseError() | ||||||
|  | 
 | ||||||
|         reset_data = AccountService.get_change_email_data(args["token"]) |         reset_data = AccountService.get_change_email_data(args["token"]) | ||||||
|         if not reset_data: |         if not reset_data: | ||||||
|             raise InvalidTokenError() |             raise InvalidTokenError() | ||||||
| 
 | 
 | ||||||
|         AccountService.revoke_change_email_token(args["token"]) |         AccountService.revoke_change_email_token(args["token"]) | ||||||
| 
 | 
 | ||||||
|         if not AccountService.check_email_unique(args["new_email"]): |  | ||||||
|             raise EmailAlreadyInUseError() |  | ||||||
| 
 |  | ||||||
|         old_email = reset_data.get("old_email", "") |         old_email = reset_data.get("old_email", "") | ||||||
|         if current_user.email != old_email: |         if current_user.email != old_email: | ||||||
|             raise AccountNotFound() |             raise AccountNotFound() | ||||||
|  | |||||||
| @ -671,6 +671,12 @@ class AccountService: | |||||||
| 
 | 
 | ||||||
|         return account |         return account | ||||||
| 
 | 
 | ||||||
|  |     @classmethod | ||||||
|  |     def is_account_in_freeze(cls, email: str) -> bool: | ||||||
|  |         if dify_config.BILLING_ENABLED and BillingService.is_email_in_freeze(email): | ||||||
|  |             return True | ||||||
|  |         return False | ||||||
|  | 
 | ||||||
|     @staticmethod |     @staticmethod | ||||||
|     @redis_fallback(default_return=None) |     @redis_fallback(default_return=None) | ||||||
|     def add_login_error_rate_limit(email: str) -> None: |     def add_login_error_rate_limit(email: str) -> None: | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user
	 zyssyz123
						zyssyz123