{
  "version": "v1beta",
  "documentationLink": "https://cloud.google.com/iam/docs/pam-overview",
  "fullyEncodeReservedExpansion": true,
  "title": "Privileged Access Manager API",
  "baseUrl": "https://privilegedaccessmanager.googleapis.com/",
  "canonicalName": "Privileged Access Manager",
  "schemas": {
    "RequesterJustificationConfig": {
      "description": "Defines how a requester must provide a justification when requesting access.",
      "type": "object",
      "id": "RequesterJustificationConfig",
      "properties": {
        "notMandatory": {
          "description": "This option means the requester isn't required to provide a justification.",
          "$ref": "NotMandatory"
        },
        "unstructured": {
          "description": "This option means the requester must provide a string as justification. If this is selected, the server allows the requester to provide a justification but doesn't validate it.",
          "$ref": "Unstructured"
        }
      }
    },
    "Ended": {
      "description": "An event representing that the grant has ended.",
      "type": "object",
      "id": "Ended",
      "properties": {}
    },
    "FetchEffectiveSettingsResponse": {
      "description": "The effective value of the settings at the given location resource, evaluated based on the crm resource hierarchy.",
      "type": "object",
      "id": "FetchEffectiveSettingsResponse",
      "properties": {
        "parent": {
          "readOnly": true,
          "description": "Output only. The resource on which the settings are effective. Possible formats: * `projects/{project-number|project-id}/locations/{region}` * `folders/{folder-number}/locations/{region}` * `organizations/{organization-number}/locations/{region}`",
          "type": "string"
        },
        "serviceAccountApproverSettings": {
          "readOnly": true,
          "description": "Output only. Effective settings for allowing service account as approvers.",
          "$ref": "FetchEffectiveSettingsResponse_ServiceAccountApproverSettings"
        },
        "emailNotificationSettings": {
          "readOnly": true,
          "description": "Output only. `EmailNotificationSettings` defines effective node-wide email notification preferences for various PAM events.",
          "$ref": "FetchEffectiveSettingsResponse_EmailNotificationSettings"
        }
      }
    },
    "FetchEffectiveSettingsResponse_EmailNotificationSettings": {
      "id": "FetchEffectiveSettingsResponse_EmailNotificationSettings",
      "properties": {
        "disableAllNotifications": {
          "readOnly": true,
          "description": "Output only. Disable all notifications.",
          "$ref": "FetchEffectiveSettingsResponseEmailNotificationSettings_DisableAllNotifications"
        },
        "customNotificationBehavior": {
          "description": "Output only. Granular settings of notifications.",
          "$ref": "FetchEffectiveSettingsResponseEmailNotificationSettings_CustomNotificationBehavior",
          "readOnly": true
        },
        "source": {
          "readOnly": true,
          "description": "Output only. The name of the resource from which the notification behavior is inherited. This field remains empty if the setting is not defined at either the parent or resource level, in which case PAM's default behavior is applied.",
          "type": "string"
        }
      },
      "description": "`EmailNotificationSettings` reflects the effective node-wide email notification settings.",
      "type": "object"
    },
    "ListGrantsResponse": {
      "description": "Message for response to listing grants.",
      "type": "object",
      "id": "ListGrantsResponse",
      "properties": {
        "unreachable": {
          "items": {
            "type": "string"
          },
          "description": "Locations that could not be reached.",
          "type": "array"
        },
        "grants": {
          "items": {
            "$ref": "Grant"
          },
          "description": "The list of grants.",
          "type": "array"
        },
        "nextPageToken": {
          "description": "A token identifying a page of results the server should return.",
          "type": "string"
        }
      }
    },
    "Grant": {
      "id": "Grant",
      "properties": {
        "externallyModified": {
          "readOnly": true,
          "description": "Output only. Flag set by the PAM system to indicate that policy bindings made by this grant have been modified from outside PAM. After it is set, this flag remains set forever irrespective of the grant state. A `true` value here indicates that PAM no longer has any certainty on the access a user has because of this grant.",
          "type": "boolean"
        },
        "auditTrail": {
          "description": "Output only. Audit trail of access provided by this grant. If unspecified then access was never granted.",
          "$ref": "AuditTrail",
          "readOnly": true
        },
        "state": {
          "type": "string",
          "enumDescriptions": [
            "Unspecified state. This value is never returned by the server.",
            "The entitlement had an approval workflow configured and this grant is waiting for the workflow to complete.",
            "The approval workflow completed with a denied result. No access is granted for this grant. This is a terminal state.",
            "The approval workflow completed successfully with an approved result or none was configured. Access is provided at an appropriate time.",
            "Access is being given.",
            "Access was successfully given and is currently active.",
            "The system could not give access due to a non-retriable error. This is a terminal state.",
            "Expired after waiting for the approval workflow to complete. This is a terminal state.",
            "Access is being revoked.",
            "Access was revoked by a user. This is a terminal state.",
            "System took back access as the requested duration was over. This is a terminal state.",
            "Access is being withdrawn.",
            "Grant was withdrawn by the grant owner. This is a terminal state."
          ],
          "readOnly": true,
          "enum": [
            "STATE_UNSPECIFIED",
            "APPROVAL_AWAITED",
            "DENIED",
            "SCHEDULED",
            "ACTIVATING",
            "ACTIVE",
            "ACTIVATION_FAILED",
            "EXPIRED",
            "REVOKING",
            "REVOKED",
            "ENDED",
            "WITHDRAWING",
            "WITHDRAWN"
          ],
          "description": "Output only. Current state of this grant."
        },
        "activationTrigger": {
          "description": "Optional. The activation trigger for this grant. This field being absent indicates default behavior for the grant, that is, the grant will get activated as soon as the required number of approvals are received or, if approvals are not required, as soon as the grant is created.",
          "$ref": "ActivationTrigger"
        },
        "updateTime": {
          "description": "Output only. Update time stamp.",
          "type": "string",
          "readOnly": true,
          "format": "google-datetime"
        },
        "createTime": {
          "description": "Output only. Create time stamp.",
          "type": "string",
          "readOnly": true,
          "format": "google-datetime"
        },
        "privilegedAccess": {
          "readOnly": true,
          "description": "Output only. The access that would be granted by this grant.",
          "$ref": "PrivilegedAccess"
        },
        "requestedPrivilegedAccess": {
          "items": {
            "$ref": "RequestedPrivilegedAccess"
          },
          "description": "Optional. The accesses requested to be granted by this grant.",
          "type": "array"
        },
        "name": {
          "description": "Identifier. Name of this grant. Possible formats: * `organizations/{organization-number}/locations/{region}/entitlements/{entitlement-id}/grants/{grant-id}` * `folders/{folder-number}/locations/{region}/entitlements/{entitlement-id}/grants/{grant-id}` * `projects/{project-id|project-number}/locations/{region}/entitlements/{entitlement-id}/grants/{grant-id}` The last segment of this name (`{grant-id}`) is autogenerated.",
          "type": "string"
        },
        "timeline": {
          "description": "Output only. Timeline of this grant.",
          "$ref": "Timeline",
          "readOnly": true
        },
        "additionalEmailRecipients": {
          "description": "Optional. Additional email addresses to notify for all the actions performed on the grant.",
          "type": "array",
          "items": {
            "type": "string"
          }
        },
        "requestedDuration": {
          "description": "Required. The amount of time access is needed for. This value should be shorter than the `max_request_duration` value of the entitlement.",
          "type": "string",
          "format": "google-duration"
        },
        "justification": {
          "description": "Optional. Justification of why this access is needed.",
          "$ref": "Justification"
        },
        "requester": {
          "readOnly": true,
          "description": "Output only. Username of the user who created this grant.",
          "type": "string"
        }
      },
      "description": "A grant represents a request from a user for obtaining the access specified in an entitlement they are eligible for.",
      "type": "object"
    },
    "GoogleProtobufEmpty": {
      "description": "A generic empty message that you can re-use to avoid defining duplicated empty messages in your APIs. A typical example is to use it as the request or the response type of an API method. For instance: service Foo { rpc Bar(google.protobuf.Empty) returns (google.protobuf.Empty); }",
      "type": "object",
      "id": "GoogleProtobufEmpty",
      "properties": {}
    },
    "AuditTrail": {
      "id": "AuditTrail",
      "properties": {
        "accessGrantTime": {
          "readOnly": true,
          "format": "google-datetime",
          "description": "Output only. The time at which access was given.",
          "type": "string"
        },
        "accessRemoveTime": {
          "description": "Output only. The time at which the system removed access. This could be because of an automatic expiry or because of a revocation. If unspecified, then access hasn't been removed yet.",
          "type": "string",
          "readOnly": true,
          "format": "google-datetime"
        }
      },
      "description": "Audit trail for the access provided by this grant.",
      "type": "object"
    },
    "FetchEffectiveSettingsResponseEmailNotificationSettingsCustomNotificationBehavior_RequesterNotifications": {
      "id": "FetchEffectiveSettingsResponseEmailNotificationSettingsCustomNotificationBehavior_RequesterNotifications",
      "properties": {
        "notifyGrantActivated": {
          "description": "Output only. Notification delivery for grant activated.",
          "type": "boolean",
          "readOnly": true
        },
        "notifyGrantExpired": {
          "description": "Output only. Notification delivery for grant request expired.",
          "type": "boolean",
          "readOnly": true
        },
        "notifyGrantDenied": {
          "readOnly": true,
          "description": "Output only. Notification delivery for grant denied.",
          "type": "boolean"
        },
        "notifyGrantActivationScheduled": {
          "description": "Output only. Notification delivery for grant activation scheduled.",
          "type": "boolean",
          "readOnly": true
        },
        "notifyGrantExternallyModified": {
          "description": "Output only. Notification delivery for grant externally modified.",
          "type": "boolean",
          "readOnly": true
        },
        "notifyGrantActivationFailed": {
          "readOnly": true,
          "description": "Output only. Notification delivery for grant activation failed.",
          "type": "boolean"
        },
        "notifyGrantRevoked": {
          "description": "Output only. Notification delivery for grant revoked.",
          "type": "boolean",
          "readOnly": true
        },
        "notifyEntitlementAssigned": {
          "readOnly": true,
          "description": "Output only. Notification delivery for entitlement assigned.",
          "type": "boolean"
        },
        "notifyGrantEnded": {
          "readOnly": true,
          "description": "Output only. Notification delivery for grant ended.",
          "type": "boolean"
        }
      },
      "description": "Email notifications specific to Requesters.",
      "type": "object"
    },
    "Expired": {
      "id": "Expired",
      "properties": {},
      "description": "An event representing that the grant was expired.",
      "type": "object"
    },
    "ExternallyModified": {
      "id": "ExternallyModified",
      "properties": {},
      "description": "An event representing that the policy bindings made by this grant were modified externally.",
      "type": "object"
    },
    "Withdrawn": {
      "description": "An event representing that the grant was withdrawn.",
      "type": "object",
      "id": "Withdrawn",
      "properties": {}
    },
    "ApproveGrantRequest": {
      "description": "Request message for `ApproveGrant` method.",
      "type": "object",
      "id": "ApproveGrantRequest",
      "properties": {
        "reason": {
          "description": "Optional. The reason for approving this grant. This is required if the `require_approver_justification` field of the `ManualApprovals` workflow used in this grant is true.",
          "type": "string"
        }
      }
    },
    "RequestedPrivilegedAccess_GcpIamAccess": {
      "description": "`GcpIamAccess` represents IAM based access control on a Google Cloud resource. Refer to https://cloud.google.com/iam/docs to understand more about IAM.",
      "type": "object",
      "id": "RequestedPrivilegedAccess_GcpIamAccess",
      "properties": {
        "resourceType": {
          "description": "Required. The type of this resource.",
          "type": "string"
        },
        "resource": {
          "description": "Required. Name of the resource.",
          "type": "string"
        },
        "roleBindings": {
          "description": "Optional. Role bindings that are requested as part of the grant.",
          "type": "array",
          "items": {
            "$ref": "RequestedPrivilegedAccessGcpIamAccess_RoleBinding"
          }
        }
      }
    },
    "SettingsEmailNotificationSettings_DisableAllNotifications": {
      "id": "SettingsEmailNotificationSettings_DisableAllNotifications",
      "properties": {},
      "description": "This option indicates that all email notifications are disabled.",
      "type": "object"
    },
    "OperationMetadata": {
      "description": "Represents the metadata of the long-running operation.",
      "type": "object",
      "id": "OperationMetadata",
      "properties": {
        "target": {
          "description": "Output only. Server-defined resource path for the target of the operation.",
          "type": "string",
          "readOnly": true
        },
        "verb": {
          "description": "Output only. Name of the verb executed by the operation.",
          "type": "string",
          "readOnly": true
        },
        "createTime": {
          "description": "Output only. The time the operation was created.",
          "type": "string",
          "readOnly": true,
          "format": "google-datetime"
        },
        "statusMessage": {
          "readOnly": true,
          "description": "Output only. Human-readable status of the operation, if any.",
          "type": "string"
        },
        "endTime": {
          "format": "google-datetime",
          "readOnly": true,
          "description": "Output only. The time the operation finished running.",
          "type": "string"
        },
        "requestedCancellation": {
          "readOnly": true,
          "description": "Output only. Identifies whether the user has requested cancellation of the operation. Operations that have been cancelled successfully have Operation.error value with a google.rpc.Status.code of 1, corresponding to `Code.CANCELLED`.",
          "type": "boolean"
        },
        "apiVersion": {
          "readOnly": true,
          "description": "Output only. API version used to start the operation.",
          "type": "string"
        }
      }
    },
    "Revoked": {
      "id": "Revoked",
      "properties": {
        "actor": {
          "description": "Output only. Username of the user who revoked the grant.",
          "type": "string",
          "readOnly": true
        },
        "reason": {
          "readOnly": true,
          "description": "Output only. The reason provided by the user for revoking the grant.",
          "type": "string"
        }
      },
      "description": "An event representing that the grant was revoked.",
      "type": "object"
    },
    "SettingsEmailNotificationSettingsCustomNotificationBehavior_AdminNotifications": {
      "id": "SettingsEmailNotificationSettingsCustomNotificationBehavior_AdminNotifications",
      "properties": {
        "grantActivated": {
          "description": "Optional. Notification mode for grant activated.",
          "type": "string",
          "enumDescriptions": [
            "Default notification behavior following PAM's standard settings.",
            "Notifications are enabled.",
            "Notifications are disabled."
          ],
          "enum": [
            "NOTIFICATION_MODE_UNSPECIFIED",
            "ENABLED",
            "DISABLED"
          ]
        },
        "grantEnded": {
          "enum": [
            "NOTIFICATION_MODE_UNSPECIFIED",
            "ENABLED",
            "DISABLED"
          ],
          "description": "Optional. Notification mode for grant ended.",
          "type": "string",
          "enumDescriptions": [
            "Default notification behavior following PAM's standard settings.",
            "Notifications are enabled.",
            "Notifications are disabled."
          ]
        },
        "grantActivationScheduled": {
          "description": "Optional. Notification mode for grant activation scheduled.",
          "type": "string",
          "enumDescriptions": [
            "Default notification behavior following PAM's standard settings.",
            "Notifications are enabled.",
            "Notifications are disabled."
          ],
          "enum": [
            "NOTIFICATION_MODE_UNSPECIFIED",
            "ENABLED",
            "DISABLED"
          ]
        },
        "grantExternallyModified": {
          "description": "Optional. Notification mode for grant externally modified.",
          "type": "string",
          "enumDescriptions": [
            "Default notification behavior following PAM's standard settings.",
            "Notifications are enabled.",
            "Notifications are disabled."
          ],
          "enum": [
            "NOTIFICATION_MODE_UNSPECIFIED",
            "ENABLED",
            "DISABLED"
          ]
        },
        "grantActivationFailed": {
          "enum": [
            "NOTIFICATION_MODE_UNSPECIFIED",
            "ENABLED",
            "DISABLED"
          ],
          "description": "Optional. Notification mode for grant activation failed.",
          "type": "string",
          "enumDescriptions": [
            "Default notification behavior following PAM's standard settings.",
            "Notifications are enabled.",
            "Notifications are disabled."
          ]
        }
      },
      "description": "Email notifications specific to Admins.",
      "type": "object"
    },
    "Denied": {
      "description": "An event representing that the grant was denied.",
      "type": "object",
      "id": "Denied",
      "properties": {
        "actor": {
          "description": "Output only. Username of the user who denied the grant.",
          "type": "string",
          "readOnly": true
        },
        "stepId": {
          "readOnly": true,
          "description": "Output only. The ID of the approval workflow step that was denied.",
          "type": "string"
        },
        "reason": {
          "readOnly": true,
          "description": "Output only. The reason provided by the approver for denying the grant.",
          "type": "string"
        }
      }
    },
    "Activated": {
      "id": "Activated",
      "properties": {},
      "description": "An event representing that the grant was successfully activated.",
      "type": "object"
    },
    "RequestedPrivilegedAccessGcpIamAccess_AccessRestrictions": {
      "id": "RequestedPrivilegedAccessGcpIamAccess_AccessRestrictions",
      "properties": {
        "resourceNames": {
          "description": "Optional. The resource names to restrict the access to. Follow https://cloud.google.com/iam/docs/conditions-resource-attributes#resource-name format.",
          "type": "array",
          "items": {
            "type": "string"
          }
        },
        "resourceNamePrefixes": {
          "description": "Optional. The resource name prefixes to restrict the access to. Follow https://cloud.google.com/iam/docs/conditions-resource-attributes#resource-name format.",
          "type": "array",
          "items": {
            "type": "string"
          }
        }
      },
      "description": "AccessRestrictions represents a set of resources to further restrict the access to. This is used to get finer grained access as part of a grant. All restrictions are OR-ed with each other.",
      "type": "object"
    },
    "DenyGrantRequest": {
      "description": "Request message for `DenyGrant` method.",
      "type": "object",
      "id": "DenyGrantRequest",
      "properties": {
        "reason": {
          "description": "Optional. The reason for denying this grant. This is required if `require_approver_justification` field of the `ManualApprovals` workflow used in this grant is true.",
          "type": "string"
        }
      }
    },
    "Requested": {
      "id": "Requested",
      "properties": {
        "expireTime": {
          "readOnly": true,
          "format": "google-datetime",
          "description": "Output only. The time at which this grant expires unless the approval workflow completes. If omitted, then the request never expires.",
          "type": "string"
        }
      },
      "description": "An event representing that a grant was requested.",
      "type": "object"
    },
    "SettingsEmailNotificationSettings_CustomNotificationBehavior": {
      "description": "`CustomNotificationBehavior` provides granular control over email notification delivery. Allows admins to selectively enable/disable notifications for specific events and specific personas.",
      "type": "object",
      "id": "SettingsEmailNotificationSettings_CustomNotificationBehavior",
      "properties": {
        "requesterNotifications": {
          "description": "Optional. Requester email notifications.",
          "$ref": "SettingsEmailNotificationSettingsCustomNotificationBehavior_RequesterNotifications"
        },
        "adminNotifications": {
          "description": "Optional. Admin email notifications.",
          "$ref": "SettingsEmailNotificationSettingsCustomNotificationBehavior_AdminNotifications"
        },
        "approverNotifications": {
          "description": "Optional. Approver email notifications.",
          "$ref": "SettingsEmailNotificationSettingsCustomNotificationBehavior_ApproverNotifications"
        }
      }
    },
    "FetchEffectiveSettingsResponse_ServiceAccountApproverSettings": {
      "id": "FetchEffectiveSettingsResponse_ServiceAccountApproverSettings",
      "properties": {
        "enabled": {
          "description": "Output only. Indicates whether service account is allowed to grant approvals.",
          "type": "boolean",
          "readOnly": true
        },
        "source": {
          "description": "Output only. The resource from which the service account approver setting is inherited. This field remains empty if the setting is not defined at either the parent or resource level, in which case PAM's default behavior is applied.",
          "type": "string",
          "readOnly": true
        }
      },
      "description": "This controls whether service accounts are allowed to approve grants or can be designated as approvers within PAM entitlements.",
      "type": "object"
    },
    "Status": {
      "id": "Status",
      "properties": {
        "message": {
          "description": "A developer-facing error message, which should be in English. Any user-facing error message should be localized and sent in the google.rpc.Status.details field, or localized by the client.",
          "type": "string"
        },
        "code": {
          "format": "int32",
          "description": "The status code, which should be an enum value of google.rpc.Code.",
          "type": "integer"
        },
        "details": {
          "description": "A list of messages that carry the error details. There is a common set of message types for APIs to use.",
          "type": "array",
          "items": {
            "type": "object",
            "additionalProperties": {
              "type": "any",
              "description": "Properties of the object. Contains field @type with type URL."
            }
          }
        }
      },
      "description": "The `Status` type defines a logical error model that is suitable for different programming environments, including REST APIs and RPC APIs. It is used by [gRPC](https://github.com/grpc). Each `Status` message contains three pieces of data: error code, error message, and error details. You can find out more about this error model and how to work with it in the [API Design Guide](https://cloud.google.com/apis/design/errors).",
      "type": "object"
    },
    "ApprovalWorkflow": {
      "description": "Different types of approval workflows that can be used to gate privileged access granting.",
      "type": "object",
      "id": "ApprovalWorkflow",
      "properties": {
        "manualApprovals": {
          "description": "An approval workflow where users designated as approvers review and act on the grants.",
          "$ref": "ManualApprovals"
        }
      }
    },
    "GcpIamAccess": {
      "description": "`GcpIamAccess` represents IAM based access control on a Google Cloud resource. Refer to https://cloud.google.com/iam/docs to understand more about IAM.",
      "type": "object",
      "id": "GcpIamAccess",
      "properties": {
        "resourceType": {
          "description": "Required. The type of this resource.",
          "type": "string"
        },
        "resource": {
          "description": "Required. Name of the resource.",
          "type": "string"
        },
        "roleBindings": {
          "items": {
            "$ref": "RoleBinding"
          },
          "description": "Required. Role bindings that are created on successful grant.",
          "type": "array"
        }
      }
    },
    "Scheduled": {
      "description": "An event representing that the grant has been scheduled to be activated later.",
      "type": "object",
      "id": "Scheduled",
      "properties": {
        "scheduledActivationTime": {
          "description": "Output only. The time at which the access is granted.",
          "type": "string",
          "format": "google-datetime",
          "readOnly": true
        }
      }
    },
    "AccessControlEntry": {
      "description": "`AccessControlEntry` is used to control who can do some operation.",
      "type": "object",
      "id": "AccessControlEntry",
      "properties": {
        "principals": {
          "description": "Optional. Users who are allowed for the operation. Each entry should be a valid v1 IAM principal identifier. The format for these is documented at: https://cloud.google.com/iam/docs/principal-identifiers#v1",
          "type": "array",
          "items": {
            "type": "string"
          }
        }
      }
    },
    "ListOperationsResponse": {
      "description": "The response message for Operations.ListOperations.",
      "type": "object",
      "id": "ListOperationsResponse",
      "properties": {
        "nextPageToken": {
          "description": "The standard List next-page token.",
          "type": "string"
        },
        "operations": {
          "items": {
            "$ref": "Operation"
          },
          "description": "A list of operations that matches the specified filter in the request.",
          "type": "array"
        },
        "unreachable": {
          "description": "Unordered list. Unreachable resources. Populated when the request sets `ListOperationsRequest.return_partial_success` and reads across collections. For example, when attempting to list all resources across all supported locations.",
          "type": "array",
          "items": {
            "type": "string"
          }
        }
      }
    },
    "SettingsEmailNotificationSettingsCustomNotificationBehavior_ApproverNotifications": {
      "description": "Email notifications specific to Approvers.",
      "type": "object",
      "id": "SettingsEmailNotificationSettingsCustomNotificationBehavior_ApproverNotifications",
      "properties": {
        "pendingApproval": {
          "description": "Optional. Notification mode for pending approval.",
          "type": "string",
          "enumDescriptions": [
            "Default notification behavior following PAM's standard settings.",
            "Notifications are enabled.",
            "Notifications are disabled."
          ],
          "enum": [
            "NOTIFICATION_MODE_UNSPECIFIED",
            "ENABLED",
            "DISABLED"
          ]
        }
      }
    },
    "FetchEffectiveSettingsResponseEmailNotificationSettingsCustomNotificationBehavior_ApproverNotifications": {
      "id": "FetchEffectiveSettingsResponseEmailNotificationSettingsCustomNotificationBehavior_ApproverNotifications",
      "properties": {
        "notifyPendingApproval": {
          "description": "Output only. Notification delivery for pending approval.",
          "type": "boolean",
          "readOnly": true
        }
      },
      "description": "Email notifications specific to Approvers.",
      "type": "object"
    },
    "Entitlement": {
      "description": "An entitlement defines the eligibility of a set of users to obtain predefined access for some time possibly after going through an approval workflow.",
      "type": "object",
      "id": "Entitlement",
      "properties": {
        "privilegedAccess": {
          "description": "Optional. The access granted to a requester on successful approval.",
          "$ref": "PrivilegedAccess"
        },
        "createTime": {
          "readOnly": true,
          "format": "google-datetime",
          "description": "Output only. Create time stamp.",
          "type": "string"
        },
        "requesterJustificationConfig": {
          "description": "Required. The manner in which the requester should provide a justification for requesting access.",
          "$ref": "RequesterJustificationConfig"
        },
        "additionalNotificationTargets": {
          "description": "Optional. Additional email addresses to be notified based on actions taken.",
          "$ref": "AdditionalNotificationTargets"
        },
        "updateTime": {
          "format": "google-datetime",
          "readOnly": true,
          "description": "Output only. Update time stamp.",
          "type": "string"
        },
        "state": {
          "type": "string",
          "enumDescriptions": [
            "Unspecified state. This value is never returned by the server.",
            "The entitlement is being created.",
            "The entitlement is available for requesting access.",
            "The entitlement is being deleted.",
            "The entitlement has been deleted.",
            "The entitlement is being updated."
          ],
          "readOnly": true,
          "enum": [
            "STATE_UNSPECIFIED",
            "CREATING",
            "AVAILABLE",
            "DELETING",
            "DELETED",
            "UPDATING"
          ],
          "description": "Output only. Current state of this entitlement."
        },
        "name": {
          "description": "Identifier. Name of the entitlement. Possible formats: * `organizations/{organization-number}/locations/{region}/entitlements/{entitlement-id}` * `folders/{folder-number}/locations/{region}/entitlements/{entitlement-id}` * `projects/{project-id|project-number}/locations/{region}/entitlements/{entitlement-id}`",
          "type": "string"
        },
        "eligibleUsers": {
          "description": "Optional. Who can create grants using this entitlement. This list should contain at most one entry.",
          "type": "array",
          "items": {
            "$ref": "AccessControlEntry"
          }
        },
        "maxRequestDuration": {
          "description": "Required. The maximum amount of time that access is granted for a request. A requester can ask for a shorter duration but never a longer one. The supported range is between 30 minutes and 168 hours (7 days).",
          "type": "string",
          "format": "google-duration"
        },
        "approvalWorkflow": {
          "description": "Optional. The approvals needed before access are granted to a requester. No approvals are needed if this field is null.",
          "$ref": "ApprovalWorkflow"
        },
        "etag": {
          "description": "An `etag` is used for optimistic concurrency control as a way to prevent simultaneous updates to the same entitlement. An `etag` is returned in the response to `GetEntitlement` and the caller should put the `etag` in the request to `UpdateEntitlement` so that their change is applied on the same version. If this field is omitted or if there is a mismatch while updating an entitlement, then the server rejects the request.",
          "type": "string"
        }
      }
    },
    "SearchEntitlementsResponse": {
      "id": "SearchEntitlementsResponse",
      "properties": {
        "nextPageToken": {
          "description": "A token identifying a page of results the server should return.",
          "type": "string"
        },
        "entitlements": {
          "items": {
            "$ref": "Entitlement"
          },
          "description": "The list of entitlements.",
          "type": "array"
        }
      },
      "description": "Response message for `SearchEntitlements` method.",
      "type": "object"
    },
    "ActivationTrigger": {
      "description": "ActivationTrigger represents the different possible activation triggers for the grant.",
      "type": "object",
      "id": "ActivationTrigger",
      "properties": {
        "requestedActivationTime": {
          "format": "google-datetime",
          "description": "A specific time at which the access should be granted.",
          "type": "string"
        }
      }
    },
    "FetchEffectiveSettingsResponseEmailNotificationSettings_CustomNotificationBehavior": {
      "id": "FetchEffectiveSettingsResponseEmailNotificationSettings_CustomNotificationBehavior",
      "properties": {
        "requesterNotifications": {
          "description": "Output only. Requester email notifications.",
          "$ref": "FetchEffectiveSettingsResponseEmailNotificationSettingsCustomNotificationBehavior_RequesterNotifications",
          "readOnly": true
        },
        "adminNotifications": {
          "readOnly": true,
          "description": "Output only. Admin email notifications.",
          "$ref": "FetchEffectiveSettingsResponseEmailNotificationSettingsCustomNotificationBehavior_AdminNotifications"
        },
        "approverNotifications": {
          "readOnly": true,
          "description": "Output only. Approver email notifications.",
          "$ref": "FetchEffectiveSettingsResponseEmailNotificationSettingsCustomNotificationBehavior_ApproverNotifications"
        }
      },
      "description": "`CustomNotificationBehavior` reflects the granular notification delivery settings for specific events and personas, as configured by the admin.",
      "type": "object"
    },
    "ManualApprovals": {
      "description": "A manual approval workflow where users who are designated as approvers need to call the `ApproveGrant`/`DenyGrant` APIs for a grant. The workflow can consist of multiple serial steps where each step defines who can act as approver in that step and how many of those users should approve before the workflow moves to the next step. This can be used to create approval workflows such as: * Require an approval from any user in a group G. * Require an approval from any k number of users from a Group G. * Require an approval from any user in a group G and then from a user U. A single user might be part of the `approvers` ACL for multiple steps in this workflow, but they can only approve once and that approval is only considered to satisfy the approval step at which it was granted.",
      "type": "object",
      "id": "ManualApprovals",
      "properties": {
        "requireApproverJustification": {
          "description": "Optional. Do the approvers need to provide a justification for their actions?",
          "type": "boolean"
        },
        "steps": {
          "items": {
            "$ref": "Step"
          },
          "description": "Optional. List of approval steps in this workflow. These steps are followed in the specified order sequentially. Only 1 step is supported.",
          "type": "array"
        }
      }
    },
    "Timeline": {
      "id": "Timeline",
      "properties": {
        "events": {
          "description": "Output only. The events that have occurred on this grant. This list contains entries in the same order as they occurred. The first entry is always be of type `Requested` and there is always at least one entry in this array.",
          "type": "array",
          "readOnly": true,
          "items": {
            "$ref": "Event"
          }
        }
      },
      "description": "Timeline of a grant describing what happened to it and when.",
      "type": "object"
    },
    "IAMAccessDenied": {
      "description": "PAM's service account is being denied access by Cloud IAM. This can be fixed by granting a role that contains the missing permissions to the service account or exempting it from deny policies if they are blocking the access.",
      "type": "object",
      "id": "IAMAccessDenied",
      "properties": {
        "missingPermissions": {
          "description": "List of permissions that are being denied.",
          "type": "array",
          "items": {
            "type": "string"
          }
        }
      }
    },
    "ActivationFailed": {
      "id": "ActivationFailed",
      "properties": {
        "error": {
          "readOnly": true,
          "description": "Output only. The error that occurred while activating the grant.",
          "$ref": "Status"
        }
      },
      "description": "An event representing that the grant activation failed.",
      "type": "object"
    },
    "ListEntitlementsResponse": {
      "id": "ListEntitlementsResponse",
      "properties": {
        "entitlements": {
          "items": {
            "$ref": "Entitlement"
          },
          "description": "The list of entitlements.",
          "type": "array"
        },
        "unreachable": {
          "items": {
            "type": "string"
          },
          "description": "Locations that could not be reached.",
          "type": "array"
        },
        "nextPageToken": {
          "description": "A token identifying a page of results the server should return.",
          "type": "string"
        }
      },
      "description": "Message for response to listing entitlements.",
      "type": "object"
    },
    "RequestedPrivilegedAccessGcpIamAccess_RoleBinding": {
      "id": "RequestedPrivilegedAccessGcpIamAccess_RoleBinding",
      "properties": {
        "entitlementRoleBindingId": {
          "description": "Required. The role binding id of the role to be granted from the entitlement.",
          "type": "string"
        },
        "accessRestrictions": {
          "description": "Optional. The access restrictions to be applied to the role binding. This further restricts the access of this role binding to specific resources.",
          "$ref": "RequestedPrivilegedAccessGcpIamAccess_AccessRestrictions"
        },
        "entitlementConditionExpression": {
          "description": "Output only. The IAM condition expression associated with the role at the time of grant request.",
          "type": "string",
          "readOnly": true
        },
        "role": {
          "readOnly": true,
          "description": "Output only. The IAM role requested as part of the grant.",
          "type": "string"
        }
      },
      "description": "IAM role bindings that are requested as part of the grant.",
      "type": "object"
    },
    "FetchEffectiveSettingsResponseEmailNotificationSettings_DisableAllNotifications": {
      "id": "FetchEffectiveSettingsResponseEmailNotificationSettings_DisableAllNotifications",
      "properties": {},
      "description": "This option indicates that all email notifications are disabled.",
      "type": "object"
    },
    "NotMandatory": {
      "description": "The justification is not mandatory but can be provided in any of the supported formats.",
      "type": "object",
      "id": "NotMandatory",
      "properties": {}
    },
    "FetchEffectiveSettingsResponseEmailNotificationSettingsCustomNotificationBehavior_AdminNotifications": {
      "id": "FetchEffectiveSettingsResponseEmailNotificationSettingsCustomNotificationBehavior_AdminNotifications",
      "properties": {
        "notifyGrantEnded": {
          "readOnly": true,
          "description": "Output only. Notification delivery for grant ended.",
          "type": "boolean"
        },
        "notifyGrantActivated": {
          "readOnly": true,
          "description": "Output only. Notification delivery for grant activated.",
          "type": "boolean"
        },
        "notifyGrantActivationScheduled": {
          "readOnly": true,
          "description": "Output only. Notification delivery for grant activation scheduled.",
          "type": "boolean"
        },
        "notifyGrantExternallyModified": {
          "readOnly": true,
          "description": "Output only. Notification delivery for grant externally modified.",
          "type": "boolean"
        },
        "notifyGrantActivationFailed": {
          "description": "Output only. Notification delivery for grant activation failed.",
          "type": "boolean",
          "readOnly": true
        }
      },
      "description": "Email notifications specific to Admins.",
      "type": "object"
    },
    "Step": {
      "id": "Step",
      "properties": {
        "id": {
          "description": "Output only. Step ID used to identify the step in the workflow.",
          "type": "string",
          "readOnly": true
        },
        "approvers": {
          "description": "Optional. The potential set of approvers in this step. This list must contain at most one entry.",
          "type": "array",
          "items": {
            "$ref": "AccessControlEntry"
          }
        },
        "approvalsNeeded": {
          "description": "Required. How many users from the above list need to approve. If there aren't enough distinct users in the list, then the workflow indefinitely blocks. Should always be greater than 0. 1 is the only supported value.",
          "type": "integer",
          "format": "int32"
        },
        "approverEmailRecipients": {
          "description": "Optional. Additional email addresses to be notified when a grant is pending approval.",
          "type": "array",
          "items": {
            "type": "string"
          }
        }
      },
      "description": "Step represents a logical step in a manual approval workflow.",
      "type": "object"
    },
    "Settings_ServiceAccountApproverSettings": {
      "description": "This controls whether service accounts are allowed to approve grants or can be designated as approvers within PAM entitlements.",
      "type": "object",
      "id": "Settings_ServiceAccountApproverSettings",
      "properties": {
        "enabled": {
          "description": "Optional. Indicates whether service account is allowed to grant approvals.",
          "type": "boolean"
        }
      }
    },
    "Settings_EmailNotificationSettings": {
      "id": "Settings_EmailNotificationSettings",
      "properties": {
        "customNotificationBehavior": {
          "description": "Granular settings of notifications.",
          "$ref": "SettingsEmailNotificationSettings_CustomNotificationBehavior"
        },
        "disableAllNotifications": {
          "description": "Disable all notifications.",
          "$ref": "SettingsEmailNotificationSettings_DisableAllNotifications"
        }
      },
      "description": "`EmailNotificationSettings` defines the node-wide email notification settings.",
      "type": "object"
    },
    "Event": {
      "id": "Event",
      "properties": {
        "denied": {
          "description": "The grant was denied.",
          "$ref": "Denied"
        },
        "activated": {
          "description": "The grant was successfully activated to give access.",
          "$ref": "Activated"
        },
        "requested": {
          "description": "The grant was requested.",
          "$ref": "Requested"
        },
        "revoked": {
          "description": "The grant was revoked.",
          "$ref": "Revoked"
        },
        "expired": {
          "description": "The approval workflow did not complete in the necessary duration, and so the grant is expired.",
          "$ref": "Expired"
        },
        "ended": {
          "description": "Access given by the grant ended automatically as the approved duration was over.",
          "$ref": "Ended"
        },
        "externallyModified": {
          "description": "The policy bindings made by grant have been modified outside of PAM.",
          "$ref": "ExternallyModified"
        },
        "scheduled": {
          "description": "The grant has been scheduled to give access.",
          "$ref": "Scheduled"
        },
        "activationFailed": {
          "description": "There was a non-retriable error while trying to give access.",
          "$ref": "ActivationFailed"
        },
        "withdrawn": {
          "description": "The grant was withdrawn.",
          "$ref": "Withdrawn"
        },
        "eventTime": {
          "description": "Output only. The time (as recorded at server) when this event occurred.",
          "type": "string",
          "readOnly": true,
          "format": "google-datetime"
        },
        "approved": {
          "description": "The grant was approved.",
          "$ref": "Approved"
        }
      },
      "description": "A single operation on the grant.",
      "type": "object"
    },
    "CheckOnboardingStatusResponse": {
      "id": "CheckOnboardingStatusResponse",
      "properties": {
        "serviceAccount": {
          "description": "The service account that PAM uses to act on this resource.",
          "type": "string"
        },
        "findings": {
          "description": "List of issues that are preventing PAM from functioning for this resource and need to be fixed to complete onboarding. Some issues might not be detected or reported.",
          "type": "array",
          "items": {
            "$ref": "Finding"
          }
        }
      },
      "description": "Response message for `CheckOnboardingStatus` method.",
      "type": "object"
    },
    "AdditionalNotificationTargets": {
      "description": "`AdditionalNotificationTargets` includes email addresses to be notified.",
      "type": "object",
      "id": "AdditionalNotificationTargets",
      "properties": {
        "adminEmailRecipients": {
          "items": {
            "type": "string"
          },
          "description": "Optional. Additional email addresses to be notified when a principal (requester) is granted access.",
          "type": "array"
        },
        "requesterEmailRecipients": {
          "items": {
            "type": "string"
          },
          "description": "Optional. Additional email address to be notified about an eligible entitlement.",
          "type": "array"
        }
      }
    },
    "RevokeGrantRequest": {
      "description": "Request message for `RevokeGrant` method.",
      "type": "object",
      "id": "RevokeGrantRequest",
      "properties": {
        "reason": {
          "description": "Optional. The reason for revoking this grant.",
          "type": "string"
        }
      }
    },
    "RoleBinding": {
      "description": "IAM role bindings that are created after a successful grant.",
      "type": "object",
      "id": "RoleBinding",
      "properties": {
        "id": {
          "description": "Output only. The ID corresponding to this role binding in the policy binding. This will be unique within an entitlement across time. Gets re-generated each time the entitlement is updated.",
          "type": "string",
          "readOnly": true
        },
        "role": {
          "description": "Required. IAM role to be granted. https://cloud.google.com/iam/docs/roles-overview.",
          "type": "string"
        },
        "conditionExpression": {
          "description": "Optional. The expression field of the IAM condition to be associated with the role. If specified, a user with an active grant for this entitlement is able to access the resource only if this condition evaluates to true for their request. This field uses the same CEL format as IAM and supports all attributes that IAM supports, except tags. https://cloud.google.com/iam/docs/conditions-overview#attributes.",
          "type": "string"
        }
      }
    },
    "Unstructured": {
      "description": "The requester has to provide a justification in the form of a string.",
      "type": "object",
      "id": "Unstructured",
      "properties": {}
    },
    "Approved": {
      "description": "An event representing that the grant was approved.",
      "type": "object",
      "id": "Approved",
      "properties": {
        "reason": {
          "readOnly": true,
          "description": "Output only. The reason provided by the approver for approving the grant.",
          "type": "string"
        },
        "actor": {
          "readOnly": true,
          "description": "Output only. Username of the user who approved the grant.",
          "type": "string"
        },
        "stepId": {
          "description": "Output only. The ID of the approval workflow step that was approved.",
          "type": "string",
          "readOnly": true
        }
      }
    },
    "ListLocationsResponse": {
      "id": "ListLocationsResponse",
      "properties": {
        "locations": {
          "items": {
            "$ref": "Location"
          },
          "description": "A list of locations that matches the specified filter in the request.",
          "type": "array"
        },
        "nextPageToken": {
          "description": "The standard List next-page token.",
          "type": "string"
        }
      },
      "description": "The response message for Locations.ListLocations.",
      "type": "object"
    },
    "Settings": {
      "description": "`Settings` resource defines the properties, applied directly to the resource or inherited through the hierarchy, to enable consistent, federated use of PAM. The behavior is as follows: 1. If explicitly set to empty at the node level, PAM's default settings are applied for that node. 2. If not set at the node level, settings are inherited from the closest ancestor with a non-empty value. If none of the ancestors has the field set, PAM's default settings are applied. 3. If explicitly set to a non-empty value at the node level, the specified settings are applied for that node.",
      "type": "object",
      "id": "Settings",
      "properties": {
        "updateTime": {
          "format": "google-datetime",
          "readOnly": true,
          "description": "Output only. Update timestamp.",
          "type": "string"
        },
        "etag": {
          "description": "Fingerprint for optimistic concurrency returned in the response of `GetSettings`. Must be provided in the requests to `UpdateSettings`. If the value provided does not match the value known to the server, ABORTED will be thrown, and the client should retry the read-modify-write cycle.",
          "type": "string"
        },
        "createTime": {
          "description": "Output only. Create timestamp.",
          "type": "string",
          "readOnly": true,
          "format": "google-datetime"
        },
        "name": {
          "description": "Identifier. Name of the settings resource. Possible formats: projects/{project-id|project-number}/locations/{location}/settings folders/{folder-number}/locations/{location}/settings organizations/{organization-number}/locations/{location}/settings",
          "type": "string"
        },
        "serviceAccountApproverSettings": {
          "description": "Optional. This controls the node-level settings for allowing service accounts as approvers.",
          "$ref": "Settings_ServiceAccountApproverSettings"
        },
        "emailNotificationSettings": {
          "description": "Optional. `EmailNotificationSettings` defines node-wide email notification preferences for various PAM events.",
          "$ref": "Settings_EmailNotificationSettings"
        }
      }
    },
    "Finding": {
      "description": "Finding represents an issue which prevents PAM from functioning properly for this resource.",
      "type": "object",
      "id": "Finding",
      "properties": {
        "iamAccessDenied": {
          "description": "PAM's service account is being denied access by Cloud IAM.",
          "$ref": "IAMAccessDenied"
        }
      }
    },
    "SettingsEmailNotificationSettingsCustomNotificationBehavior_RequesterNotifications": {
      "id": "SettingsEmailNotificationSettingsCustomNotificationBehavior_RequesterNotifications",
      "properties": {
        "grantExternallyModified": {
          "enum": [
            "NOTIFICATION_MODE_UNSPECIFIED",
            "ENABLED",
            "DISABLED"
          ],
          "description": "Optional. Notification mode for grant externally modified.",
          "type": "string",
          "enumDescriptions": [
            "Default notification behavior following PAM's standard settings.",
            "Notifications are enabled.",
            "Notifications are disabled."
          ]
        },
        "grantActivationFailed": {
          "enum": [
            "NOTIFICATION_MODE_UNSPECIFIED",
            "ENABLED",
            "DISABLED"
          ],
          "description": "Optional. Notification mode for grant activation failed.",
          "type": "string",
          "enumDescriptions": [
            "Default notification behavior following PAM's standard settings.",
            "Notifications are enabled.",
            "Notifications are disabled."
          ]
        },
        "grantActivated": {
          "enum": [
            "NOTIFICATION_MODE_UNSPECIFIED",
            "ENABLED",
            "DISABLED"
          ],
          "description": "Optional. Notification mode for grant activated.",
          "type": "string",
          "enumDescriptions": [
            "Default notification behavior following PAM's standard settings.",
            "Notifications are enabled.",
            "Notifications are disabled."
          ]
        },
        "grantEnded": {
          "description": "Optional. Notification mode for grant ended.",
          "type": "string",
          "enumDescriptions": [
            "Default notification behavior following PAM's standard settings.",
            "Notifications are enabled.",
            "Notifications are disabled."
          ],
          "enum": [
            "NOTIFICATION_MODE_UNSPECIFIED",
            "ENABLED",
            "DISABLED"
          ]
        },
        "grantExpired": {
          "enum": [
            "NOTIFICATION_MODE_UNSPECIFIED",
            "ENABLED",
            "DISABLED"
          ],
          "description": "Optional. Notification mode for grant request expired.",
          "type": "string",
          "enumDescriptions": [
            "Default notification behavior following PAM's standard settings.",
            "Notifications are enabled.",
            "Notifications are disabled."
          ]
        },
        "grantDenied": {
          "enum": [
            "NOTIFICATION_MODE_UNSPECIFIED",
            "ENABLED",
            "DISABLED"
          ],
          "description": "Optional. Notification mode for grant denied.",
          "type": "string",
          "enumDescriptions": [
            "Default notification behavior following PAM's standard settings.",
            "Notifications are enabled.",
            "Notifications are disabled."
          ]
        },
        "entitlementAssigned": {
          "enum": [
            "NOTIFICATION_MODE_UNSPECIFIED",
            "ENABLED",
            "DISABLED"
          ],
          "description": "Optional. Notification mode for entitlement assigned.",
          "type": "string",
          "enumDescriptions": [
            "Default notification behavior following PAM's standard settings.",
            "Notifications are enabled.",
            "Notifications are disabled."
          ]
        },
        "grantActivationScheduled": {
          "description": "Optional. Notification mode for grant activation scheduled.",
          "type": "string",
          "enumDescriptions": [
            "Default notification behavior following PAM's standard settings.",
            "Notifications are enabled.",
            "Notifications are disabled."
          ],
          "enum": [
            "NOTIFICATION_MODE_UNSPECIFIED",
            "ENABLED",
            "DISABLED"
          ]
        },
        "grantRevoked": {
          "description": "Optional. Notification mode for grant revoked.",
          "type": "string",
          "enumDescriptions": [
            "Default notification behavior following PAM's standard settings.",
            "Notifications are enabled.",
            "Notifications are disabled."
          ],
          "enum": [
            "NOTIFICATION_MODE_UNSPECIFIED",
            "ENABLED",
            "DISABLED"
          ]
        }
      },
      "description": "Email notifications specific to Requesters.",
      "type": "object"
    },
    "Justification": {
      "id": "Justification",
      "properties": {
        "unstructuredJustification": {
          "description": "A free form textual justification. The system only ensures that this is not empty. No other kind of validation is performed on the string.",
          "type": "string"
        }
      },
      "description": "Justification represents a justification for requesting access.",
      "type": "object"
    },
    "RequestedPrivilegedAccess": {
      "description": "Privileged access that is requested by a user via a grant.",
      "type": "object",
      "id": "RequestedPrivilegedAccess",
      "properties": {
        "gcpIamAccess": {
          "description": "Access to a Google Cloud resource through IAM.",
          "$ref": "RequestedPrivilegedAccess_GcpIamAccess"
        }
      }
    },
    "SearchGrantsResponse": {
      "description": "Response message for `SearchGrants` method.",
      "type": "object",
      "id": "SearchGrantsResponse",
      "properties": {
        "grants": {
          "description": "The list of grants.",
          "type": "array",
          "items": {
            "$ref": "Grant"
          }
        },
        "nextPageToken": {
          "description": "A token identifying a page of results the server should return.",
          "type": "string"
        }
      }
    },
    "WithdrawGrantRequest": {
      "id": "WithdrawGrantRequest",
      "properties": {},
      "description": "Request message for `WithdrawGrant` method.",
      "type": "object"
    },
    "Location": {
      "id": "Location",
      "properties": {
        "displayName": {
          "description": "The friendly name for this location, typically a nearby city name. For example, \"Tokyo\".",
          "type": "string"
        },
        "name": {
          "description": "Resource name for the location, which may vary between implementations. For example: `\"projects/example-project/locations/us-east1\"`",
          "type": "string"
        },
        "metadata": {
          "description": "Service-specific metadata. For example the available capacity at the given location.",
          "type": "object",
          "additionalProperties": {
            "type": "any",
            "description": "Properties of the object. Contains field @type with type URL."
          }
        },
        "locationId": {
          "description": "The canonical id for this location. For example: `\"us-east1\"`.",
          "type": "string"
        },
        "labels": {
          "description": "Cross-service attributes for the location. For example {\"cloud.googleapis.com/region\": \"us-east1\"}",
          "type": "object",
          "additionalProperties": {
            "type": "string"
          }
        }
      },
      "description": "A resource that represents a Google Cloud location.",
      "type": "object"
    },
    "PrivilegedAccess": {
      "description": "Privileged access that this service can be used to gate.",
      "type": "object",
      "id": "PrivilegedAccess",
      "properties": {
        "gcpIamAccess": {
          "description": "Access to a Google Cloud resource through IAM.",
          "$ref": "GcpIamAccess"
        }
      }
    },
    "Operation": {
      "id": "Operation",
      "properties": {
        "name": {
          "description": "The server-assigned name, which is only unique within the same service that originally returns it. If you use the default HTTP mapping, the `name` should be a resource name ending with `operations/{unique_id}`.",
          "type": "string"
        },
        "metadata": {
          "description": "Service-specific metadata associated with the operation. It typically contains progress information and common metadata such as create time. Some services might not provide such metadata. Any method that returns a long-running operation should document the metadata type, if any.",
          "type": "object",
          "additionalProperties": {
            "type": "any",
            "description": "Properties of the object. Contains field @type with type URL."
          }
        },
        "response": {
          "description": "The normal, successful response of the operation. If the original method returns no data on success, such as `Delete`, the response is `google.protobuf.Empty`. If the original method is standard `Get`/`Create`/`Update`, the response should be the resource. For other methods, the response should have the type `XxxResponse`, where `Xxx` is the original method name. For example, if the original method name is `TakeSnapshot()`, the inferred response type is `TakeSnapshotResponse`.",
          "type": "object",
          "additionalProperties": {
            "type": "any",
            "description": "Properties of the object. Contains field @type with type URL."
          }
        },
        "done": {
          "description": "If the value is `false`, it means the operation is still in progress. If `true`, the operation is completed, and either `error` or `response` is available.",
          "type": "boolean"
        },
        "error": {
          "description": "The error result of the operation in case of failure or cancellation.",
          "$ref": "Status"
        }
      },
      "description": "This resource represents a long-running operation that is the result of a network API call.",
      "type": "object"
    }
  },
  "version_module": true,
  "ownerDomain": "google.com",
  "parameters": {
    "key": {
      "location": "query",
      "type": "string",
      "description": "API key. Your API key identifies your project and provides you with API access, quota, and reports. Required unless you provide an OAuth 2.0 token."
    },
    "callback": {
      "location": "query",
      "type": "string",
      "description": "JSONP"
    },
    "prettyPrint": {
      "location": "query",
      "type": "boolean",
      "description": "Returns response with indentations and line breaks.",
      "default": "true"
    },
    "alt": {
      "description": "Data format for response.",
      "default": "json",
      "enum": [
        "json",
        "media",
        "proto"
      ],
      "type": "string",
      "enumDescriptions": [
        "Responses with Content-Type of application/json",
        "Media download with context-dependent Content-Type",
        "Responses with Content-Type of application/x-protobuf"
      ],
      "location": "query"
    },
    "fields": {
      "location": "query",
      "type": "string",
      "description": "Selector specifying which fields to include in a partial response."
    },
    "upload_protocol": {
      "type": "string",
      "description": "Upload protocol for media (e.g. \"raw\", \"multipart\").",
      "location": "query"
    },
    "$.xgafv": {
      "enum": [
        "1",
        "2"
      ],
      "description": "V1 error format.",
      "location": "query",
      "type": "string",
      "enumDescriptions": [
        "v1 error format",
        "v2 error format"
      ]
    },
    "access_token": {
      "type": "string",
      "description": "OAuth access token.",
      "location": "query"
    },
    "uploadType": {
      "location": "query",
      "type": "string",
      "description": "Legacy upload protocol for media (e.g. \"media\", \"multipart\")."
    },
    "oauth_token": {
      "location": "query",
      "type": "string",
      "description": "OAuth 2.0 token for the current user."
    },
    "quotaUser": {
      "type": "string",
      "description": "Available to use for quota purposes for server-side applications. Can be any arbitrary string assigned to a user, but should not exceed 40 characters.",
      "location": "query"
    }
  },
  "icons": {
    "x16": "http://www.google.com/images/icons/product/search-16.gif",
    "x32": "http://www.google.com/images/icons/product/search-32.gif"
  },
  "ownerName": "Google",
  "servicePath": "",
  "id": "privilegedaccessmanager:v1beta",
  "mtlsRootUrl": "https://privilegedaccessmanager.mtls.googleapis.com/",
  "kind": "discovery#restDescription",
  "rootUrl": "https://privilegedaccessmanager.googleapis.com/",
  "batchPath": "batch",
  "description": "Privileged Access Manager (PAM) helps you to follow least privilege best practice to mitigate risks tied to privileged access misuse and abuse. You can shift from always-on standing privileges to on-demand access using time-bound and approval-based access elevations. IAM administrators specifically can use PAM to create entitlements that can grant temporary access to a specific resource scope. Requesters can explore eligible entitlements and request the access needed for their task, and approvers are notified when approvals require their attention. Streamlined workflows facilitated using PAM support several use cases, including the following: * Emergency access for incident responders * Time-boxed access for developers for critical deployment or maintenance * Temporary access for operators for data ingestion and audits * Temporary access to service accounts for automated tasks ",
  "discoveryVersion": "v1",
  "name": "privilegedaccessmanager",
  "basePath": "",
  "resources": {
    "organizations": {
      "resources": {
        "locations": {
          "methods": {
            "checkOnboardingStatus": {
              "flatPath": "v1beta/organizations/{organizationsId}/locations/{locationsId}:checkOnboardingStatus",
              "response": {
                "$ref": "CheckOnboardingStatusResponse"
              },
              "path": "v1beta/{+parent}:checkOnboardingStatus",
              "description": "`CheckOnboardingStatus` reports the onboarding status for a project, folder, or organization. Any findings reported by this API need to be fixed before PAM can be used on the resource.",
              "parameters": {
                "parent": {
                  "description": "Required. The resource for which the onboarding status should be checked. Should be in one of the following formats: * `projects/{project-number|project-id}/locations/{region}` * `folders/{folder-number}/locations/{region}` * `organizations/{organization-number}/locations/{region}`",
                  "pattern": "^organizations/[^/]+/locations/[^/]+$",
                  "type": "string",
                  "required": true,
                  "location": "path"
                }
              },
              "id": "privilegedaccessmanager.organizations.locations.checkOnboardingStatus",
              "parameterOrder": [
                "parent"
              ],
              "httpMethod": "GET",
              "scopes": [
                "https://www.googleapis.com/auth/cloud-platform"
              ]
            },
            "getSettings": {
              "flatPath": "v1beta/organizations/{organizationsId}/locations/{locationsId}/settings",
              "response": {
                "$ref": "Settings"
              },
              "path": "v1beta/{+name}",
              "description": "`GetSettings` returns the PAM Settings for the given project, folder, or organization.",
              "parameters": {
                "name": {
                  "description": "Required. The name of the settings resource to be fetched.",
                  "pattern": "^organizations/[^/]+/locations/[^/]+/settings$",
                  "type": "string",
                  "required": true,
                  "location": "path"
                }
              },
              "id": "privilegedaccessmanager.organizations.locations.getSettings",
              "parameterOrder": [
                "name"
              ],
              "httpMethod": "GET",
              "scopes": [
                "https://www.googleapis.com/auth/cloud-platform"
              ]
            },
            "updateSettings": {
              "flatPath": "v1beta/organizations/{organizationsId}/locations/{locationsId}/settings",
              "response": {
                "$ref": "Operation"
              },
              "path": "v1beta/{+name}",
              "request": {
                "$ref": "Settings"
              },
              "description": "`UpdateSettings` updates the PAM Settings resource specified in the request. Updated fields in the settings need to be specified in an update mask. The following fields are not supported for updates: * Settings name * Create time * Update time * Etag",
              "httpMethod": "PATCH",
              "scopes": [
                "https://www.googleapis.com/auth/cloud-platform"
              ],
              "id": "privilegedaccessmanager.organizations.locations.updateSettings",
              "parameterOrder": [
                "name"
              ],
              "parameters": {
                "name": {
                  "pattern": "^organizations/[^/]+/locations/[^/]+/settings$",
                  "description": "Identifier. Name of the settings resource. Possible formats: projects/{project-id|project-number}/locations/{location}/settings folders/{folder-number}/locations/{location}/settings organizations/{organization-number}/locations/{location}/settings",
                  "required": true,
                  "type": "string",
                  "location": "path"
                },
                "updateMask": {
                  "format": "google-fieldmask",
                  "location": "query",
                  "description": "Required. The list of fields to update. A field is overwritten if, and only if, it is in the mask. Any immutable fields set in the mask are ignored by the server. Repeated fields and map fields are only allowed in the last position of a `paths` string and overwrite the existing values. Hence an update to a repeated field or a map should contain the entire list of values. The fields specified in the update_mask are relative to the resource and not to the request. A value of '*' for this field refers to full replacement of the resource.",
                  "type": "string"
                }
              }
            },
            "fetchEffectiveSettings": {
              "parameters": {
                "parent": {
                  "pattern": "^organizations/[^/]+/locations/[^/]+$",
                  "description": "Required. The resource for which the effective settings is fetched, in one of the following formats: * `projects/{project-number|project-id}/locations/{region}` * `folders/{folder-number}/locations/{region}` * `organizations/{organization-number}/locations/{region}`",
                  "location": "path",
                  "required": true,
                  "type": "string"
                }
              },
              "scopes": [
                "https://www.googleapis.com/auth/cloud-platform"
              ],
              "httpMethod": "GET",
              "id": "privilegedaccessmanager.organizations.locations.fetchEffectiveSettings",
              "parameterOrder": [
                "parent"
              ],
              "path": "v1beta/{+parent}:fetchEffectiveSettings",
              "description": "`FetchEffectiveSettings` returns the effective PAM Settings for the given project, folder, or organization.",
              "flatPath": "v1beta/organizations/{organizationsId}/locations/{locationsId}:fetchEffectiveSettings",
              "response": {
                "$ref": "FetchEffectiveSettingsResponse"
              }
            },
            "list": {
              "path": "v1beta/{+name}/locations",
              "description": "Lists information about the supported locations for this service. This method lists locations based on the resource scope provided in the ListLocationsRequest.name field: * **Global locations**: If `name` is empty, the method lists the public locations available to all projects. * **Project-specific locations**: If `name` follows the format `projects/{project}`, the method lists locations visible to that specific project. This includes public, private, or other project-specific locations enabled for the project. For gRPC and client library implementations, the resource name is passed as the `name` field. For direct service calls, the resource name is incorporated into the request path based on the specific service implementation and version.",
              "flatPath": "v1beta/organizations/{organizationsId}/locations",
              "response": {
                "$ref": "ListLocationsResponse"
              },
              "scopes": [
                "https://www.googleapis.com/auth/cloud-platform"
              ],
              "httpMethod": "GET",
              "id": "privilegedaccessmanager.organizations.locations.list",
              "parameterOrder": [
                "name"
              ],
              "parameters": {
                "extraLocationTypes": {
                  "description": "Optional. Do not use this field unless explicitly documented otherwise. This is primarily for internal usage.",
                  "type": "string",
                  "repeated": true,
                  "location": "query"
                },
                "name": {
                  "pattern": "^organizations/[^/]+$",
                  "description": "The resource that owns the locations collection, if applicable.",
                  "required": true,
                  "type": "string",
                  "location": "path"
                },
                "pageToken": {
                  "location": "query",
                  "description": "A page token received from the `next_page_token` field in the response. Send that page token to receive the subsequent page.",
                  "type": "string"
                },
                "filter": {
                  "location": "query",
                  "description": "A filter to narrow down results to a preferred subset. The filtering language accepts strings like `\"displayName=tokyo\"`, and is documented in more detail in [AIP-160](https://google.aip.dev/160).",
                  "type": "string"
                },
                "pageSize": {
                  "location": "query",
                  "format": "int32",
                  "description": "The maximum number of results to return. If not set, the service selects a default.",
                  "type": "integer"
                }
              }
            },
            "get": {
              "flatPath": "v1beta/organizations/{organizationsId}/locations/{locationsId}",
              "response": {
                "$ref": "Location"
              },
              "path": "v1beta/{+name}",
              "description": "Gets information about a location.",
              "id": "privilegedaccessmanager.organizations.locations.get",
              "parameterOrder": [
                "name"
              ],
              "httpMethod": "GET",
              "scopes": [
                "https://www.googleapis.com/auth/cloud-platform"
              ],
              "parameters": {
                "name": {
                  "location": "path",
                  "type": "string",
                  "required": true,
                  "description": "Resource name for the location.",
                  "pattern": "^organizations/[^/]+/locations/[^/]+$"
                }
              }
            }
          },
          "resources": {
            "operations": {
              "methods": {
                "delete": {
                  "flatPath": "v1beta/organizations/{organizationsId}/locations/{locationsId}/operations/{operationsId}",
                  "response": {
                    "$ref": "GoogleProtobufEmpty"
                  },
                  "path": "v1beta/{+name}",
                  "description": "Deletes a long-running operation. This method indicates that the client is no longer interested in the operation result. It does not cancel the operation. If the server doesn't support this method, it returns `google.rpc.Code.UNIMPLEMENTED`.",
                  "httpMethod": "DELETE",
                  "scopes": [
                    "https://www.googleapis.com/auth/cloud-platform"
                  ],
                  "id": "privilegedaccessmanager.organizations.locations.operations.delete",
                  "parameterOrder": [
                    "name"
                  ],
                  "parameters": {
                    "name": {
                      "description": "The name of the operation resource to be deleted.",
                      "pattern": "^organizations/[^/]+/locations/[^/]+/operations/[^/]+$",
                      "location": "path",
                      "type": "string",
                      "required": true
                    }
                  }
                },
                "list": {
                  "httpMethod": "GET",
                  "scopes": [
                    "https://www.googleapis.com/auth/cloud-platform"
                  ],
                  "id": "privilegedaccessmanager.organizations.locations.operations.list",
                  "parameterOrder": [
                    "name"
                  ],
                  "parameters": {
                    "filter": {
                      "description": "The standard list filter.",
                      "type": "string",
                      "location": "query"
                    },
                    "pageSize": {
                      "description": "The standard list page size.",
                      "type": "integer",
                      "format": "int32",
                      "location": "query"
                    },
                    "returnPartialSuccess": {
                      "description": "When set to `true`, operations that are reachable are returned as normal, and those that are unreachable are returned in the ListOperationsResponse.unreachable field. This can only be `true` when reading across collections. For example, when `parent` is set to `\"projects/example/locations/-\"`. This field is not supported by default and will result in an `UNIMPLEMENTED` error if set unless explicitly documented otherwise in service or product specific documentation.",
                      "type": "boolean",
                      "location": "query"
                    },
                    "name": {
                      "type": "string",
                      "required": true,
                      "location": "path",
                      "description": "The name of the operation's parent resource.",
                      "pattern": "^organizations/[^/]+/locations/[^/]+$"
                    },
                    "pageToken": {
                      "description": "The standard list page token.",
                      "type": "string",
                      "location": "query"
                    }
                  },
                  "flatPath": "v1beta/organizations/{organizationsId}/locations/{locationsId}/operations",
                  "response": {
                    "$ref": "ListOperationsResponse"
                  },
                  "path": "v1beta/{+name}/operations",
                  "description": "Lists operations that match the specified filter in the request. If the server doesn't support this method, it returns `UNIMPLEMENTED`."
                },
                "get": {
                  "id": "privilegedaccessmanager.organizations.locations.operations.get",
                  "parameterOrder": [
                    "name"
                  ],
                  "scopes": [
                    "https://www.googleapis.com/auth/cloud-platform"
                  ],
                  "httpMethod": "GET",
                  "parameters": {
                    "name": {
                      "required": true,
                      "type": "string",
                      "location": "path",
                      "pattern": "^organizations/[^/]+/locations/[^/]+/operations/[^/]+$",
                      "description": "The name of the operation resource."
                    }
                  },
                  "path": "v1beta/{+name}",
                  "description": "Gets the latest state of a long-running operation. Clients can use this method to poll the operation result at intervals as recommended by the API service.",
                  "flatPath": "v1beta/organizations/{organizationsId}/locations/{locationsId}/operations/{operationsId}",
                  "response": {
                    "$ref": "Operation"
                  }
                }
              }
            },
            "entitlements": {
              "methods": {
                "search": {
                  "path": "v1beta/{+parent}/entitlements:search",
                  "description": "`SearchEntitlements` returns entitlements on which the caller has the specified access.",
                  "flatPath": "v1beta/organizations/{organizationsId}/locations/{locationsId}/entitlements:search",
                  "response": {
                    "$ref": "SearchEntitlementsResponse"
                  },
                  "parameters": {
                    "callerAccessType": {
                      "location": "query",
                      "type": "string",
                      "enumDescriptions": [
                        "Unspecified access type.",
                        "The user has access to create grants using this entitlement.",
                        "The user has access to approve/deny grants created under this entitlement."
                      ],
                      "enum": [
                        "CALLER_ACCESS_TYPE_UNSPECIFIED",
                        "GRANT_REQUESTER",
                        "GRANT_APPROVER"
                      ],
                      "description": "Required. Only entitlements where the calling user has this access are returned."
                    },
                    "filter": {
                      "description": "Optional. Only entitlements matching this filter are returned in the response.",
                      "type": "string",
                      "location": "query"
                    },
                    "pageSize": {
                      "description": "Optional. Requested page size. The server may return fewer items than requested. If unspecified, the server picks an appropriate default.",
                      "type": "integer",
                      "location": "query",
                      "format": "int32"
                    },
                    "parent": {
                      "type": "string",
                      "required": true,
                      "location": "path",
                      "description": "Required. The parent which owns the entitlement resources.",
                      "pattern": "^organizations/[^/]+/locations/[^/]+$"
                    },
                    "pageToken": {
                      "location": "query",
                      "description": "Optional. A token identifying a page of results the server should return.",
                      "type": "string"
                    }
                  },
                  "id": "privilegedaccessmanager.organizations.locations.entitlements.search",
                  "parameterOrder": [
                    "parent"
                  ],
                  "scopes": [
                    "https://www.googleapis.com/auth/cloud-platform"
                  ],
                  "httpMethod": "GET"
                },
                "delete": {
                  "parameters": {
                    "name": {
                      "pattern": "^organizations/[^/]+/locations/[^/]+/entitlements/[^/]+$",
                      "description": "Required. Name of the resource.",
                      "location": "path",
                      "required": true,
                      "type": "string"
                    },
                    "force": {
                      "location": "query",
                      "description": "Optional. If set to true, any child grant under this entitlement is also deleted. (Otherwise, the request only works if the entitlement has no child grant.)",
                      "type": "boolean"
                    },
                    "requestId": {
                      "location": "query",
                      "description": "Optional. An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server knows to ignore the request if it has already been completed. The server guarantees this for at least 60 minutes after the first request. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, ignores the second request. The request ID must be a valid UUID with the exception that zero UUID is not supported (00000000-0000-0000-0000-000000000000).",
                      "type": "string"
                    }
                  },
                  "scopes": [
                    "https://www.googleapis.com/auth/cloud-platform"
                  ],
                  "httpMethod": "DELETE",
                  "id": "privilegedaccessmanager.organizations.locations.entitlements.delete",
                  "parameterOrder": [
                    "name"
                  ],
                  "path": "v1beta/{+name}",
                  "description": "Deletes a single entitlement. This method can only be called when there are no in-progress (`ACTIVE`/`ACTIVATING`/`REVOKING`) grants under the entitlement.",
                  "flatPath": "v1beta/organizations/{organizationsId}/locations/{locationsId}/entitlements/{entitlementsId}",
                  "response": {
                    "$ref": "Operation"
                  }
                },
                "list": {
                  "path": "v1beta/{+parent}/entitlements",
                  "description": "Lists the entitlements in a given project, folder, organization, and in a given location.",
                  "flatPath": "v1beta/organizations/{organizationsId}/locations/{locationsId}/entitlements",
                  "response": {
                    "$ref": "ListEntitlementsResponse"
                  },
                  "scopes": [
                    "https://www.googleapis.com/auth/cloud-platform"
                  ],
                  "httpMethod": "GET",
                  "id": "privilegedaccessmanager.organizations.locations.entitlements.list",
                  "parameterOrder": [
                    "parent"
                  ],
                  "parameters": {
                    "parent": {
                      "type": "string",
                      "required": true,
                      "location": "path",
                      "description": "Required. The parent which owns the entitlement resources.",
                      "pattern": "^organizations/[^/]+/locations/[^/]+$"
                    },
                    "pageToken": {
                      "location": "query",
                      "description": "Optional. A token identifying a page of results the server should return.",
                      "type": "string"
                    },
                    "orderBy": {
                      "description": "Optional. Hint for how to order the results.",
                      "type": "string",
                      "location": "query"
                    },
                    "pageSize": {
                      "description": "Optional. Requested page size. Server may return fewer items than requested. If unspecified, the server picks an appropriate default.",
                      "type": "integer",
                      "location": "query",
                      "format": "int32"
                    },
                    "filter": {
                      "description": "Optional. Filtering results.",
                      "type": "string",
                      "location": "query"
                    }
                  }
                },
                "get": {
                  "parameters": {
                    "name": {
                      "location": "path",
                      "required": true,
                      "type": "string",
                      "pattern": "^organizations/[^/]+/locations/[^/]+/entitlements/[^/]+$",
                      "description": "Required. Name of the resource."
                    }
                  },
                  "id": "privilegedaccessmanager.organizations.locations.entitlements.get",
                  "parameterOrder": [
                    "name"
                  ],
                  "httpMethod": "GET",
                  "scopes": [
                    "https://www.googleapis.com/auth/cloud-platform"
                  ],
                  "flatPath": "v1beta/organizations/{organizationsId}/locations/{locationsId}/entitlements/{entitlementsId}",
                  "response": {
                    "$ref": "Entitlement"
                  },
                  "path": "v1beta/{+name}",
                  "description": "Gets details of a single entitlement."
                },
                "create": {
                  "parameters": {
                    "parent": {
                      "location": "path",
                      "required": true,
                      "type": "string",
                      "pattern": "^organizations/[^/]+/locations/[^/]+$",
                      "description": "Required. Name of the parent resource for the entitlement. Possible formats: * `organizations/{organization-number}/locations/{region}` * `folders/{folder-number}/locations/{region}` * `projects/{project-id|project-number}/locations/{region}`"
                    },
                    "entitlementId": {
                      "location": "query",
                      "description": "Required. The ID to use for this entitlement. This becomes the last part of the resource name. This value should be 4-63 characters in length, and valid characters are \"[a-z]\", \"[0-9]\", and \"-\". The first character should be from [a-z]. This value should be unique among all other entitlements under the specified `parent`.",
                      "type": "string"
                    },
                    "requestId": {
                      "location": "query",
                      "description": "Optional. An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server knows to ignore the request if it has already been completed. The server guarantees this for at least 60 minutes after the first request. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, ignores the second request and returns the previous operation's response. This prevents clients from accidentally creating duplicate entitlements. The request ID must be a valid UUID with the exception that zero UUID is not supported (00000000-0000-0000-0000-000000000000).",
                      "type": "string"
                    }
                  },
                  "scopes": [
                    "https://www.googleapis.com/auth/cloud-platform"
                  ],
                  "httpMethod": "POST",
                  "id": "privilegedaccessmanager.organizations.locations.entitlements.create",
                  "parameterOrder": [
                    "parent"
                  ],
                  "path": "v1beta/{+parent}/entitlements",
                  "request": {
                    "$ref": "Entitlement"
                  },
                  "description": "Creates a new entitlement in a given project, folder, organization, and in a given location.",
                  "flatPath": "v1beta/organizations/{organizationsId}/locations/{locationsId}/entitlements",
                  "response": {
                    "$ref": "Operation"
                  }
                },
                "patch": {
                  "parameters": {
                    "name": {
                      "location": "path",
                      "type": "string",
                      "required": true,
                      "description": "Identifier. Name of the entitlement. Possible formats: * `organizations/{organization-number}/locations/{region}/entitlements/{entitlement-id}` * `folders/{folder-number}/locations/{region}/entitlements/{entitlement-id}` * `projects/{project-id|project-number}/locations/{region}/entitlements/{entitlement-id}`",
                      "pattern": "^organizations/[^/]+/locations/[^/]+/entitlements/[^/]+$"
                    },
                    "updateMask": {
                      "description": "Required. The list of fields to update. A field is overwritten if, and only if, it is in the mask. Any immutable fields set in the mask are ignored by the server. Repeated fields and map fields are only allowed in the last position of a `paths` string and overwrite the existing values. Hence an update to a repeated field or a map should contain the entire list of values. The fields specified in the update_mask are relative to the resource and not to the request. (e.g. `MaxRequestDuration`; *not* `entitlement.MaxRequestDuration`) A value of '*' for this field refers to full replacement of the resource.",
                      "type": "string",
                      "location": "query",
                      "format": "google-fieldmask"
                    }
                  },
                  "scopes": [
                    "https://www.googleapis.com/auth/cloud-platform"
                  ],
                  "httpMethod": "PATCH",
                  "id": "privilegedaccessmanager.organizations.locations.entitlements.patch",
                  "parameterOrder": [
                    "name"
                  ],
                  "path": "v1beta/{+name}",
                  "request": {
                    "$ref": "Entitlement"
                  },
                  "description": "Updates the entitlement specified in the request. Updated fields in the entitlement need to be specified in an update mask. The changes made to an entitlement are applicable only on future grants of the entitlement. However, if new approvers are added or existing approvers are removed from the approval workflow, the changes are effective on existing grants. The following fields are not supported for updates: * All immutable fields * Entitlement name * Resource name * Resource type * Adding an approval workflow in an entitlement which previously had no approval workflow. * Deleting the approval workflow from an entitlement. * Adding or deleting a step in the approval workflow (only one step is supported) Note that updates are allowed on the list of approvers in an approval workflow step.",
                  "flatPath": "v1beta/organizations/{organizationsId}/locations/{locationsId}/entitlements/{entitlementsId}",
                  "response": {
                    "$ref": "Operation"
                  }
                }
              },
              "resources": {
                "grants": {
                  "methods": {
                    "create": {
                      "id": "privilegedaccessmanager.organizations.locations.entitlements.grants.create",
                      "parameterOrder": [
                        "parent"
                      ],
                      "scopes": [
                        "https://www.googleapis.com/auth/cloud-platform"
                      ],
                      "httpMethod": "POST",
                      "parameters": {
                        "parent": {
                          "pattern": "^organizations/[^/]+/locations/[^/]+/entitlements/[^/]+$",
                          "description": "Required. Name of the parent entitlement for which this grant is being requested.",
                          "location": "path",
                          "required": true,
                          "type": "string"
                        },
                        "requestId": {
                          "description": "Optional. An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server knows to ignore the request if it has already been completed. The server guarantees this for at least 60 minutes after the first request. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, ignores the second request. This prevents clients from accidentally creating duplicate grants. The request ID must be a valid UUID with the exception that zero UUID is not supported (00000000-0000-0000-0000-000000000000).",
                          "type": "string",
                          "location": "query"
                        }
                      },
                      "path": "v1beta/{+parent}/grants",
                      "request": {
                        "$ref": "Grant"
                      },
                      "description": "Creates a grant in a given project, folder, or organization and location.",
                      "flatPath": "v1beta/organizations/{organizationsId}/locations/{locationsId}/entitlements/{entitlementsId}/grants",
                      "response": {
                        "$ref": "Grant"
                      }
                    },
                    "approve": {
                      "httpMethod": "POST",
                      "scopes": [
                        "https://www.googleapis.com/auth/cloud-platform"
                      ],
                      "id": "privilegedaccessmanager.organizations.locations.entitlements.grants.approve",
                      "parameterOrder": [
                        "name"
                      ],
                      "parameters": {
                        "name": {
                          "type": "string",
                          "required": true,
                          "location": "path",
                          "description": "Required. Name of the grant resource which is being approved.",
                          "pattern": "^organizations/[^/]+/locations/[^/]+/entitlements/[^/]+/grants/[^/]+$"
                        }
                      },
                      "flatPath": "v1beta/organizations/{organizationsId}/locations/{locationsId}/entitlements/{entitlementsId}/grants/{grantsId}:approve",
                      "response": {
                        "$ref": "Grant"
                      },
                      "path": "v1beta/{+name}:approve",
                      "request": {
                        "$ref": "ApproveGrantRequest"
                      },
                      "description": "`ApproveGrant` is used to approve a grant. This method can only be called on a grant when it's in the `APPROVAL_AWAITED` state. This operation can't be undone."
                    },
                    "deny": {
                      "id": "privilegedaccessmanager.organizations.locations.entitlements.grants.deny",
                      "parameterOrder": [
                        "name"
                      ],
                      "httpMethod": "POST",
                      "scopes": [
                        "https://www.googleapis.com/auth/cloud-platform"
                      ],
                      "parameters": {
                        "name": {
                          "pattern": "^organizations/[^/]+/locations/[^/]+/entitlements/[^/]+/grants/[^/]+$",
                          "description": "Required. Name of the grant resource which is being denied.",
                          "required": true,
                          "type": "string",
                          "location": "path"
                        }
                      },
                      "flatPath": "v1beta/organizations/{organizationsId}/locations/{locationsId}/entitlements/{entitlementsId}/grants/{grantsId}:deny",
                      "response": {
                        "$ref": "Grant"
                      },
                      "path": "v1beta/{+name}:deny",
                      "request": {
                        "$ref": "DenyGrantRequest"
                      },
                      "description": "`DenyGrant` is used to deny a grant. This method can only be called on a grant when it's in the `APPROVAL_AWAITED` state. This operation can't be undone."
                    },
                    "list": {
                      "path": "v1beta/{+parent}/grants",
                      "description": "Lists grants for a given entitlement.",
                      "flatPath": "v1beta/organizations/{organizationsId}/locations/{locationsId}/entitlements/{entitlementsId}/grants",
                      "response": {
                        "$ref": "ListGrantsResponse"
                      },
                      "id": "privilegedaccessmanager.organizations.locations.entitlements.grants.list",
                      "parameterOrder": [
                        "parent"
                      ],
                      "scopes": [
                        "https://www.googleapis.com/auth/cloud-platform"
                      ],
                      "httpMethod": "GET",
                      "parameters": {
                        "pageSize": {
                          "location": "query",
                          "format": "int32",
                          "description": "Optional. Requested page size. The server may return fewer items than requested. If unspecified, the server picks an appropriate default.",
                          "type": "integer"
                        },
                        "filter": {
                          "location": "query",
                          "description": "Optional. Filtering results.",
                          "type": "string"
                        },
                        "parent": {
                          "pattern": "^organizations/[^/]+/locations/[^/]+/entitlements/[^/]+$",
                          "description": "Required. The parent resource which owns the grants.",
                          "required": true,
                          "type": "string",
                          "location": "path"
                        },
                        "pageToken": {
                          "description": "Optional. A token identifying a page of results the server should return.",
                          "type": "string",
                          "location": "query"
                        },
                        "orderBy": {
                          "location": "query",
                          "description": "Optional. Hint for how to order the results",
                          "type": "string"
                        }
                      }
                    },
                    "get": {
                      "httpMethod": "GET",
                      "scopes": [
                        "https://www.googleapis.com/auth/cloud-platform"
                      ],
                      "id": "privilegedaccessmanager.organizations.locations.entitlements.grants.get",
                      "parameterOrder": [
                        "name"
                      ],
                      "parameters": {
                        "name": {
                          "description": "Required. Name of the resource.",
                          "pattern": "^organizations/[^/]+/locations/[^/]+/entitlements/[^/]+/grants/[^/]+$",
                          "location": "path",
                          "type": "string",
                          "required": true
                        }
                      },
                      "flatPath": "v1beta/organizations/{organizationsId}/locations/{locationsId}/entitlements/{entitlementsId}/grants/{grantsId}",
                      "response": {
                        "$ref": "Grant"
                      },
                      "path": "v1beta/{+name}",
                      "description": "Get details of a single grant."
                    },
                    "search": {
                      "httpMethod": "GET",
                      "scopes": [
                        "https://www.googleapis.com/auth/cloud-platform"
                      ],
                      "id": "privilegedaccessmanager.organizations.locations.entitlements.grants.search",
                      "parameterOrder": [
                        "parent"
                      ],
                      "parameters": {
                        "callerRelationship": {
                          "description": "Required. Only grants which the caller is related to by this relationship are returned in the response.",
                          "enum": [
                            "CALLER_RELATIONSHIP_TYPE_UNSPECIFIED",
                            "HAD_CREATED",
                            "CAN_APPROVE",
                            "HAD_APPROVED"
                          ],
                          "type": "string",
                          "enumDescriptions": [
                            "Unspecified caller relationship type.",
                            "The user created this grant by calling `CreateGrant` earlier.",
                            "The user is an approver for the entitlement that this grant is parented under and can currently approve/deny it.",
                            "The caller had successfully approved/denied this grant earlier."
                          ],
                          "location": "query"
                        },
                        "filter": {
                          "location": "query",
                          "description": "Optional. Only grants matching this filter are returned in the response.",
                          "type": "string"
                        },
                        "pageSize": {
                          "description": "Optional. Requested page size. The server may return fewer items than requested. If unspecified, server picks an appropriate default.",
                          "type": "integer",
                          "location": "query",
                          "format": "int32"
                        },
                        "parent": {
                          "location": "path",
                          "type": "string",
                          "required": true,
                          "description": "Required. The parent which owns the grant resources.",
                          "pattern": "^organizations/[^/]+/locations/[^/]+/entitlements/[^/]+$"
                        },
                        "pageToken": {
                          "description": "Optional. A token identifying a page of results the server should return.",
                          "type": "string",
                          "location": "query"
                        }
                      },
                      "flatPath": "v1beta/organizations/{organizationsId}/locations/{locationsId}/entitlements/{entitlementsId}/grants:search",
                      "response": {
                        "$ref": "SearchGrantsResponse"
                      },
                      "path": "v1beta/{+parent}/grants:search",
                      "description": "`SearchGrants` returns grants that are related to the calling user in the specified way."
                    },
                    "withdraw": {
                      "path": "v1beta/{+name}:withdraw",
                      "request": {
                        "$ref": "WithdrawGrantRequest"
                      },
                      "description": "`WithdrawGrant` is used to immediately withdraw the grant. This method can be called when the grant is in a non-terminal state.",
                      "flatPath": "v1beta/organizations/{organizationsId}/locations/{locationsId}/entitlements/{entitlementsId}/grants/{grantsId}:withdraw",
                      "response": {
                        "$ref": "Operation"
                      },
                      "scopes": [
                        "https://www.googleapis.com/auth/cloud-platform"
                      ],
                      "httpMethod": "POST",
                      "id": "privilegedaccessmanager.organizations.locations.entitlements.grants.withdraw",
                      "parameterOrder": [
                        "name"
                      ],
                      "parameters": {
                        "name": {
                          "description": "Required. Name of the grant resource which is being withdrawn.",
                          "pattern": "^organizations/[^/]+/locations/[^/]+/entitlements/[^/]+/grants/[^/]+$",
                          "type": "string",
                          "required": true,
                          "location": "path"
                        }
                      }
                    },
                    "revoke": {
                      "flatPath": "v1beta/organizations/{organizationsId}/locations/{locationsId}/entitlements/{entitlementsId}/grants/{grantsId}:revoke",
                      "response": {
                        "$ref": "Operation"
                      },
                      "path": "v1beta/{+name}:revoke",
                      "request": {
                        "$ref": "RevokeGrantRequest"
                      },
                      "description": "`RevokeGrant` is used to immediately revoke access for a grant. This method can be called when the grant is in a non-terminal state.",
                      "parameters": {
                        "name": {
                          "description": "Required. Name of the grant resource which is being revoked.",
                          "pattern": "^organizations/[^/]+/locations/[^/]+/entitlements/[^/]+/grants/[^/]+$",
                          "type": "string",
                          "required": true,
                          "location": "path"
                        }
                      },
                      "httpMethod": "POST",
                      "scopes": [
                        "https://www.googleapis.com/auth/cloud-platform"
                      ],
                      "id": "privilegedaccessmanager.organizations.locations.entitlements.grants.revoke",
                      "parameterOrder": [
                        "name"
                      ]
                    }
                  }
                }
              }
            }
          }
        }
      }
    },
    "folders": {
      "resources": {
        "locations": {
          "methods": {
            "fetchEffectiveSettings": {
              "httpMethod": "GET",
              "scopes": [
                "https://www.googleapis.com/auth/cloud-platform"
              ],
              "id": "privilegedaccessmanager.folders.locations.fetchEffectiveSettings",
              "parameterOrder": [
                "parent"
              ],
              "parameters": {
                "parent": {
                  "pattern": "^folders/[^/]+/locations/[^/]+$",
                  "description": "Required. The resource for which the effective settings is fetched, in one of the following formats: * `projects/{project-number|project-id}/locations/{region}` * `folders/{folder-number}/locations/{region}` * `organizations/{organization-number}/locations/{region}`",
                  "required": true,
                  "type": "string",
                  "location": "path"
                }
              },
              "flatPath": "v1beta/folders/{foldersId}/locations/{locationsId}:fetchEffectiveSettings",
              "response": {
                "$ref": "FetchEffectiveSettingsResponse"
              },
              "path": "v1beta/{+parent}:fetchEffectiveSettings",
              "description": "`FetchEffectiveSettings` returns the effective PAM Settings for the given project, folder, or organization."
            },
            "list": {
              "scopes": [
                "https://www.googleapis.com/auth/cloud-platform"
              ],
              "httpMethod": "GET",
              "id": "privilegedaccessmanager.folders.locations.list",
              "parameterOrder": [
                "name"
              ],
              "parameters": {
                "pageToken": {
                  "location": "query",
                  "description": "A page token received from the `next_page_token` field in the response. Send that page token to receive the subsequent page.",
                  "type": "string"
                },
                "extraLocationTypes": {
                  "location": "query",
                  "repeated": true,
                  "description": "Optional. Do not use this field unless explicitly documented otherwise. This is primarily for internal usage.",
                  "type": "string"
                },
                "name": {
                  "pattern": "^folders/[^/]+$",
                  "description": "The resource that owns the locations collection, if applicable.",
                  "required": true,
                  "type": "string",
                  "location": "path"
                },
                "filter": {
                  "location": "query",
                  "description": "A filter to narrow down results to a preferred subset. The filtering language accepts strings like `\"displayName=tokyo\"`, and is documented in more detail in [AIP-160](https://google.aip.dev/160).",
                  "type": "string"
                },
                "pageSize": {
                  "location": "query",
                  "format": "int32",
                  "description": "The maximum number of results to return. If not set, the service selects a default.",
                  "type": "integer"
                }
              },
              "path": "v1beta/{+name}/locations",
              "description": "Lists information about the supported locations for this service. This method lists locations based on the resource scope provided in the ListLocationsRequest.name field: * **Global locations**: If `name` is empty, the method lists the public locations available to all projects. * **Project-specific locations**: If `name` follows the format `projects/{project}`, the method lists locations visible to that specific project. This includes public, private, or other project-specific locations enabled for the project. For gRPC and client library implementations, the resource name is passed as the `name` field. For direct service calls, the resource name is incorporated into the request path based on the specific service implementation and version.",
              "flatPath": "v1beta/folders/{foldersId}/locations",
              "response": {
                "$ref": "ListLocationsResponse"
              }
            },
            "get": {
              "path": "v1beta/{+name}",
              "description": "Gets information about a location.",
              "flatPath": "v1beta/folders/{foldersId}/locations/{locationsId}",
              "response": {
                "$ref": "Location"
              },
              "parameters": {
                "name": {
                  "description": "Resource name for the location.",
                  "pattern": "^folders/[^/]+/locations/[^/]+$",
                  "location": "path",
                  "type": "string",
                  "required": true
                }
              },
              "scopes": [
                "https://www.googleapis.com/auth/cloud-platform"
              ],
              "httpMethod": "GET",
              "id": "privilegedaccessmanager.folders.locations.get",
              "parameterOrder": [
                "name"
              ]
            },
            "checkOnboardingStatus": {
              "path": "v1beta/{+parent}:checkOnboardingStatus",
              "description": "`CheckOnboardingStatus` reports the onboarding status for a project, folder, or organization. Any findings reported by this API need to be fixed before PAM can be used on the resource.",
              "flatPath": "v1beta/folders/{foldersId}/locations/{locationsId}:checkOnboardingStatus",
              "response": {
                "$ref": "CheckOnboardingStatusResponse"
              },
              "parameters": {
                "parent": {
                  "type": "string",
                  "required": true,
                  "location": "path",
                  "description": "Required. The resource for which the onboarding status should be checked. Should be in one of the following formats: * `projects/{project-number|project-id}/locations/{region}` * `folders/{folder-number}/locations/{region}` * `organizations/{organization-number}/locations/{region}`",
                  "pattern": "^folders/[^/]+/locations/[^/]+$"
                }
              },
              "scopes": [
                "https://www.googleapis.com/auth/cloud-platform"
              ],
              "httpMethod": "GET",
              "id": "privilegedaccessmanager.folders.locations.checkOnboardingStatus",
              "parameterOrder": [
                "parent"
              ]
            },
            "getSettings": {
              "httpMethod": "GET",
              "scopes": [
                "https://www.googleapis.com/auth/cloud-platform"
              ],
              "id": "privilegedaccessmanager.folders.locations.getSettings",
              "parameterOrder": [
                "name"
              ],
              "parameters": {
                "name": {
                  "description": "Required. The name of the settings resource to be fetched.",
                  "pattern": "^folders/[^/]+/locations/[^/]+/settings$",
                  "location": "path",
                  "type": "string",
                  "required": true
                }
              },
              "flatPath": "v1beta/folders/{foldersId}/locations/{locationsId}/settings",
              "response": {
                "$ref": "Settings"
              },
              "path": "v1beta/{+name}",
              "description": "`GetSettings` returns the PAM Settings for the given project, folder, or organization."
            },
            "updateSettings": {
              "parameters": {
                "updateMask": {
                  "description": "Required. The list of fields to update. A field is overwritten if, and only if, it is in the mask. Any immutable fields set in the mask are ignored by the server. Repeated fields and map fields are only allowed in the last position of a `paths` string and overwrite the existing values. Hence an update to a repeated field or a map should contain the entire list of values. The fields specified in the update_mask are relative to the resource and not to the request. A value of '*' for this field refers to full replacement of the resource.",
                  "type": "string",
                  "location": "query",
                  "format": "google-fieldmask"
                },
                "name": {
                  "description": "Identifier. Name of the settings resource. Possible formats: projects/{project-id|project-number}/locations/{location}/settings folders/{folder-number}/locations/{location}/settings organizations/{organization-number}/locations/{location}/settings",
                  "pattern": "^folders/[^/]+/locations/[^/]+/settings$",
                  "type": "string",
                  "required": true,
                  "location": "path"
                }
              },
              "id": "privilegedaccessmanager.folders.locations.updateSettings",
              "parameterOrder": [
                "name"
              ],
              "scopes": [
                "https://www.googleapis.com/auth/cloud-platform"
              ],
              "httpMethod": "PATCH",
              "path": "v1beta/{+name}",
              "request": {
                "$ref": "Settings"
              },
              "description": "`UpdateSettings` updates the PAM Settings resource specified in the request. Updated fields in the settings need to be specified in an update mask. The following fields are not supported for updates: * Settings name * Create time * Update time * Etag",
              "flatPath": "v1beta/folders/{foldersId}/locations/{locationsId}/settings",
              "response": {
                "$ref": "Operation"
              }
            }
          },
          "resources": {
            "entitlements": {
              "methods": {
                "search": {
                  "path": "v1beta/{+parent}/entitlements:search",
                  "description": "`SearchEntitlements` returns entitlements on which the caller has the specified access.",
                  "flatPath": "v1beta/folders/{foldersId}/locations/{locationsId}/entitlements:search",
                  "response": {
                    "$ref": "SearchEntitlementsResponse"
                  },
                  "id": "privilegedaccessmanager.folders.locations.entitlements.search",
                  "parameterOrder": [
                    "parent"
                  ],
                  "scopes": [
                    "https://www.googleapis.com/auth/cloud-platform"
                  ],
                  "httpMethod": "GET",
                  "parameters": {
                    "callerAccessType": {
                      "enum": [
                        "CALLER_ACCESS_TYPE_UNSPECIFIED",
                        "GRANT_REQUESTER",
                        "GRANT_APPROVER"
                      ],
                      "description": "Required. Only entitlements where the calling user has this access are returned.",
                      "location": "query",
                      "type": "string",
                      "enumDescriptions": [
                        "Unspecified access type.",
                        "The user has access to create grants using this entitlement.",
                        "The user has access to approve/deny grants created under this entitlement."
                      ]
                    },
                    "filter": {
                      "location": "query",
                      "description": "Optional. Only entitlements matching this filter are returned in the response.",
                      "type": "string"
                    },
                    "pageSize": {
                      "location": "query",
                      "format": "int32",
                      "description": "Optional. Requested page size. The server may return fewer items than requested. If unspecified, the server picks an appropriate default.",
                      "type": "integer"
                    },
                    "parent": {
                      "location": "path",
                      "required": true,
                      "type": "string",
                      "pattern": "^folders/[^/]+/locations/[^/]+$",
                      "description": "Required. The parent which owns the entitlement resources."
                    },
                    "pageToken": {
                      "location": "query",
                      "description": "Optional. A token identifying a page of results the server should return.",
                      "type": "string"
                    }
                  }
                },
                "delete": {
                  "parameters": {
                    "requestId": {
                      "location": "query",
                      "description": "Optional. An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server knows to ignore the request if it has already been completed. The server guarantees this for at least 60 minutes after the first request. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, ignores the second request. The request ID must be a valid UUID with the exception that zero UUID is not supported (00000000-0000-0000-0000-000000000000).",
                      "type": "string"
                    },
                    "name": {
                      "location": "path",
                      "type": "string",
                      "required": true,
                      "description": "Required. Name of the resource.",
                      "pattern": "^folders/[^/]+/locations/[^/]+/entitlements/[^/]+$"
                    },
                    "force": {
                      "description": "Optional. If set to true, any child grant under this entitlement is also deleted. (Otherwise, the request only works if the entitlement has no child grant.)",
                      "type": "boolean",
                      "location": "query"
                    }
                  },
                  "id": "privilegedaccessmanager.folders.locations.entitlements.delete",
                  "parameterOrder": [
                    "name"
                  ],
                  "scopes": [
                    "https://www.googleapis.com/auth/cloud-platform"
                  ],
                  "httpMethod": "DELETE",
                  "path": "v1beta/{+name}",
                  "description": "Deletes a single entitlement. This method can only be called when there are no in-progress (`ACTIVE`/`ACTIVATING`/`REVOKING`) grants under the entitlement.",
                  "flatPath": "v1beta/folders/{foldersId}/locations/{locationsId}/entitlements/{entitlementsId}",
                  "response": {
                    "$ref": "Operation"
                  }
                },
                "list": {
                  "path": "v1beta/{+parent}/entitlements",
                  "description": "Lists the entitlements in a given project, folder, organization, and in a given location.",
                  "flatPath": "v1beta/folders/{foldersId}/locations/{locationsId}/entitlements",
                  "response": {
                    "$ref": "ListEntitlementsResponse"
                  },
                  "parameters": {
                    "pageSize": {
                      "format": "int32",
                      "location": "query",
                      "description": "Optional. Requested page size. Server may return fewer items than requested. If unspecified, the server picks an appropriate default.",
                      "type": "integer"
                    },
                    "filter": {
                      "location": "query",
                      "description": "Optional. Filtering results.",
                      "type": "string"
                    },
                    "parent": {
                      "location": "path",
                      "type": "string",
                      "required": true,
                      "description": "Required. The parent which owns the entitlement resources.",
                      "pattern": "^folders/[^/]+/locations/[^/]+$"
                    },
                    "pageToken": {
                      "description": "Optional. A token identifying a page of results the server should return.",
                      "type": "string",
                      "location": "query"
                    },
                    "orderBy": {
                      "description": "Optional. Hint for how to order the results.",
                      "type": "string",
                      "location": "query"
                    }
                  },
                  "id": "privilegedaccessmanager.folders.locations.entitlements.list",
                  "parameterOrder": [
                    "parent"
                  ],
                  "scopes": [
                    "https://www.googleapis.com/auth/cloud-platform"
                  ],
                  "httpMethod": "GET"
                },
                "get": {
                  "parameters": {
                    "name": {
                      "pattern": "^folders/[^/]+/locations/[^/]+/entitlements/[^/]+$",
                      "description": "Required. Name of the resource.",
                      "location": "path",
                      "required": true,
                      "type": "string"
                    }
                  },
                  "id": "privilegedaccessmanager.folders.locations.entitlements.get",
                  "parameterOrder": [
                    "name"
                  ],
                  "httpMethod": "GET",
                  "scopes": [
                    "https://www.googleapis.com/auth/cloud-platform"
                  ],
                  "flatPath": "v1beta/folders/{foldersId}/locations/{locationsId}/entitlements/{entitlementsId}",
                  "response": {
                    "$ref": "Entitlement"
                  },
                  "path": "v1beta/{+name}",
                  "description": "Gets details of a single entitlement."
                },
                "create": {
                  "flatPath": "v1beta/folders/{foldersId}/locations/{locationsId}/entitlements",
                  "response": {
                    "$ref": "Operation"
                  },
                  "path": "v1beta/{+parent}/entitlements",
                  "request": {
                    "$ref": "Entitlement"
                  },
                  "description": "Creates a new entitlement in a given project, folder, organization, and in a given location.",
                  "httpMethod": "POST",
                  "scopes": [
                    "https://www.googleapis.com/auth/cloud-platform"
                  ],
                  "id": "privilegedaccessmanager.folders.locations.entitlements.create",
                  "parameterOrder": [
                    "parent"
                  ],
                  "parameters": {
                    "parent": {
                      "pattern": "^folders/[^/]+/locations/[^/]+$",
                      "description": "Required. Name of the parent resource for the entitlement. Possible formats: * `organizations/{organization-number}/locations/{region}` * `folders/{folder-number}/locations/{region}` * `projects/{project-id|project-number}/locations/{region}`",
                      "required": true,
                      "type": "string",
                      "location": "path"
                    },
                    "entitlementId": {
                      "description": "Required. The ID to use for this entitlement. This becomes the last part of the resource name. This value should be 4-63 characters in length, and valid characters are \"[a-z]\", \"[0-9]\", and \"-\". The first character should be from [a-z]. This value should be unique among all other entitlements under the specified `parent`.",
                      "type": "string",
                      "location": "query"
                    },
                    "requestId": {
                      "location": "query",
                      "description": "Optional. An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server knows to ignore the request if it has already been completed. The server guarantees this for at least 60 minutes after the first request. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, ignores the second request and returns the previous operation's response. This prevents clients from accidentally creating duplicate entitlements. The request ID must be a valid UUID with the exception that zero UUID is not supported (00000000-0000-0000-0000-000000000000).",
                      "type": "string"
                    }
                  }
                },
                "patch": {
                  "parameters": {
                    "updateMask": {
                      "description": "Required. The list of fields to update. A field is overwritten if, and only if, it is in the mask. Any immutable fields set in the mask are ignored by the server. Repeated fields and map fields are only allowed in the last position of a `paths` string and overwrite the existing values. Hence an update to a repeated field or a map should contain the entire list of values. The fields specified in the update_mask are relative to the resource and not to the request. (e.g. `MaxRequestDuration`; *not* `entitlement.MaxRequestDuration`) A value of '*' for this field refers to full replacement of the resource.",
                      "type": "string",
                      "format": "google-fieldmask",
                      "location": "query"
                    },
                    "name": {
                      "location": "path",
                      "required": true,
                      "type": "string",
                      "pattern": "^folders/[^/]+/locations/[^/]+/entitlements/[^/]+$",
                      "description": "Identifier. Name of the entitlement. Possible formats: * `organizations/{organization-number}/locations/{region}/entitlements/{entitlement-id}` * `folders/{folder-number}/locations/{region}/entitlements/{entitlement-id}` * `projects/{project-id|project-number}/locations/{region}/entitlements/{entitlement-id}`"
                    }
                  },
                  "httpMethod": "PATCH",
                  "scopes": [
                    "https://www.googleapis.com/auth/cloud-platform"
                  ],
                  "id": "privilegedaccessmanager.folders.locations.entitlements.patch",
                  "parameterOrder": [
                    "name"
                  ],
                  "flatPath": "v1beta/folders/{foldersId}/locations/{locationsId}/entitlements/{entitlementsId}",
                  "response": {
                    "$ref": "Operation"
                  },
                  "path": "v1beta/{+name}",
                  "request": {
                    "$ref": "Entitlement"
                  },
                  "description": "Updates the entitlement specified in the request. Updated fields in the entitlement need to be specified in an update mask. The changes made to an entitlement are applicable only on future grants of the entitlement. However, if new approvers are added or existing approvers are removed from the approval workflow, the changes are effective on existing grants. The following fields are not supported for updates: * All immutable fields * Entitlement name * Resource name * Resource type * Adding an approval workflow in an entitlement which previously had no approval workflow. * Deleting the approval workflow from an entitlement. * Adding or deleting a step in the approval workflow (only one step is supported) Note that updates are allowed on the list of approvers in an approval workflow step."
                }
              },
              "resources": {
                "grants": {
                  "methods": {
                    "deny": {
                      "parameters": {
                        "name": {
                          "location": "path",
                          "required": true,
                          "type": "string",
                          "pattern": "^folders/[^/]+/locations/[^/]+/entitlements/[^/]+/grants/[^/]+$",
                          "description": "Required. Name of the grant resource which is being denied."
                        }
                      },
                      "id": "privilegedaccessmanager.folders.locations.entitlements.grants.deny",
                      "parameterOrder": [
                        "name"
                      ],
                      "httpMethod": "POST",
                      "scopes": [
                        "https://www.googleapis.com/auth/cloud-platform"
                      ],
                      "flatPath": "v1beta/folders/{foldersId}/locations/{locationsId}/entitlements/{entitlementsId}/grants/{grantsId}:deny",
                      "response": {
                        "$ref": "Grant"
                      },
                      "path": "v1beta/{+name}:deny",
                      "request": {
                        "$ref": "DenyGrantRequest"
                      },
                      "description": "`DenyGrant` is used to deny a grant. This method can only be called on a grant when it's in the `APPROVAL_AWAITED` state. This operation can't be undone."
                    },
                    "create": {
                      "parameters": {
                        "parent": {
                          "type": "string",
                          "required": true,
                          "location": "path",
                          "description": "Required. Name of the parent entitlement for which this grant is being requested.",
                          "pattern": "^folders/[^/]+/locations/[^/]+/entitlements/[^/]+$"
                        },
                        "requestId": {
                          "description": "Optional. An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server knows to ignore the request if it has already been completed. The server guarantees this for at least 60 minutes after the first request. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, ignores the second request. This prevents clients from accidentally creating duplicate grants. The request ID must be a valid UUID with the exception that zero UUID is not supported (00000000-0000-0000-0000-000000000000).",
                          "type": "string",
                          "location": "query"
                        }
                      },
                      "id": "privilegedaccessmanager.folders.locations.entitlements.grants.create",
                      "parameterOrder": [
                        "parent"
                      ],
                      "httpMethod": "POST",
                      "scopes": [
                        "https://www.googleapis.com/auth/cloud-platform"
                      ],
                      "flatPath": "v1beta/folders/{foldersId}/locations/{locationsId}/entitlements/{entitlementsId}/grants",
                      "response": {
                        "$ref": "Grant"
                      },
                      "path": "v1beta/{+parent}/grants",
                      "request": {
                        "$ref": "Grant"
                      },
                      "description": "Creates a grant in a given project, folder, or organization and location."
                    },
                    "approve": {
                      "path": "v1beta/{+name}:approve",
                      "request": {
                        "$ref": "ApproveGrantRequest"
                      },
                      "description": "`ApproveGrant` is used to approve a grant. This method can only be called on a grant when it's in the `APPROVAL_AWAITED` state. This operation can't be undone.",
                      "flatPath": "v1beta/folders/{foldersId}/locations/{locationsId}/entitlements/{entitlementsId}/grants/{grantsId}:approve",
                      "response": {
                        "$ref": "Grant"
                      },
                      "scopes": [
                        "https://www.googleapis.com/auth/cloud-platform"
                      ],
                      "httpMethod": "POST",
                      "id": "privilegedaccessmanager.folders.locations.entitlements.grants.approve",
                      "parameterOrder": [
                        "name"
                      ],
                      "parameters": {
                        "name": {
                          "pattern": "^folders/[^/]+/locations/[^/]+/entitlements/[^/]+/grants/[^/]+$",
                          "description": "Required. Name of the grant resource which is being approved.",
                          "location": "path",
                          "required": true,
                          "type": "string"
                        }
                      }
                    },
                    "revoke": {
                      "path": "v1beta/{+name}:revoke",
                      "request": {
                        "$ref": "RevokeGrantRequest"
                      },
                      "description": "`RevokeGrant` is used to immediately revoke access for a grant. This method can be called when the grant is in a non-terminal state.",
                      "flatPath": "v1beta/folders/{foldersId}/locations/{locationsId}/entitlements/{entitlementsId}/grants/{grantsId}:revoke",
                      "response": {
                        "$ref": "Operation"
                      },
                      "parameters": {
                        "name": {
                          "required": true,
                          "type": "string",
                          "location": "path",
                          "pattern": "^folders/[^/]+/locations/[^/]+/entitlements/[^/]+/grants/[^/]+$",
                          "description": "Required. Name of the grant resource which is being revoked."
                        }
                      },
                      "scopes": [
                        "https://www.googleapis.com/auth/cloud-platform"
                      ],
                      "httpMethod": "POST",
                      "id": "privilegedaccessmanager.folders.locations.entitlements.grants.revoke",
                      "parameterOrder": [
                        "name"
                      ]
                    },
                    "search": {
                      "scopes": [
                        "https://www.googleapis.com/auth/cloud-platform"
                      ],
                      "httpMethod": "GET",
                      "id": "privilegedaccessmanager.folders.locations.entitlements.grants.search",
                      "parameterOrder": [
                        "parent"
                      ],
                      "parameters": {
                        "parent": {
                          "pattern": "^folders/[^/]+/locations/[^/]+/entitlements/[^/]+$",
                          "description": "Required. The parent which owns the grant resources.",
                          "location": "path",
                          "required": true,
                          "type": "string"
                        },
                        "pageToken": {
                          "location": "query",
                          "description": "Optional. A token identifying a page of results the server should return.",
                          "type": "string"
                        },
                        "callerRelationship": {
                          "location": "query",
                          "type": "string",
                          "enumDescriptions": [
                            "Unspecified caller relationship type.",
                            "The user created this grant by calling `CreateGrant` earlier.",
                            "The user is an approver for the entitlement that this grant is parented under and can currently approve/deny it.",
                            "The caller had successfully approved/denied this grant earlier."
                          ],
                          "enum": [
                            "CALLER_RELATIONSHIP_TYPE_UNSPECIFIED",
                            "HAD_CREATED",
                            "CAN_APPROVE",
                            "HAD_APPROVED"
                          ],
                          "description": "Required. Only grants which the caller is related to by this relationship are returned in the response."
                        },
                        "filter": {
                          "description": "Optional. Only grants matching this filter are returned in the response.",
                          "type": "string",
                          "location": "query"
                        },
                        "pageSize": {
                          "location": "query",
                          "format": "int32",
                          "description": "Optional. Requested page size. The server may return fewer items than requested. If unspecified, server picks an appropriate default.",
                          "type": "integer"
                        }
                      },
                      "path": "v1beta/{+parent}/grants:search",
                      "description": "`SearchGrants` returns grants that are related to the calling user in the specified way.",
                      "flatPath": "v1beta/folders/{foldersId}/locations/{locationsId}/entitlements/{entitlementsId}/grants:search",
                      "response": {
                        "$ref": "SearchGrantsResponse"
                      }
                    },
                    "withdraw": {
                      "parameters": {
                        "name": {
                          "pattern": "^folders/[^/]+/locations/[^/]+/entitlements/[^/]+/grants/[^/]+$",
                          "description": "Required. Name of the grant resource which is being withdrawn.",
                          "required": true,
                          "type": "string",
                          "location": "path"
                        }
                      },
                      "scopes": [
                        "https://www.googleapis.com/auth/cloud-platform"
                      ],
                      "httpMethod": "POST",
                      "id": "privilegedaccessmanager.folders.locations.entitlements.grants.withdraw",
                      "parameterOrder": [
                        "name"
                      ],
                      "path": "v1beta/{+name}:withdraw",
                      "request": {
                        "$ref": "WithdrawGrantRequest"
                      },
                      "description": "`WithdrawGrant` is used to immediately withdraw the grant. This method can be called when the grant is in a non-terminal state.",
                      "flatPath": "v1beta/folders/{foldersId}/locations/{locationsId}/entitlements/{entitlementsId}/grants/{grantsId}:withdraw",
                      "response": {
                        "$ref": "Operation"
                      }
                    },
                    "list": {
                      "flatPath": "v1beta/folders/{foldersId}/locations/{locationsId}/entitlements/{entitlementsId}/grants",
                      "response": {
                        "$ref": "ListGrantsResponse"
                      },
                      "path": "v1beta/{+parent}/grants",
                      "description": "Lists grants for a given entitlement.",
                      "httpMethod": "GET",
                      "scopes": [
                        "https://www.googleapis.com/auth/cloud-platform"
                      ],
                      "id": "privilegedaccessmanager.folders.locations.entitlements.grants.list",
                      "parameterOrder": [
                        "parent"
                      ],
                      "parameters": {
                        "parent": {
                          "pattern": "^folders/[^/]+/locations/[^/]+/entitlements/[^/]+$",
                          "description": "Required. The parent resource which owns the grants.",
                          "required": true,
                          "type": "string",
                          "location": "path"
                        },
                        "pageToken": {
                          "description": "Optional. A token identifying a page of results the server should return.",
                          "type": "string",
                          "location": "query"
                        },
                        "orderBy": {
                          "description": "Optional. Hint for how to order the results",
                          "type": "string",
                          "location": "query"
                        },
                        "pageSize": {
                          "format": "int32",
                          "location": "query",
                          "description": "Optional. Requested page size. The server may return fewer items than requested. If unspecified, the server picks an appropriate default.",
                          "type": "integer"
                        },
                        "filter": {
                          "description": "Optional. Filtering results.",
                          "type": "string",
                          "location": "query"
                        }
                      }
                    },
                    "get": {
                      "path": "v1beta/{+name}",
                      "description": "Get details of a single grant.",
                      "flatPath": "v1beta/folders/{foldersId}/locations/{locationsId}/entitlements/{entitlementsId}/grants/{grantsId}",
                      "response": {
                        "$ref": "Grant"
                      },
                      "parameters": {
                        "name": {
                          "required": true,
                          "type": "string",
                          "location": "path",
                          "pattern": "^folders/[^/]+/locations/[^/]+/entitlements/[^/]+/grants/[^/]+$",
                          "description": "Required. Name of the resource."
                        }
                      },
                      "scopes": [
                        "https://www.googleapis.com/auth/cloud-platform"
                      ],
                      "httpMethod": "GET",
                      "id": "privilegedaccessmanager.folders.locations.entitlements.grants.get",
                      "parameterOrder": [
                        "name"
                      ]
                    }
                  }
                }
              }
            },
            "operations": {
              "methods": {
                "delete": {
                  "parameters": {
                    "name": {
                      "type": "string",
                      "required": true,
                      "location": "path",
                      "description": "The name of the operation resource to be deleted.",
                      "pattern": "^folders/[^/]+/locations/[^/]+/operations/[^/]+$"
                    }
                  },
                  "id": "privilegedaccessmanager.folders.locations.operations.delete",
                  "parameterOrder": [
                    "name"
                  ],
                  "scopes": [
                    "https://www.googleapis.com/auth/cloud-platform"
                  ],
                  "httpMethod": "DELETE",
                  "path": "v1beta/{+name}",
                  "description": "Deletes a long-running operation. This method indicates that the client is no longer interested in the operation result. It does not cancel the operation. If the server doesn't support this method, it returns `google.rpc.Code.UNIMPLEMENTED`.",
                  "flatPath": "v1beta/folders/{foldersId}/locations/{locationsId}/operations/{operationsId}",
                  "response": {
                    "$ref": "GoogleProtobufEmpty"
                  }
                },
                "list": {
                  "path": "v1beta/{+name}/operations",
                  "description": "Lists operations that match the specified filter in the request. If the server doesn't support this method, it returns `UNIMPLEMENTED`.",
                  "flatPath": "v1beta/folders/{foldersId}/locations/{locationsId}/operations",
                  "response": {
                    "$ref": "ListOperationsResponse"
                  },
                  "parameters": {
                    "returnPartialSuccess": {
                      "location": "query",
                      "description": "When set to `true`, operations that are reachable are returned as normal, and those that are unreachable are returned in the ListOperationsResponse.unreachable field. This can only be `true` when reading across collections. For example, when `parent` is set to `\"projects/example/locations/-\"`. This field is not supported by default and will result in an `UNIMPLEMENTED` error if set unless explicitly documented otherwise in service or product specific documentation.",
                      "type": "boolean"
                    },
                    "filter": {
                      "description": "The standard list filter.",
                      "type": "string",
                      "location": "query"
                    },
                    "pageSize": {
                      "location": "query",
                      "format": "int32",
                      "description": "The standard list page size.",
                      "type": "integer"
                    },
                    "pageToken": {
                      "description": "The standard list page token.",
                      "type": "string",
                      "location": "query"
                    },
                    "name": {
                      "location": "path",
                      "required": true,
                      "type": "string",
                      "pattern": "^folders/[^/]+/locations/[^/]+$",
                      "description": "The name of the operation's parent resource."
                    }
                  },
                  "scopes": [
                    "https://www.googleapis.com/auth/cloud-platform"
                  ],
                  "httpMethod": "GET",
                  "id": "privilegedaccessmanager.folders.locations.operations.list",
                  "parameterOrder": [
                    "name"
                  ]
                },
                "get": {
                  "httpMethod": "GET",
                  "scopes": [
                    "https://www.googleapis.com/auth/cloud-platform"
                  ],
                  "id": "privilegedaccessmanager.folders.locations.operations.get",
                  "parameterOrder": [
                    "name"
                  ],
                  "parameters": {
                    "name": {
                      "pattern": "^folders/[^/]+/locations/[^/]+/operations/[^/]+$",
                      "description": "The name of the operation resource.",
                      "location": "path",
                      "required": true,
                      "type": "string"
                    }
                  },
                  "flatPath": "v1beta/folders/{foldersId}/locations/{locationsId}/operations/{operationsId}",
                  "response": {
                    "$ref": "Operation"
                  },
                  "path": "v1beta/{+name}",
                  "description": "Gets the latest state of a long-running operation. Clients can use this method to poll the operation result at intervals as recommended by the API service."
                }
              }
            }
          }
        }
      }
    },
    "projects": {
      "resources": {
        "locations": {
          "methods": {
            "fetchEffectiveSettings": {
              "parameters": {
                "parent": {
                  "pattern": "^projects/[^/]+/locations/[^/]+$",
                  "description": "Required. The resource for which the effective settings is fetched, in one of the following formats: * `projects/{project-number|project-id}/locations/{region}` * `folders/{folder-number}/locations/{region}` * `organizations/{organization-number}/locations/{region}`",
                  "required": true,
                  "type": "string",
                  "location": "path"
                }
              },
              "scopes": [
                "https://www.googleapis.com/auth/cloud-platform"
              ],
              "httpMethod": "GET",
              "id": "privilegedaccessmanager.projects.locations.fetchEffectiveSettings",
              "parameterOrder": [
                "parent"
              ],
              "path": "v1beta/{+parent}:fetchEffectiveSettings",
              "description": "`FetchEffectiveSettings` returns the effective PAM Settings for the given project, folder, or organization.",
              "flatPath": "v1beta/projects/{projectsId}/locations/{locationsId}:fetchEffectiveSettings",
              "response": {
                "$ref": "FetchEffectiveSettingsResponse"
              }
            },
            "list": {
              "parameters": {
                "extraLocationTypes": {
                  "description": "Optional. Do not use this field unless explicitly documented otherwise. This is primarily for internal usage.",
                  "type": "string",
                  "repeated": true,
                  "location": "query"
                },
                "name": {
                  "description": "The resource that owns the locations collection, if applicable.",
                  "pattern": "^projects/[^/]+$",
                  "type": "string",
                  "required": true,
                  "location": "path"
                },
                "pageToken": {
                  "description": "A page token received from the `next_page_token` field in the response. Send that page token to receive the subsequent page.",
                  "type": "string",
                  "location": "query"
                },
                "filter": {
                  "description": "A filter to narrow down results to a preferred subset. The filtering language accepts strings like `\"displayName=tokyo\"`, and is documented in more detail in [AIP-160](https://google.aip.dev/160).",
                  "type": "string",
                  "location": "query"
                },
                "pageSize": {
                  "location": "query",
                  "format": "int32",
                  "description": "The maximum number of results to return. If not set, the service selects a default.",
                  "type": "integer"
                }
              },
              "id": "privilegedaccessmanager.projects.locations.list",
              "parameterOrder": [
                "name"
              ],
              "httpMethod": "GET",
              "scopes": [
                "https://www.googleapis.com/auth/cloud-platform"
              ],
              "flatPath": "v1beta/projects/{projectsId}/locations",
              "response": {
                "$ref": "ListLocationsResponse"
              },
              "path": "v1beta/{+name}/locations",
              "description": "Lists information about the supported locations for this service. This method lists locations based on the resource scope provided in the ListLocationsRequest.name field: * **Global locations**: If `name` is empty, the method lists the public locations available to all projects. * **Project-specific locations**: If `name` follows the format `projects/{project}`, the method lists locations visible to that specific project. This includes public, private, or other project-specific locations enabled for the project. For gRPC and client library implementations, the resource name is passed as the `name` field. For direct service calls, the resource name is incorporated into the request path based on the specific service implementation and version."
            },
            "get": {
              "flatPath": "v1beta/projects/{projectsId}/locations/{locationsId}",
              "response": {
                "$ref": "Location"
              },
              "path": "v1beta/{+name}",
              "description": "Gets information about a location.",
              "httpMethod": "GET",
              "scopes": [
                "https://www.googleapis.com/auth/cloud-platform"
              ],
              "id": "privilegedaccessmanager.projects.locations.get",
              "parameterOrder": [
                "name"
              ],
              "parameters": {
                "name": {
                  "pattern": "^projects/[^/]+/locations/[^/]+$",
                  "description": "Resource name for the location.",
                  "required": true,
                  "type": "string",
                  "location": "path"
                }
              }
            },
            "checkOnboardingStatus": {
              "parameters": {
                "parent": {
                  "pattern": "^projects/[^/]+/locations/[^/]+$",
                  "description": "Required. The resource for which the onboarding status should be checked. Should be in one of the following formats: * `projects/{project-number|project-id}/locations/{region}` * `folders/{folder-number}/locations/{region}` * `organizations/{organization-number}/locations/{region}`",
                  "required": true,
                  "type": "string",
                  "location": "path"
                }
              },
              "httpMethod": "GET",
              "scopes": [
                "https://www.googleapis.com/auth/cloud-platform"
              ],
              "id": "privilegedaccessmanager.projects.locations.checkOnboardingStatus",
              "parameterOrder": [
                "parent"
              ],
              "flatPath": "v1beta/projects/{projectsId}/locations/{locationsId}:checkOnboardingStatus",
              "response": {
                "$ref": "CheckOnboardingStatusResponse"
              },
              "path": "v1beta/{+parent}:checkOnboardingStatus",
              "description": "`CheckOnboardingStatus` reports the onboarding status for a project, folder, or organization. Any findings reported by this API need to be fixed before PAM can be used on the resource."
            },
            "getSettings": {
              "flatPath": "v1beta/projects/{projectsId}/locations/{locationsId}/settings",
              "response": {
                "$ref": "Settings"
              },
              "path": "v1beta/{+name}",
              "description": "`GetSettings` returns the PAM Settings for the given project, folder, or organization.",
              "httpMethod": "GET",
              "scopes": [
                "https://www.googleapis.com/auth/cloud-platform"
              ],
              "id": "privilegedaccessmanager.projects.locations.getSettings",
              "parameterOrder": [
                "name"
              ],
              "parameters": {
                "name": {
                  "required": true,
                  "type": "string",
                  "location": "path",
                  "pattern": "^projects/[^/]+/locations/[^/]+/settings$",
                  "description": "Required. The name of the settings resource to be fetched."
                }
              }
            },
            "updateSettings": {
              "path": "v1beta/{+name}",
              "request": {
                "$ref": "Settings"
              },
              "description": "`UpdateSettings` updates the PAM Settings resource specified in the request. Updated fields in the settings need to be specified in an update mask. The following fields are not supported for updates: * Settings name * Create time * Update time * Etag",
              "flatPath": "v1beta/projects/{projectsId}/locations/{locationsId}/settings",
              "response": {
                "$ref": "Operation"
              },
              "parameters": {
                "name": {
                  "location": "path",
                  "type": "string",
                  "required": true,
                  "description": "Identifier. Name of the settings resource. Possible formats: projects/{project-id|project-number}/locations/{location}/settings folders/{folder-number}/locations/{location}/settings organizations/{organization-number}/locations/{location}/settings",
                  "pattern": "^projects/[^/]+/locations/[^/]+/settings$"
                },
                "updateMask": {
                  "description": "Required. The list of fields to update. A field is overwritten if, and only if, it is in the mask. Any immutable fields set in the mask are ignored by the server. Repeated fields and map fields are only allowed in the last position of a `paths` string and overwrite the existing values. Hence an update to a repeated field or a map should contain the entire list of values. The fields specified in the update_mask are relative to the resource and not to the request. A value of '*' for this field refers to full replacement of the resource.",
                  "type": "string",
                  "format": "google-fieldmask",
                  "location": "query"
                }
              },
              "id": "privilegedaccessmanager.projects.locations.updateSettings",
              "parameterOrder": [
                "name"
              ],
              "scopes": [
                "https://www.googleapis.com/auth/cloud-platform"
              ],
              "httpMethod": "PATCH"
            }
          },
          "resources": {
            "operations": {
              "methods": {
                "list": {
                  "scopes": [
                    "https://www.googleapis.com/auth/cloud-platform"
                  ],
                  "httpMethod": "GET",
                  "id": "privilegedaccessmanager.projects.locations.operations.list",
                  "parameterOrder": [
                    "name"
                  ],
                  "parameters": {
                    "returnPartialSuccess": {
                      "location": "query",
                      "description": "When set to `true`, operations that are reachable are returned as normal, and those that are unreachable are returned in the ListOperationsResponse.unreachable field. This can only be `true` when reading across collections. For example, when `parent` is set to `\"projects/example/locations/-\"`. This field is not supported by default and will result in an `UNIMPLEMENTED` error if set unless explicitly documented otherwise in service or product specific documentation.",
                      "type": "boolean"
                    },
                    "filter": {
                      "description": "The standard list filter.",
                      "type": "string",
                      "location": "query"
                    },
                    "pageSize": {
                      "format": "int32",
                      "location": "query",
                      "description": "The standard list page size.",
                      "type": "integer"
                    },
                    "pageToken": {
                      "description": "The standard list page token.",
                      "type": "string",
                      "location": "query"
                    },
                    "name": {
                      "location": "path",
                      "required": true,
                      "type": "string",
                      "pattern": "^projects/[^/]+/locations/[^/]+$",
                      "description": "The name of the operation's parent resource."
                    }
                  },
                  "path": "v1beta/{+name}/operations",
                  "description": "Lists operations that match the specified filter in the request. If the server doesn't support this method, it returns `UNIMPLEMENTED`.",
                  "flatPath": "v1beta/projects/{projectsId}/locations/{locationsId}/operations",
                  "response": {
                    "$ref": "ListOperationsResponse"
                  }
                },
                "get": {
                  "parameters": {
                    "name": {
                      "location": "path",
                      "type": "string",
                      "required": true,
                      "description": "The name of the operation resource.",
                      "pattern": "^projects/[^/]+/locations/[^/]+/operations/[^/]+$"
                    }
                  },
                  "id": "privilegedaccessmanager.projects.locations.operations.get",
                  "parameterOrder": [
                    "name"
                  ],
                  "scopes": [
                    "https://www.googleapis.com/auth/cloud-platform"
                  ],
                  "httpMethod": "GET",
                  "path": "v1beta/{+name}",
                  "description": "Gets the latest state of a long-running operation. Clients can use this method to poll the operation result at intervals as recommended by the API service.",
                  "flatPath": "v1beta/projects/{projectsId}/locations/{locationsId}/operations/{operationsId}",
                  "response": {
                    "$ref": "Operation"
                  }
                },
                "delete": {
                  "flatPath": "v1beta/projects/{projectsId}/locations/{locationsId}/operations/{operationsId}",
                  "response": {
                    "$ref": "GoogleProtobufEmpty"
                  },
                  "path": "v1beta/{+name}",
                  "description": "Deletes a long-running operation. This method indicates that the client is no longer interested in the operation result. It does not cancel the operation. If the server doesn't support this method, it returns `google.rpc.Code.UNIMPLEMENTED`.",
                  "parameters": {
                    "name": {
                      "required": true,
                      "type": "string",
                      "location": "path",
                      "pattern": "^projects/[^/]+/locations/[^/]+/operations/[^/]+$",
                      "description": "The name of the operation resource to be deleted."
                    }
                  },
                  "httpMethod": "DELETE",
                  "scopes": [
                    "https://www.googleapis.com/auth/cloud-platform"
                  ],
                  "id": "privilegedaccessmanager.projects.locations.operations.delete",
                  "parameterOrder": [
                    "name"
                  ]
                }
              }
            },
            "entitlements": {
              "methods": {
                "search": {
                  "parameters": {
                    "callerAccessType": {
                      "type": "string",
                      "enumDescriptions": [
                        "Unspecified access type.",
                        "The user has access to create grants using this entitlement.",
                        "The user has access to approve/deny grants created under this entitlement."
                      ],
                      "location": "query",
                      "description": "Required. Only entitlements where the calling user has this access are returned.",
                      "enum": [
                        "CALLER_ACCESS_TYPE_UNSPECIFIED",
                        "GRANT_REQUESTER",
                        "GRANT_APPROVER"
                      ]
                    },
                    "filter": {
                      "location": "query",
                      "description": "Optional. Only entitlements matching this filter are returned in the response.",
                      "type": "string"
                    },
                    "pageSize": {
                      "location": "query",
                      "format": "int32",
                      "description": "Optional. Requested page size. The server may return fewer items than requested. If unspecified, the server picks an appropriate default.",
                      "type": "integer"
                    },
                    "parent": {
                      "required": true,
                      "type": "string",
                      "location": "path",
                      "pattern": "^projects/[^/]+/locations/[^/]+$",
                      "description": "Required. The parent which owns the entitlement resources."
                    },
                    "pageToken": {
                      "description": "Optional. A token identifying a page of results the server should return.",
                      "type": "string",
                      "location": "query"
                    }
                  },
                  "scopes": [
                    "https://www.googleapis.com/auth/cloud-platform"
                  ],
                  "httpMethod": "GET",
                  "id": "privilegedaccessmanager.projects.locations.entitlements.search",
                  "parameterOrder": [
                    "parent"
                  ],
                  "path": "v1beta/{+parent}/entitlements:search",
                  "description": "`SearchEntitlements` returns entitlements on which the caller has the specified access.",
                  "flatPath": "v1beta/projects/{projectsId}/locations/{locationsId}/entitlements:search",
                  "response": {
                    "$ref": "SearchEntitlementsResponse"
                  }
                },
                "list": {
                  "id": "privilegedaccessmanager.projects.locations.entitlements.list",
                  "parameterOrder": [
                    "parent"
                  ],
                  "scopes": [
                    "https://www.googleapis.com/auth/cloud-platform"
                  ],
                  "httpMethod": "GET",
                  "parameters": {
                    "pageSize": {
                      "description": "Optional. Requested page size. Server may return fewer items than requested. If unspecified, the server picks an appropriate default.",
                      "type": "integer",
                      "location": "query",
                      "format": "int32"
                    },
                    "filter": {
                      "location": "query",
                      "description": "Optional. Filtering results.",
                      "type": "string"
                    },
                    "parent": {
                      "description": "Required. The parent which owns the entitlement resources.",
                      "pattern": "^projects/[^/]+/locations/[^/]+$",
                      "location": "path",
                      "type": "string",
                      "required": true
                    },
                    "pageToken": {
                      "description": "Optional. A token identifying a page of results the server should return.",
                      "type": "string",
                      "location": "query"
                    },
                    "orderBy": {
                      "location": "query",
                      "description": "Optional. Hint for how to order the results.",
                      "type": "string"
                    }
                  },
                  "path": "v1beta/{+parent}/entitlements",
                  "description": "Lists the entitlements in a given project, folder, organization, and in a given location.",
                  "flatPath": "v1beta/projects/{projectsId}/locations/{locationsId}/entitlements",
                  "response": {
                    "$ref": "ListEntitlementsResponse"
                  }
                },
                "get": {
                  "httpMethod": "GET",
                  "scopes": [
                    "https://www.googleapis.com/auth/cloud-platform"
                  ],
                  "id": "privilegedaccessmanager.projects.locations.entitlements.get",
                  "parameterOrder": [
                    "name"
                  ],
                  "parameters": {
                    "name": {
                      "description": "Required. Name of the resource.",
                      "pattern": "^projects/[^/]+/locations/[^/]+/entitlements/[^/]+$",
                      "type": "string",
                      "required": true,
                      "location": "path"
                    }
                  },
                  "flatPath": "v1beta/projects/{projectsId}/locations/{locationsId}/entitlements/{entitlementsId}",
                  "response": {
                    "$ref": "Entitlement"
                  },
                  "path": "v1beta/{+name}",
                  "description": "Gets details of a single entitlement."
                },
                "delete": {
                  "path": "v1beta/{+name}",
                  "description": "Deletes a single entitlement. This method can only be called when there are no in-progress (`ACTIVE`/`ACTIVATING`/`REVOKING`) grants under the entitlement.",
                  "flatPath": "v1beta/projects/{projectsId}/locations/{locationsId}/entitlements/{entitlementsId}",
                  "response": {
                    "$ref": "Operation"
                  },
                  "id": "privilegedaccessmanager.projects.locations.entitlements.delete",
                  "parameterOrder": [
                    "name"
                  ],
                  "scopes": [
                    "https://www.googleapis.com/auth/cloud-platform"
                  ],
                  "httpMethod": "DELETE",
                  "parameters": {
                    "requestId": {
                      "location": "query",
                      "description": "Optional. An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server knows to ignore the request if it has already been completed. The server guarantees this for at least 60 minutes after the first request. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, ignores the second request. The request ID must be a valid UUID with the exception that zero UUID is not supported (00000000-0000-0000-0000-000000000000).",
                      "type": "string"
                    },
                    "name": {
                      "type": "string",
                      "required": true,
                      "location": "path",
                      "description": "Required. Name of the resource.",
                      "pattern": "^projects/[^/]+/locations/[^/]+/entitlements/[^/]+$"
                    },
                    "force": {
                      "description": "Optional. If set to true, any child grant under this entitlement is also deleted. (Otherwise, the request only works if the entitlement has no child grant.)",
                      "type": "boolean",
                      "location": "query"
                    }
                  }
                },
                "patch": {
                  "path": "v1beta/{+name}",
                  "request": {
                    "$ref": "Entitlement"
                  },
                  "description": "Updates the entitlement specified in the request. Updated fields in the entitlement need to be specified in an update mask. The changes made to an entitlement are applicable only on future grants of the entitlement. However, if new approvers are added or existing approvers are removed from the approval workflow, the changes are effective on existing grants. The following fields are not supported for updates: * All immutable fields * Entitlement name * Resource name * Resource type * Adding an approval workflow in an entitlement which previously had no approval workflow. * Deleting the approval workflow from an entitlement. * Adding or deleting a step in the approval workflow (only one step is supported) Note that updates are allowed on the list of approvers in an approval workflow step.",
                  "flatPath": "v1beta/projects/{projectsId}/locations/{locationsId}/entitlements/{entitlementsId}",
                  "response": {
                    "$ref": "Operation"
                  },
                  "parameters": {
                    "updateMask": {
                      "location": "query",
                      "format": "google-fieldmask",
                      "description": "Required. The list of fields to update. A field is overwritten if, and only if, it is in the mask. Any immutable fields set in the mask are ignored by the server. Repeated fields and map fields are only allowed in the last position of a `paths` string and overwrite the existing values. Hence an update to a repeated field or a map should contain the entire list of values. The fields specified in the update_mask are relative to the resource and not to the request. (e.g. `MaxRequestDuration`; *not* `entitlement.MaxRequestDuration`) A value of '*' for this field refers to full replacement of the resource.",
                      "type": "string"
                    },
                    "name": {
                      "location": "path",
                      "required": true,
                      "type": "string",
                      "pattern": "^projects/[^/]+/locations/[^/]+/entitlements/[^/]+$",
                      "description": "Identifier. Name of the entitlement. Possible formats: * `organizations/{organization-number}/locations/{region}/entitlements/{entitlement-id}` * `folders/{folder-number}/locations/{region}/entitlements/{entitlement-id}` * `projects/{project-id|project-number}/locations/{region}/entitlements/{entitlement-id}`"
                    }
                  },
                  "id": "privilegedaccessmanager.projects.locations.entitlements.patch",
                  "parameterOrder": [
                    "name"
                  ],
                  "scopes": [
                    "https://www.googleapis.com/auth/cloud-platform"
                  ],
                  "httpMethod": "PATCH"
                },
                "create": {
                  "path": "v1beta/{+parent}/entitlements",
                  "request": {
                    "$ref": "Entitlement"
                  },
                  "description": "Creates a new entitlement in a given project, folder, organization, and in a given location.",
                  "flatPath": "v1beta/projects/{projectsId}/locations/{locationsId}/entitlements",
                  "response": {
                    "$ref": "Operation"
                  },
                  "parameters": {
                    "requestId": {
                      "location": "query",
                      "description": "Optional. An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server knows to ignore the request if it has already been completed. The server guarantees this for at least 60 minutes after the first request. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, ignores the second request and returns the previous operation's response. This prevents clients from accidentally creating duplicate entitlements. The request ID must be a valid UUID with the exception that zero UUID is not supported (00000000-0000-0000-0000-000000000000).",
                      "type": "string"
                    },
                    "parent": {
                      "description": "Required. Name of the parent resource for the entitlement. Possible formats: * `organizations/{organization-number}/locations/{region}` * `folders/{folder-number}/locations/{region}` * `projects/{project-id|project-number}/locations/{region}`",
                      "pattern": "^projects/[^/]+/locations/[^/]+$",
                      "location": "path",
                      "type": "string",
                      "required": true
                    },
                    "entitlementId": {
                      "location": "query",
                      "description": "Required. The ID to use for this entitlement. This becomes the last part of the resource name. This value should be 4-63 characters in length, and valid characters are \"[a-z]\", \"[0-9]\", and \"-\". The first character should be from [a-z]. This value should be unique among all other entitlements under the specified `parent`.",
                      "type": "string"
                    }
                  },
                  "id": "privilegedaccessmanager.projects.locations.entitlements.create",
                  "parameterOrder": [
                    "parent"
                  ],
                  "scopes": [
                    "https://www.googleapis.com/auth/cloud-platform"
                  ],
                  "httpMethod": "POST"
                }
              },
              "resources": {
                "grants": {
                  "methods": {
                    "search": {
                      "flatPath": "v1beta/projects/{projectsId}/locations/{locationsId}/entitlements/{entitlementsId}/grants:search",
                      "response": {
                        "$ref": "SearchGrantsResponse"
                      },
                      "path": "v1beta/{+parent}/grants:search",
                      "description": "`SearchGrants` returns grants that are related to the calling user in the specified way.",
                      "parameters": {
                        "parent": {
                          "type": "string",
                          "required": true,
                          "location": "path",
                          "description": "Required. The parent which owns the grant resources.",
                          "pattern": "^projects/[^/]+/locations/[^/]+/entitlements/[^/]+$"
                        },
                        "pageToken": {
                          "description": "Optional. A token identifying a page of results the server should return.",
                          "type": "string",
                          "location": "query"
                        },
                        "filter": {
                          "location": "query",
                          "description": "Optional. Only grants matching this filter are returned in the response.",
                          "type": "string"
                        },
                        "pageSize": {
                          "description": "Optional. Requested page size. The server may return fewer items than requested. If unspecified, server picks an appropriate default.",
                          "type": "integer",
                          "location": "query",
                          "format": "int32"
                        },
                        "callerRelationship": {
                          "type": "string",
                          "enumDescriptions": [
                            "Unspecified caller relationship type.",
                            "The user created this grant by calling `CreateGrant` earlier.",
                            "The user is an approver for the entitlement that this grant is parented under and can currently approve/deny it.",
                            "The caller had successfully approved/denied this grant earlier."
                          ],
                          "location": "query",
                          "description": "Required. Only grants which the caller is related to by this relationship are returned in the response.",
                          "enum": [
                            "CALLER_RELATIONSHIP_TYPE_UNSPECIFIED",
                            "HAD_CREATED",
                            "CAN_APPROVE",
                            "HAD_APPROVED"
                          ]
                        }
                      },
                      "id": "privilegedaccessmanager.projects.locations.entitlements.grants.search",
                      "parameterOrder": [
                        "parent"
                      ],
                      "httpMethod": "GET",
                      "scopes": [
                        "https://www.googleapis.com/auth/cloud-platform"
                      ]
                    },
                    "withdraw": {
                      "id": "privilegedaccessmanager.projects.locations.entitlements.grants.withdraw",
                      "parameterOrder": [
                        "name"
                      ],
                      "httpMethod": "POST",
                      "scopes": [
                        "https://www.googleapis.com/auth/cloud-platform"
                      ],
                      "parameters": {
                        "name": {
                          "pattern": "^projects/[^/]+/locations/[^/]+/entitlements/[^/]+/grants/[^/]+$",
                          "description": "Required. Name of the grant resource which is being withdrawn.",
                          "location": "path",
                          "required": true,
                          "type": "string"
                        }
                      },
                      "flatPath": "v1beta/projects/{projectsId}/locations/{locationsId}/entitlements/{entitlementsId}/grants/{grantsId}:withdraw",
                      "response": {
                        "$ref": "Operation"
                      },
                      "path": "v1beta/{+name}:withdraw",
                      "request": {
                        "$ref": "WithdrawGrantRequest"
                      },
                      "description": "`WithdrawGrant` is used to immediately withdraw the grant. This method can be called when the grant is in a non-terminal state."
                    },
                    "revoke": {
                      "parameters": {
                        "name": {
                          "pattern": "^projects/[^/]+/locations/[^/]+/entitlements/[^/]+/grants/[^/]+$",
                          "description": "Required. Name of the grant resource which is being revoked.",
                          "required": true,
                          "type": "string",
                          "location": "path"
                        }
                      },
                      "id": "privilegedaccessmanager.projects.locations.entitlements.grants.revoke",
                      "parameterOrder": [
                        "name"
                      ],
                      "scopes": [
                        "https://www.googleapis.com/auth/cloud-platform"
                      ],
                      "httpMethod": "POST",
                      "path": "v1beta/{+name}:revoke",
                      "request": {
                        "$ref": "RevokeGrantRequest"
                      },
                      "description": "`RevokeGrant` is used to immediately revoke access for a grant. This method can be called when the grant is in a non-terminal state.",
                      "flatPath": "v1beta/projects/{projectsId}/locations/{locationsId}/entitlements/{entitlementsId}/grants/{grantsId}:revoke",
                      "response": {
                        "$ref": "Operation"
                      }
                    },
                    "list": {
                      "flatPath": "v1beta/projects/{projectsId}/locations/{locationsId}/entitlements/{entitlementsId}/grants",
                      "response": {
                        "$ref": "ListGrantsResponse"
                      },
                      "path": "v1beta/{+parent}/grants",
                      "description": "Lists grants for a given entitlement.",
                      "parameters": {
                        "parent": {
                          "pattern": "^projects/[^/]+/locations/[^/]+/entitlements/[^/]+$",
                          "description": "Required. The parent resource which owns the grants.",
                          "required": true,
                          "type": "string",
                          "location": "path"
                        },
                        "pageToken": {
                          "location": "query",
                          "description": "Optional. A token identifying a page of results the server should return.",
                          "type": "string"
                        },
                        "orderBy": {
                          "description": "Optional. Hint for how to order the results",
                          "type": "string",
                          "location": "query"
                        },
                        "pageSize": {
                          "description": "Optional. Requested page size. The server may return fewer items than requested. If unspecified, the server picks an appropriate default.",
                          "type": "integer",
                          "format": "int32",
                          "location": "query"
                        },
                        "filter": {
                          "description": "Optional. Filtering results.",
                          "type": "string",
                          "location": "query"
                        }
                      },
                      "httpMethod": "GET",
                      "scopes": [
                        "https://www.googleapis.com/auth/cloud-platform"
                      ],
                      "id": "privilegedaccessmanager.projects.locations.entitlements.grants.list",
                      "parameterOrder": [
                        "parent"
                      ]
                    },
                    "get": {
                      "flatPath": "v1beta/projects/{projectsId}/locations/{locationsId}/entitlements/{entitlementsId}/grants/{grantsId}",
                      "response": {
                        "$ref": "Grant"
                      },
                      "path": "v1beta/{+name}",
                      "description": "Get details of a single grant.",
                      "id": "privilegedaccessmanager.projects.locations.entitlements.grants.get",
                      "parameterOrder": [
                        "name"
                      ],
                      "httpMethod": "GET",
                      "scopes": [
                        "https://www.googleapis.com/auth/cloud-platform"
                      ],
                      "parameters": {
                        "name": {
                          "pattern": "^projects/[^/]+/locations/[^/]+/entitlements/[^/]+/grants/[^/]+$",
                          "description": "Required. Name of the resource.",
                          "location": "path",
                          "required": true,
                          "type": "string"
                        }
                      }
                    },
                    "deny": {
                      "path": "v1beta/{+name}:deny",
                      "request": {
                        "$ref": "DenyGrantRequest"
                      },
                      "description": "`DenyGrant` is used to deny a grant. This method can only be called on a grant when it's in the `APPROVAL_AWAITED` state. This operation can't be undone.",
                      "flatPath": "v1beta/projects/{projectsId}/locations/{locationsId}/entitlements/{entitlementsId}/grants/{grantsId}:deny",
                      "response": {
                        "$ref": "Grant"
                      },
                      "parameters": {
                        "name": {
                          "description": "Required. Name of the grant resource which is being denied.",
                          "pattern": "^projects/[^/]+/locations/[^/]+/entitlements/[^/]+/grants/[^/]+$",
                          "location": "path",
                          "type": "string",
                          "required": true
                        }
                      },
                      "id": "privilegedaccessmanager.projects.locations.entitlements.grants.deny",
                      "parameterOrder": [
                        "name"
                      ],
                      "scopes": [
                        "https://www.googleapis.com/auth/cloud-platform"
                      ],
                      "httpMethod": "POST"
                    },
                    "create": {
                      "path": "v1beta/{+parent}/grants",
                      "request": {
                        "$ref": "Grant"
                      },
                      "description": "Creates a grant in a given project, folder, or organization and location.",
                      "flatPath": "v1beta/projects/{projectsId}/locations/{locationsId}/entitlements/{entitlementsId}/grants",
                      "response": {
                        "$ref": "Grant"
                      },
                      "id": "privilegedaccessmanager.projects.locations.entitlements.grants.create",
                      "parameterOrder": [
                        "parent"
                      ],
                      "scopes": [
                        "https://www.googleapis.com/auth/cloud-platform"
                      ],
                      "httpMethod": "POST",
                      "parameters": {
                        "parent": {
                          "description": "Required. Name of the parent entitlement for which this grant is being requested.",
                          "pattern": "^projects/[^/]+/locations/[^/]+/entitlements/[^/]+$",
                          "location": "path",
                          "type": "string",
                          "required": true
                        },
                        "requestId": {
                          "location": "query",
                          "description": "Optional. An optional request ID to identify requests. Specify a unique request ID so that if you must retry your request, the server knows to ignore the request if it has already been completed. The server guarantees this for at least 60 minutes after the first request. For example, consider a situation where you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if original operation with the same request ID was received, and if so, ignores the second request. This prevents clients from accidentally creating duplicate grants. The request ID must be a valid UUID with the exception that zero UUID is not supported (00000000-0000-0000-0000-000000000000).",
                          "type": "string"
                        }
                      }
                    },
                    "approve": {
                      "scopes": [
                        "https://www.googleapis.com/auth/cloud-platform"
                      ],
                      "httpMethod": "POST",
                      "id": "privilegedaccessmanager.projects.locations.entitlements.grants.approve",
                      "parameterOrder": [
                        "name"
                      ],
                      "parameters": {
                        "name": {
                          "type": "string",
                          "required": true,
                          "location": "path",
                          "description": "Required. Name of the grant resource which is being approved.",
                          "pattern": "^projects/[^/]+/locations/[^/]+/entitlements/[^/]+/grants/[^/]+$"
                        }
                      },
                      "path": "v1beta/{+name}:approve",
                      "request": {
                        "$ref": "ApproveGrantRequest"
                      },
                      "description": "`ApproveGrant` is used to approve a grant. This method can only be called on a grant when it's in the `APPROVAL_AWAITED` state. This operation can't be undone.",
                      "flatPath": "v1beta/projects/{projectsId}/locations/{locationsId}/entitlements/{entitlementsId}/grants/{grantsId}:approve",
                      "response": {
                        "$ref": "Grant"
                      }
                    }
                  }
                }
              }
            }
          }
        }
      }
    }
  },
  "revision": "20260506",
  "auth": {
    "oauth2": {
      "scopes": {
        "https://www.googleapis.com/auth/cloud-platform": {
          "description": "See, edit, configure, and delete your Google Cloud data and see the email address for your Google Account."
        }
      }
    }
  },
  "protocol": "rest"
}
