Sha256: 1980b9d455897aaee1f719bfab2fe382fb1962eb9f85334a0ac96c184e1a8a37

Contents?: true

Size: 934 Bytes

Versions: 6

Compression:

Stored size: 934 Bytes

Contents

# frozen_string_literal: true

module Noise
  module Functions
    module DH
      class ED25519
        DHLEN = 32
        def generate_keypair
          private_key = 1 + SecureRandom.random_number(RbNaCl::GroupElement::STANDARD_GROUP_ORDER - 1)
          scalar_as_string = ECDSA::Format::IntegerOctetString.encode(private_key, 32)
          public_key = RbNaCl::GroupElements::Curve25519.base.mult(scalar_as_string)
          Noise::Key.new(ECDSA::Format::IntegerOctetString.encode(private_key, 32), public_key.to_bytes)
        end

        def dh(private_key, public_key)
          RbNaCl::GroupElement.new(public_key).mult(private_key).to_bytes
        end

        def dhlen
          DHLEN
        end

        def self.from_private(private_key)
          public_key = RbNaCl::GroupElements::Curve25519.base.mult(private_key)
          Noise::Key.new(private_key, public_key.to_bytes)
        end
      end
    end
  end
end

Version data entries

6 entries across 6 versions & 1 rubygems

Version Path
noise-ruby-0.10.1 lib/noise/functions/dh/ed25519.rb
noise-ruby-0.10.0 lib/noise/functions/dh/ed25519.rb
noise-ruby-0.9.4 lib/noise/functions/dh/ed25519.rb
noise-ruby-0.8.4 lib/noise/functions/dh/ed25519.rb
noise-ruby-0.7.4 lib/noise/functions/dh/ed25519.rb
noise-ruby-0.7.3 lib/noise/functions/dh/ed25519.rb