Class: Wampproto::Auth::Cryptosign
- Inherits:
-
Base
- Object
- Base
- Wampproto::Auth::Cryptosign
show all
- Includes:
- Helpers
- Defined in:
- lib/wampproto/auth/cryptosign.rb
Overview
generates wampcra authentication signature
Constant Summary
collapse
- AUTH_METHOD =
"cryptosign"
Instance Attribute Summary collapse
Attributes inherited from Base
#authextra, #authid, #authmethod
Class Method Summary
collapse
-
.create_challenge ⇒ Object
-
.create_signature(private_key, challenge, channel_id = nil) ⇒ Object
-
.handle_channel_binding(private_key, hex_challenge, channel_id) ⇒ Object
-
.handle_without_channel_binding(private_key, hex_challenge) ⇒ Object
-
.sign_challenge(private_key, challenge, channel_id = nil) ⇒ Object
-
.verify_challenge(signature, msg, public_key) ⇒ Object
-
.xored_strings(channel_id, challenge_str) ⇒ Object
Instance Method Summary
collapse
Methods included from Helpers
included
Constructor Details
#initialize(private_key, authid, authextra = {}) ⇒ Cryptosign
16
17
18
19
|
# File 'lib/wampproto/auth/cryptosign.rb', line 16
def initialize(private_key, authid, = {})
@private_key = Validate.string!("Private Key", private_key)
super(AUTH_METHOD, authid, )
end
|
Instance Attribute Details
#channel_id ⇒ Object
Returns the value of attribute channel_id.
12
13
14
|
# File 'lib/wampproto/auth/cryptosign.rb', line 12
def channel_id
@channel_id
end
|
#private_key ⇒ Object
Returns the value of attribute private_key.
11
12
13
|
# File 'lib/wampproto/auth/cryptosign.rb', line 11
def private_key
@private_key
end
|
Class Method Details
.create_challenge ⇒ Object
27
28
29
30
|
# File 'lib/wampproto/auth/cryptosign.rb', line 27
def create_challenge
binary_challenge = SecureRandom.random_bytes(32)
binary_to_hex(binary_challenge)
end
|
.create_signature(private_key, challenge, channel_id = nil) ⇒ Object
48
49
50
51
52
|
# File 'lib/wampproto/auth/cryptosign.rb', line 48
def create_signature(private_key, challenge, channel_id = nil)
return handle_channel_binding(private_key, challenge, channel_id) if channel_id
handle_without_channel_binding(private_key, challenge)
end
|
.handle_channel_binding(private_key, hex_challenge, channel_id) ⇒ Object
64
65
66
67
68
69
70
71
72
73
74
|
# File 'lib/wampproto/auth/cryptosign.rb', line 64
def handle_channel_binding(private_key, hex_challenge, channel_id)
key_pair = Ed25519::SigningKey.new(hex_to_binary(private_key))
channel_id = hex_to_binary(channel_id)
challenge = hex_to_binary(hex_challenge)
xored_challenge = xored_strings(channel_id, challenge)
binary_signed_challenge = key_pair.sign(xored_challenge)
signature = binary_to_hex(binary_signed_challenge)
hex_xored_challenge = binary_to_hex(xored_challenge)
"#{signature}#{hex_xored_challenge}"
end
|
.handle_without_channel_binding(private_key, hex_challenge) ⇒ Object
54
55
56
57
58
59
60
61
62
|
# File 'lib/wampproto/auth/cryptosign.rb', line 54
def handle_without_channel_binding(private_key, hex_challenge)
key_pair = Ed25519::SigningKey.new(hex_to_binary(private_key))
binary_challenge = hex_to_binary(hex_challenge)
binary_signature = key_pair.sign(binary_challenge)
signature = binary_to_hex(binary_signature)
"#{signature}#{hex_challenge}"
end
|
.sign_challenge(private_key, challenge, channel_id = nil) ⇒ Object
44
45
46
|
# File 'lib/wampproto/auth/cryptosign.rb', line 44
def sign_challenge(private_key, challenge, channel_id = nil)
create_signature(private_key, challenge, channel_id)
end
|
.verify_challenge(signature, msg, public_key) ⇒ Object
32
33
34
35
36
37
38
39
40
41
42
|
# File 'lib/wampproto/auth/cryptosign.rb', line 32
def verify_challenge(signature, msg, public_key)
verify_key = Ed25519::VerifyKey.new(hex_to_binary(public_key))
binary_signature = hex_to_binary(signature)
signature = binary_signature[0, 64].to_s
message = binary_signature[64, 32].to_s
return false if message.empty? || signature.empty?
return false if msg != binary_to_hex(message)
verify_key.verify(signature, message)
end
|
.xored_strings(channel_id, challenge_str) ⇒ Object
76
77
78
79
80
81
82
|
# File 'lib/wampproto/auth/cryptosign.rb', line 76
def xored_strings(channel_id, challenge_str)
channel_id_bytes = channel_id.bytes
challenge_bytes = challenge_str.bytes
xored = channel_id_bytes.zip(challenge_bytes).map { |byte1, byte2| (byte1 || 0) ^ (byte2 || 0) }
xored.pack("C*")
end
|
Instance Method Details
#authenticate(challenge) ⇒ Object
21
22
23
24
|
# File 'lib/wampproto/auth/cryptosign.rb', line 21
def authenticate(challenge)
signature = self.class.create_signature(private_key, challenge.[:challenge], channel_id)
Message::Authenticate.new(signature)
end
|