12
4

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 3 years have passed since last update.

nemAdvent Calendar 2020

Day 10

オプトインは何してるの?

Last updated at Posted at 2020-12-09

オプトイン

Symbolの新しいブロックチェーンに、現行のNEMのチェーンの残高を引き継ぐためには、オプトインという作業が必要です。

Symbolでは、秘密鍵からアドレスまでの導出方法が変わりましたので、同じ秘密鍵を使っても異なる公開鍵やアドレスが生成されます。

なのでもう、Symbol用に新しく秘密鍵を生成して、そのアカウント情報を現行NEMのブロックチェーンに書き込むことによって、新旧のアカウントの紐づけを行うようになりました(推測)。

オプトイン作業の中で、このような画面でSymbolのアカウントが生成されます。

image.png

image.png

で、オプトインでは新しいアカウント情報を含んだトランザクションが送信されるのですが、それがどんな形なのかちゃんと見たことはなかったので、この機会に見ていこうと思います。

ちょっとやってみる

VRFなしで普通のアカウント

このようなアカウントが生成されました

mnemonic: (himitsu)
address: NANWI6-5UYYB3-B5SZKM-ZVIDVM-XZQ5KS-6KSMTN-4PI
publicKey: D8ADEF6ED85EDAEE06763A9C29504DD354ECB155C17F8DE06923C91BE095EC4F

公開鍵の導出方法

オプトイントランザクションを送信してみます

35f292b6880834948cabc80c20d982254e343037150cb2226da142e821e047c6

こんなメッセージが入った転送トランザクションが送信されました。

{
  "type": 1,
  "destination": "D8ADEF6ED85EDAEE06763A9C29504DD354ECB155C17F8DE06923C91BE095EC4F"
}

type1で、destinationに何か入っていますね。

見比べてみると、オプトイン時に生成されたアカウントの公開鍵だということがわかります。

これで、このトランザクションの送信者のアカウント(現行NEMアカウント)と、このメッセージに書かれているアカウントの情報(Symbolアカウント)が紐づけられました。

VRFありの普通のアカウント

オプトイン作業に、ハーベストがどうこうとかいって、VRFアカウントを作るかを聞かれます。

これをチェックしたら何か変わるのかやってみます。

このようなアカウントが生成されました

mnemonic: (himitsu)
address: NBVC4Q-LNWH7R-SKQHXL-F5NZQY-ERZSDS-DCZX6T-2TA
publicKey: 717082D8AFB7E9CDED9A1281F96CFB90C985752E19178503BDABA596B0721567
VrfPublicAddress: ND6QGD-27KHW5-YMBIOM-J7NEH2-OVRF2R-ZGWCUX-GEA
VrfPrivateKey: (himitsu)
VrfPublicKey: 93EC5F71BE10DA46CF092724FD0B63F95D4521301FDE424004CFE25AFF917FC5

公開鍵の導出方法

オプトイントランザクションを送信してみます

2つ送信されました。

type 1

4be498c0321de706f8abee91dbed60ee55ff6020c7b61ff9a1e33fc85c023fb2

{
  "type": 1,
  "destination": "717082D8AFB7E9CDED9A1281F96CFB90C985752E19178503BDABA596B0721567"
}

こちらは先ほどと同じで、type1で、destinationがオプトイン時に生成されたアカウントの公開鍵です。

type 6

2つ目のトランザクションです。

cce5929a70044535379b3df7df236430a2fcb4b7ba444c81ccb4ed6f1fdbc946

{
  "type": 6,
  "destination": "717082D8AFB7E9CDED9A1281F96CFB90C985752E19178503BDABA596B0721567",
  "payload": "A100000000000000489C21A3793B079454E6964FE46F30DD967558DEFFCC2BD54532FF0DA7CF13A60BFA8504A415363BB5195477FC833F5EA93C2A435CB06BC34D478CB82EC3F700717082D8AFB7E9CDED9A1281F96CFB90C985752E19178503BDABA596B072156700000000016843420000000000000000010000000000000093EC5F71BE10DA46CF092724FD0B63F95D4521301FDE424004CFE25AFF917FC501",
  "hash": "3CFF9BCAB2E3E9403681EA2CE20137E2F8B42AAC780DD463C97B024C7D77CDA3"
}

なんかいろいろあります。

destinationは、オプトイン時に生成されたアカウントの公開鍵です。

payloadは何だかSymbolのトランザクションのように見えました。ということは、hashはトランザクションハッシュかもしれません。

payloadを分解してみました。

size: A1000000
reserve: 00000000
signature: 489C21A3793B079454E6964FE46F30DD967558DEFFCC2BD54532FF0DA7CF13A60BFA8504A415363BB5195477FC833F5EA93C2A435CB06BC34D478CB82EC3F700
publicKey: 717082D8AFB7E9CDED9A1281F96CFB90C985752E19178503BDABA596B0721567
reserve: 00000000
version: 0168
type: 4342
fee: 0000000000000000
deadline: 0100000000000000
linkedPublicKey: 93EC5F71BE10DA46CF092724FD0B63F95D4521301FDE424004CFE25AFF917FC5
linkAction: 01

type0x4243なので、symbol-sdkを参考に、VRFキーリンクトランザクションであることがわかります。

オプトインの時に表示されたSymbolアカウントとVRFアカウントとリンクするトランザクションですね。

後は、手数料が無しで、期限が0x01であるところから、これがそのままSymbolチェーンのネメシスブロックに入りそうです。

試しにこのトランザクションのハッシュを計算してみると、ぴったりhashの値と一致しましたので、VRFキーリンクトランザクションのハッシュであることがわかりました。

この記事を書いている頃(2020年12月)では、委任ハーベストをするには、VRFリンクとアカウントリンクとノードリンクが必要なので、このトランザクションにはどれほどの意味があるのかはわかりません。

マルチシグ

1of1のマルチシグを作ってオプトインしました。基本的には連署者がオプトインするのですが、まず、連署者が自らのオプトインを完了している必要があるので、それを終わらせてから、マルチシグのオプトインをしました。

現行NEMのアカウントと、生成されたSymbolアカウントはこんな感じです。

nem1:
  multisig:
    address: NAZDWW2RWOVTBHTTLKQU6M5KCSSJTTEADCZYE5TS
    publicKey: 9bf8307e9f1b288cc0bc4a7279a151a2bb81b64fdd0561d7e912769f76997371
  cosigner:
    address: NBHRY4FDBJFZTP7MW3JBOBML7YEUNF6AGFRMHWVI
    publicKey: 0e00873e0efa602221440c2f3450982b76c2ba90f2d421893963401b268c7441
symbol:
  multisig:
    mnemonic: (himitsu)
    address: NDC2MR-SLL5FC-7AECLV-EB2AN7-SOIWXO-MPQZ5A-BTA
    publicKey: 01B4CC3E5E735C31187857CDDD00B6417C4689D8DD7A8120BADA6A1E38C58371
  cosigner:
    mnemonic: (himitsu)
    address: NBVC4Q-LNWH7R-SKQHXL-F5NZQY-ERZSDS-DCZX6T-2TA
    addressHex: 686a2e416db1ff192a07bacbd6e618247321c862cdfd3d4c
    publicKey: 717082D8AFB7E9CDED9A1281F96CFB90C985752E19178503BDABA596B0721567

公開鍵の導出方法

オプトインすると、トランザクションが3つ送信されました。

type 2

{
  "type": 2,
  "destination": "01B4CC3E5E735C31187857CDDD00B6417C4689D8DD7A8120BADA6A1E38C58371",
  "multisig": "9bf8307e9f1b288cc0bc4a7279a151a2bb81b64fdd0561d7e912769f76997371"
}

destinationにマルチシグアカウントの方のSymbolの公開鍵、multisigにはマルチシグアカウントの方のnem1の公開鍵がありました。

type1のマルチシグ版という感じですね。

type 3

{
  "type": 3,
  "d": "01B4CC3E5E735C31187857CDDD00B6417C4689D8DD7A8120BADA6A1E38C58371",
  "p": "F800000000000000EA349EB7107F9F07C338EFA92D689CBDF951942CC98E2165A7884050561DEC2A87BF957478758EB2DE107A080EB433E3B51205A57050E08F9CFBB52307A8E30B01B4CC3E5E735C31187857CDDD00B6417C4689D8DD7A8120BADA6A1E38C58371000000000168414100000000000000000100000000000000EA45E6D0778D60D930BBE461E8309642003DCD68F70DDE4CE9FEE147B8B099015000000000000000500000000000000001B4CC3E5E735C31187857CDDD00B6417C4689D8DD7A8120BADA6A1E38C5837100000000016855410101010000000000686A2E416DB1FF192A07BACBD6E618247321C862CDFD3D4C",
  "h": "17F752A6399550727919EB2EFFAC178D6F1DE964F06BABD711113020AD71D1DB"
}

たぶんSymbolでマルチシグアカウント作成するトランザクションを作っていると思います。dがdestinationでpがpayloadでhがhashだと思います。

文字が省略されているのは、payloadが長いからだと思います。1of1で655文字あるんですが、連署者が増えていくとどうなるんでしょう。

nem1の転送トランザクションのメッセージの長さって、APIドキュメントの3によると

The payload is allowed to have a maximal size of 1024 bytes.

ってあるけど、足りるのかな。

Symbolのマルチシグの連署者は、最大で15人だったはず。

1人の連署者で655バイト必要っで、14人を追加するとしたら、アドレスが24バイトだったと思うので、14*24=336バイト増加、合計991バイトなので、ギリギリ入るような気がしますね。

気を取り直してpを見ていきます。

size: F8000000
reserved: 00000000
signature: EA349EB7107F9F07C338EFA92D689CBDF951942CC98E2165A7884050561DEC2A87BF957478758EB2DE107A080EB433E3B51205A57050E08F9CFBB52307A8E30B
publicKey: 01B4CC3E5E735C31187857CDDD00B6417C4689D8DD7A8120BADA6A1E38C58371
reserved: 00000000
version: 0168
type: 4141
fee: 0000000000000000
deadline: 0100000000000000
aggregateHash: EA45E6D0778D60D930BBE461E8309642003DCD68F70DDE4CE9FEE147B8B09901
payloadSize: 50000000
reserved: 00000000
transactions:
  size: 50000000
  reserved: 00000000
  publicKey: 01B4CC3E5E735C31187857CDDD00B6417C4689D8DD7A8120BADA6A1E38C58371
  reserved: 00000000
  version: 0168
  type: 5541
  minRemovalDelta: 01
  minApprovalDelta: 01
  addressAdditionsCount: 01
  addressDeletionsCount: 00
  reserved: 00000000
  addressAdditions: 686A2E416DB1FF192A07BACBD6E618247321C862CDFD3D4C
cosignatures:

Symbol側でマルチシグアカウントを設定するようなトランザクションになっています。

type: 0x4141のアグリゲートコンプリートでラップして、中身はtype: 0x4155がのマルチシグモディフィケーショントランザクションです。

このトランザクションのハッシュを計算すると、hの値になりました。

type 4

{
  "type": 4,
  "multisig": "01B4CC3E5E735C31187857CDDD00B6417C4689D8DD7A8120BADA6A1E38C58371",
  "signature": "BF51455E759C3CF55C1104B2699183328181EBAD68FD7B53DF53A88F99F633CFAC08C9D2D6E8B3EABEC0B6F017017737440AB6C0C92B74BA7B1EE2B71475BD06"
}

ちょっとよくわかりませんでした。

Symbolでは、マルチシグアカウントを構成する際、連署者の全員の署名がないと、マルチシグにできないのですが、上記のトランザクションでは連署者の署名がありません。

なので、それを追加しているのではないかと思ったのですが、署名検証をうまく成功させることができませんでした。

もしかしたら、メッセージ欄の1024バイトの制限があったので、連署者の署名をわける必要があったのかもしれません。type3のトランザクションがアグリゲートコンプリートなのに、連署者の署名がないところからも、そういうにおいがしてきます。

type 5

ここまで3種類のオプトインをやってきて、トランザクションのメッセージにあるtypeについて、1,2,3,4,6が出たのですが、5がありません。

結論から言うと、これはネームスペースのオプトインです。ネームスペースを持っていないこと、借りるのに100XEM必要なので、試すのはやめました。

なので既にあるトランザクションを見ていきます。

{
  "type": 5,
  "destination": "8BCCF5FE753DE2F7848125F1CDB2DC2FE951B7E24A2234D3EDE0A5A609923264",
  "payload": "9700000000000000C39FD375377937ED4A476C92F30763831CD6B37F89D292FF3A772718186C36C3487D3FAC288BA844D129343348869658E59FBB06AD394CE668C5B983F14C86028BCCF5FE753DE2F7848125F1CDB2DC2FE951B7E24A2234D3EDE0A5A6099232640000000001684E4100000000000000000100000000000000801420000000000019DB28864028E2860005636F6D7361",
  "hash": "DE95921B8365072EE28B2DECA75ABE3E1B7213EE36239AD5E360B2BD6670A88D"
}
size: 97000000
reserved: 00000000
signature: C39FD375377937ED4A476C92F30763831CD6B37F89D292FF3A772718186C36C3487D3FAC288BA844D129343348869658E59FBB06AD394CE668C5B983F14C8602
publicKey: 8BCCF5FE753DE2F7848125F1CDB2DC2FE951B7E24A2234D3EDE0A5A609923264
reserved: 00000000
version: 0168
type: 4E41
fee: 0000000000000000
deadline: 0100000000000000
duration/parentId: 8014200000000000
namespaceId: 19DB28864028E286
NamespaceRegistrationType: 00
nameSize: 05
name: 636F6D7361

このネームスペースは、「636F6D7361」、utf8で「comsa」でした。

VRFアカウントについて

ここのソースを見る限り、オプトインをしたときに生成されたSymbolのニーモニックをもとに生成されています。

オプトイン後のアカウントがm/44'/4343'/0'/0'/0'で導出されるのに対し、VRFはm/44'/4343'/0'/1'/0'で導出されているようです。

オプトイントランザクションの宛先アドレスについて

何回かやってみた感じ、すべて同じ宛先に送られました。

NAQ7RCYM4PRUAKA7AMBLN4NPBJEJMRCHHJYAVA72

おそらくどこかにハードコーディングされているのでしょう。

このアドレスをNanoWalletのGitHubのソースを検索してみましたが、出てきませんでした。

しかし、NanoWalletのビルドしたものを検索すると、ハードコーディングしてあるのがわかります。

image.png

12
4
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
12
4

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?