This method provides admission control for services that are integrated with Service Infrastructure. It checks whether an operation should be allowed based on the service configuration and relevant policies. It must be called before the operation is executed. For more information, see Admission Control.
NOTE: The admission control has an expected policy propagation delay of 60s. The caller must not depend on the most recent policy changes.
NOTE: The admission control has a hard limit of 1 referenced resources per call. If an operation refers to more than 1 resources, the caller must call the services.check method multiple times.
This method requires the servicemanagement.services.check permission on the specified service. For more information, see Service Control API Access Control.
HTTP request
POST https://servicecontrol.googleapis.com/v2/services/{serviceName}:check
The URL uses gRPC Transcoding syntax.
Path parameters
| Parameters | |
|---|---|
| serviceName | 
 The service name as specified in its service configuration. For example,  See google.api.Service for the definition of a service name. | 
Request body
The request body contains data with the following structure:
| JSON representation | 
|---|
| { "serviceConfigId": string, "attributes": { object ( | 
| Fields | |
|---|---|
| serviceConfigId | 
 Specifies the version of the service configuration that should be used to process the request. Must not be empty. Set this field to 'latest' to specify using the latest configuration. | 
| attributes | 
 Describes attributes about the operation being executed by the service. | 
| resources[] | 
 Describes the resources and the policies applied to each resource. | 
| flags | 
 Optional. Contains a comma-separated list of flags. | 
Response body
Response message for the services.check method.
If successful, the response body contains data with the following structure:
| JSON representation | 
|---|
| {
  "status": {
    object ( | 
| Fields | |
|---|---|
| status | 
 Operation is allowed when this field is not set. Any non-'OK' status indicates a denial;  | 
| headers | 
 Returns a set of request contexts generated from the  An object containing a list of  | 
| dynamicMetadata | 
 Optional response metadata that will be emitted as dynamic metadata to be consumed by the caller of ServiceController. For compatibility with the ext_authz interface. | 
Authorization scopes
Requires one of the following OAuth scopes:
- https://www.googleapis.com/auth/servicecontrol
- https://www.googleapis.com/auth/cloud-platform
For more information, see the Authentication Overview.
ResourceInfo
Describes a resource referenced in the request.
| JSON representation | 
|---|
| { "name": string, "type": string, "permission": string, "container": string, "location": string } | 
| Fields | |
|---|---|
| name | 
 The name of the resource referenced in the request. | 
| type | 
 The resource type in the format of "{service}/{kind}". | 
| permission | 
 The resource permission needed for this request. The format must be "{service}/{plural}.{verb}". | 
| container | 
 Optional. The identifier of the container of this resource. For Google Cloud APIs, the resource container must be one of the following formats:  -  | 
| location | 
 Optional. The location of the resource, it must be a valid zone, region or multiregion, for example: "europe-west4", "northamerica-northeast1-a". Required for location policy check. |