Fix decryption IV
This commit is contained in:
+1
-1
@@ -15,7 +15,7 @@ module Encryption
|
||||
aes = OpenSSL::Cipher.new(cipher_type)
|
||||
aes.decrypt
|
||||
aes.key = key[0..31]
|
||||
aes.iv = iv[0.15] if iv != nil
|
||||
aes.iv = iv[0..15] if iv != nil
|
||||
decoded = Base64.strict_decode64("#{val}")
|
||||
aes.update("#{decoded}") + aes.final
|
||||
end
|
||||
|
||||
@@ -0,0 +1,24 @@
|
||||
# frozen_string_literal: true
|
||||
require "spec_helper"
|
||||
require_relative "../../lib/encryption"
|
||||
|
||||
describe Encryption do
|
||||
let(:value) {
|
||||
allow(Encryption).to receive(:key).and_return(SecureRandom.bytes(32))
|
||||
allow(Encryption).to receive(:iv).and_return(SecureRandom.bytes(16))
|
||||
|
||||
"OMG PII"
|
||||
}
|
||||
|
||||
it "encrypts values" do
|
||||
encrypted = Encryption.encrypt_sensitive_value(value)
|
||||
expect(Base64.decode64(encrypted)).not_to eq(value)
|
||||
end
|
||||
|
||||
it "decrypts values" do
|
||||
encrypted = Encryption.encrypt_sensitive_value(value)
|
||||
decrypted = Encryption.decrypt_sensitive_value(encrypted)
|
||||
|
||||
expect(decrypted).to eq(value)
|
||||
end
|
||||
end
|
||||
Reference in New Issue
Block a user