Top Level Namespace

Constant Summary collapse

SYMMETRIC_KEY_LENGTH =
32
BEGIN_TAG =
'""""""""'.b

Instance Method Summary collapse

Instance Method Details

#create_acrastruct(data, acra_public_key, context = nil) ⇒ Object



20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
# File 'lib/acrawriter.rb', line 20

def create_acrastruct(data, acra_public_key, context=nil)
  if data.nil? or data == ''
    return data
  end
  generator = Themis::SKeyPairGen.new
  private, public = generator.ec
  smessage = Themis::Smessage.new(private.to_s, acra_public_key.to_s)
  private.clear
  random_key = Random.new.bytes(SYMMETRIC_KEY_LENGTH)
  wrapped_random_key = smessage.wrap(random_key.to_s)
  scell = Themis::Scell.new(random_key.to_s, Themis::Scell::SEAL_MODE)
  random_key.clear
  encrypted_data = scell.encrypt(data, context)
  data_length = Array(encrypted_data.length).pack('Q<')
  BEGIN_TAG + public + wrapped_random_key + data_length + encrypted_data
end