Class: Google::Apis::SpannerV1::RestoreDatabaseEncryptionConfig

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

Overview

Encryption configuration for the restored database.

Instance Attribute Summary collapse

Instance Method Summary collapse

Constructor Details

#initialize(**args) ⇒ RestoreDatabaseEncryptionConfig

Returns a new instance of RestoreDatabaseEncryptionConfig.



6031
6032
6033
# File 'lib/google/apis/spanner_v1/classes.rb', line 6031

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

Instance Attribute Details

#encryption_typeString

Required. The encryption type of the restored database. Corresponds to the JSON property encryptionType

Returns:

  • (String)


6001
6002
6003
# File 'lib/google/apis/spanner_v1/classes.rb', line 6001

def encryption_type
  @encryption_type
end

#kms_key_nameString

Optional. This field is maintained for backwards compatibility. For new callers, we recommend using kms_key_names to specify the KMS key. Only use kms_key_name if the location of the KMS key matches the database instance's configuration (location) exactly. For example, if the KMS location is in us- central1 or nam3, then the database instance must also be in us-central1 or nam3. The Cloud KMS key that is used to encrypt and decrypt the restored database. Set this field only when encryption_type is CUSTOMER_MANAGED_ENCRYPTION. Values are of the form projects//locations// keyRings//cryptoKeys/. Corresponds to the JSON property kmsKeyName

Returns:

  • (String)


6014
6015
6016
# File 'lib/google/apis/spanner_v1/classes.rb', line 6014

def kms_key_name
  @kms_key_name
end

#kms_key_namesArray<String>

Optional. Specifies the KMS configuration for one or more keys used to encrypt the database. Values have the form projects//locations//keyRings//cryptoKeys/ . The keys referenced by kms_key_names must fully cover all regions of the database's instance configuration. Some examples: * For regional (single- region) instance configurations, specify a regional location KMS key. * For multi-region instance configurations of type GOOGLE_MANAGED, either specify a multi-region location KMS key or multiple regional location KMS keys that cover all regions in the instance configuration. * For an instance configuration of type USER_MANAGED, specify only regional location KMS keys to cover each region in the instance configuration. Multi-region location KMS keys aren't supported for USER_MANAGED type instance configurations. Corresponds to the JSON property kmsKeyNames

Returns:

  • (Array<String>)


6029
6030
6031
# File 'lib/google/apis/spanner_v1/classes.rb', line 6029

def kms_key_names
  @kms_key_names
end

Instance Method Details

#update!(**args) ⇒ Object

Update properties of this object



6036
6037
6038
6039
6040
# File 'lib/google/apis/spanner_v1/classes.rb', line 6036

def update!(**args)
  @encryption_type = args[:encryption_type] if args.key?(:encryption_type)
  @kms_key_name = args[:kms_key_name] if args.key?(:kms_key_name)
  @kms_key_names = args[:kms_key_names] if args.key?(:kms_key_names)
end