以太坊 Eth源码解析:accounts账户管理源码分析(一)
作者:互联网
accounts账户管理源码分析(一)
###目录分析
目录总共如下:
首先看account.go文件,里面有一个account结构体,这也是账户的核心结构文件
``` json
Address common.Address `json:"address"` // 由密钥派生的以太坊账户地址
URL URL `json:"url"` // 可选的资源派生器
```
接下来是一个Wallet接口,也就是说只要实现了这个接口,就可以作为一个以太坊钱包来交互,里面包含了
URL,Status,SignData,SignText等方法,这些也是账户的加密和签名的实现和校验方法。
``` json
type Wallet interface
```
还有一个就是Backend接口,这个接口的主要作用是一个“钱包提供商”,可能包含他们可以使用的一批账户
来根据要求签署交易
``` json
type Backend interface
```
里面就定义了一个方法和一个订阅:
``` json
Wallets() []Wallet
Subscribe(sink chan<- WalletEvent) event.Subscription //创建一个异步订阅以接收通知,当
后端检测钱包的接入
```
###二、钱包管理manger.go文件
里面有一个manager结构体,里面记录的是钱包管理的一些事件
``` json
type Manager struct {
config *Config // Global account manager configurations
backends map[reflect.Type][]Backend // Index of backends currently registered
updaters []event.Subscription // 所有backends的订阅更新
updates chan WalletEvent // backends的订阅更新修改
newBackends chan newBackendEvent // Incoming backends to be tracked by the manager
wallets []Wallet // 钱包缓存
feed event.Feed // Wallet feed notifying of arrivals/departures
quit chan chan error
term chan struct{} // Channel is closed upon termination of the update loop
lock sync.RWMutex
}
```
还有就是一个NewManager 创建一个通用帐户管理器以通过各种支持的后端签署交易
剩下都是一个钱包事件的处理了:Subscribe,merge,drop
标签:账户,backends,chan,Wallet,源码,accounts,钱包,Eth 来源: https://www.cnblogs.com/michaelyang064/p/16533247.html