Class: MTProto::AuthKeyGenerator
- Inherits:
-
Object
- Object
- MTProto::AuthKeyGenerator
- Defined in:
- lib/mtproto/auth_key_generator.rb
Instance Attribute Summary collapse
-
#auth_key ⇒ Object
readonly
Returns the value of attribute auth_key.
-
#connection ⇒ Object
readonly
Returns the value of attribute connection.
-
#server_salt ⇒ Object
readonly
Returns the value of attribute server_salt.
-
#time_offset ⇒ Object
readonly
Returns the value of attribute time_offset.
-
#timeout ⇒ Object
readonly
Returns the value of attribute timeout.
Instance Method Summary collapse
- #generate ⇒ Object
-
#initialize(connection, public_key, dc_number = nil, test_mode: false, timeout: 10) ⇒ AuthKeyGenerator
constructor
A new instance of AuthKeyGenerator.
Constructor Details
#initialize(connection, public_key, dc_number = nil, test_mode: false, timeout: 10) ⇒ AuthKeyGenerator
Returns a new instance of AuthKeyGenerator.
17 18 19 20 21 22 23 24 25 26 27 28 29 |
# File 'lib/mtproto/auth_key_generator.rb', line 17 def initialize(connection, public_key, dc_number = nil, test_mode: false, timeout: 10) raise ArgumentError, "public_key is required" if public_key.nil? || public_key.empty? raise ArgumentError, "dc_number must be positive. Use test_mode: true for test DCs" if dc_number && dc_number < 0 @connection = connection @public_key = public_key @dc_number = dc_number @test_mode = test_mode @timeout = timeout @auth_key = nil @server_salt = nil @time_offset = 0 end |
Instance Attribute Details
#auth_key ⇒ Object (readonly)
Returns the value of attribute auth_key.
15 16 17 |
# File 'lib/mtproto/auth_key_generator.rb', line 15 def auth_key @auth_key end |
#connection ⇒ Object (readonly)
Returns the value of attribute connection.
15 16 17 |
# File 'lib/mtproto/auth_key_generator.rb', line 15 def connection @connection end |
#server_salt ⇒ Object (readonly)
Returns the value of attribute server_salt.
15 16 17 |
# File 'lib/mtproto/auth_key_generator.rb', line 15 def server_salt @server_salt end |
#time_offset ⇒ Object (readonly)
Returns the value of attribute time_offset.
15 16 17 |
# File 'lib/mtproto/auth_key_generator.rb', line 15 def time_offset @time_offset end |
#timeout ⇒ Object (readonly)
Returns the value of attribute timeout.
15 16 17 |
# File 'lib/mtproto/auth_key_generator.rb', line 15 def timeout @timeout end |
Instance Method Details
#generate ⇒ Object
31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 |
# File 'lib/mtproto/auth_key_generator.rb', line 31 def generate res_pq = req_pq_multi server_key = find_server_key(res_pq[:fingerprints]) p, q = Crypto::Factorization.factorize_pq(res_pq[:pq]) new_nonce = SecureRandom.random_bytes(32) encrypted_data = encrypt_pq_inner_data(res_pq, p, q, server_key, new_nonce) server_dh_params = send_req_dh_params(res_pq, p, q, server_key, encrypted_data) server_dh_inner_data = decrypt_server_dh_params(res_pq, new_nonce, server_dh_params) Crypto::DHValidator.validate_dh_params( server_dh_inner_data.g, server_dh_inner_data.dh_prime, server_dh_inner_data.g_a ) client_dh_params = Crypto::DHKeyExchange.generate_client_dh_params( server_dh_inner_data.g, server_dh_inner_data.dh_prime ) auth_key = Crypto::DHKeyExchange.compute_auth_key( server_dh_inner_data.g_a, client_dh_params[:b], server_dh_inner_data.dh_prime ) tmp_aes_key = Crypto::AuthKeyHelper.derive_tmp_aes_key(new_nonce, res_pq[:server_nonce]) tmp_aes_iv = Crypto::AuthKeyHelper.derive_tmp_aes_iv(new_nonce, res_pq[:server_nonce]) dh_gen_response = send_client_dh_params( res_pq, new_nonce, client_dh_params, tmp_aes_key, tmp_aes_iv ) verify_dh_gen_response(dh_gen_response, res_pq, new_nonce, auth_key) @auth_key = auth_key @server_salt = compute_server_salt(new_nonce, res_pq[:server_nonce]) @time_offset = server_dh_inner_data.server_time - Time.now.to_i { auth_key: @auth_key, server_salt: @server_salt, time_offset: @time_offset, server_dh_params: server_dh_params, server_dh_inner_data: server_dh_inner_data, client_dh_params: client_dh_params, dh_gen_response: dh_gen_response } end |