Sha256: 727f2e8849d66d3cd929e80d3abdc057e8735afcfbd6056f7a25d501ea13d421

Contents?: true

Size: 1.08 KB

Versions: 4

Compression:

Stored size: 1.08 KB

Contents

module Bip44

  # "44'",  # bip 44
  # "60'",  # coin, 0': bitcoin, 60': ethereum
  # "0'",   # wallet
  # "0"     # 0 - public, 1 = private
  # "0"     # index
  class Wallet
    include Bip44::Bitcoin
    include Bip44::Ethereum

    def self.from_seed(seed, path)
      master = MoneyTree::Master.new(seed_hex: seed) # 3. 种子用于使用 HMAC-SHA512 生成根私钥(参见 BIP32)
      wallet_node = master.node_for_path(path) # 4. 从该根私钥,导出子私钥(参见 BIP32),其中节点布局由BIP44设置
      Wallet.new(wallet_node)
    end

    def self.from_mnemonic(mnemonic, path)
      seed = BipMnemonic.to_seed(mnemonic: mnemonic) # 2. 该助记词使用 PBKDF2 转化为种子(参见 BIP39)
      Wallet.from_seed(seed, path)
    end
    
    def self.from_xpub(xpub)
      wallet_node = MoneyTree::Node.from_bip32(xpub)
      Wallet.new(wallet_node)
    end

    def xpub
      @wallet_node.to_bip32
    end

    def xprv
      @wallet_node.to_bip32(:private)
    end

    private

    def initialize(wallet_node)
      @wallet_node = wallet_node
    end

  end

end

Version data entries

4 entries across 4 versions & 1 rubygems

Version Path
bip44-0.2.6 lib/bip44/wallet.rb
bip44-0.2.5 lib/bip44/wallet.rb
bip44-0.2.4 lib/bip44/wallet.rb
bip44-0.2.3 lib/bip44/wallet.rb