Class: Google::Apis::CloudassetV1beta1::Asset

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

Overview

Cloud asset. This includes all Google Cloud Platform resources, Cloud IAM policies, and other non-GCP assets.

Instance Attribute Summary collapse

Instance Method Summary collapse

Methods included from Google::Apis::Core::JsonObjectSupport

#to_json

Methods included from Google::Apis::Core::Hashable

process_value, #to_h

Constructor Details

#initialize(**args) ⇒ Asset

Returns a new instance of Asset



104
105
106
# File 'generated/google/apis/cloudasset_v1beta1/classes.rb', line 104

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

Instance Attribute Details

#asset_typeString

Type of the asset. Example: "google.compute.Disk". Corresponds to the JSON property assetType

Returns:

  • (String)


33
34
35
# File 'generated/google/apis/cloudasset_v1beta1/classes.rb', line 33

def asset_type
  @asset_type
end

#iam_policyGoogle::Apis::CloudassetV1beta1::Policy

Defines an Identity and Access Management (IAM) policy. It is used to specify access control policies for Cloud Platform resources. A Policy is a collection of bindings. A binding binds one or more members to a single role. Members can be user accounts, service accounts, Google groups, and domains (such as G Suite). A role is a named list of permissions (defined by IAM or configured by users). A binding can optionally specify a condition, which is a logic expression that further constrains the role binding based on attributes about the request and/or target resource. JSON Example "bindings": [ "role": "roles/resourcemanager.organizationAdmin", "members": [ "user:mike@example.com", "group:admins@example.com", "domain:google.com", "serviceAccount:my-project-id@appspot.gserviceaccount.com" ] , "role": "roles/resourcemanager.organizationViewer", "members": ["user:eve@example.com"], "condition": "title": "expirable access", "description": "Does not grant access after Sep 2020", "expression": "request.time < timestamp('2020-10-01T00:00:00.000Z')", ] YAML Example bindings:



87
88
89
# File 'generated/google/apis/cloudasset_v1beta1/classes.rb', line 87

def iam_policy
  @iam_policy
end

#nameString

The full name of the asset. For example: //compute.googleapis.com/projects/my_project_123/zones/zone1/instances/ instance1. See Resource Names for more information. Corresponds to the JSON property name

Returns:

  • (String)


97
98
99
# File 'generated/google/apis/cloudasset_v1beta1/classes.rb', line 97

def name
  @name
end

#resourceGoogle::Apis::CloudassetV1beta1::Resource

Representation of a cloud resource. Corresponds to the JSON property resource



102
103
104
# File 'generated/google/apis/cloudasset_v1beta1/classes.rb', line 102

def resource
  @resource
end

Instance Method Details

#update!(**args) ⇒ Object

Update properties of this object



109
110
111
112
113
114
# File 'generated/google/apis/cloudasset_v1beta1/classes.rb', line 109

def update!(**args)
  @asset_type = args[:asset_type] if args.key?(:asset_type)
  @iam_policy = args[:iam_policy] if args.key?(:iam_policy)
  @name = args[:name] if args.key?(:name)
  @resource = args[:resource] if args.key?(:resource)
end