BAB:Code Review 回顾:算法稳定币 Basis_ASI价格

2021年1月6日晚上9点,我们组织大家一起review了算法稳定币中的Basis,视频回顾在这里:https://www.bilibili.com/video/BV1bK4y157aR/,非常感谢菠菜的分享。

目前的稳定币一共分为三种:

锚定法币,比如USDT和USDC,也包括交易所发行的稳定币,例如BUSD、HUSD等。

链上资产抵押型,比如MakerDAO的DAI和Synthetix的sUSD。

算法稳定币,比如AMPL、ESD、Frax,还有今天要说的Basis。

算法稳定币经历了几个阶段,basis是一个很新的项目,采用了三币模型。

Basis机制

Basis有三个币:BAC、BAS、BAB,三者相当于货币,股票和债券。可以将Basis理解为一个央行,BAC是央行发行的货币;BAS是央行的股东持有的股票,需要承担系统风险,也获取系统的收益;BAB是债券,相当于央行的债券。这3个都是erc20token,BAB目前没有日期限制,只要在合适的价格就可以兑付。

Wombat Gamers项目Discord服务器遭入侵:金色财经消息,据CertiK监测,Wombat Gamers项目Discord服务器遭入侵,有黑客发布钓鱼链接。请用户勿与相关链接交互。[2023/6/16 21:41:18]

BAC价格调节机制就是一个市场供需的调节机制。

当BAC价格少于1美元,需要减少BAC流通,让BAC的价格自然上升到1美元

BAC价格少于1美元,用户可以用申购债券BAB,方式是销毁BAC,得到BAB

BAB价格=BAC价格的平方,因为BAC价格小于1,所以平方后的BAB的价格会更低

未来可以用一个BAB换回一个BAC

当BAC价格超过1美元,需要增加BAC流通,让BAC的价格自然下降到1美元

澳大利亚政府建议遭受网络攻击后禁止支付加密货币:金色财经报道,在一家当地企业遭受大规模数据泄露和随后的赎金要求之后,澳大利亚政府被迫禁止支付网络赎金,通常要求以加密货币形式支付。

澳大利亚金融机构 Latitude Financial 于 3 月 16 日首次宣布受到网络攻击,并于 4 月 11 日提供了更新,表明它收到了拒绝支付的赎金要求:“根据网络犯罪专家的建议,Latitude 坚信支付赎金将对我们的客户不利,并通过鼓励进一步的犯罪攻击对更广泛的社区造成伤害。”

这次攻击导致大约 790 万个澳大利亚和新西兰驾照号码被盗,此外还有 610 万个客户记录、53,000 个护照号码和 100 份客户财务报表。

澳大利亚政府的主要网络安全机构澳大利亚网络安全中心 (ACSC) 目前建议勒索软件攻击的受害者永远不要支付赎金,称不能保证信息会被退回而不是在网上出售。[2023/4/12 13:58:55]

目前的阈值是当BAC>1.05时,可以触发系统增发BAC

动态 | Codebase Ventures子公司测试以太坊游戏加密猫:金色财经报道,Codebase Ventures区块链子公司Arcology正在其区块链网络上测试基于以太坊的游戏CryptoKitties(加密猫)。由于交易量大,该游戏可能会造成严重的网络拥堵。Arcology提供了一个允许并行处理多笔交易的解决方案,可以根据可用的计算机数量线性扩大交易处理。[2020/2/20]

增发的BAC会发给持有BAB和BAS的用户

优先还债,所以先给持有BAB的用户,方式是销毁BAB,得到BAC

剩下的BAC给BAS持有人,如果没有剩余,则不给BAS持有人分配

BAS相当于股东,只有锁定到boardroom合约的BAS才能获得这部分收益

动态 | CyberCode Twins 将在奥克兰举行 EOS 智能合约研讨会:据 IMEOS 报道,CyberCode Twins 发推宣布在 EOS 黑客马拉松旧金山站前一天,也就是11 月 9 日将在美国奥克兰举行 EOS 智能合约研讨会,旨在向参会者讲解如何设置开发环境,EOS 智能合约,以及帮助以太坊token 迁移至 EOS 主网的 EOS21 协议。[2018/10/28]

代码解读

源码:https://github.com/Basis-Cash/basiscash-protocol

treasury.sol

合约中主要的方法包括:

setFund:修改社区发展基金接收地址?

setFundAllocationRate:修改社区发展基金从BAC增发中接收的比率?

Kocodo成功测试第一个可扩展的原子交换解决方案:Kocodo(KMD)是Zcash的一个分支,宣布它已经成功测试了第一个可扩展原子交换解决方案。原子交换或原子交叉链交易是将一种加密货币交换为另一种加密货币,而不需要信任第三方。原子交叉链交易正在改变用户之间的交易方式。

Kocodo专注于授权两类用户:区块链企业家和平均加密货币投资者。提供了与比特币网络一样强大的独特而创新的安全形式。它建立在现有最先进的区块链安全形式-工作证明技术(PoW)上。[2018/2/12]

getBondOraclePrice:通过预言机获取Uniswap上BAB的价格?

getSeigniorageOraclePrice:通过预言机获取Uniswap上BAC的价格

bugBonds:购买债券,targetPrice参数是给前端进行校验的,只有当BAC小于1美元才能执行

redeemBonds:赎回债券,BAC价格要大于1.05美元才能执行

allocateSeigniorage:分配系统收入

价格小于1.05不执行,大于1.05才计算发多少钱

需要在一个epoch开始后才能执行,代码中的checkEpoch是1个modifier,用来检查这个条件

计算增发量,并增发

uint256?seigniorage?=?cashSupply.mul(percentage).div(1e18);?

IBasisAsset(cash).mint(address(this),?seigniorage);

每次增发的总量的2%会进入到CommunityDevelopmentFund

uint256?fundReserve?=?seigniorage.mul(fundAllocationRate).div(100);

IERC20(cash).safeApprove(fund,?fundReserve);

ISimpleERCFund(fund).deposit(...)

发给债券持有人

uint256?treasuryReserve?=?...;

accumulatedSeigniorage?=?accumulatedSeigniorage.add(treasuryReserve);

emit?TreasuryFunded(now,?treasuryReserve);

给股票持有人,也就是给boardroom

IBoardroom(boardroom).allocateSeigniorage(boardroomReserve);

Boardroom.sol

Boardroom相当于董事会,是Basis股份的持有者。合约的主要方法有:

allocateSeigniorage:计算可以分配多少钱?

claimReward:取钱操作

Timelock.sol

时间锁是治理体系不可或缺的一部分,通过Timelock限制超级用户对系统参数的修改,使普通用户有足够的时间进行决策,这里的Timelock,参数需要等待至少2天才能生效。

uint256?public?constant?MINIMUM_DELAY?=?2?days;uint256?public?constant?GRACE_PERIOD?=?14?days;uint256?public?constant?MAXIMUM_DELAY?=?30?days;

还有个巧妙的onlyOneBlock,限制1个块中只能有1个操作者,防止多次调用。

_status?=?true;_status?=?true;

总结

Basis的代码很巧妙,化繁为简,也很整洁,通过3种token的互相转化,保持价格稳定。AMPL的供应量是自动调整的,而Basis的token供应调整是通过激励用户的投机行为,让用户主动参与的。

郑重声明: 本文版权归原作者所有, 转载文章仅为传播更多信息之目的, 如作者信息标记有误, 请第一时间联系我们修改或删除, 多谢。

区块博客

[0:0ms0-3:466ms