A simple descriptor of a resource type.
ResourceDescriptor annotates a resource message (either by means of a protobuf annotation or use in the service config), and associates the resource's schema, the resource type, and the pattern of the resource name. Example: message Topic { // Indicates this message defines a resource schema. // Declares the resource type in the format of {service}/{kind}. // For Kubernetes resources, the format is {api group}/{kind}. option (google.api.resource) = { type: "pubsub.googleapis.com/Topic" pattern: "projects/{project}/topics/{topic}" }; } The ResourceDescriptor Yaml config will look like: resources: - type: "pubsub.googleapis.com/Topic" pattern: "projects/{project}/topics/{topic}" Sometimes, resources have multiple patterns, typically because they can live under multiple parents. Example: message LogEntry { option (google.api.resource) = { type: "logging.googleapis.com/LogEntry" pattern: "projects/{project}/logs/{log}" pattern: "folders/{folder}/logs/{log}" pattern: "organizations/{organization}/logs/{log}" pattern: "billingAccounts/{billing_account}/logs/{log}" }; } The ResourceDescriptor Yaml config will look like: resources: - type: 'logging.googleapis.com/LogEntry' pattern: "projects/{project}/logs/{log}" pattern: "folders/{folder}/logs/{log}" pattern: "organizations/{organization}/logs/{log}" pattern: "billingAccounts/{billing_account}/logs/{log}"
Generated from protobuf message google.api.ResourceDescriptor
Methods |
public __construct( $data = NULL) Constructor.
|
public getHistory() Optional. The historical or future-looking state of the resource pattern. Example: // The InspectTemplate message originally only supported resource // names with organization, and project was added later. message InspectTemplate { option (google.api.resource) = { type: "dlp.googleapis.com/InspectTemplate" pattern: "organizations/{organization}/inspectTemplates/{inspect_template}" pattern: "projects/{project}/inspectTemplates/{inspect_template}" history: ORIGINALLY_SINGLE_PATTERN }; } Generated from protobuf field .google.api.ResourceDescriptor.History history = 4;
|
public getNameField() Optional. The field on the resource that designates the resource name field. If omitted, this is assumed to be "name". Generated from protobuf field string name_field = 3;
|
public getPattern() Optional. The relative resource name pattern associated with this resource type. The DNS prefix of the full resource name shouldn't be specified here. The path pattern must follow the syntax, which aligns with HTTP binding syntax: Template = Segment { "/" Segment } ; Segment = LITERAL | Variable ; Variable = "{" LITERAL "}" ; Examples: - "projects/{project}/topics/{topic}" - "projects/{project}/knowledgeBases/{knowledge_base}" The components in braces correspond to the IDs for each resource in the hierarchy. It is expected that, if multiple patterns are provided, the same component name (e.g. "project") refers to IDs of the same type of resource. Generated from protobuf field repeated string pattern = 2;
|
public getPlural() The plural name used in the resource name and permission names, such as
'projects' for the resource name of 'projects/{project}' and the permission
name of 'cloudresourcemanager.googleapis.com/projects.get'. One exception
to this is for Nested Collections that have stuttering names, as defined
in AIP-122, where the
collection ID in the resource name pattern does not necessarily directly
match the It is the same concept of the Generated from protobuf field string plural = 5;
|
public getSingular() The same concept of the Generated from protobuf field string singular = 6;
|
public getStyle() Style flag(s) for this resource. These indicate that a resource is expected to conform to a given style. See the specific style flags for additional information. Generated from protobuf field repeated .google.api.ResourceDescriptor.Style style = 10;
|
public getType() The resource type. It must be in the format of
{service_name}/{resource_type_kind}. The Example: Generated from protobuf field string type = 1;
|
public setHistory( $var) Optional. The historical or future-looking state of the resource pattern. Example: // The InspectTemplate message originally only supported resource // names with organization, and project was added later. message InspectTemplate { option (google.api.resource) = { type: "dlp.googleapis.com/InspectTemplate" pattern: "organizations/{organization}/inspectTemplates/{inspect_template}" pattern: "projects/{project}/inspectTemplates/{inspect_template}" history: ORIGINALLY_SINGLE_PATTERN }; } Generated from protobuf field .google.api.ResourceDescriptor.History history = 4;
|
public setNameField( $var) Optional. The field on the resource that designates the resource name field. If omitted, this is assumed to be "name". Generated from protobuf field string name_field = 3;
|
public setPattern( $var) Optional. The relative resource name pattern associated with this resource type. The DNS prefix of the full resource name shouldn't be specified here. The path pattern must follow the syntax, which aligns with HTTP binding syntax: Template = Segment { "/" Segment } ; Segment = LITERAL | Variable ; Variable = "{" LITERAL "}" ; Examples: - "projects/{project}/topics/{topic}" - "projects/{project}/knowledgeBases/{knowledge_base}" The components in braces correspond to the IDs for each resource in the hierarchy. It is expected that, if multiple patterns are provided, the same component name (e.g. "project") refers to IDs of the same type of resource. Generated from protobuf field repeated string pattern = 2;
|
public setPlural( $var) The plural name used in the resource name and permission names, such as
'projects' for the resource name of 'projects/{project}' and the permission
name of 'cloudresourcemanager.googleapis.com/projects.get'. One exception
to this is for Nested Collections that have stuttering names, as defined
in AIP-122, where the
collection ID in the resource name pattern does not necessarily directly
match the It is the same concept of the Generated from protobuf field string plural = 5;
|
public setSingular( $var) The same concept of the Generated from protobuf field string singular = 6;
|
public setStyle( $var) Style flag(s) for this resource. These indicate that a resource is expected to conform to a given style. See the specific style flags for additional information. Generated from protobuf field repeated .google.api.ResourceDescriptor.Style style = 10;
|
public setType( $var) The resource type. It must be in the format of
{service_name}/{resource_type_kind}. The Example: Generated from protobuf field string type = 1;
|
Properties |
protected $history = 0 Optional. The historical or future-looking state of the resource pattern. Example: // The InspectTemplate message originally only supported resource // names with organization, and project was added later. message InspectTemplate { option (google.api.resource) = { type: "dlp.googleapis.com/InspectTemplate" pattern: "organizations/{organization}/inspectTemplates/{inspect_template}" pattern: "projects/{project}/inspectTemplates/{inspect_template}" history: ORIGINALLY_SINGLE_PATTERN }; } Generated from protobuf field .google.api.ResourceDescriptor.History history = 4; |
protected $name_field = '' Optional. The field on the resource that designates the resource name field. If omitted, this is assumed to be "name". Generated from protobuf field string name_field = 3; |
protected $plural = '' The plural name used in the resource name and permission names, such as
'projects' for the resource name of 'projects/{project}' and the permission
name of 'cloudresourcemanager.googleapis.com/projects.get'. One exception
to this is for Nested Collections that have stuttering names, as defined
in AIP-122, where the
collection ID in the resource name pattern does not necessarily directly
match the It is the same concept of the Generated from protobuf field string plural = 5; |
protected $singular = '' The same concept of the Generated from protobuf field string singular = 6; |
protected $type = '' The resource type. It must be in the format of
{service_name}/{resource_type_kind}. The Example: Generated from protobuf field string type = 1; |
Methods |
Properties |
private $pattern = NULL Optional. The relative resource name pattern associated with this resource type. The DNS prefix of the full resource name shouldn't be specified here. The path pattern must follow the syntax, which aligns with HTTP binding syntax: Template = Segment { "/" Segment } ; Segment = LITERAL | Variable ; Variable = "{" LITERAL "}" ; Examples: - "projects/{project}/topics/{topic}" - "projects/{project}/knowledgeBases/{knowledge_base}" The components in braces correspond to the IDs for each resource in the hierarchy. It is expected that, if multiple patterns are provided, the same component name (e.g. "project") refers to IDs of the same type of resource. Generated from protobuf field repeated string pattern = 2; |
private $style = NULL Style flag(s) for this resource. These indicate that a resource is expected to conform to a given style. See the specific style flags for additional information. Generated from protobuf field repeated .google.api.ResourceDescriptor.Style style = 10; |