ccipher_factory 0.1.0
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +7 -0
- data/.rspec +3 -0
- data/Gemfile +30 -0
- data/Gemfile.lock-java +65 -0
- data/Gemfile.lock-ruby +67 -0
- data/README.md +80 -0
- data/Rakefile +10 -0
- data/bin/console +15 -0
- data/bin/setup +8 -0
- data/ccipher_factory.gemspec +46 -0
- data/lib/ccipher_factory/asymkey/asymkey.rb +16 -0
- data/lib/ccipher_factory/asymkey/asymkey_generator.rb +87 -0
- data/lib/ccipher_factory/asymkey/ecc_keypair.rb +56 -0
- data/lib/ccipher_factory/asymkey_cipher/asymkey_cipher.rb +63 -0
- data/lib/ccipher_factory/asymkey_cipher/asymkey_signer.rb +44 -0
- data/lib/ccipher_factory/asymkey_cipher/ecc/ecc_att_decrypt.rb +55 -0
- data/lib/ccipher_factory/asymkey_cipher/ecc/ecc_att_encrypt.rb +70 -0
- data/lib/ccipher_factory/asymkey_cipher/ecc/ecc_att_signer.rb +88 -0
- data/lib/ccipher_factory/asymkey_cipher/ecc/ecc_att_verifier.rb +100 -0
- data/lib/ccipher_factory/asymkey_cipher/ecc/ecc_decrypt.rb +80 -0
- data/lib/ccipher_factory/asymkey_cipher/ecc/ecc_encrypt.rb +101 -0
- data/lib/ccipher_factory/asymkey_cipher/ecc/ecc_signer.rb +80 -0
- data/lib/ccipher_factory/asymkey_cipher/ecc/ecc_verifier.rb +56 -0
- data/lib/ccipher_factory/composite_cipher/composite_cipher.rb +28 -0
- data/lib/ccipher_factory/composite_cipher/decrypt_verifier.rb +116 -0
- data/lib/ccipher_factory/composite_cipher/sign_encryptor.rb +100 -0
- data/lib/ccipher_factory/compression/compression_helper.rb +103 -0
- data/lib/ccipher_factory/compression/compressor.rb +55 -0
- data/lib/ccipher_factory/compression/zlib_compressor.rb +48 -0
- data/lib/ccipher_factory/compression/zlib_decompressor.rb +67 -0
- data/lib/ccipher_factory/digest/digest.rb +180 -0
- data/lib/ccipher_factory/digest/supported_digest.rb +47 -0
- data/lib/ccipher_factory/encoding/asn1.rb +43 -0
- data/lib/ccipher_factory/encoding/bin_struct.rb +207 -0
- data/lib/ccipher_factory/encoding/binenc_constant.rb +149 -0
- data/lib/ccipher_factory/helpers/common.rb +124 -0
- data/lib/ccipher_factory/kcv/kcv.rb +89 -0
- data/lib/ccipher_factory/kdf/hkdf.rb +114 -0
- data/lib/ccipher_factory/kdf/kdf.rb +73 -0
- data/lib/ccipher_factory/kdf/pbkdf2.rb +82 -0
- data/lib/ccipher_factory/kdf/scrypt.rb +105 -0
- data/lib/ccipher_factory/shamir/shamir_sharing.rb +293 -0
- data/lib/ccipher_factory/shamir/shamir_sharing_helper.rb +88 -0
- data/lib/ccipher_factory/symkey/derived_symkey.rb +110 -0
- data/lib/ccipher_factory/symkey/hardware_symkey.rb +0 -0
- data/lib/ccipher_factory/symkey/soft_symkey.rb +63 -0
- data/lib/ccipher_factory/symkey/symkey.rb +122 -0
- data/lib/ccipher_factory/symkey/symkey_generator.rb +70 -0
- data/lib/ccipher_factory/symkey_cipher/symkey_att_decrypt.rb +64 -0
- data/lib/ccipher_factory/symkey_cipher/symkey_att_encrypt.rb +65 -0
- data/lib/ccipher_factory/symkey_cipher/symkey_att_sign.rb +84 -0
- data/lib/ccipher_factory/symkey_cipher/symkey_att_verify.rb +85 -0
- data/lib/ccipher_factory/symkey_cipher/symkey_cipher.rb +101 -0
- data/lib/ccipher_factory/symkey_cipher/symkey_decrypt.rb +144 -0
- data/lib/ccipher_factory/symkey_cipher/symkey_encrypt.rb +164 -0
- data/lib/ccipher_factory/symkey_cipher/symkey_sign.rb +70 -0
- data/lib/ccipher_factory/symkey_cipher/symkey_signer.rb +59 -0
- data/lib/ccipher_factory/symkey_cipher/symkey_verify.rb +76 -0
- data/lib/ccipher_factory/version.rb +5 -0
- data/lib/ccipher_factory.rb +52 -0
- data/run_test.rb +27 -0
- metadata +172 -0
@@ -0,0 +1,70 @@
|
|
1
|
+
|
2
|
+
|
3
|
+
module CcipherFactory
|
4
|
+
module AsymKeyCipher
|
5
|
+
module ECCAttEncrypt
|
6
|
+
include Common
|
7
|
+
include TR::CondUtils
|
8
|
+
include Compression::CompressionHelper
|
9
|
+
|
10
|
+
attr_accessor :recipient_key, :sender_keypair
|
11
|
+
|
12
|
+
def att_encrypt_init(opts = { }, &block)
|
13
|
+
|
14
|
+
@enc = AsymKeyCipher.encryptor(:ecc)
|
15
|
+
@enc.output(intOutputFile)
|
16
|
+
|
17
|
+
if is_compression_on?
|
18
|
+
logger.tdebug :ecc_att_enc, "Compression on"
|
19
|
+
@enc.compression_on
|
20
|
+
else
|
21
|
+
logger.tdebug :ecc_att_enc, "Compression off"
|
22
|
+
@enc.compression_off
|
23
|
+
end
|
24
|
+
|
25
|
+
@enc.recipient_key = @recipient_key
|
26
|
+
@enc.sender_keypair = @sender_keypair
|
27
|
+
|
28
|
+
@enc.encrypt_init(opts)
|
29
|
+
|
30
|
+
if block
|
31
|
+
instance_eval(&block)
|
32
|
+
att_encrypt_final
|
33
|
+
else
|
34
|
+
self
|
35
|
+
end
|
36
|
+
|
37
|
+
end
|
38
|
+
|
39
|
+
def att_encrypt_update(val)
|
40
|
+
raise ECCCipherError, "Output is required for encryption" if not is_output_given?
|
41
|
+
@enc.encrypt_update(val)
|
42
|
+
end
|
43
|
+
|
44
|
+
def att_encrypt_final
|
45
|
+
|
46
|
+
ts = @enc.encrypt_final
|
47
|
+
|
48
|
+
write_to_output(ts)
|
49
|
+
|
50
|
+
intOutputFile.rewind
|
51
|
+
while not intOutputFile.eof?
|
52
|
+
write_to_output(intOutputFile.read)
|
53
|
+
end
|
54
|
+
|
55
|
+
intOutputFile.close!
|
56
|
+
|
57
|
+
@output
|
58
|
+
|
59
|
+
end
|
60
|
+
|
61
|
+
def logger
|
62
|
+
if @logger.nil?
|
63
|
+
@logger = Tlogger.new
|
64
|
+
end
|
65
|
+
@logger
|
66
|
+
end
|
67
|
+
|
68
|
+
end
|
69
|
+
end
|
70
|
+
end
|
@@ -0,0 +1,88 @@
|
|
1
|
+
|
2
|
+
|
3
|
+
|
4
|
+
|
5
|
+
module CcipherFactory
|
6
|
+
module AsymKeySigner
|
7
|
+
|
8
|
+
module ECCAttSigner
|
9
|
+
include Common
|
10
|
+
include Compression::CompressionHelper
|
11
|
+
|
12
|
+
attr_accessor :signing_key
|
13
|
+
def att_sign_init(*args, &block)
|
14
|
+
|
15
|
+
@signer = AsymKeySigner.signer
|
16
|
+
@signer.signing_key = @signing_key
|
17
|
+
|
18
|
+
@signer.sign_init(*args)
|
19
|
+
|
20
|
+
@totalPlain = 0
|
21
|
+
@totalCompressed = 0
|
22
|
+
|
23
|
+
if block
|
24
|
+
instance_eval(&block)
|
25
|
+
att_sign_final
|
26
|
+
else
|
27
|
+
self
|
28
|
+
end
|
29
|
+
|
30
|
+
end
|
31
|
+
|
32
|
+
def att_sign_update(val)
|
33
|
+
|
34
|
+
raise ECCSignerError, "Output is required for attached sign with ECC" if not is_output_given?
|
35
|
+
|
36
|
+
@totalPlain += val.length
|
37
|
+
@signer.sign_update(val)
|
38
|
+
res = compress_data_if_active(val)
|
39
|
+
intOutputFile.write(res)
|
40
|
+
@totalCompressed += res.length
|
41
|
+
|
42
|
+
res
|
43
|
+
|
44
|
+
end
|
45
|
+
|
46
|
+
def att_sign_final
|
47
|
+
meta = @signer.sign_final
|
48
|
+
|
49
|
+
#ts = Encoding::ASN1Encoder.instance(:ecc_att_sign)
|
50
|
+
ts = BinStruct.instance.struct(:ecc_att_sign)
|
51
|
+
ts.ecc_signature = meta
|
52
|
+
|
53
|
+
#ts.set(:ecc_signature, meta)
|
54
|
+
if is_compression_on?
|
55
|
+
#ts.set(:compression, compressor.compress_final)
|
56
|
+
ts.compression = compressor.compress_final
|
57
|
+
else
|
58
|
+
#ts.set(:compression, encode_null_compressor)
|
59
|
+
ts.compression = encode_null_compressor
|
60
|
+
end
|
61
|
+
|
62
|
+
smeta = ts.encoded
|
63
|
+
write_to_output(smeta)
|
64
|
+
|
65
|
+
intOutputFile.rewind
|
66
|
+
while not intOutputFile.eof?
|
67
|
+
write_to_output(intOutputFile.read)
|
68
|
+
end
|
69
|
+
|
70
|
+
disposeOutput(intOutputFile)
|
71
|
+
|
72
|
+
logger.tdebug :ecc_att_sign, "Total Plain : #{@totalPlain} / Total Compressed : #{@totalCompressed} = #{(@totalCompressed*1.0)/@totalPlain*100} %" if is_compression_on?
|
73
|
+
|
74
|
+
smeta
|
75
|
+
|
76
|
+
end
|
77
|
+
|
78
|
+
def logger
|
79
|
+
if @logger.nil?
|
80
|
+
@logger = Tlogger.new
|
81
|
+
end
|
82
|
+
@logger
|
83
|
+
end
|
84
|
+
|
85
|
+
end
|
86
|
+
|
87
|
+
end
|
88
|
+
end
|
@@ -0,0 +1,100 @@
|
|
1
|
+
|
2
|
+
|
3
|
+
|
4
|
+
module CcipherFactory
|
5
|
+
module AsymKeySigner
|
6
|
+
|
7
|
+
module ECCAttVerifier
|
8
|
+
include Common
|
9
|
+
include Compression::CompressionHelper
|
10
|
+
|
11
|
+
def embedded_signer
|
12
|
+
if not_empty?(@ver)
|
13
|
+
@ver.embedded_signer
|
14
|
+
else
|
15
|
+
nil
|
16
|
+
end
|
17
|
+
end
|
18
|
+
|
19
|
+
def att_verify_init(*args, &block)
|
20
|
+
|
21
|
+
@params = args
|
22
|
+
|
23
|
+
if block
|
24
|
+
instance_eval(&block)
|
25
|
+
att_verify_final
|
26
|
+
else
|
27
|
+
self
|
28
|
+
end
|
29
|
+
|
30
|
+
end
|
31
|
+
|
32
|
+
def att_verify_update(val)
|
33
|
+
|
34
|
+
if @ver.nil?
|
35
|
+
|
36
|
+
intOutputBuf.write(val)
|
37
|
+
begin
|
38
|
+
Encoding.extract_meta(intOutputBuf) do |meta, bal|
|
39
|
+
|
40
|
+
ts = BinStruct.instance.struct_from_bin(meta)
|
41
|
+
smeta = ts.ecc_signature
|
42
|
+
compression = ts.compression
|
43
|
+
|
44
|
+
decompressor_from_encoded(compression)
|
45
|
+
if is_compression_on?
|
46
|
+
logger.tdebug :ecc_att_ver, "Compression on"
|
47
|
+
else
|
48
|
+
logger.tdebug :ecc_att_ver, "No compression"
|
49
|
+
end
|
50
|
+
|
51
|
+
@ver = AsymKeySigner.verifier
|
52
|
+
@ver.output(@output) if is_output_given?
|
53
|
+
|
54
|
+
@ver.verify_init(*@params)
|
55
|
+
@ver.verify_update_meta(smeta)
|
56
|
+
|
57
|
+
att_verify_update(bal) if bal.length > 0
|
58
|
+
|
59
|
+
disposeOutput(intOutputBuf)
|
60
|
+
|
61
|
+
end
|
62
|
+
rescue Encoding::InsufficientData
|
63
|
+
end
|
64
|
+
|
65
|
+
else
|
66
|
+
logger.tdebug :ecc_att_ver, "Compressed size : #{val.length}" if is_compression_on?
|
67
|
+
res = decompress_data_if_active(val)
|
68
|
+
@ver.verify_update_data(res)
|
69
|
+
intOutputFile.write(res)
|
70
|
+
end
|
71
|
+
|
72
|
+
end
|
73
|
+
|
74
|
+
def att_verify_final
|
75
|
+
|
76
|
+
res = @ver.verify_final
|
77
|
+
|
78
|
+
if is_output_given?
|
79
|
+
intOutputFile.rewind
|
80
|
+
while not intOutputFile.eof?
|
81
|
+
write_to_output(intOutputFile.read)
|
82
|
+
end
|
83
|
+
end
|
84
|
+
|
85
|
+
disposeOutput(intOutputFile)
|
86
|
+
res
|
87
|
+
|
88
|
+
end
|
89
|
+
|
90
|
+
def logger
|
91
|
+
if @logger.nil?
|
92
|
+
@logger = Tlogger.new
|
93
|
+
end
|
94
|
+
@logger
|
95
|
+
end
|
96
|
+
|
97
|
+
end
|
98
|
+
|
99
|
+
end
|
100
|
+
end
|
@@ -0,0 +1,80 @@
|
|
1
|
+
|
2
|
+
|
3
|
+
require_relative '../../symkey_cipher/symkey_cipher'
|
4
|
+
require_relative '../../kdf/kdf'
|
5
|
+
require_relative '../../asymkey/ecc_keypair'
|
6
|
+
|
7
|
+
module CcipherFactory
|
8
|
+
module AsymKeyCipher
|
9
|
+
module ECCDecrypt
|
10
|
+
include TR::CondUtils
|
11
|
+
include Common
|
12
|
+
|
13
|
+
class ECCCipherError < AsymKeyCipherError; end
|
14
|
+
|
15
|
+
attr_accessor :decryption_key
|
16
|
+
def decrypt_init(opts = { }, &block)
|
17
|
+
|
18
|
+
#raise ECCCipherError, "Decryption keypair is mandatory" if is_empty?(eccKeypair)
|
19
|
+
|
20
|
+
#@eccKeypair = eccKeypair
|
21
|
+
|
22
|
+
if block
|
23
|
+
instance_eval(&block)
|
24
|
+
decrypt_final
|
25
|
+
else
|
26
|
+
self
|
27
|
+
end
|
28
|
+
|
29
|
+
end
|
30
|
+
|
31
|
+
def decrypt_update_meta(meta)
|
32
|
+
|
33
|
+
raise ECCCipherError, "Output is required" if not is_output_given?
|
34
|
+
|
35
|
+
ts = BinStruct.instance.struct_from_bin(meta)
|
36
|
+
senderPub = ts.sender_public
|
37
|
+
cipherConf = ts.cipher_config
|
38
|
+
keyConf = ts.key_config
|
39
|
+
|
40
|
+
sender = Ccrypto::AlgoFactory.engine(Ccrypto::ECCPublicKey).to_key(senderPub)
|
41
|
+
derived = @decryption_key.derive_dh_shared_secret(sender)
|
42
|
+
|
43
|
+
sessKey = DerivedSymKey.from_encoded(keyConf) do |ops|
|
44
|
+
case ops
|
45
|
+
when :password
|
46
|
+
derived
|
47
|
+
end
|
48
|
+
end
|
49
|
+
|
50
|
+
@cipher = SymKeyCipher.decryptor
|
51
|
+
@cipher.output(@output)
|
52
|
+
@cipher.key = sessKey
|
53
|
+
@cipher.decrypt_init
|
54
|
+
@cipher.decrypt_update_meta(cipherConf)
|
55
|
+
|
56
|
+
end
|
57
|
+
|
58
|
+
def decrypt_update_cipher(cipher)
|
59
|
+
raise ECCCipherError, "Please update meta first before update cipher" if is_empty?(@cipher)
|
60
|
+
|
61
|
+
@cipher.decrypt_update_cipher(cipher)
|
62
|
+
end
|
63
|
+
|
64
|
+
def decrypt_final
|
65
|
+
|
66
|
+
@cipher.decrypt_final
|
67
|
+
|
68
|
+
end
|
69
|
+
|
70
|
+
def logger
|
71
|
+
if @logger.nil?
|
72
|
+
@logger = Tlogger.new
|
73
|
+
@logger.tag = :ecc_dec
|
74
|
+
end
|
75
|
+
@logger
|
76
|
+
end
|
77
|
+
|
78
|
+
end
|
79
|
+
end
|
80
|
+
end
|
@@ -0,0 +1,101 @@
|
|
1
|
+
|
2
|
+
require_relative '../../symkey_cipher/symkey_cipher'
|
3
|
+
require_relative '../../kdf/kdf'
|
4
|
+
|
5
|
+
require_relative '../../asymkey/asymkey_generator'
|
6
|
+
require_relative '../../compression/compression_helper'
|
7
|
+
|
8
|
+
module CcipherFactory
|
9
|
+
module AsymKeyCipher
|
10
|
+
module ECCEncrypt
|
11
|
+
include TR::CondUtils
|
12
|
+
include Common
|
13
|
+
include Compression::CompressionHelper
|
14
|
+
|
15
|
+
class ECCCipherError < AsymKeyCipher::AsymKeyCipherError; end
|
16
|
+
|
17
|
+
attr_accessor :recipient_key, :sender_keypair
|
18
|
+
|
19
|
+
def encrypt_init(opts = { }, &block)
|
20
|
+
|
21
|
+
#@sender = opts[:sender_keypair]
|
22
|
+
#recpPub = opts[:recipient_public]
|
23
|
+
recpPub = @recipient_key
|
24
|
+
|
25
|
+
raise ECCCipherError, "Receipient public key is required" if is_empty?(recpPub)
|
26
|
+
raise ECCCipherError, "Cipher requires output to be set" if not is_output_given?
|
27
|
+
raise ECCCipherError, "Sender Keypair is required" if is_empty?(@sender_keypair)
|
28
|
+
|
29
|
+
#if is_empty?(@sender_keypair)
|
30
|
+
# @sender_keypair = AsymKeyGenerator.generate(:ecc)
|
31
|
+
#end
|
32
|
+
|
33
|
+
#derived = @sender_keypair.dh_compute_key(recpPub)
|
34
|
+
#logger.debug "sender : #{@sender_keypair.inspect} / #{@sender_keypair.private?}"
|
35
|
+
#logger.debug "recp : #{recpPub.inspect}"
|
36
|
+
derived = @sender_keypair.derive_dh_shared_secret(recpPub)
|
37
|
+
|
38
|
+
@sessKey = SymKeyGenerator.derive(:aes, 256) do |ops|
|
39
|
+
case ops
|
40
|
+
when :password
|
41
|
+
derived
|
42
|
+
end
|
43
|
+
end
|
44
|
+
|
45
|
+
@cipher = SymKeyCipher.encryptor
|
46
|
+
@cipher.output(intOutputFile)
|
47
|
+
@cipher.key = @sessKey
|
48
|
+
|
49
|
+
if is_compression_on?
|
50
|
+
logger.debug "Turning on compression"
|
51
|
+
@cipher.compression_on
|
52
|
+
else
|
53
|
+
logger.debug "Compression not active"
|
54
|
+
@cipher.compression_off
|
55
|
+
end
|
56
|
+
|
57
|
+
@cipher.encrypt_init
|
58
|
+
|
59
|
+
if block
|
60
|
+
instance_eval(&block)
|
61
|
+
encrypt_final
|
62
|
+
else
|
63
|
+
self
|
64
|
+
end
|
65
|
+
|
66
|
+
end
|
67
|
+
|
68
|
+
def encrypt_update(val)
|
69
|
+
@cipher.encrypt_update(val)
|
70
|
+
end
|
71
|
+
|
72
|
+
def encrypt_final
|
73
|
+
|
74
|
+
cipherConfig = @cipher.encrypt_final
|
75
|
+
|
76
|
+
intOutputFile.rewind
|
77
|
+
while not intOutputFile.eof?
|
78
|
+
write_to_output(intOutputFile.read)
|
79
|
+
end
|
80
|
+
cleanup_intOutputFile
|
81
|
+
|
82
|
+
pkBin = @sender_keypair.public_key.to_bin
|
83
|
+
ts = BinStruct.instance.struct(:ecc_cipher)
|
84
|
+
ts.sender_public = @sender_keypair.public_key.to_bin
|
85
|
+
ts.cipher_config = cipherConfig
|
86
|
+
ts.key_config = @sessKey.encoded
|
87
|
+
ts.encoded
|
88
|
+
|
89
|
+
end
|
90
|
+
|
91
|
+
def logger
|
92
|
+
if @logger.nil?
|
93
|
+
@logger = Tlogger.new
|
94
|
+
@logger.tag = :ecc_enc
|
95
|
+
end
|
96
|
+
@logger
|
97
|
+
end
|
98
|
+
|
99
|
+
end
|
100
|
+
end
|
101
|
+
end
|
@@ -0,0 +1,80 @@
|
|
1
|
+
|
2
|
+
require_relative '../../digest/digest'
|
3
|
+
require_relative '../../compression/compressor'
|
4
|
+
|
5
|
+
module CcipherFactory
|
6
|
+
module AsymKeySigner
|
7
|
+
module ECCSigner
|
8
|
+
include TR::CondUtils
|
9
|
+
include Common
|
10
|
+
|
11
|
+
class ECCSignerError < AsymKeySignerError; end
|
12
|
+
|
13
|
+
attr_accessor :signing_key
|
14
|
+
|
15
|
+
def compression_on
|
16
|
+
@compress = true
|
17
|
+
end
|
18
|
+
|
19
|
+
def compression_off
|
20
|
+
@compress = false
|
21
|
+
end
|
22
|
+
|
23
|
+
def sign_init(opts = { }, &block)
|
24
|
+
|
25
|
+
raise ECCSignerError, "Signer must be given" if is_empty?(@signing_key)
|
26
|
+
|
27
|
+
@digest = Digest.instance
|
28
|
+
@digest.output(intOutputBuf)
|
29
|
+
@digest.digest_init
|
30
|
+
|
31
|
+
if @compress
|
32
|
+
logger.tdebug :asymkey_enc, "Compression on"
|
33
|
+
@compressor = CcipherFactory::Compression::Compressor.new
|
34
|
+
@compressor.compress
|
35
|
+
@compressor.compress_init
|
36
|
+
else
|
37
|
+
logger.tdebug :asymkey_enc, "Compression off"
|
38
|
+
end
|
39
|
+
|
40
|
+
|
41
|
+
if block
|
42
|
+
instance_eval(&block)
|
43
|
+
sign_final
|
44
|
+
else
|
45
|
+
self
|
46
|
+
end
|
47
|
+
|
48
|
+
end
|
49
|
+
|
50
|
+
def sign_update(val)
|
51
|
+
@digest.digest_update(val)
|
52
|
+
end
|
53
|
+
|
54
|
+
def sign_final
|
55
|
+
dig = @digest.digest_final
|
56
|
+
|
57
|
+
eccConf = Ccrypto::ECCConfig.new
|
58
|
+
eccConf.keypair = @signing_key.keypair
|
59
|
+
eccEng = Ccrypto::AlgoFactory.engine(eccConf)
|
60
|
+
sign = eccEng.sign(intOutputBuf.bytes)
|
61
|
+
|
62
|
+
ts = BinStruct.instance.struct(:ecc_signature)
|
63
|
+
ts.digest_info = dig
|
64
|
+
ts.signer_info = @signing_key.to_signer_info
|
65
|
+
ts.signature = sign
|
66
|
+
ts.encoded
|
67
|
+
|
68
|
+
end
|
69
|
+
|
70
|
+
def logger
|
71
|
+
if @logger.nil?
|
72
|
+
@logger = Tlogger.new
|
73
|
+
end
|
74
|
+
@logger
|
75
|
+
end
|
76
|
+
|
77
|
+
|
78
|
+
end
|
79
|
+
end
|
80
|
+
end
|
@@ -0,0 +1,56 @@
|
|
1
|
+
|
2
|
+
require_relative '../../asymkey/ecc_keypair'
|
3
|
+
|
4
|
+
module CcipherFactory
|
5
|
+
module AsymKeySigner
|
6
|
+
module ECCVerifier
|
7
|
+
include Common
|
8
|
+
|
9
|
+
attr_accessor :verification_key
|
10
|
+
attr_reader :embedded_signer
|
11
|
+
def verify_init(*args, &block)
|
12
|
+
|
13
|
+
if block
|
14
|
+
instance_eval(&block)
|
15
|
+
verify_final
|
16
|
+
else
|
17
|
+
self
|
18
|
+
end
|
19
|
+
|
20
|
+
end
|
21
|
+
|
22
|
+
def verify_update_meta(meta)
|
23
|
+
|
24
|
+
ts = BinStruct.instance.struct_from_bin(meta)
|
25
|
+
digInfo = ts.digest_info
|
26
|
+
sigInfo = ts.signer_info
|
27
|
+
@sign = ts.signature
|
28
|
+
|
29
|
+
@digest = Digest.from_encoded(digInfo)
|
30
|
+
@digest.output(intOutputBuf)
|
31
|
+
|
32
|
+
@signer = KeyPair::ECCKeyPair.from_signer_info(sigInfo)
|
33
|
+
@embedded_signer = @signer
|
34
|
+
|
35
|
+
end
|
36
|
+
|
37
|
+
def verify_update_data(data)
|
38
|
+
@digest.digest_update(data)
|
39
|
+
end
|
40
|
+
|
41
|
+
def verify_final
|
42
|
+
|
43
|
+
@digest.digest_final
|
44
|
+
|
45
|
+
res = Ccrypto::AlgoFactory.engine(Ccrypto::ECCConfig).verify(@signer, intOutputBuf.bytes, @sign)
|
46
|
+
|
47
|
+
#res = @signer.dsa_verify_asn1(intOutputBuf.string, @sign)
|
48
|
+
|
49
|
+
res
|
50
|
+
|
51
|
+
end
|
52
|
+
|
53
|
+
end
|
54
|
+
end
|
55
|
+
|
56
|
+
end
|
@@ -0,0 +1,28 @@
|
|
1
|
+
|
2
|
+
|
3
|
+
module CcipherFactory
|
4
|
+
module CompositeCipher
|
5
|
+
|
6
|
+
class CompositeCipherError < StandardError; end
|
7
|
+
|
8
|
+
class CompCipher; end
|
9
|
+
|
10
|
+
def self.sign_encryptor(opts = { })
|
11
|
+
cc = CompCipher.new
|
12
|
+
cc.extend(SignEncryptor)
|
13
|
+
cc
|
14
|
+
end
|
15
|
+
|
16
|
+
def self.decrypt_verifier(opts = { })
|
17
|
+
cc = CompCipher.new
|
18
|
+
cc.extend(DecryptVerifier)
|
19
|
+
cc
|
20
|
+
end
|
21
|
+
|
22
|
+
end
|
23
|
+
end
|
24
|
+
|
25
|
+
require_relative 'sign_encryptor'
|
26
|
+
require_relative 'decrypt_verifier'
|
27
|
+
|
28
|
+
|