Internet Computerには、Principalという識別子があります。
Principalによって、Canisterを呼び出したユーザーや別のCanisterを識別することができます。
Principalはユーザーの公開鍵(または秘密鍵)から導出されますが、どのように組み立てられているかアルゴリズムの解説サイトがありましたので、実際に検証してみることにします。
https://5n2bt-lqaaa-aaaae-aajfa-cai.raw.icp0.io/arrow-up-right
We convert a DER public key to a principal IDs by computing its SHA224 hash then appending the byte 02, indicating a self-authenticating ID in Internet Computer parlance. Like other principal IDs, we can cook self-authenticating IDs by prepending a CRC32 checksum, encoding with base32, and inserting dashes. Some tools expect these
dfxコマンドを使っている方であれば、defaultのIdentityが以下に格納されているかと思います。
コピー ~ /.config/dfx/identity/default/identity.pem 自分のテスト環境では、以下のPrincipalでしたので、この値を 秘密鍵 → 公開鍵 → Principal という流れで求めてみることにします。
コピー $ dfx identity get-principal
rjfvh-5kjv6-svpk2-vf3sl-h24gi-qwmfe-22o2e-jcxqg-im5h6-2apbx-hqe (1) 秘密鍵(PEM形式)から公開鍵(DER形式)を出力
コピー $ openssl ec -in ~/.config/dfx/identity/default/identity.pem -pubout -outform DER バイナリですので、中身を確認したい場合は| hexdump -Cのようにパイプでつなげるとよいでしょう。
公開鍵(DER形式)のsha224ハッシュを求めます。
(3) 末尾に'02'追加 (Principal ID raw)
末尾に付与するbyteは以下のようです。
public key (self-authenticating ID)
Principal ID (raw)のCRC32を計算します。
(5) 先頭にCRC32を追加してBase32
CRC32値 (8a4b53f)をPrincipal ID (raw)の先頭に追加した値をBase32エンコードします。
(6) 小文字化して、5桁ずつ区切る
Base32エンコード値を見やすいように整形します。
Principal導出スクリプト
上記の内容をまとめたスクリプトを用意してみました。
derivePrincipal.sharrow-up-right
あくまでも学習目的で用意したものにすぎませんので内容は保証しません。
実際の運用では、公式のdfx identity get-principalコマンドなどをお使いください。