NEO改进协议提案6(NEP-6)

文章目录

  • 摘要
  • 动机
  • 基本原理
  • 详述
    • 钱包
    • Scrypt参数
    • 帐户
    • 合约
  • 向后兼容性
  • 实现

 

摘要

本NEP描述了一个钱包标准用于钱包文件在NEO多种实现间的兼容。git

动机

目前,不一样的客户端程序生成不一样的钱包文件。它们具备不一样的文件格式,不一样的存储方式以及不一样的加密方式。用户很难在不一样的客户端程序之间进行迁移,由于钱包文件的格式不一样。尽管能够经过导出私钥来实现迁移,可是对于具备多个私钥的钱包来讲是很麻烦的。咱们须要一种通用钱包格式,容许用户安全轻松地跨全部平台迁移,而无需更改钱包文件或导出私钥。github

基本原理

钱包标准应考虑安全性和跨平台兼容性。为了安全起见,咱们要求实现使用NEP-2机制来加密或解密私钥。对于跨平台,咱们使用JSON格式来描述钱包文件,以即可以在每一个平台上轻松识别钱包文件的内容。算法

详述

钱包

Json格式的钱包文件具备如下的基础结构:
{
“name”: “MyWallet”,
“version”: “1.0”,
“scrypt”: {},
“accounts”: [],
“extra”: null
}
name是用户对钱包文件所作的标签。
version目前固定为1.0,未来用于功能性升级。
scrypt是一个ScryptParameters对象,用于描述钱包私钥加密解密用的SCrypt算法的参数。
accounts是一个Account对象数组,用于描述钱包中每一个账户的详细信息。
extra是由客户端的实现者定义,用于存储额外的数据。该字段能够为null。数组

Scrypt参数

ScryptParameters 对象具备一下结构:
{
“n”: 16384,
“r”: 8,
“p”: 8
}
n是定义CPU /内存开销的参数。必须是2 ^ N的值。
r是调整参数。
p是调整参数(并行参数)。大的p值能够在不增长内存使用量的状况下增长SCrypt的计算成本。安全

帐户

帐户对象具备如下结构:
{
“address”: “AQLASLtT6pWbThcSCYU1biVqhMnzhTgLFq”,
“label”: “MyAddress”,
“isDefault”: true,
“lock”: false,
“key”: “6PYWB8m1bCnu5bQkRUKAwbZp2BHNvQ3BQRLbpLdTuizpyLkQPSZbtZfoxx”,
“contract”: {},
“extra”: null
}
address 是帐户的base58编码地址
label是用户对钱包作的标签
isDefault 表明帐户是不是默认找零地址
lock表示账户是否被用户锁定。客户端不能花费锁定账户中的资金。
key是账户私钥的NEP-2格式。此字段能够为空(仅限观察地址或非标准地址)。
contract是一个Contract对象,用于描述合约的细节。该字段能够为null(仅限监视地址)。
extra是由客户端的实现者定义的用于存储额外数据的对象。该字段能够为null。函数

合约

合约对象有如下结构:
{
“script”: “21036dc4bf8f0405dcf5d12a38487b359cb4bd693357a387d74fc438ffc7757948b0ac”,
“parameters”: [],
“deployed”: false
}
script是合约的脚本代码。若是合约已经被部署在区块链上,则该值能够为null。
parameters是参数对象数组,用于描述合约函数中每一个参数的细节。须要更多参数对象的信息,能够查看NEP-3:NeoContractABI中的描述。区块链

向后兼容性

全部旧格式的钱包必需能够轻易转换成这种新的JSON格式。若是这些钱包文件包含额外的数据,能够被存储在extra值中。ui

实现

• neo-project/neo: https://github.com/neo-project/neo/blob/master/neo/Implementations/Wallets/NEP6/NEP6Wallet.cs
• CityOfZion/neon-js: https://github.com/CityOfZion/neon-js/blob/master/src/wallet/Wallet.js编码

原文连接:https://github.com/neo-project/proposals/blob/master/nep-6.mediawiki加密

相关文章
相关标签/搜索