ERC1155

2024-07-29 18:50:38 浏览数 (1)

从外网找的博客,自己翻译了一下,记录一下(留着以后用)。

/** @title ERC-1155 Multi Token Standard @dev 参见 https://eips.ethereum.org/EIPS/eip-1155 注意:此接口的 ERC-165 标识符为 0xd9b67a26。 / interface ERC1155 / is ERC165 / { /* @dev 无论是 TransferSingle 还是 TransferBatch 都必须在代币转移时发出,包括零值转移以及铸造或燃烧(参见“安全转移规则”部分标准)。 _operator 参数必须是被批准进行转账的账户/合约的地址(应该是 msg.sender)。 _from 参数必须是余额减少的持有者的地址。 _to 参数必须是余额增加的收件人的地址。 _id 参数必须是被传输的令牌类型。 _value 参数必须是持有者余额减少的代币数量,并与接收者余额增加的数量相匹配。 在铸造/创建令牌时,_from 参数必须设置为 0x0(即零地址)。 当销毁/销毁令牌时,_to 参数必须设置为 0x0(即零地址)。 */ event TransferSingle(address indexed _operator, address indexed _from, address indexed _to, uint256 _id, uint256 _value);

代码语言:javascript复制
/** 
    @dev `TransferSingle` 或 `TransferBatch` 必须在代币传输时发出,包括零值传输以及铸造或燃烧(参见标准的“安全传输规则”部分)。      
    `_operator` 参数必须是被批准进行转账的账户/合约的地址(应该是 msg.sender)。
    `_from` 参数必须是余额减少的持有者的地址。
    `_to` 参数必须是余额增加的收件人的地址。
    `_ids` 参数必须是正在传输的令牌列表。
    `_values` 参数必须是代币数量列表(与 _ids 中指定的代币列表和顺序匹配),持有者余额减少并匹配接收者余额增加的数量。
    在铸造/创建令牌时,`_from` 参数必须设置为 `0x0`(即零地址)。
    当销毁/销毁令牌时,`_to` 参数必须设置为 `0x0`(即零地址)。                
*/
event TransferBatch(address indexed _operator, address indexed _from, address indexed _to, uint256[] _ids, uint256[] _values);

/** @dev 必须在允许或禁用第二方/运营商地址管理所有者地址的所有令牌时发出(没有事件假定已禁用)。 */ event ApprovalForAll(address indexed _owner, address indexed _operator, bool _approved);

/** @dev 必须在为令牌 ID 更新 URI 时发出。 URI 在 RFC 3986 中定义。URI 必须指向符合“ERC-1155 元数据 URI JSON 模式”的 JSON 文件。 */ event URI(string _value, uint256 indexed _id);

代码语言:javascript复制
/** 
    @notice 从 `_from` 地址转移 `_value` 数量的 `_id` 到指定的 `_to` 地址(带安全调用)。
    @dev Caller 必须获得批准才能管理从 `_from` 帐户转出的代币(请参阅标准的“批准”部分)。
    如果 `_to` 是零地址,则必须恢复。
    如果代币“_id”的持有者余额低于发送的“_value”,则必须恢复。
    必须在任何其他错误时恢复。
    必须发出 `TransferSingle` 事件以反映余额变化(参见标准的“安全转移规则”部分)。
    满足上述条件后,该函数必须检查 `_to` 是否为智能合约(例如代码大小 > 0)。如果是这样,它必须在 `_to` 上调用 `onERC1155Received` 并采取适当的行动(参见标准的“安全传输规则”部分)。        
    @param _from 源地址
    @param _to 目标地址
    @param _id 令牌类型的 ID 
    @param _value 传输量 @param _data
    没有指定格式的附加数据,必须在调用 `_to` 上的 `onERC1155Received` 时不变地发送
*/
function safeTransferFrom(address _from, address _to, uint256 _id, uint256 _value, bytes calldata _data) external;

/** @notice 将 _values 数量的 _ids_from 地址转移到指定的 _to 地址(带安全调用)。 @dev Caller 必须获得批准才能管理从 _from 帐户转出的代币(请参阅标准的“批准”部分)。 如果 _to 是零地址,则必须恢复。 如果 _ids 的长度与 _values 的长度不同,则必须恢复。 如果 _ids 中代币持有者的任何余额低于发送给接收者的 _values 中的相应金额,则必须恢复。 必须在任何其他错误时恢复。 必须发出 TransferSingleTransferBatch 事件,以便反映所有余额变化(参见标准的“安全转移规则”部分)。 余额变化和事件必须遵循数组的顺序(_ids[0]/_values[0] 在 _ids[1]/_values[1] 之前,等等)。 在批处理中满足上述转移条件后,此函数必须检查_to 是否为智能合约(例如代码大小> 0)。如果是这样,它必须在 _to 上调用相关的 ERC1155TokenReceiver 钩子并采取适当的行动(参见标准的“安全传输规则”部分)。

代码语言:javascript复制
    @param _values 每种令牌类型的传输量(顺序和长度必须与 _ids 数组匹配)
    @param _data 没有指定格式的附加数据,必须在调用 `_to` 上的 `ERC1155TokenReceiver` 钩子时保持不变发送
*/
function safeBatchTransferFrom(address _from, address _to, uint256[] calldata _ids, uint256[] calldata _values, bytes calldata _data) external;

  /** 
    @notice 获取账户代币余额。
    @param _owner 代币持有者地址
    @param _id 代币ID 
    @return 请求代币类型的_owner 余额
 */ 
function balanceOf(address _owner, uint256 _id) external view returns (uint256);

/** 
    @notice 获取多个账户/代币对的余额
    @param _owners 代币持有者的地址
    @param _ids 代币的ID 
    @return _owner 所请求代币类型的余额(即每个(owner, id)的余额) pair) 
 */ 
function balanceOfBatch(address[] calldata _owners, uint256[] calldata _ids) external view returns (uint256[] memory);

/** @notice 启用或禁用第三方(“运营商”)管理所有调用者令牌的批准。 @dev 必须在成功时发出 ApprovalForAll 事件。 @param _operator 添加到授权运营商集合的地址 @param _approved 如果运营商获得批准,则为真,撤销批准为假 */ function setApprovalForAll(address _operator, bool _approved) external;

代码语言:javascript复制
  /** 
    @notice 查询给定所有者的操作员的批准状态。
    @param _owner 代币的拥有者
    @param _operator 授权运营商的地址
    @return 如果运营商被批准为真,否则为假
*/ 
function isApprovedForAll(address _owner, address _operator) external view returns (bool);

}

0 人点赞