- JSON representation
- Resource
- Policy
- ListPolicy
- AllValues
- BooleanPolicy
- RestoreDefault
- AccessPolicy
- AccessLevel
- BasicLevel
- Condition
- DevicePolicy
- DeviceEncryptionStatus
- OsConstraint
- OsType
- DeviceManagementLevel
- VpcNetworkSource
- VpcSubNetwork
- ConditionCombiningFunction
- CustomLevel
- ServicePerimeter
- PerimeterType
- ServicePerimeterConfig
- VpcAccessibleServices
- IngressPolicy
- IngressFrom
- IngressSource
- IdentityType
- IngressTo
- ApiOperation
- MethodSelector
- EgressPolicy
- EgressFrom
- EgressSource
- SourceRestriction
- EgressTo
- Inventory
- OsInfo
- Item
- OriginType
- Type
- SoftwarePackage
- VersionedPackage
- ZypperPatch
- WindowsUpdatePackage
- WindowsUpdateCategory
- WindowsQuickFixEngineeringPackage
- WindowsApplication
- Date
- RelatedAssets
- RelationshipAttributes
- RelatedAsset
- AssetException
- ExceptionType
An asset in Google Cloud. An asset can be any resource in the Google Cloud resource hierarchy, a resource outside the Google Cloud resource hierarchy (such as Google Kubernetes Engine clusters and objects), or a policy (e.g. IAM policy), or a relationship (e.g. an INSTANCE_TO_INSTANCEGROUP relationship). See Supported asset types for more information.
| JSON representation | 
|---|
| { "updateTime": string, "name": string, "assetType": string, "resource": { object ( | 
| Fields | |
|---|---|
| updateTime | 
 The last update timestamp of an asset. updateTime is updated when create/update/delete operation is performed. Uses RFC 3339, where generated output will always be Z-normalized and uses 0, 3, 6 or 9 fractional digits. Offsets other than "Z" are also accepted. Examples:  | 
| name | 
 The full name of the asset. Example:  See Resource names for more information. | 
| assetType | 
 The type of the asset. Example:  See Supported asset types for more information. | 
| resource | 
 A representation of the resource. | 
| iamPolicy | 
 A representation of the IAM policy set on a Google Cloud resource. There can be a maximum of one IAM policy set on any given resource. In addition, IAM policies inherit their granted access scope from any policies set on parent resources in the resource hierarchy. Therefore, the effectively policy is the union of both the policy set on this resource and each policy set on all of the resource's ancestry resource levels in the hierarchy. See this topic for more information. | 
| orgPolicy[] | 
 A representation of an organization policy. There can be more than one organization policy with different constraints set on a given resource. | 
| osInventory | 
 A representation of runtime OS Inventory information. See this topic for more information. | 
| relatedAssets | 
 DEPRECATED. This field only presents for the purpose of backward-compatibility. The server will never generate responses with this field. The related assets of the asset of one relationship type. One asset only represents one type of relationship. | 
| relatedAsset | 
 One related asset of the current asset. | 
| ancestors[] | 
 The ancestry path of an asset in Google Cloud resource hierarchy, represented as a list of relative resource names. An ancestry path starts with the closest ancestor in the hierarchy and ends at root. If the asset is a project, folder, or organization, the ancestry path starts from the asset itself. Example:  | 
| assetExceptions[] | 
 The exceptions of a resource. | 
| Union field access_context_policy. A representation of an access policy.access_context_policycan be only one of the following: | |
| accessPolicy | 
 Also refer to the access policy user guide. | 
| accessLevel | 
 Also refer to the access level user guide. | 
| servicePerimeter | 
 Also refer to the service perimeter user guide. | 
Resource
A representation of a Google Cloud resource.
| JSON representation | 
|---|
| { "version": string, "discoveryDocumentUri": string, "discoveryName": string, "resourceUrl": string, "parent": string, "data": { object }, "location": string } | 
| Fields | |
|---|---|
| version | 
 The API version. Example:  | 
| discoveryDocumentUri | 
 The URL of the discovery document containing the resource's JSON schema. Example:  This value is unspecified for resources that do not have an API based on a discovery document, such as Cloud Bigtable. | 
| discoveryName | 
 The JSON schema name listed in the discovery document. Example:  This value is unspecified for resources that do not have an API based on a discovery document, such as Cloud Bigtable. | 
| resourceUrl | 
 The REST URL for accessing the resource. An HTTP  This value is unspecified for resources without a REST API. | 
| parent | 
 The full name of the immediate parent of this resource. See Resource Names for more information. For Google Cloud assets, this value is the parent resource defined in the IAM policy hierarchy. Example:  | 
| data | 
 The content of the resource, in which some sensitive fields are removed and may not be present. | 
| location | 
 The location of the resource in Google Cloud, such as its zone and region. For more information, see https://cloud.google.com/about/locations/. | 
Policy
Defines a Cloud Organization Policy which is used to specify Constraints for configurations of Cloud Platform resources.
| JSON representation | 
|---|
| { "version": integer, "constraint": string, "etag": string, "updateTime": string, // Union field | 
| Fields | |
|---|---|
| version | 
 Version of the  | 
| constraint | 
 The name of the  A list of available constraints is available. Immutable after creation. | 
| etag | 
 An opaque tag indicating the current version of the  When the  When the  When the  A base64-encoded string. | 
| updateTime | 
 The time stamp the  Uses RFC 3339, where generated output will always be Z-normalized and uses 0, 3, 6 or 9 fractional digits. Offsets other than "Z" are also accepted. Examples:  | 
| Union field  A  Providing a *_policy that is incompatible with the  Attempting to set a  | |
| listPolicy | 
 List of values either allowed or disallowed. | 
| booleanPolicy | 
 For boolean  | 
| restoreDefault | 
 Restores the default behavior of the constraint; independent of  | 
ListPolicy
Used in policyType to specify how listPolicy behaves at this resource.
ListPolicy can define specific values and subtrees of Cloud Resource Manager resource hierarchy (Organizations, Folders, Projects) that are allowed or denied by setting the allowedValues and deniedValues fields. This is achieved by using the under: and optional is: prefixes. The under: prefix is used to denote resource subtree values. The is: prefix is used to denote specific values, and is required only if the value contains a ":". Values prefixed with "is:" are treated the same as values with no prefix. Ancestry subtrees must be in one of the following formats:
- "projects/", e.g. "projects/tokyo-rain-123" 
- "folders/", e.g. "folders/1234" 
- "organizations/", e.g. "organizations/1234" 
The supportsUnder field of the associated Constraint defines whether ancestry prefixes can be used. You can set allowedValues and deniedValues in the same Policy if allValues is ALL_VALUES_UNSPECIFIED. ALLOW or DENY are used to allow or deny all values. If allValues is set to either ALLOW or DENY, allowedValues and deniedValues must be unset.
| JSON representation | 
|---|
| {
  "allowedValues": [
    string
  ],
  "deniedValues": [
    string
  ],
  "allValues": enum ( | 
| Fields | |
|---|---|
| allowedValues[] | 
 List of values allowed at this resource. Can only be set if  | 
| deniedValues[] | 
 List of values denied at this resource. Can only be set if  | 
| allValues | 
 The policy allValues state. | 
| suggestedValue | 
 Optional. The Google Cloud Console will try to default to a configuration that matches the value specified in this  | 
| inheritFromParent | 
 Determines the inheritance behavior for this  By default, a  Setting  For example, suppose you have a  The following examples demonstrate different possible layerings for  Example 1 (no inherited values):   Example 2 (inherited values):   Example 3 (inheriting both allowed and denied values):   Example 4 (RestoreDefault):   Example 5 (no policy inherits parent policy):   Example 6 (ListConstraint allowing all):   Example 7 (ListConstraint allowing none):   Example 10 (allowed and denied subtrees of Resource Manager hierarchy): Given the following resource hierarchy  O1->{F1, F2}; F1->{P1}; F2->{P2, P3},   | 
AllValues
This enum can be used to set Policies that apply to all possible configuration values rather than specific values in allowedValues or deniedValues.
Setting this to ALLOW will mean this Policy allows all values. Similarly, setting it to DENY will mean no values are allowed. If set to either ALLOW or DENY,allowedValuesanddeniedValues
          must be unset. Setting this toALL_VALUES_UNSPECIFIEDallows for
          settingallowedValuesanddeniedValues`.
| Enums | |
|---|---|
| ALL_VALUES_UNSPECIFIED | Indicates that allowedValues or deniedValues must be set. | 
| ALLOW | A policy with this set allows all values. | 
| DENY | A policy with this set denies all values. | 
BooleanPolicy
Used in policyType to specify how booleanPolicy will behave at this resource.
| JSON representation | 
|---|
| { "enforced": boolean } | 
| Fields | |
|---|---|
| enforced | 
 If  Suppose you have a  The following examples demonstrate the different possible layerings: Example 1 (nearest  Example 2 (enforcement gets replaced):   Example 3 (RestoreDefault):   | 
RestoreDefault
This type has no fields.
Ignores policies set above this resource and restores the constraintDefault enforcement behavior of the specific Constraint at this resource.
Suppose that constraintDefault is set to ALLOW for the Constraint constraints/serviceuser.services. Suppose that organization foo.com sets a Policy at their Organization resource node that restricts the allowed service activations to deny all service activations. They could then set a Policy with the policyType restoreDefault on several experimental projects, restoring the constraintDefault enforcement of the Constraint for only those projects, allowing those projects to have all services activated.
AccessPolicy
AccessPolicy is a container for AccessLevels (which define the necessary attributes to use Google Cloud services) and ServicePerimeters (which define regions of services able to freely pass data within a perimeter). An access policy is globally visible within an organization, and the restrictions it specifies apply to all projects within an organization.
| JSON representation | 
|---|
| { "name": string, "parent": string, "title": string, "scopes": [ string ], "etag": string } | 
| Fields | |
|---|---|
| name | 
 Output only. Identifier. Resource name of the  | 
| parent | 
 Required. The parent of this  | 
| title | 
 Required. Human readable title. Does not affect behavior. | 
| scopes[] | 
 The scopes of the  
 If no scopes are provided, then any resource within the organization can be restricted. Scopes cannot be modified after a policy is created. Policies can only have a single scope. Format: list of  | 
| etag | 
 Output only. An opaque identifier for the current version of the  | 
AccessLevel
An AccessLevel is a label that can be applied to requests to Google Cloud services, along with a list of requirements necessary for the label to be applied.
| JSON representation | 
|---|
| { "name": string, "title": string, "description": string, // Union field | 
| Fields | |
|---|---|
| name | 
 Identifier. Resource name for the  The  After you create an  | 
| title | 
 Human readable title. Must be unique within the Policy. | 
| description | 
 Description of the  | 
| Union field level. Required. Describes the necessary conditions for the level to apply.levelcan be only one of the following: | |
| basic | 
 A  | 
| custom | 
 A  | 
BasicLevel
BasicLevel is an AccessLevel using a set of recommended features.
| JSON representation | 
|---|
| { "conditions": [ { object ( | 
| Fields | |
|---|---|
| conditions[] | 
 Required. A list of requirements for the  | 
| combiningFunction | 
 How the  | 
Condition
A condition necessary for an AccessLevel to be granted. The Condition is an AND over its fields. So a Condition is true if: 1) the request IP is from one of the listed subnetworks AND 2) the originating device complies with the listed device policy AND 3) all listed access levels are granted AND 4) the request was sent at a time allowed by the DateTimeRestriction.
| JSON representation | 
|---|
| { "ipSubnetworks": [ string ], "devicePolicy": { object ( | 
| Fields | |
|---|---|
| ipSubnetworks[] | 
 CIDR block IP subnetwork specification. May be IPv4 or IPv6. Note that for a CIDR IP address block, the specified IP address portion must be properly truncated (i.e. all the host bits must be zero) or the input is considered malformed. For example, "192.0.2.0/24" is accepted but "192.0.2.1/24" is not. Similarly, for IPv6, "2001:db8::/32" is accepted whereas "2001:db8::1/32" is not. The originating IP of a request must be in one of the listed subnets in order for this Condition to be true. If empty, all IP addresses are allowed. | 
| devicePolicy | 
 Device specific restrictions, all restrictions must hold for the Condition to be true. If not specified, all devices are allowed. | 
| requiredAccessLevels[] | 
 A list of other access levels defined in the same  | 
| negate | 
 Whether to negate the Condition. If true, the Condition becomes a NAND over its non-empty fields. Any non-empty field criteria evaluating to false will result in the Condition to be satisfied. Defaults to false. | 
| members[] | 
 The request must be made by one of the provided user or service accounts. Groups are not supported. Syntax:  | 
| regions[] | 
 The request must originate from one of the provided countries/regions. Must be valid ISO 3166-1 alpha-2 codes. | 
| vpcNetworkSources[] | 
 The request must originate from one of the provided VPC networks in Google Cloud. Cannot specify this field together with  | 
DevicePolicy
DevicePolicy specifies device specific restrictions necessary to acquire a given access level. A DevicePolicy specifies requirements for requests from devices to be granted access levels, it does not do any enforcement on the device. DevicePolicy acts as an AND over all specified fields, and each repeated field is an OR over its elements. Any unset fields are ignored. For example, if the proto is { osType : DESKTOP_WINDOWS, osType : DESKTOP_LINUX, encryption_status: ENCRYPTED}, then the DevicePolicy will be true for requests originating from encrypted Linux desktops and encrypted Windows desktops.
| JSON representation | 
|---|
| { "requireScreenlock": boolean, "allowedEncryptionStatuses": [ enum ( | 
| Fields | |
|---|---|
| requireScreenlock | 
 Whether or not screenlock is required for the DevicePolicy to be true. Defaults to  | 
| allowedEncryptionStatuses[] | 
 Allowed encryptions statuses, an empty list allows all statuses. | 
| osConstraints[] | 
 Allowed OS versions, an empty list allows all types and all versions. | 
| allowedDeviceManagementLevels[] | 
 Allowed device management levels, an empty list allows all management levels. | 
| requireAdminApproval | 
 Whether the device needs to be approved by the customer admin. | 
| requireCorpOwned | 
 Whether the device needs to be corp owned. | 
DeviceEncryptionStatus
The encryption state of the device.
| Enums | |
|---|---|
| ENCRYPTION_UNSPECIFIED | The encryption status of the device is not specified or not known. | 
| ENCRYPTION_UNSUPPORTED | The device does not support encryption. | 
| UNENCRYPTED | The device supports encryption, but is currently unencrypted. | 
| ENCRYPTED | The device is encrypted. | 
OsConstraint
A restriction on the OS type and version of devices making requests.
| JSON representation | 
|---|
| {
  "osType": enum ( | 
| Fields | |
|---|---|
| osType | 
 Required. The allowed OS type. | 
| minimumVersion | 
 The minimum allowed OS version. If not set, any version of this OS satisfies the constraint. Format:  | 
| requireVerifiedChromeOs | 
 Only allows requests from devices with a verified Chrome OS. Verifications includes requirements that the device is enterprise-managed, conformant to domain policies, and the caller has permission to call the API targeted by the request. | 
OsType
The operating system type of the device.
| Enums | |
|---|---|
| OS_UNSPECIFIED | The operating system of the device is not specified or not known. | 
| DESKTOP_MAC | A desktop Mac operating system. | 
| DESKTOP_WINDOWS | A desktop Windows operating system. | 
| DESKTOP_LINUX | A desktop Linux operating system. | 
| DESKTOP_CHROME_OS | A desktop ChromeOS operating system. | 
| ANDROID | An Android operating system. | 
| IOS | An iOS operating system. | 
DeviceManagementLevel
The degree to which the device is managed by the Cloud organization.
| Enums | |
|---|---|
| MANAGEMENT_UNSPECIFIED | The device's management level is not specified or not known. | 
| NONE | The device is not managed. | 
| BASIC | Basic management is enabled, which is generally limited to monitoring and wiping the corporate account. | 
| COMPLETE | Complete device management. This includes more thorough monitoring and the ability to directly manage the device (such as remote wiping). This can be enabled through the Android Enterprise Platform. | 
VpcNetworkSource
The originating network source in Google Cloud.
| JSON representation | 
|---|
| { // Union field | 
| Fields | |
|---|---|
| Union field kind. The type of the originating network source of the request.kindcan be only one of the following: | |
| vpcSubnetwork | 
 Sub-segment ranges of a VPC network. | 
VpcSubNetwork
Sub-segment ranges inside of a VPC Network.
| JSON representation | 
|---|
| { "network": string, "vpcIpSubnetworks": [ string ] } | 
| Fields | |
|---|---|
| network | 
 Required. Network name. If the network is not part of the organization, the  | 
| vpcIpSubnetworks[] | 
 CIDR block IP subnetwork specification. The IP address must be an IPv4 address and can be a public or private IP address. Note that for a CIDR IP address block, the specified IP address portion must be properly truncated (i.e. all the host bits must be zero) or the input is considered malformed. For example, "192.0.2.0/24" is accepted but "192.0.2.1/24" is not. If empty, all IP addresses are allowed. | 
ConditionCombiningFunction
Options for how the conditions list should be combined to determine if this AccessLevel is applied. Default is AND.
| Enums | |
|---|---|
| AND | All Conditionsmust be true for theBasicLevelto be true. | 
| OR | If at least one Conditionis true, then theBasicLevelis true. | 
CustomLevel
CustomLevel is an AccessLevel using the Cloud Common Expression Language to represent the necessary conditions for the level to apply to a request. See CEL spec at: https://github.com/google/cel-spec
| JSON representation | 
|---|
| {
  "expr": {
    object ( | 
| Fields | |
|---|---|
| expr | 
 Required. A Cloud CEL expression evaluating to a boolean. | 
ServicePerimeter
ServicePerimeter describes a set of Google Cloud resources which can freely import and export data amongst themselves, but not export outside of the ServicePerimeter. If a request with a source within this ServicePerimeter has a target outside of the ServicePerimeter, the request will be blocked. Otherwise the request is allowed. There are two types of Service Perimeter - Regular and Bridge. Regular Service Perimeters cannot overlap, a single Google Cloud project or VPC network can only belong to a single regular Service Perimeter. Service Perimeter Bridges can contain only Google Cloud projects as members, a single Google Cloud project may belong to multiple Service Perimeter Bridges.
| JSON representation | 
|---|
| { "name": string, "title": string, "description": string, "perimeterType": enum ( | 
| Fields | |
|---|---|
| name | 
 Identifier. Resource name for the  The  After you create a  | 
| title | 
 Human readable title. Must be unique within the Policy. | 
| description | 
 Description of the  | 
| perimeterType | 
 Perimeter type indicator. A single project or VPC network is allowed to be a member of single regular perimeter, but multiple service perimeter bridges. A project cannot be a included in a perimeter bridge without being included in regular perimeter. For perimeter bridges, the restricted service list as well as access level lists must be empty. | 
| status | 
 Current ServicePerimeter configuration. Specifies sets of resources, restricted services and access levels that determine perimeter content and boundaries. | 
| spec | 
 Proposed (or dry run) ServicePerimeter configuration. This configuration allows to specify and test ServicePerimeter configuration without enforcing actual access restrictions. Only allowed to be set when the "useExplicitDryRunSpec" flag is set. | 
| useExplicitDryRunSpec | 
 Use explicit dry run spec flag. Ordinarily, a dry-run spec implicitly exists for all Service Perimeters, and that spec is identical to the status for those Service Perimeters. When this flag is set, it inhibits the generation of the implicit spec, thereby allowing the user to explicitly provide a configuration ("spec") to use in a dry-run version of the Service Perimeter. This allows the user to test changes to the enforced config ("status") without actually enforcing them. This testing is done through analyzing the differences between currently enforced and suggested restrictions. useExplicitDryRunSpec must bet set to True if any of the fields in the spec are set to non-default values. | 
| etag | 
 Optional. An opaque identifier for the current version of the  | 
PerimeterType
Specifies the type of the Perimeter. There are two types: regular and bridge. Regular Service Perimeter contains resources, access levels, and restricted services. Every resource can be in at most ONE regular Service Perimeter.
In addition to being in a regular service perimeter, a resource can also be in zero or more perimeter bridges. A perimeter bridge only contains resources. Cross project operations are permitted if all effected resources share some perimeter (whether bridge or regular). Perimeter Bridge does not contain access levels or services: those are governed entirely by the regular perimeter that resource is in.
Perimeter Bridges are typically useful when building more complex toplogies with many independent perimeters that need to share some data with a common perimeter, but should not be able to share data among themselves.
| Enums | |
|---|---|
| PERIMETER_TYPE_REGULAR | Regular Perimeter. When no value is specified, the perimeter uses this type. | 
| PERIMETER_TYPE_BRIDGE | Perimeter Bridge. | 
ServicePerimeterConfig
ServicePerimeterConfig specifies a set of Google Cloud resources that describe specific Service Perimeter configuration.
| JSON representation | 
|---|
| { "resources": [ string ], "accessLevels": [ string ], "restrictedServices": [ string ], "vpcAccessibleServices": { object ( | 
| Fields | |
|---|---|
| resources[] | 
 A list of Google Cloud resources that are inside of the service perimeter. Currently only projects and VPCs are allowed. Project format:  | 
| accessLevels[] | 
 A list of  | 
| restrictedServices[] | 
 Google Cloud services that are subject to the Service Perimeter restrictions. For example, if  | 
| vpcAccessibleServices | 
 Configuration for APIs allowed within Perimeter. | 
| ingressPolicies[] | 
 List of  | 
| egressPolicies[] | 
 List of  | 
VpcAccessibleServices
Specifies how APIs are allowed to communicate within the Service Perimeter.
| JSON representation | 
|---|
| { "enableRestriction": boolean, "allowedServices": [ string ] } | 
| Fields | |
|---|---|
| enableRestriction | 
 Whether to restrict API calls within the Service Perimeter to the list of APIs specified in 'allowedServices'. | 
| allowedServices[] | 
 The list of APIs usable within the Service Perimeter. Must be empty unless 'enableRestriction' is True. You can specify a list of individual services, as well as include the 'RESTRICTED-SERVICES' value, which automatically includes all of the services protected by the perimeter. | 
IngressPolicy
Policy for ingress into ServicePerimeter.
IngressPolicies match requests based on ingressFrom and ingressTo stanzas. For an ingress policy to match, both the ingressFrom and ingressTo stanzas must be matched. If an IngressPolicy matches a request, the request is allowed through the perimeter boundary from outside the perimeter.
For example, access from the internet can be allowed either based on an AccessLevel or, for traffic hosted on Google Cloud, the project of the source network. For access from private networks, using the project of the hosting network is required.
Individual ingress policies can be limited by restricting which services and/or actions they match using the ingressTo field.
| JSON representation | 
|---|
| { "ingressFrom": { object ( | 
| Fields | |
|---|---|
| ingressFrom | 
 Defines the conditions on the source of a request causing this  | 
| ingressTo | 
 Defines the conditions on the  | 
| title | 
 Optional. Human-readable title for the ingress rule. The title must be unique within the perimeter and can not exceed 100 characters. Within the access policy, the combined length of all rule titles must not exceed 240,000 characters. | 
IngressFrom
Defines the conditions under which an IngressPolicy matches a request. Conditions are based on information about the source of the request. The request must satisfy what is defined in sources AND identity related fields in order to match.
| JSON representation | 
|---|
| { "sources": [ { object ( | 
| Fields | |
|---|---|
| sources[] | 
 Sources that this  | 
| identities[] | 
 A list of identities that are allowed access through [IngressPolicy]. Identities can be an individual user, service account, Google group, or third-party identity. For third-party identity, only single identities are supported and other identity types are not supported. The  | 
| identityType | 
 Specifies the type of identities that are allowed access from outside the perimeter. If left unspecified, then members of  | 
IngressSource
The source that IngressPolicy authorizes access from.
| JSON representation | 
|---|
| { // Union field | 
| Fields | |
|---|---|
| Union field source. Allowed ingress source. It can be one ofAccessLevelor Google Cloud resource.sourcecan be only one of the following: | |
| accessLevel | 
 An  | 
| resource | 
 A Google Cloud resource that is allowed to ingress the perimeter. Requests from these resources will be allowed to access perimeter data. Currently only projects and VPCs are allowed. Project format:  | 
IdentityType
Specifies the types of identities that are allowed access in either IngressFrom or EgressFrom rules.
| Enums | |
|---|---|
| IDENTITY_TYPE_UNSPECIFIED | No blanket identity group specified. | 
| ANY_IDENTITY | Authorize access from all identities outside the perimeter. | 
| ANY_USER_ACCOUNT | Authorize access from all human users outside the perimeter. | 
| ANY_SERVICE_ACCOUNT | Authorize access from all service accounts outside the perimeter. | 
IngressTo
Defines the conditions under which an IngressPolicy matches a request. Conditions are based on information about the ApiOperation intended to be performed on the target resource of the request. The request must satisfy what is defined in operations AND resources in order to match.
| JSON representation | 
|---|
| {
  "operations": [
    {
      object ( | 
| Fields | |
|---|---|
| operations[] | 
 A list of  | 
| resources[] | 
 A list of resources, currently only projects in the form  | 
| roles[] | 
 IAM roles that represent the set of operations that the sources specified in the corresponding  | 
ApiOperation
Identification for an API Operation.
| JSON representation | 
|---|
| {
  "serviceName": string,
  "methodSelectors": [
    {
      object ( | 
| Fields | |
|---|---|
| serviceName | 
 The name of the API whose methods or permissions the  | 
| methodSelectors[] | 
 API methods or permissions to allow. Method or permission must belong to the service specified by  | 
MethodSelector
An allowed method or permission of a service specified in ApiOperation.
| JSON representation | 
|---|
| { // Union field | 
| Fields | |
|---|---|
| Union field kind. The API method name or Cloud IAM permission name to allow.kindcan be only one of the following: | |
| method | 
 A valid method name for the corresponding  | 
| permission | 
 A valid Cloud IAM permission for the corresponding  | 
EgressPolicy
Policy for egress from perimeter.
EgressPolicies match requests based on egressFrom and egressTo stanzas. For an EgressPolicy to match, both egressFrom and egressTo stanzas must be matched. If an EgressPolicy matches a request, the request is allowed to span the ServicePerimeter boundary. For example, an EgressPolicy can be used to allow VMs on networks within the ServicePerimeter to access a defined set of projects outside the perimeter in certain contexts (e.g. to read data from a Cloud Storage bucket or query against a BigQuery dataset).
EgressPolicies are concerned with the resources that a request relates as well as the API services and API actions being used. They do not related to the direction of data movement. More detailed documentation for this concept can be found in the descriptions of EgressFrom and EgressTo.
| JSON representation | 
|---|
| { "egressFrom": { object ( | 
| Fields | |
|---|---|
| egressFrom | 
 Defines conditions on the source of a request causing this  | 
| egressTo | 
 Defines the conditions on the  | 
| title | 
 Optional. Human-readable title for the egress rule. The title must be unique within the perimeter and can not exceed 100 characters. Within the access policy, the combined length of all rule titles must not exceed 240,000 characters. | 
EgressFrom
Defines the conditions under which an EgressPolicy matches a request. Conditions based on information about the source of the request. Note that if the destination of the request is also protected by a ServicePerimeter, then that ServicePerimeter must have an IngressPolicy which allows access in order for this request to succeed.
| JSON representation | 
|---|
| { "identities": [ string ], "identityType": enum ( | 
| Fields | |
|---|---|
| identities[] | 
 A list of identities that are allowed access through [EgressPolicy]. Identities can be an individual user, service account, Google group, or third-party identity. For third-party identity, only single identities are supported and other identity types are not supported. The  | 
| identityType | 
 Specifies the type of identities that are allowed access to outside the perimeter. If left unspecified, then members of  | 
| sources[] | 
 Sources that this [EgressPolicy]
                  [google.identity.accesscontextmanager.v1alpha.ServicePerimeterConfig.EgressPolicy] authorizes access from. If this field is not empty, then  | 
| sourceRestriction | 
 Whether to enforce traffic restrictions based on  | 
EgressSource
The source that [EgressPolicy] [google.identity.accesscontextmanager.v1alpha.ServicePerimeterConfig.EgressPolicy] authorizes access from inside the [ServicePerimeter] [google.identity.accesscontextmanager.v1alpha.ServicePerimeter] to somewhere outside the [ServicePerimeter] [google.identity.accesscontextmanager.v1alpha.ServicePerimeter] boundaries.
| JSON representation | 
|---|
| { // Union field | 
| Fields | |
|---|---|
| Union field source. Allowed egress source.sourcecan be only one of the following: | |
| accessLevel | 
 An [AccessLevel]
                  [google.identity.accesscontextmanager.v1alpha.AccessLevel] resource name that allows protected resources inside the [ServicePerimeters]
                  [google.identity.accesscontextmanager.v1alpha.ServicePerimeter] to access outside the [ServicePerimeter]
                  [google.identity.accesscontextmanager.v1alpha.ServicePerimeter] boundaries. [AccessLevels]
                  [google.identity.accesscontextmanager.v1alpha.AccessLevel] listed must be in the same policy as this [ServicePerimeter]
                  [google.identity.accesscontextmanager.v1alpha.ServicePerimeter]. Referencing a nonexistent [AccessLevel]
                  [google.identity.accesscontextmanager.v1alpha.AccessLevel] will cause an error. If an [AccessLevel]
                  [google.identity.accesscontextmanager.v1alpha.AccessLevel] name is not specified, only resources within the perimeter can be accessed through Google Cloud calls with request origins within the perimeter. Example:  | 
| resource | 
 A Google Cloud resource from the service perimeter that you want to allow to access data outside the perimeter. This field supports only projects. The project format is  | 
SourceRestriction
Whether to enable the enforcement of traffic based on on the sources field. Only applies to [EgressFrom]
          [google.identity.accesscontextmanager.v1alpha.ServicePerimeterConfig.EgressFrom].
| Enums | |
|---|---|
| SOURCE_RESTRICTION_UNSPECIFIED | Enforcement preference unspecified, will not enforce traffic restrictions based on  | 
| SOURCE_RESTRICTION_ENABLED | Enforcement preference enabled, traffic restrictions will be enforced based on  | 
| SOURCE_RESTRICTION_DISABLED | Enforcement preference disabled, will not enforce traffic restrictions based on  | 
EgressTo
Defines the conditions under which an EgressPolicy matches a request. Conditions are based on information about the ApiOperation intended to be performed on the resources specified. Note that if the destination of the request is also protected by a ServicePerimeter, then that ServicePerimeter must have an IngressPolicy which allows access in order for this request to succeed. The request must match operations AND resources fields in order to be allowed egress out of the perimeter.
| JSON representation | 
|---|
| {
  "resources": [
    string
  ],
  "operations": [
    {
      object ( | 
| Fields | |
|---|---|
| resources[] | 
 A list of resources, currently only projects in the form  | 
| operations[] | 
 A list of  | 
| externalResources[] | 
 A list of external resources that are allowed to be accessed. Only AWS and Azure resources are supported. For Amazon S3, the supported formats are s3://BUCKET_NAME, s3a://BUCKET_NAME, and s3n://BUCKET_NAME. For Azure Storage, the supported format is azure://myaccount.blob.core.windows.net/CONTAINER_NAME. A request matches if it contains an external resource in this list (Example: s3://bucket/path). Currently '*' is not allowed. | 
| roles[] | 
 IAM roles that represent the set of operations that the sources specified in the corresponding  | 
Inventory
This API resource represents the available inventory data for a Compute Engine virtual machine (VM) instance at a given point in time.
You can use this API resource to determine the inventory data of your VM.
For more information, see Information provided by OS inventory management.
| JSON representation | 
|---|
| { "name": string, "osInfo": { object ( | 
| Fields | |
|---|---|
| name | 
 Output only. The  Format:  | 
| osInfo | 
 Base level operating system information for the VM. | 
| items | 
 Inventory items related to the VM keyed by an opaque unique identifier for each inventory item. The identifier is unique to each distinct and addressable inventory item and will change, when there is a new package version. An object containing a list of  | 
| updateTime | 
 Output only. Timestamp of the last reported inventory for the VM. Uses RFC 3339, where generated output will always be Z-normalized and uses 0, 3, 6 or 9 fractional digits. Offsets other than "Z" are also accepted. Examples:  | 
OsInfo
Operating system information for the VM.
| JSON representation | 
|---|
| { "hostname": string, "longName": string, "shortName": string, "version": string, "architecture": string, "kernelVersion": string, "kernelRelease": string, "osconfigAgentVersion": string } | 
| Fields | |
|---|---|
| hostname | 
 The VM hostname. | 
| longName | 
 The operating system long name. For example 'Debian GNU/Linux 9' or 'Microsoft Window Server 2019 Datacenter'. | 
| shortName | 
 The operating system short name. For example, 'windows' or 'debian'. | 
| version | 
 The version of the operating system. | 
| architecture | 
 The system architecture of the operating system. | 
| kernelVersion | 
 The kernel version of the operating system. | 
| kernelRelease | 
 The kernel release of the operating system. | 
| osconfigAgentVersion | 
 The current version of the OS Config agent running on the VM. | 
Item
A single piece of inventory on a VM.
| JSON representation | 
|---|
| { "id": string, "originType": enum ( | 
| Fields | |
|---|---|
| id | 
 Identifier for this item, unique across items for this VM. | 
| originType | 
 The origin of this inventory item. | 
| createTime | 
 When this inventory item was first detected. Uses RFC 3339, where generated output will always be Z-normalized and uses 0, 3, 6 or 9 fractional digits. Offsets other than "Z" are also accepted. Examples:  | 
| updateTime | 
 When this inventory item was last modified. Uses RFC 3339, where generated output will always be Z-normalized and uses 0, 3, 6 or 9 fractional digits. Offsets other than "Z" are also accepted. Examples:  | 
| type | 
 The specific type of inventory, correlating to its specific details. | 
| Union field details. Specific details of this inventory item based on its type.detailscan be only one of the following: | |
| installedPackage | 
 Software package present on the VM instance. | 
| availablePackage | 
 Software package available to be installed on the VM instance. | 
OriginType
The origin of a specific inventory item.
| Enums | |
|---|---|
| ORIGIN_TYPE_UNSPECIFIED | Invalid. An origin type must be specified. | 
| INVENTORY_REPORT | This inventory item was discovered as the result of the agent reporting inventory via the reporting API. | 
Type
The different types of inventory that are tracked on a VM.
| Enums | |
|---|---|
| TYPE_UNSPECIFIED | Invalid. A type must be specified. | 
| INSTALLED_PACKAGE | This represents a package that is installed on the VM. | 
| AVAILABLE_PACKAGE | This represents an update that is available for a package. | 
SoftwarePackage
Software package information of the operating system.
| JSON representation | 
|---|
| { // Union field | 
| Fields | |
|---|---|
| Union field details. Information about the different types of software packages.detailscan be only one of the following: | |
| yumPackage | 
 Yum package info. For details about the yum package manager, see https://access.redhat.com/documentation/en-us/red_hat_enterprise_linux/6/html/deployment_guide/ch-yum. | 
| aptPackage | 
 Details of an APT package. For details about the apt package manager, see https://wiki.debian.org/Apt. | 
| zypperPackage | 
 Details of a Zypper package. For details about the Zypper package manager, see https://en.opensuse.org/SDB:Zypper_manual. | 
| googetPackage | 
 Details of a Googet package. For details about the googet package manager, see https://github.com/google/googet. | 
| zypperPatch | 
 Details of a Zypper patch. For details about the Zypper package manager, see https://en.opensuse.org/SDB:Zypper_manual. | 
| wuaPackage | 
 Details of a Windows Update package. See https://docs.microsoft.com/en-us/windows/win32/api/_wua/ for information about Windows Update. | 
| qfePackage | 
 Details of a Windows Quick Fix engineering package. See https://docs.microsoft.com/en-us/windows/win32/cimwin32prov/win32-quickfixengineering for info in Windows Quick Fix Engineering. | 
| cosPackage | 
 Details of a COS package. | 
| windowsApplication | 
 Details of Windows Application. | 
VersionedPackage
Information related to the a standard versioned package. This includes package info for APT, Yum, Zypper, and Googet package managers.
| JSON representation | 
|---|
| { "packageName": string, "architecture": string, "version": string } | 
| Fields | |
|---|---|
| packageName | 
 The name of the package. | 
| architecture | 
 The system architecture this package is intended for. | 
| version | 
 The version of the package. | 
ZypperPatch
Details related to a Zypper Patch.
| JSON representation | 
|---|
| { "patchName": string, "category": string, "severity": string, "summary": string } | 
| Fields | |
|---|---|
| patchName | 
 The name of the patch. | 
| category | 
 The category of the patch. | 
| severity | 
 The severity specified for this patch | 
| summary | 
 Any summary information provided about this patch. | 
WindowsUpdatePackage
Details related to a Windows Update package. Field data and names are taken from Windows Update API IUpdate Interface: https://docs.microsoft.com/en-us/windows/win32/api/_wua/ Descriptive fields like title, and description are localized based on the locale of the VM being updated.
| JSON representation | 
|---|
| {
  "title": string,
  "description": string,
  "categories": [
    {
      object ( | 
| Fields | |
|---|---|
| title | 
 The localized title of the update package. | 
| description | 
 The localized description of the update package. | 
| categories[] | 
 The categories that are associated with this update package. | 
| kbArticleIds[] | 
 A collection of Microsoft Knowledge Base article IDs that are associated with the update package. | 
| supportUrl | 
 A hyperlink to the language-specific support information for the update. | 
| moreInfoUrls[] | 
 A collection of URLs that provide more information about the update package. | 
| updateId | 
 Gets the identifier of an update package. Stays the same across revisions. | 
| revisionNumber | 
 The revision number of this update package. | 
| lastDeploymentChangeTime | 
 The last published date of the update, in (UTC) date and time. Uses RFC 3339, where generated output will always be Z-normalized and uses 0, 3, 6 or 9 fractional digits. Offsets other than "Z" are also accepted. Examples:  | 
WindowsUpdateCategory
Categories specified by the Windows Update.
| JSON representation | 
|---|
| { "id": string, "name": string } | 
| Fields | |
|---|---|
| id | 
 The identifier of the windows update category. | 
| name | 
 The name of the windows update category. | 
WindowsQuickFixEngineeringPackage
Information related to a Quick Fix Engineering package. Fields are taken from Windows QuickFixEngineering Interface and match the source names: https://docs.microsoft.com/en-us/windows/win32/cimwin32prov/win32-quickfixengineering
| JSON representation | 
|---|
| { "caption": string, "description": string, "hotFixId": string, "installTime": string } | 
| Fields | |
|---|---|
| caption | 
 A short textual description of the QFE update. | 
| description | 
 A textual description of the QFE update. | 
| hotFixId | 
 Unique identifier associated with a particular QFE update. | 
| installTime | 
 Date that the QFE update was installed. Mapped from installed_on field. Uses RFC 3339, where generated output will always be Z-normalized and uses 0, 3, 6 or 9 fractional digits. Offsets other than "Z" are also accepted. Examples:  | 
WindowsApplication
Contains information about a Windows application that is retrieved from the Windows Registry. For more information about these fields, see: https://docs.microsoft.com/en-us/windows/win32/msi/uninstall-registry-key
| JSON representation | 
|---|
| {
  "displayName": string,
  "displayVersion": string,
  "publisher": string,
  "installDate": {
    object ( | 
| Fields | |
|---|---|
| displayName | 
 The name of the application or product. | 
| displayVersion | 
 The version of the product or application in string format. | 
| publisher | 
 The name of the manufacturer for the product or application. | 
| installDate | 
 The last time this product received service. The value of this property is replaced each time a patch is applied or removed from the product or the command-line option is used to repair the product. | 
| helpLink | 
 The internet address for technical support. | 
Date
Represents a whole or partial calendar date, such as a birthday. The time of day and time zone are either specified elsewhere or are insignificant. The date is relative to the Gregorian Calendar. This can represent one of the following:
- A full date, with non-zero year, month, and day values.
- A month and day, with a zero year (for example, an anniversary).
- A year on its own, with a zero month and a zero day.
- A year and month, with a zero day (for example, a credit card expiration date).
Related types:
- google.type.TimeOfDay
- google.type.DateTime
- google.protobuf.Timestamp
| JSON representation | 
|---|
| { "year": integer, "month": integer, "day": integer } | 
| Fields | |
|---|---|
| year | 
 Year of the date. Must be from 1 to 9999, or 0 to specify a date without a year. | 
| month | 
 Month of a year. Must be from 1 to 12, or 0 to specify a year without a month and day. | 
| day | 
 Day of a month. Must be from 1 to 31 and valid for the year and month, or 0 to specify a year by itself or a year and month where the day isn't significant. | 
RelatedAssets
DEPRECATED. This message only presents for the purpose of backward-compatibility. The server will never populate this message in responses. The detailed related assets with the relationshipType.
| JSON representation | 
|---|
| { "relationshipAttributes": { object ( | 
| Fields | |
|---|---|
| relationshipAttributes | 
 The detailed relationship attributes. | 
| assets[] | 
 The peer resources of the relationship. | 
RelationshipAttributes
DEPRECATED. This message only presents for the purpose of backward-compatibility. The server will never populate this message in responses. The relationship attributes which include type, sourceResourceType, targetResourceType and action.
| JSON representation | 
|---|
| { "type": string, "sourceResourceType": string, "targetResourceType": string, "action": string } | 
| Fields | |
|---|---|
| type | 
 The unique identifier of the relationship type. Example:  | 
| sourceResourceType | 
 The source asset type. Example:  | 
| targetResourceType | 
 The target asset type. Example:  | 
| action | 
 The detail of the relationship, e.g.  | 
RelatedAsset
An asset identifier in Google Cloud which contains its name, type and ancestors. An asset can be any resource in the Google Cloud resource hierarchy, a resource outside the Google Cloud resource hierarchy (such as Google Kubernetes Engine clusters and objects), or a policy (e.g. IAM policy). See Supported asset types for more information.
| JSON representation | 
|---|
| { "asset": string, "assetType": string, "ancestors": [ string ], "relationshipType": string } | 
| Fields | |
|---|---|
| asset | 
 The full name of the asset. Example:  See Resource names for more information. | 
| assetType | 
 The type of the asset. Example:  See Supported asset types for more information. | 
| ancestors[] | 
 The ancestors of an asset in Google Cloud resource hierarchy, represented as a list of relative resource names. An ancestry path starts with the closest ancestor in the hierarchy and ends at root. Example:  | 
| relationshipType | 
 The unique identifier of the relationship type. Example:  | 
AssetException
An exception of an asset.
| JSON representation | 
|---|
| {
  "exceptionType": enum ( | 
| Fields | |
|---|---|
| exceptionType | 
 The type of exception. | 
| details | 
 The details of the exception. | 
ExceptionType
The type of exception.
| Enums | |
|---|---|
| EXCEPTION_TYPE_UNSPECIFIED | exceptionType is not applicable for the current asset. | 
| TRUNCATION | The asset content is truncated. |