Class: Google::Apis::ComputeAlpha::Rule

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

Overview

A rule to be applied in a Policy.

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) ⇒ Rule

Returns a new instance of Rule



19734
19735
19736
# File 'generated/google/apis/compute_alpha/classes.rb', line 19734

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

Instance Attribute Details

#actionString

Required Corresponds to the JSON property action

Returns:

  • (String)


19696
19697
19698
# File 'generated/google/apis/compute_alpha/classes.rb', line 19696

def action
  @action
end

#conditionsArray<Google::Apis::ComputeAlpha::Condition>

Additional restrictions that must be met. All conditions must pass for the rule to match. Corresponds to the JSON property conditions



19702
19703
19704
# File 'generated/google/apis/compute_alpha/classes.rb', line 19702

def conditions
  @conditions
end

#descriptionString

Human-readable description of the rule. Corresponds to the JSON property description

Returns:

  • (String)


19707
19708
19709
# File 'generated/google/apis/compute_alpha/classes.rb', line 19707

def description
  @description
end

#insArray<String>

If one or more 'in' clauses are specified, the rule matches if the PRINCIPAL/ AUTHORITY_SELECTOR is in at least one of these entries. Corresponds to the JSON property ins

Returns:

  • (Array<String>)


19713
19714
19715
# File 'generated/google/apis/compute_alpha/classes.rb', line 19713

def ins
  @ins
end

#log_configsArray<Google::Apis::ComputeAlpha::LogConfig>

The config returned to callers of tech.iam.IAM.CheckPolicy for any entries that match the LOG action. Corresponds to the JSON property logConfigs



19719
19720
19721
# File 'generated/google/apis/compute_alpha/classes.rb', line 19719

def log_configs
  @log_configs
end

#not_insArray<String>

If one or more 'not_in' clauses are specified, the rule matches if the PRINCIPAL/AUTHORITY_SELECTOR is in none of the entries. Corresponds to the JSON property notIns

Returns:

  • (Array<String>)


19725
19726
19727
# File 'generated/google/apis/compute_alpha/classes.rb', line 19725

def not_ins
  @not_ins
end

#permissionsArray<String>

A permission is a string of form '..' (e.g., 'storage.buckets.list'). A value of '' matches all permissions, and a verb part of '' (e.g., 'storage.buckets. *') matches all verbs. Corresponds to the JSON property permissions

Returns:

  • (Array<String>)


19732
19733
19734
# File 'generated/google/apis/compute_alpha/classes.rb', line 19732

def permissions
  @permissions
end

Instance Method Details

#update!(**args) ⇒ Object

Update properties of this object



19739
19740
19741
19742
19743
19744
19745
19746
19747
# File 'generated/google/apis/compute_alpha/classes.rb', line 19739

def update!(**args)
  @action = args[:action] if args.key?(:action)
  @conditions = args[:conditions] if args.key?(:conditions)
  @description = args[:description] if args.key?(:description)
  @ins = args[:ins] if args.key?(:ins)
  @log_configs = args[:log_configs] if args.key?(:log_configs)
  @not_ins = args[:not_ins] if args.key?(:not_ins)
  @permissions = args[:permissions] if args.key?(:permissions)
end