22 lines
		
	
	
		
			539 B
		
	
	
	
		
			Ruby
		
	
	
	
			
		
		
	
	
			22 lines
		
	
	
		
			539 B
		
	
	
	
		
			Ruby
		
	
	
	
| # frozen_string_literal: true
 | |
| 
 | |
| module Gitlab
 | |
|   module Graphql
 | |
|     module Authorize
 | |
|       class Instrumentation
 | |
|         # Replace the resolver for the field with one that will only return the
 | |
|         # resolved object if the permissions check is successful.
 | |
|         def instrument(_type, field)
 | |
|           service = AuthorizeFieldService.new(field)
 | |
| 
 | |
|           if service.authorizations?
 | |
|             field.redefine { resolve(service.authorized_resolve) }
 | |
|           else
 | |
|             field
 | |
|           end
 | |
|         end
 | |
|       end
 | |
|     end
 | |
|   end
 | |
| end
 |