public static final class IamPolicyAnalysisQuery.Options extends GeneratedMessageV3 implements IamPolicyAnalysisQuery.OptionsOrBuilder
Contains query options.
Protobuf type google.cloud.asset.v1.IamPolicyAnalysisQuery.Options
Static Fields
ANALYZE_SERVICE_ACCOUNT_IMPERSONATION_FIELD_NUMBER
public static final int ANALYZE_SERVICE_ACCOUNT_IMPERSONATION_FIELD_NUMBER
Field Value
EXPAND_GROUPS_FIELD_NUMBER
public static final int EXPAND_GROUPS_FIELD_NUMBER
Field Value
EXPAND_RESOURCES_FIELD_NUMBER
public static final int EXPAND_RESOURCES_FIELD_NUMBER
Field Value
EXPAND_ROLES_FIELD_NUMBER
public static final int EXPAND_ROLES_FIELD_NUMBER
Field Value
OUTPUT_GROUP_EDGES_FIELD_NUMBER
public static final int OUTPUT_GROUP_EDGES_FIELD_NUMBER
Field Value
OUTPUT_RESOURCE_EDGES_FIELD_NUMBER
public static final int OUTPUT_RESOURCE_EDGES_FIELD_NUMBER
Field Value
Static Methods
getDefaultInstance()
public static IamPolicyAnalysisQuery.Options getDefaultInstance()
Returns
getDescriptor()
public static final Descriptors.Descriptor getDescriptor()
Returns
newBuilder()
public static IamPolicyAnalysisQuery.Options.Builder newBuilder()
Returns
newBuilder(IamPolicyAnalysisQuery.Options prototype)
public static IamPolicyAnalysisQuery.Options.Builder newBuilder(IamPolicyAnalysisQuery.Options prototype)
Parameter
Returns
public static IamPolicyAnalysisQuery.Options parseDelimitedFrom(InputStream input)
Parameter
Returns
Exceptions
public static IamPolicyAnalysisQuery.Options parseDelimitedFrom(InputStream input, ExtensionRegistryLite extensionRegistry)
Parameters
Returns
Exceptions
parseFrom(byte[] data)
public static IamPolicyAnalysisQuery.Options parseFrom(byte[] data)
Parameter
Name | Description |
data | byte[]
|
Returns
Exceptions
parseFrom(byte[] data, ExtensionRegistryLite extensionRegistry)
public static IamPolicyAnalysisQuery.Options parseFrom(byte[] data, ExtensionRegistryLite extensionRegistry)
Parameters
Returns
Exceptions
parseFrom(ByteString data)
public static IamPolicyAnalysisQuery.Options parseFrom(ByteString data)
Parameter
Returns
Exceptions
parseFrom(ByteString data, ExtensionRegistryLite extensionRegistry)
public static IamPolicyAnalysisQuery.Options parseFrom(ByteString data, ExtensionRegistryLite extensionRegistry)
Parameters
Returns
Exceptions
public static IamPolicyAnalysisQuery.Options parseFrom(CodedInputStream input)
Parameter
Returns
Exceptions
public static IamPolicyAnalysisQuery.Options parseFrom(CodedInputStream input, ExtensionRegistryLite extensionRegistry)
Parameters
Returns
Exceptions
public static IamPolicyAnalysisQuery.Options parseFrom(InputStream input)
Parameter
Returns
Exceptions
public static IamPolicyAnalysisQuery.Options parseFrom(InputStream input, ExtensionRegistryLite extensionRegistry)
Parameters
Returns
Exceptions
parseFrom(ByteBuffer data)
public static IamPolicyAnalysisQuery.Options parseFrom(ByteBuffer data)
Parameter
Returns
Exceptions
parseFrom(ByteBuffer data, ExtensionRegistryLite extensionRegistry)
public static IamPolicyAnalysisQuery.Options parseFrom(ByteBuffer data, ExtensionRegistryLite extensionRegistry)
Parameters
Returns
Exceptions
parser()
public static Parser<IamPolicyAnalysisQuery.Options> parser()
Returns
Methods
equals(Object obj)
public boolean equals(Object obj)
Parameter
Returns
Overrides
getAnalyzeServiceAccountImpersonation()
public boolean getAnalyzeServiceAccountImpersonation()
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. We
highly recommend you use
AssetService.AnalyzeIamPolicyLongrunning
rpc instead.
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.
Only the following permissions are considered in this analysis:
iam.serviceAccounts.actAs
iam.serviceAccounts.signBlob
iam.serviceAccounts.signJwt
iam.serviceAccounts.getAccessToken
iam.serviceAccounts.getOpenIdToken
iam.serviceAccounts.implicitDelegation
Default is false.
bool analyze_service_account_impersonation = 6 [(.google.api.field_behavior) = OPTIONAL];
Returns
Type | Description |
boolean | The analyzeServiceAccountImpersonation.
|
getDefaultInstanceForType()
public IamPolicyAnalysisQuery.Options getDefaultInstanceForType()
Returns
getExpandGroups()
public boolean getExpandGroups()
Optional. If true, the identities section of the result will expand any
Google groups appearing in an IAM policy binding.
If
IamPolicyAnalysisQuery.identity_selector
is specified, the identity in the result will be determined by the
selector, and this flag is not allowed to set.
If true, the default max expansion per group is 1000 for
AssetService.AnalyzeIamPolicy][].
Default is false.
bool expand_groups = 1 [(.google.api.field_behavior) = OPTIONAL];
Returns
Type | Description |
boolean | The expandGroups.
|
getExpandResources()
public boolean getExpandResources()
Optional. If true and
IamPolicyAnalysisQuery.resource_selector
is not specified, 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 true and
IamPolicyAnalysisQuery.resource_selector
is specified, the resource section of the result will expand the
specified resource to include resources lower in the resource hierarchy.
Only project or lower resources are supported. Folder and organization
resource cannot be used together with this option.
For example, if the request analyzes for which users have permission P on
a GCP project with this option enabled, the results will include all
users who have permission P on that project or any lower resource.
If true, the default max expansion per resource is 1000 for
AssetService.AnalyzeIamPolicy][] and 100000 for
AssetService.AnalyzeIamPolicyLongrunning][].
Default is false.
bool expand_resources = 3 [(.google.api.field_behavior) = OPTIONAL];
Returns
Type | Description |
boolean | The expandResources.
|
getExpandRoles()
public boolean getExpandRoles()
Optional. If true, the access section of result will expand any roles
appearing in IAM policy bindings to include their permissions.
If
IamPolicyAnalysisQuery.access_selector
is specified, the access section of the result will be determined by the
selector, and this flag is not allowed to set.
Default is false.
bool expand_roles = 2 [(.google.api.field_behavior) = OPTIONAL];
Returns
Type | Description |
boolean | The expandRoles.
|
getOutputGroupEdges()
public boolean getOutputGroupEdges()
Optional. If true, the result will output the relevant membership
relationships between groups and other groups, and between groups and
principals. Default is false.
bool output_group_edges = 5 [(.google.api.field_behavior) = OPTIONAL];
Returns
Type | Description |
boolean | The outputGroupEdges.
|
getOutputResourceEdges()
public boolean getOutputResourceEdges()
Optional. If true, the result will output the relevant parent/child
relationships between resources. Default is false.
bool output_resource_edges = 4 [(.google.api.field_behavior) = OPTIONAL];
Returns
Type | Description |
boolean | The outputResourceEdges.
|
getParserForType()
public Parser<IamPolicyAnalysisQuery.Options> getParserForType()
Returns
Overrides
getSerializedSize()
public int getSerializedSize()
Returns
Overrides
getUnknownFields()
public final UnknownFieldSet getUnknownFields()
Returns
Overrides
hashCode()
Returns
Overrides
internalGetFieldAccessorTable()
protected GeneratedMessageV3.FieldAccessorTable internalGetFieldAccessorTable()
Returns
Overrides
isInitialized()
public final boolean isInitialized()
Returns
Overrides
newBuilderForType()
public IamPolicyAnalysisQuery.Options.Builder newBuilderForType()
Returns
newBuilderForType(GeneratedMessageV3.BuilderParent parent)
protected IamPolicyAnalysisQuery.Options.Builder newBuilderForType(GeneratedMessageV3.BuilderParent parent)
Parameter
Returns
Overrides
newInstance(GeneratedMessageV3.UnusedPrivateParameter unused)
protected Object newInstance(GeneratedMessageV3.UnusedPrivateParameter unused)
Parameter
Returns
Overrides
toBuilder()
public IamPolicyAnalysisQuery.Options.Builder toBuilder()
Returns
writeTo(CodedOutputStream output)
public void writeTo(CodedOutputStream output)
Parameter
Overrides
Exceptions