Use the instance service key for registry JWT signing
This commit is contained in:
		
							parent
							
								
									a4aa5cc02a
								
							
						
					
					
						commit
						8887f09ba8
					
				
					 26 changed files with 457 additions and 278 deletions
				
			
		|  | @ -3,7 +3,7 @@ import json | |||
| import os | ||||
| 
 | ||||
| from data.users.federated import FederatedUsers, VerifiedCredentials | ||||
| from util.security import strictjwt | ||||
| from util.security import jwtutil | ||||
| 
 | ||||
| 
 | ||||
| logger = logging.getLogger(__name__) | ||||
|  | @ -45,12 +45,12 @@ class ExternalJWTAuthN(FederatedUsers): | |||
| 
 | ||||
|     # Load the JWT returned. | ||||
|     encoded = result_data.get('token', '') | ||||
|     exp_limit_options = strictjwt.exp_max_s_option(self.max_fresh_s) | ||||
|     exp_limit_options = jwtutil.exp_max_s_option(self.max_fresh_s) | ||||
|     try: | ||||
|       payload = strictjwt.decode(encoded, self.public_key, algorithms=['RS256'], | ||||
|                                  audience='quay.io/jwtauthn', issuer=self.issuer, | ||||
|                                  options=exp_limit_options) | ||||
|     except strictjwt.InvalidTokenError: | ||||
|       payload = jwtutil.decode(encoded, self.public_key, algorithms=['RS256'], | ||||
|                                audience='quay.io/jwtauthn', issuer=self.issuer, | ||||
|                                options=exp_limit_options) | ||||
|     except jwtutil.InvalidTokenError: | ||||
|       logger.exception('Exception when decoding returned JWT') | ||||
|       return (None, 'Invalid username or password') | ||||
| 
 | ||||
|  |  | |||
		Reference in a new issue