ERC1155

简介: 从外网找的博客,自己翻译了一下,记录一下

/**

@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);



相关文章
|
存储 供应链 Oracle
探究ERP系统的云端部署与SaaS模式
探究ERP系统的云端部署与SaaS模式
1415 0
|
NoSQL 算法 Linux
秋招无望,五个C++项目助你上岸(可以写进简历)
秋招无望,五个C++项目助你上岸(可以写进简历)
|
机器学习/深度学习 人工智能 算法
【机器学习基础】K-Means聚类算法
【机器学习基础】K-Means聚类算法
477 0
|
JavaScript 前端开发 HTML5
分享9款漂亮的浪漫情侣网站模板
  当你需要在短时间内制作出一个网站的时候,模板就非常有用了。这篇文章收集了9款漂亮又浪漫的情侣网站模板分享给大家,您可以免费下载使用,希望这些网站模板能帮助到您。 Love and Romance 1 下载模板 Love and Romance 2 下载模板 Love and R...
5443 0
|
存储 缓存 关系型数据库
|
10月前
|
NoSQL Redis Docker
Docker——阿里云服务器利用docker搭建redis集群
本文详细记录了使用Docker搭建Redis集群的过程,包括检查Docker和Docker Compose的安装、创建Redis配置文件、编写`docker-compose.yml`文件、启动Redis节点、创建Redis集群的具体步骤,以及最终的验证方法。文章还提供了在多服务器环境下搭建Redis集群的注意事项,帮助读者全面了解 Redis 集群的部署流程。
1218 68
|
11月前
|
JSON 数据格式 Python
X86架构属于国产化架构吗
在信息时代,处理器架构至关重要。本文通过简单流程和代码示例,帮助初学者理解X86架构是否属于国产化架构。首先明确国产化架构指本土研发的处理器架构,如龙芯、飞腾等。X86架构由Intel设计,主要由外资公司开发,通常不被视为国产架构。文章提供了一个判断X86架构是否国产化的流程图,并用Python代码实现判断过程。Architecture类描述架构来源和类型,App类负责获取和判定架构信息。通过这些步骤,初学者可以更好地掌握相关知识并提升开发技能。
918 5
|
运维 Kubernetes 负载均衡
深入探索Kubernetes在微服务架构中的应用
【10月更文挑战第18天】深入探索Kubernetes在微服务架构中的应用
403 0
|
应用服务中间件 Linux nginx
nginx + geoip2简明配置
有时候需要nginx结合IP地址库做一些事情,比如过滤掉某个国家的IP,该如何做呢?