Add support for registry type in scope
Signed-off-by: Derek McGowan <derek@mcgstyle.net> (github: dmcgowan)
This commit is contained in:
		
							parent
							
								
									edd7cb5249
								
							
						
					
					
						commit
						022416c502
					
				
					 1 changed files with 12 additions and 5 deletions
				
			
		|  | @ -163,14 +163,21 @@ func filterAccessList(ctx context.Context, scope string, requestedAccessList []a | |||
| 	} | ||||
| 	grantedAccessList := make([]auth.Access, 0, len(requestedAccessList)) | ||||
| 	for _, access := range requestedAccessList { | ||||
| 		if access.Type != "repository" { | ||||
| 			context.GetLogger(ctx).Debugf("Skipping unsupported resource type: %s", access.Type) | ||||
| 			continue | ||||
| 		} | ||||
| 		if access.Type == "repository" { | ||||
| 			if !strings.HasPrefix(access.Name, scope) { | ||||
| 				context.GetLogger(ctx).Debugf("Resource scope not allowed: %s", access.Name) | ||||
| 				continue | ||||
| 			} | ||||
| 		} else if access.Type == "registry" { | ||||
| 			if access.Name != "catalog" { | ||||
| 				context.GetLogger(ctx).Debugf("Unknown registry resource: %s", access.Name) | ||||
| 				continue | ||||
| 			} | ||||
| 			// TODO: Limit some actions to "admin" users | ||||
| 		} else { | ||||
| 			context.GetLogger(ctx).Debugf("Skipping unsupported resource type: %s", access.Type) | ||||
| 			continue | ||||
| 		} | ||||
| 		grantedAccessList = append(grantedAccessList, access) | ||||
| 	} | ||||
| 	return grantedAccessList | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue