DAOrayakiDAO研究奖金池:
资助地址:DAOrayaki
从现在开始,我们就可以通过添加--profilelocal命令以在本地测试网上运行它们。
ps:这里的--profile,就像是k8s里的kube-config,可以设置不同的profile环境,控制不同的网络。
profile的配置,会设置执行者地址、node-rest-api、faucet-api信息。
#列出cli控制的所有账户aptosaccountlist#为账户注资:aptosaccountfund--profile$PROFILE--account$PROFILE#创建新的资源账户aptosaccountcreate-resource-account--profile$PROFILE--seed1#编译move合约aptosmovecompile--package-dirhello_blockchain#部署合约aptosmovepublish--package-dirhello_blockchain--named-addressesbasecoin=--profilelocal#调用合约aptosmoverun--function-id::::--profilelocal#列出指定账户的modules/resources信息aptosaccountlist--querymodules--account0xa1285adb4b8abedf5faf7a46d260c5844f1f64d59dd9b8869db1543cf5bbadf4--profilelocalaptosaccountlist--queryresources--account0x4200c2b801870f20a709abba80b6edb90a45ecd9b8acce9842b93d597602edcf--profilelocal#合约升级aptosmovepublish--upgrade-policy`arbitrary`,`compatible`,`immutable`对应0,1,20不做任何检查,强制替换code,1做兼容性检查(同样的public函数,不能改变已有Resource的内存布局)2禁止升级每次publish的时候会比较链上的policy和此次publish的policy(默认是1),只有此次的policy小于链上的policy时才允许合约升级
MakerDAO已拨款5亿枚DAI,其中80%购买美国国债20%购买公司债券:10月6日消息,稳定币发行机构MakerDAO已拨款5亿枚DAI用于投资美国短期国债和公司债券,其中80%将购买美国短期国债,其余20%将购买投资级公司债券。
此前报道,MakerDAO在推特公布近几个月有关MakerDAO收入多元化的多项提案进展,其中有关流动债券策略与执行的MIP65提案以71.19%的投票率通过。(CoinDesk)[2022/10/6 18:41:12]
部署一个简单的Move合约
moduleMyCounterAddr::MyCounter{usestd::signer;structCounterhaskey,store{value:u64,}publicfuninit(account:&signer){move_to(account,Counter{value:0});}publicfunincr(account:&signer)acquiresCounter{letcounter=borrow_global_mut(signer::address_of(account));counter
publicentryfuninit_counter(account:signer){Self::init(&account。publicentryfunincr_counter(account:signer)acquiresCounter{Self::incr(&account。
MyCounter源码分析
module是发布在特定地址下的打包在一起的一组函数和结构体。使用script时需要与已发布的module或标准库一起运行,而标准库本身就是在0x1地址下发布的一组module。
moduleMyCounterAddr::MyCounter{}则在该MyCounterAddr地址下(对应Move
Struct&Abilities
structCounterhaskey,store{value:u64,}
YFI核心开发者:yvWETH MakerDAO策略存在会计逻辑缺陷,安全团队已修复:yearn.finance (YFI)核心开发者banteg表示,yvWETH MakerDAO策略的目标抵押率的提高揭示了会计逻辑中的缺陷,并导致该策略报告虚假损失。Yearn安全团队介入并提供了修复程序,没有资金损失。[2021/5/23 22:33:21]
使用struct定义了一个叫做Counter的结构体,同时被key,store两种限制符修饰。
Move的类型系统灵活,每种类型都可以定义四种能力。
它们定义了类型的值是否可以被复制、丢弃和存储。
这四种abilities限制符分别是:Copy,Drop,Store和Key。
它们的功能分别是:
Copy-值可以被复制。
Drop-在作用域结束时值可以被丢弃。
Key-值可以作为键值被「全局存储操作」进行访问。
Store-值可以被存储到全局状态。
这里用key、store修饰,则表示它不能被复制,也不能被丢弃或重新使用,但是它却可以被安全地存储和转移。
Abilities的语法
基本类型和内建类型的abilities是预先定义好的并且不可改变:integers,vector,addresses和boolean类型的值先天具有copy、drop和storeability。
然而,结构体的ability可以按照下面的语法进行添加:
structNAMEhasABILITY{}
一个简单的图书馆例子:
moduleLibrary{//eachabilityhasmatchingkeyword//multipleabilitiesarelistedwithcommastructBookhasstore,copy,drop{year:u64}//singleabilityisalsopossiblestructStoragehaskey{books:vector}//thisonehasnoabilitiesstructEmpty{}}
MakerDAO成8月份开发活跃第四高ERC-20项目:MakerDAO成为8月份开发活跃度第四高的ERC-20项目,Gnosis位列第一。[2020/9/4]
什么是Resource
Move白皮书中详细描述了Resource这个概念。最初,它是作为一种名为resource的结构体类型被实现,自从引入ability以后,它被实现成拥有Key和Store两种ability的结构体。Resource可以安全的表示数字资产,它不能被复制,也不能被丢弃或重新使用,但是它却可以被安全地存储和转移。
Resource的定义
Resource是一种用key和storeability限制了的结构体:
moduleM{structThaskey,store{field:u8}}Resource的限制
在代码中,Resource类型有几个主要限制:
Resource存储在帐户下。因此,只有在分配帐户后才会存在,并且只能通过该帐户访问。
一个帐户同一时刻只能容纳一个某类型的Resource。
Resource不能被复制;与它对应的是一种特殊的kind:resource,它与copyable不同,这一点在泛型章节中已经介绍。
Resource必需被使用,这意味着必须将新创建的Resourcemove到某个帐户下,从帐户移出的Resource必须被解构或存储在另一个帐户下。
刚才的案例
structCounterhaskey,store{value:u64,}
所以这里就有一个和solidity的区别了,在eth上如果需要发行一个新资产,比如usdc。那这个资产是记录在合约里的某个map中。而move就不同了,资产是作为resource存在用户地址下的。
定义函数
publicfuninit(account:&signer){move_to(account,Counter{value:0});}publicfunincr(account:&signer)acquiresCounter{letcounter=borrow_global_mut(signer::address_of(account));counter
YFI筹码分析:总共30000个 近三分之一在YDAO:微博大V“超级比特币”对DeFi代币YFI进行分析,详情如下:
YFI筹码分析:总共30000个。
1. 近三分之一在YDAO,参与治理,年化收益率4%;相当感人,这是很低的收益。好像“收益优先”法则在这里失效了。
2. Aave抵押借贷3300个,感人,很多人是抵押出USDT,再去买YFI。
3. Binance,2621个,搏杀。
4. 参与YFV挖矿500多个。
5. YFI的机关池500多个,在冰淇淋挖矿。[2020/8/30]
publicentryfuninit_counter(account:signer){Self::init(&account。publicentryfunincr_counter(account:signer)acquiresCounter{Self::incr(&account。
定义格式则是:
publicfun函数名(参数:参数类型){}
move函数默认是私有函数,只能在定义它们的模块中访问。关键字public将更改函数的默认可见性并使其公开,即可以从外部访问。
init方法参数是一个&signer,意味着该方法必须是一个账户合法签名过后才可以调用,move_to则是move的一个原语,作用是发布、添加Counter资源到signer的地址下。Move的账户模型,code和data是存储在一个账户地址下的。
下面是列举的常用原语
move_to<T>(&signer,T):发布、添加类型为T的Resource到signer的地址下。
move_from<T>(addr:address):T-从地址下删除类型为T的Resource并返回这个资源。
borrow_global<T>(addr:address):&T-返回地址下类型为T的Resource的不可变引用。
borrow_global_mut<T>(addr:address):&mutT-返回地址下类型为T的Resource的可变引用。
DeFi项目Curve将在未来几天发布治理论坛和DAO:去中心化稳定币交易协议Curve(CRV)团队成员Charlie发推表示,治理论坛和DAO将在未来几天发布。另外,从28日起,用户将能够投票锁定CRV获得高达2.5倍的流动性奖励。此前报道,Curve在8月初完成了CRV的初始预挖(pre-launch)活动,共计约9000个地址参与本次活动,初始预挖活动发放的代币会锁定1年的时间。8月中旬,Curve正式宣布发放代币CRV。CRV代币总供应量为30.3亿枚,初始发行数量为13亿枚。[2020/8/20]
exists<T>(address):bool:判断地址下是否有类型为T的Resource。
incr方法参数也是一个&signer,意味着该方法必须是一个账户合法签名过后才可以调用,
关键字acquires,放在函数返回值之后,用来显式定义此函数获取的所有Resource。
Signer::address_of(account)从签名者中拿到address
borrow_global_mut上面有介绍到,可变借用到address下的resourceCounter,然后将Counter结构体下的value进行+1操作。
这下面的两个方法则是script方法,它与上面两个函数有什么区别呢?
publicfun:方法可以在任何模块中被调用。
public(script)fun/publicentryfun:scriptfunction是模块中的入口方法,表示该方法可以通过控制台发起一个交易来调用,就像本地执行脚本一样
下个版本的Move会用publicentryfun替代public(script)fun
Self则是代表自身module。
使用AptosCli编译、部署、调用合约
#创建新的测试环境aptosinit--profiledevtest--rest-url--faucet-url#编译move合约aptosmovecompile--package-dirmy-counter#部署合约#例如:aptosmovepublish--package-dirmy-counter--named-addressesbasecoin=0x8e00bd9827faf171996ef37f006dd622bb5c3e43ec52298a8f37fd38cd59664--profiledevtestaptosmovepublish--package-dirmy-counter--named-addressesbasecoin=--profiledevtest#调用合约#例如:#aptosmoverun--function-id0x8e00bd9827faf171996ef37f006dd622bb5c3e43ec52298a8f37fd38cd59664::MyCounter::init_counter--profiledevtest#aptosmoverun--function-id0x8e00bd9827faf171996ef37f006dd622bb5c3e43ec52298a8f37fd38cd59664::MyCounter::incr_counter--profiledevtestaptosmoverun--function-id::::--profiledevtest#列出指定账户的modules/resources信息aptosaccountlist--querymodules--account0xa1285adb4b8abedf5faf7a46d260c5844f1f64d59dd9b8869db1543cf5bbadf4--profiledevtestaptosaccountlist--queryresources--account0x4200c2b801870f20a709abba80b6edb90a45ecd9b8acce9842b93d597602edcf--profiledevtest
AptosSDK调用Move合约
编译好合约之后,我们可以通过sdk调用我们的合约。
我们可以选择通过sdk部署合约,也可以通过sdk调用move合约。
通过sdk部署合约
当我们编译完成之后,会在move合约文件夹下生成build/文件夹
我们需要把my-counter/build/Examples/bytecode_modules/MyCounter
通过SDK发送交易
这里,我们以my-counter合约中的init_counter和incr_counter为例。
构造两个方法用于调用这两个方法,从而实现客户端调用init和incr的功能。
asyncfunctioninitCounter(contractAddress:string,accountFrom:AptosAccount):Promise<string>{constscriptFunctionPayload=newTxnBuilderTypes
asyncfunctionincrCounter(contractAddress:string,accountFrom:AptosAccount):Promise<string>{constscriptFunctionPayload=newTxnBuilderTypes
通过SDK获取账户里的资源信息。
resource是存放在所属的账户地址下的,我们可以根据account地址,查询相关的resource信息。
getCounter()方法其实就是获取my-counter下的**Counter**资源。
asyncfunctiongetCounter(contractAddress:string,accountAddress:MaybeHexString):Promise<string>{try{constresource=awaitclient
catch(_){return"";}}
其实这个效果就类似sdk里的
aptosaccountlist--queryresources--account0x4200c2b801870f20a709abba80b6edb90a45ecd9b8acce9842b93d597602edcf
最终的主函数
asyncfunctionmain(){assert(process
,);});constmodulePath=process
执行效果
执行成功,在这里通过SDK,给一个随机生成的账户init了Counter资源,然后incr了三次,所以最后Counter的Value为3。
image-20220831200516865
my-counter相关代码:https://github.com/99Kies/Aptos-Move-Dapp
参考资料
UsingCLItoRunaLocalTestnet|AptosDocs:https://aptos.dev/nodes/local-testnet/using-cli-to-run-a-local-testnet
源码:https://github.com/aptos-labs/aptos-core/blob/main/aptos-move/framework/move-stdlib/sources/signer.move
标签:UNTCOURESTERBlockchain Monster HuntCouchainXPRESSeternalcontract
对冲基金三箭资本传出疑似破产,今日Terra研究员FatMan爆料三箭资本曾使用从机构贷款的款项,在机构不知情的情况下秘密转移Anchor赚取20%利率套现.
1900/1/1 0:00:00波场TRON月报新鲜出炉,一起来看看7月波场TRON都有哪些亮眼表现吧。 一、上所动态1、日本知名加密货币交易所BTCBOX正式上线TRX.
1900/1/1 0:00:00Bitfinex等计划明年推出借贷平台Debifi,以比特币作为抵押品托管比特币交易所HoldHodl的首席执行官MaxKeidun正在与Casa、Blockstream、Bitfinex等合作.
1900/1/1 0:00:00关于以流动性/资本化的名义使DAO国债多元化的重要性,已经有很多论述。往期文章参考:DAOrayaki|DAO:如何创造可观的财务和非财务优势;DAOrayaki|DAO国库多元化的范围代币;D.
1900/1/1 0:00:00“波卡知识图谱”是我们针对波卡从零到一的入门级文章,我们尝试从波卡最基础的部分讲起,为大家提供全方位了解波卡的内容,当然这是一项巨大的工程,也充满了挑战.
1900/1/1 0:00:00最近,基于Move语言的区块链项目即Aptos,被广泛关注。截止到今天为主Aptos,社区成员已经突破10w用户,生态项目覆盖Wallet、DEX、DeFi、Web3、NFT和MemeCoin、.
1900/1/1 0:00:00