Sha256: 29b7ca6fd33f8b501cd1d313c925530be40c9dd7882e6ea45955f6b6a38a4db0
Contents?: true
Size: 1.16 KB
Versions: 1
Compression:
Stored size: 1.16 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 # # Returns a string def encrypt(value) aes.encrypt aes.key = key Base64::encode64("#{aes.random_iv}#{SEPARATOR}#{aes.update(value.to_s) + aes.final}") end # Public: Decrypt a string # # Returns a string def decrypt(value) 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
1 entries across 1 versions & 1 rubygems
Version | Path |
---|---|
crypt_keeper-0.9.0.pre | lib/crypt_keeper/provider/aes.rb |