account

package
v1.2.1-0...-2ff222c Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Sep 29, 2021 License: GPL-3.0 Imports: 19 Imported by: 8

Documentation

Overview

Copyright 2017 The go-ethereum Authors This file is part of the go-ethereum library.

The go-ethereum library is free software: you can redistribute it and/or modify it under the terms of the GNU Lesser General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version.

The go-ethereum library is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License for more details.

You should have received a copy of the GNU Lesser General Public License along with the go-ethereum library. If not, see <http://www.gnu.org/licenses/>.

  • Copyright (C) 2019 Zilliqa *
  • This program is free software: you can redistribute it and/or modify
  • it under the terms of the GNU General Public License as published by
  • the Free Software Foundation, either version 3 of the License, or
  • (at your option) any later version. *
  • This program is distributed in the hope that it will be useful,
  • but WITHOUT ANY WARRANTY; without even the implied warranty of
  • MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  • GNU General Public License for more details. *
  • You should have received a copy of the GNU General Public License
  • along with this program. If not, see <https://www.gnu.org/licenses/>.

Index

Constants

This section is empty.

Variables

View Source
var DefaultBaseDerivationPath = DerivationPath{0x80000000 + 44, 0x80000000 + 60, 0x80000000 + 0, 0, 0}

DefaultBaseDerivationPath is the base path from which custom derivation endpoints are incremented. As such, the first account will be at m/44'/60'/0'/0/0, the second at m/44'/60'/0'/0/1, etc.

View Source
var DefaultRootDerivationPath = DerivationPath{0x80000000 + 44, 0x80000000 + 60, 0x80000000 + 0, 0}

DefaultRootDerivationPath is the root path to which custom derivation endpoints are appended. As such, the first account will be at m/44'/60'/0'/0, the second at m/44'/60'/0'/1, etc.

View Source
var LegacyLedgerBaseDerivationPath = DerivationPath{0x80000000 + 44, 0x80000000 + 60, 0x80000000 + 0, 0}

LegacyLedgerBaseDerivationPath is the legacy base path from which custom derivation endpoints are incremented. As such, the first account will be at m/44'/60'/0'/0, the second at m/44'/60'/0'/1, etc.

Functions

func ToFile

func ToFile(privateKey, passphrase string, t crypto.KDFType) (string, error)

Types

type Account

type Account struct {
	PrivateKey []byte
	PublicKey  []byte
	Address    string
}

func FromFile

func FromFile(file, passphrase string) (*Account, error)

func NewAccount

func NewAccount(privateKey []byte) *Account

func NewDefaultHDAccount

func NewDefaultHDAccount(mnemonic string, index uint32) (*Account, error)

func NewHDAccountWithDerivationPath

func NewHDAccountWithDerivationPath(mnemonic, path string) (*Account, error)

type BatchSendingResult added in v1.1.0

type BatchSendingResult struct {
	Index       int
	Hash        string
	ErrMsg      string
	Transaction *transaction.Transaction
}

type DerivationPath

type DerivationPath []uint32

DerivationPath represents the computer friendly version of a hierarchical deterministic wallet account derivaion path.

The BIP-32 spec https://github.com/bitcoin/bips/blob/master/bip-0032.mediawiki defines derivation paths to be of the form:

m / purpose' / coin_type' / account' / change / address_index

The BIP-44 spec https://github.com/bitcoin/bips/blob/master/bip-0044.mediawiki defines that the `purpose` be 44' (or 0x8000002C) for crypto currencies, and SLIP-44 https://github.com/satoshilabs/slips/blob/master/slip-0044.md assigns the `coin_type` 60' (or 0x8000003C) to Ethereum.

The root path for Ethereum is m/44'/60'/0'/0 according to the specification from https://github.com/ethereum/EIPs/issues/84, albeit it's not set in stone yet whether accounts should increment the last component or the children of that. We will go with the simpler approach of incrementing the last component.

func ParseDerivationPath

func ParseDerivationPath(path string) (DerivationPath, error)

ParseDerivationPath converts a user specified derivation path string to the internal binary representation.

Full derivation paths need to start with the `m/` prefix, relative derivation paths (which will get appended to the default root path) must not have prefixes in front of the first element. Whitespace is ignored.

func (DerivationPath) MarshalJSON

func (path DerivationPath) MarshalJSON() ([]byte, error)

MarshalJSON turns a derivation path into its json-serialized string

func (DerivationPath) String

func (path DerivationPath) String() string

String implements the stringer interface, converting a binary derivation path to its canonical representation.

func (*DerivationPath) UnmarshalJSON

func (path *DerivationPath) UnmarshalJSON(b []byte) error

UnmarshalJSON a json-serialized string back into a derivation path

type Wallet

type Wallet struct {
	Accounts       map[string]*Account
	DefaultAccount *Account
}

func NewWallet

func NewWallet() *Wallet

func (*Wallet) AddByKeyStore

func (w *Wallet) AddByKeyStore(keystore, passphrase string)

func (*Wallet) AddByPrivateKey

func (w *Wallet) AddByPrivateKey(privateKey string)

func (*Wallet) CreateAccount

func (w *Wallet) CreateAccount()

func (*Wallet) SendBatch added in v1.1.0

func (w *Wallet) SendBatch(signedTransactions []*transaction.Transaction, provider provider.Provider) []BatchSendingResult

Send transactions sequentially

func (*Wallet) SendBatchAsync added in v1.1.0

func (w *Wallet) SendBatchAsync(signedTransactions []*transaction.Transaction, provider provider.Provider, batchNum int) []BatchSendingResult

Send transactions using golang WaitGroup

func (*Wallet) SendBatchOneGo added in v1.1.0

func (w *Wallet) SendBatchOneGo(signedTransactions []*transaction.Transaction, p provider.Provider) ([]BatchSendingResult, error)

Send transactions using JSON-RPC batch request https://www.jsonrpc.org/specification#batch

func (*Wallet) SetDefault

func (w *Wallet) SetDefault(address string)

func (*Wallet) Sign

func (w *Wallet) Sign(tx *transaction.Transaction, provider provider.Provider) error

func (*Wallet) SignBatch added in v1.1.0

func (w *Wallet) SignBatch(transactions []*transaction.Transaction, provider provider.Provider) error

func (Wallet) SignBatchWithNonce added in v1.1.0

func (w Wallet) SignBatchWithNonce(transactions []*transaction.Transaction, provider provider.Provider, nonce int64) error

func (*Wallet) SignWith

func (w *Wallet) SignWith(tx *transaction.Transaction, signer string, provider provider.Provider) error

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL