jwk 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/.codeclimate.yml +15 -0
- data/.gitignore +17 -0
- data/.rspec +3 -0
- data/.rubocop.yml +16 -0
- data/.travis.yml +16 -0
- data/Gemfile +4 -0
- data/LICENSE.md +23 -0
- data/README.md +26 -0
- data/Rakefile +6 -0
- data/bin/console +14 -0
- data/bin/setup +8 -0
- data/docs/asn1.md +62 -0
- data/jwk.gemspec +23 -0
- data/lib/jwk.rb +15 -0
- data/lib/jwk/asn1.rb +101 -0
- data/lib/jwk/ec_key.rb +79 -0
- data/lib/jwk/key.rb +64 -0
- data/lib/jwk/oct_key.rb +38 -0
- data/lib/jwk/rsa_key.rb +91 -0
- data/lib/jwk/utils.rb +41 -0
- data/lib/jwk/version.rb +3 -0
- data/spec/jwk/asn1_spec.rb +70 -0
- data/spec/jwk/ec_key_spec.rb +84 -0
- data/spec/jwk/key_spec.rb +66 -0
- data/spec/jwk/oct_key_spec.rb +54 -0
- data/spec/jwk/rsa_key_spec.rb +92 -0
- data/spec/jwk_spec.rb +5 -0
- data/spec/spec_helper.rb +20 -0
- data/spec/support/ec_private.json +7 -0
- data/spec/support/ec_private.pem +5 -0
- data/spec/support/ec_public.json +6 -0
- data/spec/support/oct.json +4 -0
- data/spec/support/rsa_partial.json +7 -0
- data/spec/support/rsa_private.json +11 -0
- data/spec/support/rsa_private.pem +27 -0
- data/spec/support/rsa_public.json +5 -0
- data/spec/support/rsa_public.pem +9 -0
- metadata +137 -0
@@ -0,0 +1,54 @@
|
|
1
|
+
describe JWK::OctKey do
|
2
|
+
let(:jwk) do
|
3
|
+
File.read('spec/support/oct.json')
|
4
|
+
end
|
5
|
+
|
6
|
+
describe '#to_pem' do
|
7
|
+
it 'raises' do
|
8
|
+
key = JWK::Key.from_json(jwk)
|
9
|
+
expect { key.to_pem }.to raise_error(NotImplementedError)
|
10
|
+
end
|
11
|
+
end
|
12
|
+
|
13
|
+
describe '#to_s' do
|
14
|
+
it 'returns the key' do
|
15
|
+
key = JWK::Key.from_json(jwk)
|
16
|
+
expect(key.to_s).to eq 'hello world'
|
17
|
+
end
|
18
|
+
end
|
19
|
+
|
20
|
+
describe '#to_openssl_key' do
|
21
|
+
it 'raises' do
|
22
|
+
key = JWK::Key.from_json(jwk)
|
23
|
+
expect { key.to_openssl_key }.to raise_error(NotImplementedError)
|
24
|
+
end
|
25
|
+
end
|
26
|
+
|
27
|
+
describe '#to_json' do
|
28
|
+
it 'responds with the JWK JSON key' do
|
29
|
+
key = JWK::Key.from_json(jwk)
|
30
|
+
expect(JSON.parse(key.to_json)).to eq JSON.parse(jwk)
|
31
|
+
end
|
32
|
+
end
|
33
|
+
|
34
|
+
describe '#kty' do
|
35
|
+
it 'equals oct' do
|
36
|
+
key = JWK::Key.from_json(jwk)
|
37
|
+
expect(key.kty).to eq 'oct'
|
38
|
+
end
|
39
|
+
end
|
40
|
+
|
41
|
+
describe '#public?' do
|
42
|
+
it 'is true' do
|
43
|
+
key = JWK::Key.from_json(jwk)
|
44
|
+
expect(key.public?).to be_truthy
|
45
|
+
end
|
46
|
+
end
|
47
|
+
|
48
|
+
describe '#private?' do
|
49
|
+
it 'is true' do
|
50
|
+
key = JWK::Key.from_json(jwk)
|
51
|
+
expect(key.private?).to be_truthy
|
52
|
+
end
|
53
|
+
end
|
54
|
+
end
|
@@ -0,0 +1,92 @@
|
|
1
|
+
describe JWK::RSAKey do
|
2
|
+
let(:private_jwk) do
|
3
|
+
File.read('spec/support/rsa_private.json')
|
4
|
+
end
|
5
|
+
|
6
|
+
let(:public_jwk) do
|
7
|
+
File.read('spec/support/rsa_public.json')
|
8
|
+
end
|
9
|
+
|
10
|
+
let(:partial_jwk) do
|
11
|
+
File.read('spec/support/rsa_partial.json')
|
12
|
+
end
|
13
|
+
|
14
|
+
let(:private_pem) do
|
15
|
+
File.read('spec/support/rsa_private.pem')
|
16
|
+
end
|
17
|
+
|
18
|
+
let(:public_pem) do
|
19
|
+
File.read('spec/support/rsa_public.pem')
|
20
|
+
end
|
21
|
+
|
22
|
+
describe '#to_pem' do
|
23
|
+
it 'converts private keys to the right format' do
|
24
|
+
key = JWK::Key.from_json(private_jwk)
|
25
|
+
expect(key.to_pem).to eq private_pem
|
26
|
+
end
|
27
|
+
|
28
|
+
it 'converts public keys keys to the right format' do
|
29
|
+
key = JWK::Key.from_json(public_jwk)
|
30
|
+
expect(key.to_pem).to eq public_pem
|
31
|
+
end
|
32
|
+
|
33
|
+
it 'fails on private keys with missing parameters' do
|
34
|
+
key = JWK::Key.from_json(partial_jwk)
|
35
|
+
expect { key.to_pem }.to raise_error NotImplementedError
|
36
|
+
end
|
37
|
+
end
|
38
|
+
|
39
|
+
describe '#to_s' do
|
40
|
+
it 'converts to pem' do
|
41
|
+
key = JWK::Key.from_json(public_jwk)
|
42
|
+
expect(key.to_s).to eq(key.to_pem)
|
43
|
+
end
|
44
|
+
end
|
45
|
+
|
46
|
+
describe '#to_openssl_key' do
|
47
|
+
it 'converts the private key to an openssl object' do
|
48
|
+
key = JWK::Key.from_json(private_jwk)
|
49
|
+
expect(key.to_openssl_key).to be_a OpenSSL::PKey::RSA
|
50
|
+
end
|
51
|
+
end
|
52
|
+
|
53
|
+
describe '#to_json' do
|
54
|
+
it 'responds with the JWK JSON key' do
|
55
|
+
key = JWK::Key.from_json(private_jwk)
|
56
|
+
expect(JSON.parse(key.to_json)).to eq JSON.parse(private_jwk)
|
57
|
+
end
|
58
|
+
end
|
59
|
+
|
60
|
+
describe '#kty' do
|
61
|
+
it 'equals RSA' do
|
62
|
+
key = JWK::Key.from_json(private_jwk)
|
63
|
+
expect(key.kty).to eq 'RSA'
|
64
|
+
end
|
65
|
+
end
|
66
|
+
|
67
|
+
describe '#public?' do
|
68
|
+
it 'is true' do
|
69
|
+
key = JWK::Key.from_json(private_jwk)
|
70
|
+
expect(key.public?).to be_truthy
|
71
|
+
end
|
72
|
+
end
|
73
|
+
|
74
|
+
describe '#private?' do
|
75
|
+
it 'is true for private keys' do
|
76
|
+
key = JWK::Key.from_json(private_jwk)
|
77
|
+
expect(key.private?).to be_truthy
|
78
|
+
end
|
79
|
+
|
80
|
+
it 'is false for public keys' do
|
81
|
+
key = JWK::Key.from_json(public_jwk)
|
82
|
+
expect(key.private?).to be_falsey
|
83
|
+
end
|
84
|
+
end
|
85
|
+
|
86
|
+
describe '#x5t_s256' do
|
87
|
+
it 'responds with the x5t#S256 element of the JWK' do
|
88
|
+
key = JWK::Key.from_json('{"kty":"RSA","n":"1","e":"2","x5t#S256":"hello"}')
|
89
|
+
expect(key.x5t_s256).to eq 'hello'
|
90
|
+
end
|
91
|
+
end
|
92
|
+
end
|
data/spec/jwk_spec.rb
ADDED
data/spec/spec_helper.rb
ADDED
@@ -0,0 +1,20 @@
|
|
1
|
+
require 'simplecov'
|
2
|
+
SimpleCov.start do
|
3
|
+
add_filter 'spec/'
|
4
|
+
end
|
5
|
+
|
6
|
+
require 'bundler/setup'
|
7
|
+
require 'jwk'
|
8
|
+
|
9
|
+
Dir['spec/support/**/*.rb'].each { |f| require File.expand_path(f) }
|
10
|
+
|
11
|
+
RSpec.configure do |config|
|
12
|
+
# Enable flags like --only-failures and --next-failure
|
13
|
+
config.example_status_persistence_file_path = '.rspec_status'
|
14
|
+
|
15
|
+
config.expect_with :rspec do |c|
|
16
|
+
c.syntax = :expect
|
17
|
+
end
|
18
|
+
|
19
|
+
config.order = 'random'
|
20
|
+
end
|
@@ -0,0 +1,7 @@
|
|
1
|
+
{
|
2
|
+
"kty":"RSA",
|
3
|
+
"n":"oahUIoWw0K0usKNuOR6H4wkf4oBUXHTxRvgb48E-BVvxkeDNjbC4he8rUWcJoZmds2h7M70imEVhRU5djINXtqllXI4DFqcI1DgjT9LewND8MW2Krf3Spsk_ZkoFnilakGygTwpZ3uesH-PFABNIUYpOiN15dsQRkgr0vEhxN92i2asbOenSZeyaxziK72UwxrrKoExv6kc5twXTq4h-QChLOln0_mtUZwfsRaMStPs6mS6XrgxnxbWhojf663tuEQueGC-FCMfra36C9knDFGzKsNa7LZK2djYgyD3JR_MB_4NUJW_TqOQtwHYbxevoJArm-L5StowjzGy-_bq6Gw",
|
4
|
+
"e":"AQAB",
|
5
|
+
"d":"kLdtIj6GbDks_ApCSTYQtelcNttlKiOyPzMrXHeI-yk1F7-kpDxY4-WY5NWV5KntaEeXS1j82E375xxhWMHXyvjYecPT9fpwR_M9gV8n9Hrh2anTpTD93Dt62ypW3yDsJzBnTnrYu1iwWRgBKrEYY46qAZIrA2xAwnm2X7uGR1hghkqDp0Vqj3kbSCz1XyfCs6_LehBwtxHIyh8Ripy40p24moOAbgxVw3rxT_vlt3UVe4WO3JkJOzlpUf-KTVI2Ptgm-dARxTEtE-id-4OJr0h-K-VFs3VSndVTIznSxfyrj8ILL6MG_Uv8YAu7VILSB3lOW085-4qE3DzgrTjgyQ",
|
6
|
+
"p":"1r52Xk46c-LsfB5P442p7atdPUrxQSy4mti_tZI3Mgf2EuFVbUoDBvaRQ-SWxkbkmoEzL7JXroSBjSrK3YIQgYdMgyAEPTPjXv_hI2_1eTSPVZfzL0lffNn03IXqWF5MDFuoUYE0hzb2vhrlN_rKrbfDIwUbTrjjgieRbwC6Cl0"
|
7
|
+
}
|
@@ -0,0 +1,11 @@
|
|
1
|
+
{
|
2
|
+
"kty":"RSA",
|
3
|
+
"n":"oahUIoWw0K0usKNuOR6H4wkf4oBUXHTxRvgb48E-BVvxkeDNjbC4he8rUWcJoZmds2h7M70imEVhRU5djINXtqllXI4DFqcI1DgjT9LewND8MW2Krf3Spsk_ZkoFnilakGygTwpZ3uesH-PFABNIUYpOiN15dsQRkgr0vEhxN92i2asbOenSZeyaxziK72UwxrrKoExv6kc5twXTq4h-QChLOln0_mtUZwfsRaMStPs6mS6XrgxnxbWhojf663tuEQueGC-FCMfra36C9knDFGzKsNa7LZK2djYgyD3JR_MB_4NUJW_TqOQtwHYbxevoJArm-L5StowjzGy-_bq6Gw",
|
4
|
+
"e":"AQAB",
|
5
|
+
"d":"kLdtIj6GbDks_ApCSTYQtelcNttlKiOyPzMrXHeI-yk1F7-kpDxY4-WY5NWV5KntaEeXS1j82E375xxhWMHXyvjYecPT9fpwR_M9gV8n9Hrh2anTpTD93Dt62ypW3yDsJzBnTnrYu1iwWRgBKrEYY46qAZIrA2xAwnm2X7uGR1hghkqDp0Vqj3kbSCz1XyfCs6_LehBwtxHIyh8Ripy40p24moOAbgxVw3rxT_vlt3UVe4WO3JkJOzlpUf-KTVI2Ptgm-dARxTEtE-id-4OJr0h-K-VFs3VSndVTIznSxfyrj8ILL6MG_Uv8YAu7VILSB3lOW085-4qE3DzgrTjgyQ",
|
6
|
+
"p":"1r52Xk46c-LsfB5P442p7atdPUrxQSy4mti_tZI3Mgf2EuFVbUoDBvaRQ-SWxkbkmoEzL7JXroSBjSrK3YIQgYdMgyAEPTPjXv_hI2_1eTSPVZfzL0lffNn03IXqWF5MDFuoUYE0hzb2vhrlN_rKrbfDIwUbTrjjgieRbwC6Cl0",
|
7
|
+
"q":"wLb35x7hmQWZsWJmB_vle87ihgZ19S8lBEROLIsZG4ayZVe9Hi9gDVCOBmUDdaDYVTSNx_8Fyw1YYa9XGrGnDew00J28cRUoeBB_jKI1oma0Orv1T9aXIWxKwd4gvxFImOWr3QRL9KEBRzk2RatUBnmDZJTIAfwTs0g68UZHvtc",
|
8
|
+
"dp":"ZK-YwE7diUh0qR1tR7w8WHtolDx3MZ_OTowiFvgfeQ3SiresXjm9gZ5KLhMXvo-uz-KUJWDxS5pFQ_M0evdo1dKiRTjVw_x4NyqyXPM5nULPkcpU827rnpZzAJKpdhWAgqrXGKAECQH0Xt4taznjnd_zVpAmZZq60WPMBMfKcuE",
|
9
|
+
"dq":"Dq0gfgJ1DdFGXiLvQEZnuKEN0UUmsJBxkjydc3j4ZYdBiMRAy86x0vHCjywcMlYYg4yoC4YZa9hNVcsjqA3FeiL19rk8g6Qn29Tt0cj8qqyFpz9vNDBUfCAiJVeESOjJDZPYHdHY8v1b-o-Z2X5tvLx-TCekf7oxyeKDUqKWjis",
|
10
|
+
"qi":"VIMpMYbPf47dT1w_zDUXfPimsSegnMOA1zTaX7aGk_8urY6R8-ZW1FxU7AlWAyLWybqq6t16VFd7hQd0y6flUK4SlOydB61gwanOsXGOAOv82cHq0E3eL4HrtZkUuKvnPrMnsUUFlfUdybVzxyjz9JF_XyaY14ardLSjf4L_FNY"
|
11
|
+
}
|
@@ -0,0 +1,27 @@
|
|
1
|
+
-----BEGIN RSA PRIVATE KEY-----
|
2
|
+
MIIEowIBAAKCAQEAoahUIoWw0K0usKNuOR6H4wkf4oBUXHTxRvgb48E+BVvxkeDN
|
3
|
+
jbC4he8rUWcJoZmds2h7M70imEVhRU5djINXtqllXI4DFqcI1DgjT9LewND8MW2K
|
4
|
+
rf3Spsk/ZkoFnilakGygTwpZ3uesH+PFABNIUYpOiN15dsQRkgr0vEhxN92i2asb
|
5
|
+
OenSZeyaxziK72UwxrrKoExv6kc5twXTq4h+QChLOln0/mtUZwfsRaMStPs6mS6X
|
6
|
+
rgxnxbWhojf663tuEQueGC+FCMfra36C9knDFGzKsNa7LZK2djYgyD3JR/MB/4NU
|
7
|
+
JW/TqOQtwHYbxevoJArm+L5StowjzGy+/bq6GwIDAQABAoIBAQCQt20iPoZsOSz8
|
8
|
+
CkJJNhC16Vw222UqI7I/Mytcd4j7KTUXv6SkPFjj5Zjk1ZXkqe1oR5dLWPzYTfvn
|
9
|
+
HGFYwdfK+Nh5w9P1+nBH8z2BXyf0euHZqdOlMP3cO3rbKlbfIOwnMGdOeti7WLBZ
|
10
|
+
GAEqsRhjjqoBkisDbEDCebZfu4ZHWGCGSoOnRWqPeRtILPVfJ8Kzr8t6EHC3EcjK
|
11
|
+
HxGKnLjSnbiag4BuDFXDevFP++W3dRV7hY7cmQk7OWlR/4pNUjY+2Cb50BHFMS0T
|
12
|
+
6J37g4mvSH4r5UWzdVKd1VMjOdLF/KuPwgsvowb9S/xgC7tUgtIHeU5bTzn7ioTc
|
13
|
+
POCtOODJAoGBANa+dl5OOnPi7HweT+ONqe2rXT1K8UEsuJrYv7WSNzIH9hLhVW1K
|
14
|
+
Awb2kUPklsZG5JqBMy+yV66EgY0qyt2CEIGHTIMgBD0z417/4SNv9Xk0j1WX8y9J
|
15
|
+
X3zZ9NyF6lheTAxbqFGBNIc29r4a5Tf6yq23wyMFG06444InkW8AugpdAoGBAMC2
|
16
|
+
9+ce4ZkFmbFiZgf75XvO4oYGdfUvJQRETiyLGRuGsmVXvR4vYA1QjgZlA3Wg2FU0
|
17
|
+
jcf/BcsNWGGvVxqxpw3sNNCdvHEVKHgQf4yiNaJmtDq79U/WlyFsSsHeIL8RSJjl
|
18
|
+
q90ES/ShAUc5NkWrVAZ5g2SUyAH8E7NIOvFGR77XAoGAZK+YwE7diUh0qR1tR7w8
|
19
|
+
WHtolDx3MZ/OTowiFvgfeQ3SiresXjm9gZ5KLhMXvo+uz+KUJWDxS5pFQ/M0evdo
|
20
|
+
1dKiRTjVw/x4NyqyXPM5nULPkcpU827rnpZzAJKpdhWAgqrXGKAECQH0Xt4taznj
|
21
|
+
nd/zVpAmZZq60WPMBMfKcuECgYAOrSB+AnUN0UZeIu9ARme4oQ3RRSawkHGSPJ1z
|
22
|
+
ePhlh0GIxEDLzrHS8cKPLBwyVhiDjKgLhhlr2E1VyyOoDcV6IvX2uTyDpCfb1O3R
|
23
|
+
yPyqrIWnP280MFR8ICIlV4RI6MkNk9gd0djy/Vv6j5nZfm28vH5MJ6R/ujHJ4oNS
|
24
|
+
opaOKwKBgFSDKTGGz3+O3U9cP8w1F3z4prEnoJzDgNc02l+2hpP/Lq2OkfPmVtRc
|
25
|
+
VOwJVgMi1sm6qurdelRXe4UHdMun5VCuEpTsnQetYMGpzrFxjgDr/NnB6tBN3i+B
|
26
|
+
67WZFLir5z6zJ7FFBZX1Hcm1c8co8/SRf18mmNeGq3S0o3+C/xTW
|
27
|
+
-----END RSA PRIVATE KEY-----
|
@@ -0,0 +1,5 @@
|
|
1
|
+
{
|
2
|
+
"kty":"RSA",
|
3
|
+
"n":"oahUIoWw0K0usKNuOR6H4wkf4oBUXHTxRvgb48E-BVvxkeDNjbC4he8rUWcJoZmds2h7M70imEVhRU5djINXtqllXI4DFqcI1DgjT9LewND8MW2Krf3Spsk_ZkoFnilakGygTwpZ3uesH-PFABNIUYpOiN15dsQRkgr0vEhxN92i2asbOenSZeyaxziK72UwxrrKoExv6kc5twXTq4h-QChLOln0_mtUZwfsRaMStPs6mS6XrgxnxbWhojf663tuEQueGC-FCMfra36C9knDFGzKsNa7LZK2djYgyD3JR_MB_4NUJW_TqOQtwHYbxevoJArm-L5StowjzGy-_bq6Gw",
|
4
|
+
"e":"AQAB"
|
5
|
+
}
|
@@ -0,0 +1,9 @@
|
|
1
|
+
-----BEGIN PUBLIC KEY-----
|
2
|
+
MIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEAoahUIoWw0K0usKNuOR6H
|
3
|
+
4wkf4oBUXHTxRvgb48E+BVvxkeDNjbC4he8rUWcJoZmds2h7M70imEVhRU5djINX
|
4
|
+
tqllXI4DFqcI1DgjT9LewND8MW2Krf3Spsk/ZkoFnilakGygTwpZ3uesH+PFABNI
|
5
|
+
UYpOiN15dsQRkgr0vEhxN92i2asbOenSZeyaxziK72UwxrrKoExv6kc5twXTq4h+
|
6
|
+
QChLOln0/mtUZwfsRaMStPs6mS6XrgxnxbWhojf663tuEQueGC+FCMfra36C9knD
|
7
|
+
FGzKsNa7LZK2djYgyD3JR/MB/4NUJW/TqOQtwHYbxevoJArm+L5StowjzGy+/bq6
|
8
|
+
GwIDAQAB
|
9
|
+
-----END PUBLIC KEY-----
|
metadata
ADDED
@@ -0,0 +1,137 @@
|
|
1
|
+
--- !ruby/object:Gem::Specification
|
2
|
+
name: jwk
|
3
|
+
version: !ruby/object:Gem::Version
|
4
|
+
version: 0.1.0
|
5
|
+
platform: ruby
|
6
|
+
authors:
|
7
|
+
- Francesco Boffa
|
8
|
+
autorequire:
|
9
|
+
bindir: bin
|
10
|
+
cert_chain: []
|
11
|
+
date: 2017-11-10 00:00:00.000000000 Z
|
12
|
+
dependencies:
|
13
|
+
- !ruby/object:Gem::Dependency
|
14
|
+
name: rspec
|
15
|
+
requirement: !ruby/object:Gem::Requirement
|
16
|
+
requirements:
|
17
|
+
- - ">="
|
18
|
+
- !ruby/object:Gem::Version
|
19
|
+
version: '0'
|
20
|
+
type: :development
|
21
|
+
prerelease: false
|
22
|
+
version_requirements: !ruby/object:Gem::Requirement
|
23
|
+
requirements:
|
24
|
+
- - ">="
|
25
|
+
- !ruby/object:Gem::Version
|
26
|
+
version: '0'
|
27
|
+
- !ruby/object:Gem::Dependency
|
28
|
+
name: rake
|
29
|
+
requirement: !ruby/object:Gem::Requirement
|
30
|
+
requirements:
|
31
|
+
- - ">="
|
32
|
+
- !ruby/object:Gem::Version
|
33
|
+
version: '0'
|
34
|
+
type: :development
|
35
|
+
prerelease: false
|
36
|
+
version_requirements: !ruby/object:Gem::Requirement
|
37
|
+
requirements:
|
38
|
+
- - ">="
|
39
|
+
- !ruby/object:Gem::Version
|
40
|
+
version: '0'
|
41
|
+
- !ruby/object:Gem::Dependency
|
42
|
+
name: simplecov
|
43
|
+
requirement: !ruby/object:Gem::Requirement
|
44
|
+
requirements:
|
45
|
+
- - ">="
|
46
|
+
- !ruby/object:Gem::Version
|
47
|
+
version: '0'
|
48
|
+
type: :development
|
49
|
+
prerelease: false
|
50
|
+
version_requirements: !ruby/object:Gem::Requirement
|
51
|
+
requirements:
|
52
|
+
- - ">="
|
53
|
+
- !ruby/object:Gem::Version
|
54
|
+
version: '0'
|
55
|
+
- !ruby/object:Gem::Dependency
|
56
|
+
name: codeclimate-test-reporter
|
57
|
+
requirement: !ruby/object:Gem::Requirement
|
58
|
+
requirements:
|
59
|
+
- - ">="
|
60
|
+
- !ruby/object:Gem::Version
|
61
|
+
version: '0'
|
62
|
+
type: :development
|
63
|
+
prerelease: false
|
64
|
+
version_requirements: !ruby/object:Gem::Requirement
|
65
|
+
requirements:
|
66
|
+
- - ">="
|
67
|
+
- !ruby/object:Gem::Version
|
68
|
+
version: '0'
|
69
|
+
description: A Ruby implementation of the RFC 7517 JSON Web Keys (JWK) standard
|
70
|
+
email:
|
71
|
+
- fra.boffa@gmail.com
|
72
|
+
executables: []
|
73
|
+
extensions: []
|
74
|
+
extra_rdoc_files: []
|
75
|
+
files:
|
76
|
+
- ".codeclimate.yml"
|
77
|
+
- ".gitignore"
|
78
|
+
- ".rspec"
|
79
|
+
- ".rubocop.yml"
|
80
|
+
- ".travis.yml"
|
81
|
+
- Gemfile
|
82
|
+
- LICENSE.md
|
83
|
+
- README.md
|
84
|
+
- Rakefile
|
85
|
+
- bin/console
|
86
|
+
- bin/setup
|
87
|
+
- docs/asn1.md
|
88
|
+
- jwk.gemspec
|
89
|
+
- lib/jwk.rb
|
90
|
+
- lib/jwk/asn1.rb
|
91
|
+
- lib/jwk/ec_key.rb
|
92
|
+
- lib/jwk/key.rb
|
93
|
+
- lib/jwk/oct_key.rb
|
94
|
+
- lib/jwk/rsa_key.rb
|
95
|
+
- lib/jwk/utils.rb
|
96
|
+
- lib/jwk/version.rb
|
97
|
+
- spec/jwk/asn1_spec.rb
|
98
|
+
- spec/jwk/ec_key_spec.rb
|
99
|
+
- spec/jwk/key_spec.rb
|
100
|
+
- spec/jwk/oct_key_spec.rb
|
101
|
+
- spec/jwk/rsa_key_spec.rb
|
102
|
+
- spec/jwk_spec.rb
|
103
|
+
- spec/spec_helper.rb
|
104
|
+
- spec/support/ec_private.json
|
105
|
+
- spec/support/ec_private.pem
|
106
|
+
- spec/support/ec_public.json
|
107
|
+
- spec/support/oct.json
|
108
|
+
- spec/support/rsa_partial.json
|
109
|
+
- spec/support/rsa_private.json
|
110
|
+
- spec/support/rsa_private.pem
|
111
|
+
- spec/support/rsa_public.json
|
112
|
+
- spec/support/rsa_public.pem
|
113
|
+
homepage: https://github.com/aomega08/jwk
|
114
|
+
licenses:
|
115
|
+
- MIT
|
116
|
+
metadata: {}
|
117
|
+
post_install_message:
|
118
|
+
rdoc_options: []
|
119
|
+
require_paths:
|
120
|
+
- lib
|
121
|
+
required_ruby_version: !ruby/object:Gem::Requirement
|
122
|
+
requirements:
|
123
|
+
- - ">="
|
124
|
+
- !ruby/object:Gem::Version
|
125
|
+
version: '0'
|
126
|
+
required_rubygems_version: !ruby/object:Gem::Requirement
|
127
|
+
requirements:
|
128
|
+
- - ">="
|
129
|
+
- !ruby/object:Gem::Version
|
130
|
+
version: '0'
|
131
|
+
requirements: []
|
132
|
+
rubyforge_project:
|
133
|
+
rubygems_version: 2.6.11
|
134
|
+
signing_key:
|
135
|
+
specification_version: 4
|
136
|
+
summary: JSON Web Keys implementation in Ruby
|
137
|
+
test_files: []
|