Module: Chef::EncryptedDataBagItem::Encryptor

Defined in:
lib/chef/encrypted_data_bag_item.rb

Overview

Implementation class for converting plaintext data bag item values to an encrypted value, including any necessary wrappers and metadata.

Defined Under Namespace

Classes: Version1Encryptor, Version2Encryptor

Class Method Summary collapse

Class Method Details

.new(value, secret, iv = nil) ⇒ Object

“factory” method that creates an encryptor object with the proper class for the desired encrypted data bag format version.

Chef::Config[:data_bag_encrypt_version] determines which version is used.



73
74
75
76
77
78
79
80
81
82
83
84
# File 'lib/chef/encrypted_data_bag_item.rb', line 73

def self.new(value, secret, iv=nil)
  format_version = Chef::Config[:data_bag_encrypt_version]
  case format_version
  when 1
    Version1Encryptor.new(value, secret, iv)
  when 2
    Version2Encryptor.new(value, secret, iv)
  else
    raise UnsupportedEncryptedDataBagItemFormat,
      "Invalid encrypted data bag format version `#{format_version}'. Supported versions are '1', '2'"
  end
end