Class: Google::Apis::SpannerV1::Rule

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

Overview

A rule to be applied in a Policy.

Instance Attribute Summary collapse

Instance Method Summary collapse

Methods included from Core::JsonObjectSupport

#to_json

Methods included from Core::Hashable

process_value, #to_h

Constructor Details

#initialize(**args) ⇒ Rule

Returns a new instance of Rule



1277
1278
1279
# File 'generated/google/apis/spanner_v1/classes.rb', line 1277

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

Instance Attribute Details

#actionString

Required Corresponds to the JSON property action

Returns:

  • (String)


1275
1276
1277
# File 'generated/google/apis/spanner_v1/classes.rb', line 1275

def action
  @action
end

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

Additional restrictions that must be met Corresponds to the JSON property conditions



1251
1252
1253
# File 'generated/google/apis/spanner_v1/classes.rb', line 1251

def conditions
  @conditions
end

#descriptionString

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

Returns:

  • (String)


1246
1247
1248
# File 'generated/google/apis/spanner_v1/classes.rb', line 1246

def description
  @description
end

#inArray<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 in

Returns:

  • (Array<String>)


1263
1264
1265
# File 'generated/google/apis/spanner_v1/classes.rb', line 1263

def in
  @in
end

#log_configArray<Google::Apis::SpannerV1::LogConfig>

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



1257
1258
1259
# File 'generated/google/apis/spanner_v1/classes.rb', line 1257

def log_config
  @log_config
end

#not_inArray<String>

If one or more 'not_in' clauses are specified, the rule matches if the PRINCIPAL/AUTHORITY_SELECTOR is in none of the entries. The format for in and not_in entries is the same as for members in a Binding (see google/iam/v1/policy.proto). Corresponds to the JSON property notIn

Returns:

  • (Array<String>)


1241
1242
1243
# File 'generated/google/apis/spanner_v1/classes.rb', line 1241

def not_in
  @not_in
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>)


1270
1271
1272
# File 'generated/google/apis/spanner_v1/classes.rb', line 1270

def permissions
  @permissions
end

Instance Method Details

#update!(**args) ⇒ Object

Update properties of this object



1282
1283
1284
1285
1286
1287
1288
1289
1290
# File 'generated/google/apis/spanner_v1/classes.rb', line 1282

def update!(**args)
  @not_in = args[:not_in] if args.key?(:not_in)
  @description = args[:description] if args.key?(:description)
  @conditions = args[:conditions] if args.key?(:conditions)
  @log_config = args[:log_config] if args.key?(:log_config)
  @in = args[:in] if args.key?(:in)
  @permissions = args[:permissions] if args.key?(:permissions)
  @action = args[:action] if args.key?(:action)
end