[][src]Struct gcp_client::google::cloud::policytroubleshooter::v1::BindingExplanation

pub struct BindingExplanation {
    pub access: i32,
    pub role: String,
    pub role_permission: i32,
    pub role_permission_relevance: i32,
    pub memberships: HashMap<String, AnnotatedMembership>,
    pub relevance: i32,
    pub condition: Option<Expr>,
}

Details about how a binding in a policy affects a member's ability to use a permission.

Fields

access: i32

Required. Indicates whether this binding provides the specified permission to the specified member for the specified resource.

This field does not indicate whether the member actually has the permission for the resource. There might be another binding that overrides this binding. To determine whether the member actually has the permission, use the access field in the [TroubleshootIamPolicyResponse][IamChecker.TroubleshootIamPolicyResponse].

role: String

The role that this binding grants. For example, roles/compute.serviceAgent.

For a complete list of predefined IAM roles, as well as the permissions in each role, see https://cloud.google.com/iam/help/roles/reference.

role_permission: i32

Indicates whether the role granted by this binding contains the specified permission.

role_permission_relevance: i32

The relevance of the permission's existence, or nonexistence, in the role to the overall determination for the entire policy.

memberships: HashMap<String, AnnotatedMembership>

Indicates whether each member in the binding includes the member specified in the request, either directly or indirectly. Each key identifies a member in the binding, and each value indicates whether the member in the binding includes the member in the request.

For example, suppose that a binding includes the following members:

  • user:alice@example.com
  • group:product-eng@example.com

You want to troubleshoot access for user:bob@example.com. This user is a member of the group group:product-eng@example.com.

For the first member in the binding, the key is user:alice@example.com, and the membership field in the value is set to MEMBERSHIP_NOT_INCLUDED.

For the second member in the binding, the key is group:product-eng@example.com, and the membership field in the value is set to MEMBERSHIP_INCLUDED.

relevance: i32

The relevance of this binding to the overall determination for the entire policy.

condition: Option<Expr>

A condition expression that prevents access unless the expression evaluates to true.

To learn about IAM Conditions, see http://cloud.google.com/iam/help/conditions/overview.

Implementations

impl BindingExplanation[src]

pub fn access(&self) -> AccessState[src]

Returns the enum value of access, or the default if the field is set to an invalid enum value.

pub fn set_access(&mut self, value: AccessState)[src]

Sets access to the provided enum value.

pub fn role_permission(&self) -> RolePermission[src]

Returns the enum value of role_permission, or the default if the field is set to an invalid enum value.

pub fn set_role_permission(&mut self, value: RolePermission)[src]

Sets role_permission to the provided enum value.

pub fn role_permission_relevance(&self) -> HeuristicRelevance[src]

Returns the enum value of role_permission_relevance, or the default if the field is set to an invalid enum value.

pub fn set_role_permission_relevance(&mut self, value: HeuristicRelevance)[src]

Sets role_permission_relevance to the provided enum value.

pub fn relevance(&self) -> HeuristicRelevance[src]

Returns the enum value of relevance, or the default if the field is set to an invalid enum value.

pub fn set_relevance(&mut self, value: HeuristicRelevance)[src]

Sets relevance to the provided enum value.

Trait Implementations

impl Clone for BindingExplanation[src]

impl Debug for BindingExplanation[src]

impl Default for BindingExplanation[src]

impl Message for BindingExplanation[src]

impl PartialEq<BindingExplanation> for BindingExplanation[src]

impl StructuralPartialEq for BindingExplanation[src]

Auto Trait Implementations

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]