Class: Google::Apis::CloudassetV1::GoogleIdentityAccesscontextmanagerV1AccessPolicy

Inherits:
Object
  • Object
show all
Includes:
Google::Apis::Core::Hashable, Google::Apis::Core::JsonObjectSupport
Defined in:
lib/google/apis/cloudasset_v1/classes.rb,
lib/google/apis/cloudasset_v1/representations.rb,
lib/google/apis/cloudasset_v1/representations.rb
more...

Overview

AccessPolicy is a container for AccessLevels (which define the necessary attributes to use Google Cloud services) and ServicePerimeters (which define regions of services able to freely pass data within a perimeter). An access policy is globally visible within an organization, and the restrictions it specifies apply to all projects within an organization.

Instance Attribute Summary collapse

Instance Method Summary collapse

Constructor Details

#initialize(**args) ⇒ GoogleIdentityAccesscontextmanagerV1AccessPolicy

Returns a new instance of GoogleIdentityAccesscontextmanagerV1AccessPolicy.

[View source]

2923
2924
2925
# File 'lib/google/apis/cloudasset_v1/classes.rb', line 2923

def initialize(**args)
   update!(**args)
end

Instance Attribute Details

#etagString

Output only. An opaque identifier for the current version of the AccessPolicy . This will always be a strongly validated etag, meaning that two Access Policies will be identical if and only if their etags are identical. Clients should not expect this to be in any specific format. Corresponds to the JSON property etag

Returns:

  • (String)

2890
2891
2892
# File 'lib/google/apis/cloudasset_v1/classes.rb', line 2890

def etag
  @etag
end

#nameString

Output only. Identifier. Resource name of the AccessPolicy. Format: accessPolicies/access_policy` Corresponds to the JSON propertyname`

Returns:

  • (String)

2896
2897
2898
# File 'lib/google/apis/cloudasset_v1/classes.rb', line 2896

def name
  @name
end

#parentString

Required. The parent of this AccessPolicy in the Cloud Resource Hierarchy. Currently immutable once created. Format: organizations/organization_id` Corresponds to the JSON propertyparent`

Returns:

  • (String)

2902
2903
2904
# File 'lib/google/apis/cloudasset_v1/classes.rb', line 2902

def parent
  @parent
end

#scopesArray<String>

The scopes of the AccessPolicy. Scopes define which resources a policy can restrict and where its resources can be referenced. For example, policy A with scopes=["folders/123"] has the following behavior: - ServicePerimeter can only restrict projects within folders/123. - ServicePerimeter within policy A can only reference access levels defined within policy A. - Only one policy can include a given scope; thus, attempting to create a second policy which includes folders/123 will result in an error. If no scopes are provided, then any resource within the organization can be restricted. Scopes cannot be modified after a policy is created. Policies can only have a single scope. Format: list of folders/folder_numberor `projects/`project_number Corresponds to the JSON property scopes

Returns:

  • (Array<String>)

2916
2917
2918
# File 'lib/google/apis/cloudasset_v1/classes.rb', line 2916

def scopes
  @scopes
end

#titleString

Required. Human readable title. Does not affect behavior. Corresponds to the JSON property title

Returns:

  • (String)

2921
2922
2923
# File 'lib/google/apis/cloudasset_v1/classes.rb', line 2921

def title
  @title
end

Instance Method Details

#update!(**args) ⇒ Object

Update properties of this object

[View source]

2928
2929
2930
2931
2932
2933
2934
# File 'lib/google/apis/cloudasset_v1/classes.rb', line 2928

def update!(**args)
  @etag = args[:etag] if args.key?(:etag)
  @name = args[:name] if args.key?(:name)
  @parent = args[:parent] if args.key?(:parent)
  @scopes = args[:scopes] if args.key?(:scopes)
  @title = args[:title] if args.key?(:title)
end