Sha256: 73093963be6d13f033c17b7b746e08f2fae6553651dc0feb220f47482a3220f6
Contents?: true
Size: 1.59 KB
Versions: 5
Compression:
Stored size: 1.59 KB
Contents
require 'digest/sha2' require 'openssl' require 'base64' module CryptKeeper module Provider class Aes SEPARATOR = ":crypt_keeper:" # Public: The encryption key attr_accessor :key # Public: An instance of OpenSSL::Cipher::Cipher attr_accessor :aes # Public: Initializes the class # # options - A hash of options. :key is required def initialize(options = {}) @aes = ::OpenSSL::Cipher::Cipher.new("AES-256-CBC") @aes.padding = 1 key = options.fetch(:key) do raise ArgumentError, "Missing :key" end @key = Digest::SHA256.digest(key) end # Public: Encrypt a string # # Note: nil and empty strings are not encryptable with AES. # When they are encountered, the orignal value is returned. # Otherwise, returns the encrypted string def encrypt(value) return value if value == '' || value.nil? aes.encrypt aes.key = key Base64::encode64("#{aes.random_iv}#{SEPARATOR}#{aes.update(value.to_s) + aes.final}") end # Public: Decrypt a string # # Note: nil and empty strings are not encryptable with AES (and thus cannot be decrypted). # When they are encountered, the orignal value is returned. # Otherwise, returns the decrypted string def decrypt(value) return value if value == '' || value.nil? iv, value = Base64::decode64(value.to_s).split(SEPARATOR) aes.decrypt aes.key = key aes.iv = iv aes.update(value) + aes.final end end end end
Version data entries
5 entries across 5 versions & 1 rubygems