class Google::Apis::CloudassetV1p4beta1::Options

Contains request options.

Attributes

analyze_service_account_impersonation[RW]

Optional. If true, the response will include access analysis from identities to resources via service account impersonation. This is a very expensive operation, because many derived queries will be executed. For example, if the request analyzes for which resources user A has permission P, and there's an IAM policy states user A has iam.serviceAccounts.getAccessToken permission to a service account SA, and there's another IAM policy states service account SA has permission P to a GCP folder F, then user A potentially has access to the GCP folder F. And those advanced analysis results will be included in AnalyzeIamPolicyResponse.service_account_impersonation_analysis. Another example, if the request analyzes for who has permission P to a GCP folder F, and there's an IAM policy states user A has iam.serviceAccounts.actAs permission to a service account SA, and there's another IAM policy states service account SA has permission P to the GCP folder F, then user A potentially has access to the GCP folder F. And those advanced analysis results will be included in AnalyzeIamPolicyResponse. service_account_impersonation_analysis. Default is false. Corresponds to the JSON property `analyzeServiceAccountImpersonation` @return [Boolean]

analyze_service_account_impersonation?[RW]

Optional. If true, the response will include access analysis from identities to resources via service account impersonation. This is a very expensive operation, because many derived queries will be executed. For example, if the request analyzes for which resources user A has permission P, and there's an IAM policy states user A has iam.serviceAccounts.getAccessToken permission to a service account SA, and there's another IAM policy states service account SA has permission P to a GCP folder F, then user A potentially has access to the GCP folder F. And those advanced analysis results will be included in AnalyzeIamPolicyResponse.service_account_impersonation_analysis. Another example, if the request analyzes for who has permission P to a GCP folder F, and there's an IAM policy states user A has iam.serviceAccounts.actAs permission to a service account SA, and there's another IAM policy states service account SA has permission P to the GCP folder F, then user A potentially has access to the GCP folder F. And those advanced analysis results will be included in AnalyzeIamPolicyResponse. service_account_impersonation_analysis. Default is false. Corresponds to the JSON property `analyzeServiceAccountImpersonation` @return [Boolean]

expand_groups[RW]

Optional. If true, the identities section of the result will expand any Google groups appearing in an IAM policy binding. If identity_selector is specified, the identity in the result will be determined by the selector, and this flag will have no effect. Default is false. Corresponds to the JSON property `expandGroups` @return [Boolean]

expand_groups?[RW]

Optional. If true, the identities section of the result will expand any Google groups appearing in an IAM policy binding. If identity_selector is specified, the identity in the result will be determined by the selector, and this flag will have no effect. Default is false. Corresponds to the JSON property `expandGroups` @return [Boolean]

expand_resources[RW]

Optional. If true, the resource section of the result will expand any resource attached to an IAM policy to include resources lower in the resource hierarchy. For example, if the request analyzes for which resources user A has permission P, and the results include an IAM policy with P on a GCP folder, the results will also include resources in that folder with permission P. If resource_selector is specified, the resource section of the result will be determined by the selector, and this flag will have no effect. Default is false. Corresponds to the JSON property `expandResources` @return [Boolean]

expand_resources?[RW]

Optional. If true, the resource section of the result will expand any resource attached to an IAM policy to include resources lower in the resource hierarchy. For example, if the request analyzes for which resources user A has permission P, and the results include an IAM policy with P on a GCP folder, the results will also include resources in that folder with permission P. If resource_selector is specified, the resource section of the result will be determined by the selector, and this flag will have no effect. Default is false. Corresponds to the JSON property `expandResources` @return [Boolean]

expand_roles[RW]

Optional. If true, the access section of result will expand any roles appearing in IAM policy bindings to include their permissions. If access_selector is specified, the access section of the result will be determined by the selector, and this flag will have no effect. Default is false. Corresponds to the JSON property `expandRoles` @return [Boolean]

expand_roles?[RW]

Optional. If true, the access section of result will expand any roles appearing in IAM policy bindings to include their permissions. If access_selector is specified, the access section of the result will be determined by the selector, and this flag will have no effect. Default is false. Corresponds to the JSON property `expandRoles` @return [Boolean]

output_group_edges[RW]

Optional. If true, the result will output group identity edges, starting from the binding's group members, to any expanded identities. Default is false. Corresponds to the JSON property `outputGroupEdges` @return [Boolean]

output_group_edges?[RW]

Optional. If true, the result will output group identity edges, starting from the binding's group members, to any expanded identities. Default is false. Corresponds to the JSON property `outputGroupEdges` @return [Boolean]

output_resource_edges[RW]

Optional. If true, the result will output resource edges, starting from the policy attached resource, to any expanded resources. Default is false. Corresponds to the JSON property `outputResourceEdges` @return [Boolean]

output_resource_edges?[RW]

Optional. If true, the result will output resource edges, starting from the policy attached resource, to any expanded resources. Default is false. Corresponds to the JSON property `outputResourceEdges` @return [Boolean]

Public Class Methods

new(**args) click to toggle source
# File lib/google/apis/cloudasset_v1p4beta1/classes.rb, line 2336
def initialize(**args)
   update!(**args)
end

Public Instance Methods

update!(**args) click to toggle source

Update properties of this object

# File lib/google/apis/cloudasset_v1p4beta1/classes.rb, line 2341
def update!(**args)
  @analyze_service_account_impersonation = args[:analyze_service_account_impersonation] if args.key?(:analyze_service_account_impersonation)
  @expand_groups = args[:expand_groups] if args.key?(:expand_groups)
  @expand_resources = args[:expand_resources] if args.key?(:expand_resources)
  @expand_roles = args[:expand_roles] if args.key?(:expand_roles)
  @output_group_edges = args[:output_group_edges] if args.key?(:output_group_edges)
  @output_resource_edges = args[:output_resource_edges] if args.key?(:output_resource_edges)
end