[][src]Struct gcp_client::google::cloud::asset::v1p4beta1::export_iam_policy_analysis_request::Options

pub struct Options {
    pub expand_groups: bool,
    pub expand_roles: bool,
    pub expand_resources: bool,
    pub output_resource_edges: bool,
    pub output_group_edges: bool,
    pub analyze_service_account_impersonation: bool,
}

Contains request options.

Fields

expand_groups: bool

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.

expand_roles: bool

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.

expand_resources: bool

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.

output_resource_edges: bool

Optional. If true, the result will output resource edges, starting from the policy attached resource, to any expanded resources. Default is false.

output_group_edges: bool

Optional. If true, the result will output group identity edges, starting from the binding's group members, to any expanded identities. Default is false.

analyze_service_account_impersonation: bool

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][google.cloud.asset.v1p4beta1.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][google.cloud.asset.v1p4beta1.AnalyzeIamPolicyResponse.service_account_impersonation_analysis].

Default is false.

Trait Implementations

impl Clone for Options[src]

impl Debug for Options[src]

impl Default for Options[src]

impl Message for Options[src]

impl PartialEq<Options> for Options[src]

impl StructuralPartialEq for Options[src]

Auto Trait Implementations

impl RefUnwindSafe for Options

impl Send for Options

impl Sync for Options

impl Unpin for Options

impl UnwindSafe for Options

Blanket Implementations

impl<T> Any for T where
    T: 'static + ?Sized
[src]

impl<T> Borrow<T> for T where
    T: ?Sized
[src]

impl<T> BorrowMut<T> for T where
    T: ?Sized
[src]

impl<T> From<T> for T[src]

impl<T> Instrument for T[src]

impl<T, U> Into<U> for T where
    U: From<T>, 
[src]

impl<T> IntoRequest<T> for T[src]

impl<T> ToOwned for T where
    T: Clone
[src]

type Owned = T

The resulting type after obtaining ownership.

impl<T, U> TryFrom<U> for T where
    U: Into<T>, 
[src]

type Error = Infallible

The type returned in the event of a conversion error.

impl<T, U> TryInto<U> for T where
    U: TryFrom<T>, 
[src]

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.

impl<V, T> VZip<V> for T where
    V: MultiLane<T>, 

impl<T> WithSubscriber for T[src]