vault-tree 0.6.0 → 0.8.0
Sign up to get free protection for your applications and to get access to all the features.
- data/.gitignore +2 -0
- data/lib/vault-tree/contract/vault.rb +9 -13
- data/lib/vault-tree/contract/vault_list.rb +15 -7
- data/lib/vault-tree/lock_smith.rb +1 -1
- data/lib/vault-tree/version.rb +1 -1
- data/spec/shamir_key_shares_spec.rb +1 -1
- data/vault-tree.gemspec +1 -1
- metadata +7 -7
data/.gitignore
CHANGED
@@ -19,31 +19,23 @@ module VaultTree
|
|
19
19
|
end
|
20
20
|
|
21
21
|
def filler
|
22
|
-
|
22
|
+
interpret_keyword('fill_with')
|
23
23
|
end
|
24
24
|
|
25
25
|
def locking_key
|
26
|
-
VaultKey.new
|
26
|
+
VaultKey.new interpret_keyword('lock_with')
|
27
27
|
end
|
28
28
|
|
29
29
|
def unlocking_key
|
30
|
-
VaultKey.new
|
30
|
+
VaultKey.new interpret_keyword('unlock_with')
|
31
31
|
end
|
32
32
|
|
33
33
|
def locked_contents
|
34
|
-
|
35
|
-
already_locked? ? properties['contents'] : ciphertext(filler)
|
36
|
-
rescue RbNaCl::CryptoError => e
|
37
|
-
raise Exceptions::FailedLockAttempt.new(e, vault_id: id)
|
38
|
-
end
|
34
|
+
already_locked? ? properties['contents'] : ciphertext(filler)
|
39
35
|
end
|
40
36
|
|
41
37
|
def unlocked_contents
|
42
|
-
|
43
|
-
plaintext properties['contents']
|
44
|
-
rescue RbNaCl::CryptoError => e
|
45
|
-
raise Exceptions::FailedUnlockAttempt.new(e, vault_id: id)
|
46
|
-
end
|
38
|
+
plaintext properties['contents']
|
47
39
|
end
|
48
40
|
|
49
41
|
def ciphertext(m)
|
@@ -58,5 +50,9 @@ module VaultTree
|
|
58
50
|
! (properties['contents'].nil? || properties['contents'].empty?)
|
59
51
|
end
|
60
52
|
|
53
|
+
def interpret_keyword(prop_key)
|
54
|
+
KeywordInterpreter.new(properties[prop_key], self).evaluate
|
55
|
+
end
|
56
|
+
|
61
57
|
end
|
62
58
|
end
|
@@ -8,14 +8,22 @@ module VaultTree
|
|
8
8
|
end
|
9
9
|
|
10
10
|
def close_vault(id)
|
11
|
-
|
12
|
-
|
13
|
-
|
11
|
+
begin
|
12
|
+
validate_vault(id)
|
13
|
+
update_vaults(id, vault(id).close)
|
14
|
+
self
|
15
|
+
rescue RbNaCl::CryptoError => e
|
16
|
+
raise Exceptions::FailedLockAttempt.new(e, vault_id: id)
|
17
|
+
end
|
14
18
|
end
|
15
19
|
|
16
20
|
def open_vault(id)
|
17
|
-
|
18
|
-
|
21
|
+
begin
|
22
|
+
validate_vault(id)
|
23
|
+
vault(id).open
|
24
|
+
rescue RbNaCl::CryptoError => e
|
25
|
+
raise Exceptions::FailedUnlockAttempt.new(e, vault_id: id)
|
26
|
+
end
|
19
27
|
end
|
20
28
|
|
21
29
|
def vault_closed?(id)
|
@@ -36,8 +44,8 @@ module VaultTree
|
|
36
44
|
vaults_hash[id]['contents'].nil? || vaults_hash[id]['contents'].empty?
|
37
45
|
end
|
38
46
|
|
39
|
-
def update_vaults(vault)
|
40
|
-
@vaults_hash[
|
47
|
+
def update_vaults(id, vault)
|
48
|
+
@vaults_hash[id] = vault.properties unless vault.kind_of?(NullVault)
|
41
49
|
end
|
42
50
|
|
43
51
|
def vault(id)
|
data/lib/vault-tree/version.rb
CHANGED
data/vault-tree.gemspec
CHANGED
@@ -18,7 +18,7 @@ Gem::Specification.new do |spec|
|
|
18
18
|
spec.test_files = spec.files.grep(%r{^(test|spec|features)/})
|
19
19
|
spec.require_paths = ["lib"]
|
20
20
|
|
21
|
-
spec.add_dependency "rbnacl"
|
21
|
+
spec.add_dependency "rbnacl-libsodium"
|
22
22
|
spec.add_dependency "secretsharing", "0.3"
|
23
23
|
spec.add_development_dependency "bundler", "~> 1.3"
|
24
24
|
spec.add_development_dependency "rspec"
|
metadata
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: vault-tree
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 0.
|
4
|
+
version: 0.8.0
|
5
5
|
prerelease:
|
6
6
|
platform: ruby
|
7
7
|
authors:
|
@@ -9,24 +9,24 @@ authors:
|
|
9
9
|
autorequire:
|
10
10
|
bindir: bin
|
11
11
|
cert_chain: []
|
12
|
-
date: 2014-
|
12
|
+
date: 2014-08-24 00:00:00.000000000 Z
|
13
13
|
dependencies:
|
14
14
|
- !ruby/object:Gem::Dependency
|
15
|
-
name: rbnacl
|
15
|
+
name: rbnacl-libsodium
|
16
16
|
requirement: !ruby/object:Gem::Requirement
|
17
17
|
none: false
|
18
18
|
requirements:
|
19
|
-
- - '
|
19
|
+
- - ! '>='
|
20
20
|
- !ruby/object:Gem::Version
|
21
|
-
version:
|
21
|
+
version: '0'
|
22
22
|
type: :runtime
|
23
23
|
prerelease: false
|
24
24
|
version_requirements: !ruby/object:Gem::Requirement
|
25
25
|
none: false
|
26
26
|
requirements:
|
27
|
-
- - '
|
27
|
+
- - ! '>='
|
28
28
|
- !ruby/object:Gem::Version
|
29
|
-
version:
|
29
|
+
version: '0'
|
30
30
|
- !ruby/object:Gem::Dependency
|
31
31
|
name: secretsharing
|
32
32
|
requirement: !ruby/object:Gem::Requirement
|