Class: Cakewalk::SASL::DiffieHellman Private
- Inherits:
-
Object
- Object
- Cakewalk::SASL::DiffieHellman
- Defined in:
- lib/cakewalk/sasl/diffie_hellman.rb
Overview
This class is part of a private API. You should avoid using this class if possible, as it may be removed or be changed in the future.
Instance Attribute Summary collapse
-
#e ⇒ Object
readonly
private
-
#g ⇒ Object
readonly
private
-
#p ⇒ Object
readonly
private
-
#q ⇒ Object
readonly
private
-
#x ⇒ Object
readonly
private
Instance Method Summary collapse
-
#generate(tries = 16) ⇒ Object
private
-
#initialize(p, g, q) ⇒ DiffieHellman
constructor
private
A new instance of DiffieHellman.
-
#secret(f) ⇒ Object
private
compute the shared secret, given the public key.
Constructor Details
#initialize(p, g, q) ⇒ DiffieHellman
This method is part of a private API. You should avoid using this method if possible, as it may be removed or be changed in the future.
Returns a new instance of DiffieHellman.
6 7 8 9 10 |
# File 'lib/cakewalk/sasl/diffie_hellman.rb', line 6 def initialize(p, g, q) @p = p @g = g @q = q end |
Instance Attribute Details
#e ⇒ Object (readonly)
This method is part of a private API. You should avoid using this method if possible, as it may be removed or be changed in the future.
4 5 6 |
# File 'lib/cakewalk/sasl/diffie_hellman.rb', line 4 def e @e end |
#g ⇒ Object (readonly)
This method is part of a private API. You should avoid using this method if possible, as it may be removed or be changed in the future.
4 5 6 |
# File 'lib/cakewalk/sasl/diffie_hellman.rb', line 4 def g @g end |
#p ⇒ Object (readonly)
This method is part of a private API. You should avoid using this method if possible, as it may be removed or be changed in the future.
4 5 6 |
# File 'lib/cakewalk/sasl/diffie_hellman.rb', line 4 def p @p end |
#q ⇒ Object (readonly)
This method is part of a private API. You should avoid using this method if possible, as it may be removed or be changed in the future.
4 5 6 |
# File 'lib/cakewalk/sasl/diffie_hellman.rb', line 4 def q @q end |
#x ⇒ Object (readonly)
This method is part of a private API. You should avoid using this method if possible, as it may be removed or be changed in the future.
4 5 6 |
# File 'lib/cakewalk/sasl/diffie_hellman.rb', line 4 def x @x end |
Instance Method Details
#generate(tries = 16) ⇒ Object
This method is part of a private API. You should avoid using this method if possible, as it may be removed or be changed in the future.
12 13 14 15 16 17 18 19 |
# File 'lib/cakewalk/sasl/diffie_hellman.rb', line 12 def generate(tries = 16) tries.times do @x = rand(@q) @e = mod_exp(@g, @x, @p) return @e if valid? end raise ArgumentError, "can't generate valid e" end |
#secret(f) ⇒ Object
This method is part of a private API. You should avoid using this method if possible, as it may be removed or be changed in the future.
compute the shared secret, given the public key
22 23 24 |
# File 'lib/cakewalk/sasl/diffie_hellman.rb', line 22 def secret(f) mod_exp(f, @x, @p) end |