Class: Google::Apis::IapV1::Resource

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

Instance Attribute Summary collapse

Instance Method Summary collapse

Constructor Details

#initialize(**args) ⇒ Resource

Returns a new instance of Resource.



789
790
791
# File 'generated/google/apis/iap_v1/classes.rb', line 789

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

Instance Attribute Details

#labelsHash<String,String>

The service defined labels of the resource on which the conditions will be evaluated. The semantics - including the key names - are vague to IAM. If the effective condition has a reference to a resource.labels[foo] construct, IAM consults with this map to retrieve the values associated with foo key for Conditions evaluation. If the provided key is not found in the labels map, the condition would evaluate to false. This field is in limited use. If your intended use case is not expected to express resource.labels attribute in IAM Conditions, leave this field empty. Before planning on using this attribute please: * Read go/iam-conditions-labels-comm and ensure your service can meet the data availability and management requirements. * Talk to iam-conditions- eng@ about your use case. Corresponds to the JSON property labels

Returns:

  • (Hash<String,String>)


754
755
756
# File 'generated/google/apis/iap_v1/classes.rb', line 754

def labels
  @labels
end

#nameString

Name of the resource on which conditions will be evaluated. Must use the Relative Resource Name of the resource, which is the URI path of the resource without the leading "/". Examples are "projects/_/buckets/[BUCKET-ID]" for storage buckets or "projects/[PROJECT-ID]/global/firewalls/[FIREWALL-ID]" for a firewall. This field is required for evaluating conditions with rules on resource names. For a list permission check, the resource.name value must be set to the parent resource. If the parent resource is a project, this field should be left unset. Corresponds to the JSON property name

Returns:

  • (String)


766
767
768
# File 'generated/google/apis/iap_v1/classes.rb', line 766

def name
  @name
end

#serviceString

The name of the service this resource belongs to. It is configured using the official_service_name of the Service as defined in service configurations under //configs/cloud/resourcetypes. For example, the official_service_name of cloud resource manager service is set as 'cloudresourcemanager.googleapis.com' according to //configs/cloud/resourcetypes/google/cloud/resourcemanager/prod. yaml Corresponds to the JSON property service

Returns:

  • (String)


776
777
778
# File 'generated/google/apis/iap_v1/classes.rb', line 776

def service
  @service
end

#typeString

The public resource type name of the resource on which conditions will be evaluated. It is configured using the official_name of the ResourceType as defined in service configurations under //configs/cloud/resourcetypes. For example, the official_name for GCP projects is set as 'cloudresourcemanager. googleapis.com/Project' according to //configs/cloud/resourcetypes/google/ cloud/resourcemanager/prod.yaml For details see go/iam-conditions-integration- guide. Corresponds to the JSON property type

Returns:

  • (String)


787
788
789
# File 'generated/google/apis/iap_v1/classes.rb', line 787

def type
  @type
end

Instance Method Details

#update!(**args) ⇒ Object

Update properties of this object



794
795
796
797
798
799
# File 'generated/google/apis/iap_v1/classes.rb', line 794

def update!(**args)
  @labels = args[:labels] if args.key?(:labels)
  @name = args[:name] if args.key?(:name)
  @service = args[:service] if args.key?(:service)
  @type = args[:type] if args.key?(:type)
end