EIP-4973 を理解したい

EthereumEIP-4973ERC-4973

EIP を読む

まずは https://eips.ethereum.org/EIPS/eip-4973 を読もう。

EIP-4973: Account-bound Tokens An interface for non-transferrable NFTs binding to an Ethereum account like a legendary World of Warcraft item binds to a character.

とのことで、Soulbound Token 的なことを表現したいように思える。

概念的な Soul を扱うのはたいへんだから、まずは少なくとも Account に紐づけるような堅実な実装を目指している印象。

関数のインターフェイスは以下の通り。ERC-721 と比べると transfer 系がないのがわかる。

function balanceOf(address owner) external view returns (uint256);
function ownerOf(uint256 tokenId) external view returns (address);
function unequip(uint256 tokenId) external;
function give(address to, string calldata uri, bytes calldata signature) external returns (uint256);
function take(address from, string calldata uri, bytes calldata signature) external returns (uint256);

givetake があるってことは、二者間の合意にもとづいた受け渡しはできるってことかね〜。

unequip がとても重要そうな印象を受ける。が、説明を読んでもよくわからなかった。

実装を読む

https://github.com/rugpullindex/ERC4973/blob/master/src/ERC4973.sol を読んでみよう。

import {SignatureChecker} from "@openzeppelin/contracts/utils/cryptography/SignatureChecker.sol";
import {EIP712} from "@openzeppelin/contracts/utils/cryptography/draft-EIP712.sol";
import {ERC165} from "@openzeppelin/contracts/utils/introspection/ERC165.sol";
import {BitMaps} from "@openzeppelin/contracts/utils/structs/BitMaps.sol";

知らないことだらけだ。

知らないことは、別途で理解を進めていく。

関数 unequip は「トークンを捨てる」みたいな感じかねぇ。英単語 equip の否定形で「装備を外す」的な? Account-bound Tokens において装備を外すってのはそのトークンは誰にも使えなくなる、って理解で合っているだろうか。

function unequip(uint256 tokenId) public virtual override {
  require(msg.sender == ownerOf(tokenId), "unequip: sender must be owner");
  _usedHashes.unset(tokenId);
  _burn(tokenId);
}

まとめ

  • transfer のように一方的に送りつけたりはできないっぽい
  • give と take によって、双方の合意のもとに受け渡しすることはできるっぽい?
  • unequip によって誰も二度と使えない状態にできるっぽい

ここから先は、ERC-4973 を実装したトークンを発行して誰かといっしょに触ってみるのがいいだろう。