github.com/yinchengtsinghua/golang-Eos-dpos-Ethereum@v0.0.0-20190121132951-92cc4225ed8e/accounts/abi/bind/auth.go (about)

     1  
     2  //此源码被清华学神尹成大魔王专业翻译分析并修改
     3  //尹成QQ77025077
     4  //尹成微信18510341407
     5  //尹成所在QQ群721929980
     6  //尹成邮箱 yinc13@mails.tsinghua.edu.cn
     7  //尹成毕业于清华大学,微软区块链领域全球最有价值专家
     8  //https://mvp.microsoft.com/zh-cn/PublicProfile/4033620
     9  //版权所有2016 Go Ethereum作者
    10  //此文件是Go以太坊库的一部分。
    11  //
    12  //Go-Ethereum库是免费软件:您可以重新分发它和/或修改
    13  //根据GNU发布的较低通用公共许可证的条款
    14  //自由软件基金会,或者许可证的第3版,或者
    15  //(由您选择)任何更高版本。
    16  //
    17  //Go以太坊图书馆的发行目的是希望它会有用,
    18  //但没有任何保证;甚至没有
    19  //适销性或特定用途的适用性。见
    20  //GNU较低的通用公共许可证,了解更多详细信息。
    21  //
    22  //你应该收到一份GNU较低级别的公共许可证副本
    23  //以及Go以太坊图书馆。如果没有,请参见<http://www.gnu.org/licenses/>。
    24  
    25  package bind
    26  
    27  import (
    28  	"crypto/ecdsa"
    29  	"errors"
    30  	"io"
    31  	"io/ioutil"
    32  
    33  	"github.com/ethereum/go-ethereum/accounts/keystore"
    34  	"github.com/ethereum/go-ethereum/common"
    35  	"github.com/ethereum/go-ethereum/core/types"
    36  	"github.com/ethereum/go-ethereum/crypto"
    37  )
    38  
    39  //newTransactior是一种实用方法,可以轻松地从中创建事务签名者
    40  //加密的JSON密钥流和相关的密码短语。
    41  func NewTransactor(keyin io.Reader, passphrase string) (*TransactOpts, error) {
    42  	json, err := ioutil.ReadAll(keyin)
    43  	if err != nil {
    44  		return nil, err
    45  	}
    46  	key, err := keystore.DecryptKey(json, passphrase)
    47  	if err != nil {
    48  		return nil, err
    49  	}
    50  	return NewKeyedTransactor(key.PrivateKey), nil
    51  }
    52  
    53  //NewKeyedTransactor是一种实用方法,可以轻松创建事务签名者
    54  //从单个私钥。
    55  func NewKeyedTransactor(key *ecdsa.PrivateKey) *TransactOpts {
    56  	keyAddr := crypto.PubkeyToAddress(key.PublicKey)
    57  	return &TransactOpts{
    58  		From: keyAddr,
    59  		Signer: func(signer types.Signer, address common.Address, tx *types.Transaction) (*types.Transaction, error) {
    60  			if address != keyAddr {
    61  				return nil, errors.New("not authorized to sign this account")
    62  			}
    63  			signature, err := crypto.Sign(signer.Hash(tx).Bytes(), key)
    64  			if err != nil {
    65  				return nil, err
    66  			}
    67  			return tx.WithSignature(signer, signature)
    68  		},
    69  	}
    70  }