从外网找的博客,自己翻译了一下,记录一下(留着以后用)。
/**
@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);
/**
@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);
/**
@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
中的相应金额,则必须恢复。
必须在任何其他错误时恢复。
必须发出 TransferSingle
或 TransferBatch
事件,以便反映所有余额变化(参见标准的“安全转移规则”部分)。
余额变化和事件必须遵循数组的顺序(_ids[0]/_values[0] 在 _ids[1]/_values[1] 之前,等等)。
在批处理中满足上述转移条件后,此函数必须检查_to
是否为智能合约(例如代码大小> 0)。如果是这样,它必须在 _to
上调用相关的 ERC1155TokenReceiver
钩子并采取适当的行动(参见标准的“安全传输规则”部分)。
@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;
/**
@notice 查询给定所有者的操作员的批准状态。
@param _owner 代币的拥有者
@param _operator 授权运营商的地址
@return 如果运营商被批准为真,否则为假
*/
function isApprovedForAll(address _owner, address _operator) external view returns (bool);
}