什么是NYM?这与VERINYM有何关系

时间:2018-10-05 14:07:55

标签: hyperledger-indy

在Hyperledger Indy文档和代码中,我经常看到对NYM的引用,但是在official glossary中找不到这意味着什么的清晰描述。

什么是NYM?这与VERINYM有何不同?

3 个答案:

答案 0 :(得分:1)

DID大致分为Verinym或Pseudonym。

创建分类帐已知的DID被称为Verinym,用于创建Verinym的交易被称为NYM跨事务。

查看getting started教程以了解更多详细信息。

答案 1 :(得分:1)

当我刚进入代码时,我有同样的问题。然后我在英语词典网站上找到了这个

nym = nim = nom = name

例如:笔名:)

答案 2 :(得分:1)

文档 here (on hyperledger-indy.readthedocs.io)here (github.com) 中提供了有关 NYM 的其他信息:

所以从第二个链接:

纽约

为特定用户、背书人、管理员或受托人创建新的 NYM 记录。请注意,只有受托人和管理人才能创建新的背书人,而受托人只能由其他受托人创建(请参阅roles)。

该交易可用于创建新的 DID、设置和轮换验证密钥、设置和更改角色。

  • dest(base58 编码的字符串):

目标 DID 作为 16 或 32 字节 DID 值的 base58 编码字符串。它可能不同于 from 元数据字段,其中 from 是提交者的 DID。如果它们相等(在无需许可的情况下),则交易必须由新创建的 verkey 签名。

例如:from 是一个 Endorser 的 DID 创建一个新的 DID,dest 是一个新创建的 DID。

  • role(作为整数的枚举数;可选): 为其创建 NYM 记录的用户的角色。以下值之一
    • 无(普通用户)
    • “0”(受托人)
    • “2”(管家)
    • “101”(代言人)
    • “201”(NETWORK_MONITOR)

受托人可以将任何 Nym 的角色更改为 None,从而阻止其进行任何进一步的写入(请参阅 roles)。

  • verkey(base58 编码的字符串,可能以“~”开头;可选):

目标验证密钥为 base58 编码字符串。它可以以“~”开头,这意味着它是一个缩写的 verkey,解码时应该是 16 字节长,否则它是一个完整的 verkey,解码时应该是 32 字节长。如果未设置,则目标标识符 (did) 是 32 位密码 CID(已弃用),或者这是受监护的用户(尚未拥有该标识符)。 Verkey 可以由所有者更改为“None”,表示该用户在监护下返回。

  • alias(字符串;可选):

    NYM 的别名。

如果指定的 DID (did) 还没有 NYM 交易,那么这可以被认为是创建了一个新的 DID。

如果已经存在具有指定 DID (did) 的 NYM 事务,则这被视为该 DID 的更新。在这种情况下,只应指定需要更新的值,因为任何指定的值都被视为更新,即使它与账本中的当前值匹配。所有未指定的值保持不变。

因此,如果需要执行密钥轮换,则 DID 的所有者只需要发送带有 did 和 verkey 的 NYM 请求。角色和别名将保持不变。

示例:

{
    "ver": 1,
    "txn": {
        "type":"1",
        "ver": 1,        
        "protocolVersion":2,

        "data": {
            "dest":"GEzcdDLhCpGCYRHW82kjHd",
            "verkey":"~HmUWn928bnFT6Ephf65YXv",
            "role":101,
        },

        "metadata": {
            "reqId":1513945121191691,
            "from":"L5AD5g65TDQr1PPHHRoiGf",
            "digest": "4ba05d9b2c27e52aa8778708fb4b3e5d7001eecd02784d8e311d27b9090d9453",
            "payloadDigest": "21f0f5c158ed6ad49ff855baf09a2ef9b4ed1a8015ac24bccc2e0106cd905685",
            "taaAcceptance": {
                "taaDigest": "6sh15d9b2c27e52aa8778708fb4b3e5d7001eecd02784d8e311d27b9090d9453",
                "mechanism": "EULA",
                "time": 1513942017
             }
        },
    },
    "txnMetadata": {
        "txnTime":1513945121,
        "seqNo": 10,
        "txnId": "N22KY2Dyvmuu2PyyqSFKue|01"
    },
    "reqSignature": {
        "type": "ED25519",
        "values": [{
            "from": "L5AD5g65TDQr1PPHHRoiGf",
            "value": "4X3skpoEK2DRgZxQ9PwuEvCJpL8JHdQ8X4HDDFyztgqE15DM2ZnkvrAh9bQY16egVinZTzwHqznmnkaFM4jjyDgd"
        }]
    }

}