DAOrayaki:Aptos & Move实操讲解-ODAILY_COU:TokenBetter

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时才允许合约升级

UDAO宣布与Rockstar合作推出全新的投资平台:据官方消息,量化对冲机构UDAO宣布与知名投资机构Rockstar合作,共同推出全新的投资平台。这一平台将融合UDAO量化对冲机构的先进技术和Rockstar在投资领域的丰富经验,旨在为投资者提供更加全面和专业的投资服务。该平台将采用最先进的人工智能和机器学习技术,通过对市场趋势和交易信号的分析,为客户提供投资解决方案。

据悉,该平台已经获得了多个机构的投资支持,预计将在近期正式上线。[2023/7/30 16:06:29]

部署一个简单的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,}

V神、孙宇晨支持的生命科学组织VitaDAO拟设营利性公司推动长寿技术发展:4月6日消息,由以太坊创始人“V神”支持创立的生命科学研究去中心化组织VitaDAO在推特宣布,正在投票决定是否创建一家营利性公司来确保和分配长寿研究的资金。该公司将命名为 VitaTech,作为 VitaDAO 的子公司/附属公司运营,它将利用公共资金来授权美国大学开发的长寿技术,并支持它们的持续发展。除V神外,波场TRON创始人孙宇晨此前也曾大力支持VitaDAO的发展。

今年1月,VitaDAO宣布完成410 万美元融资,融资方包括Coinbase的前首席技术官 Balaji Srinivasan、全球最大的药企辉瑞的投资部门 Pfizer Ventures,这也是辉瑞在 Web3 领域的首笔投资。VitaDAO 表示将会利用这笔资金进一步资助长寿研究项目和将于明年从DAO中剥离出来的生物技术初创公司。

去年10月,孙宇晨向VitaDAO旗下“长寿奖基金”进行捐款,孙宇晨也因此次捐赠成为“长寿奖基金”的第二大捐赠者,仅次于以太坊创始人V神。[2023/4/6 13:47:30]

使用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。

FriesDAO因Profanity漏洞遭到攻击,损失约230万美元:金色财经报道,据CertiK监测,FriesDAO于今日遭到攻击,损失约230万美元,起因是攻击者获得了该协议操作者钱包的控制权——似乎是由于Profanity钱包生成器的漏洞导致的,这一漏洞会令通过该工具生成地址的私钥被强制使用。

1.在获得对操作者钱包的访问权后,攻击者从DAO的资金钱包中提取了$FRIES,并将其于Uniswap上以wETH的价格出售。

2.攻击者使用只能由操作员地址调用的函数governanceRecoverUnsupported()从抵押池中提取资金。

3.攻击者最终将所有资金转换为DAI。

截至撰写本文时,存储被盗资金的钱包价值约为232.5万美元。

FriesDAO在官方Discord频道中确认了这次攻击,指出钱包地址确实是用Profanity生成的。

目前官方开发人员试图与攻击者进行谈判,协商用白帽赏金来换取被盗资金的归还。

这次攻击本可以被预防,因为Profanity漏洞作为做市商Wintermute被盗超过1.6亿美元攻击事件的罪魁祸首,已经被公开了一个多月了。

CertiK呼吁所有使用过Profanity工具的Web3.0项目立即将受影响钱包中所有资产的控制权转移到安全生成的地址。[2022/10/28 11:52:27]

然而,结构体的ability可以按照下面的语法进行添加:

structNAMEhasABILITY{}

一个简单的图书馆例子:

moduleLibrary{//eachabilityhasmatchingkeyword//multipleabilitiesarelistedwithcommastructBookhasstore,copy,drop{year:u64}//singleabilityisalsopossiblestructStoragehaskey{books:vector}//thisonehasnoabilitiesstructEmpty{}}

什么是Resource

Move白皮书中详细描述了Resource这个概念。最初,它是作为一种名为resource的结构体类型被实现,自从引入ability以后,它被实现成拥有Key和Store两种ability的结构体。Resource可以安全的表示数字资产,它不能被复制,也不能被丢弃或重新使用,但是它却可以被安全地存储和转移。

MakerDAO风控小组成员发表在Curve上建立新稳定币池提案:金色财经消息,MakerDAO风控小组成员monetsupply.eth发表在Curve上建立新稳定币池提案,该提案建议建立DAI、USDC、USDP、GUSD Basepool,该池可以作为FEI、FRAX、MIM等算法稳定币的配对资产,以维持较高深度的流动性。MakerDAO还将考虑允许与Basepool配对的流动性池LP作为抵押品。MakerDAO将扣留LP获得的CRV激励并作为协议的CRV储备,使得MakerDAO与Curve生态具有激励一致性。此外,MakerDAO将发行包装资产mkrCRV,此举将使得MakerDAO获得额外的投票影响力并且使得CRV质押者可以释放流动性并且同时依然可以获取收益。Curve表示支持该提案,但建议将USDP改为BUSD。[2022/4/30 2:41:43]

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存在用户地址下的。

DAO流动性提供商RiftFinance完成1800万美元融资,PanteraCapital领投:2月8日消息,DAO流动性提供商RiftFinance完成1800万美元融资,PanteraCapital领投,TwoSigmaVentures、CoinbaseVentures、SpartanGroup、DefianceCapital、Hashed、JumpCapital、VesselCapital和MorningstarVentures等机构参投。这笔资金将用于建立其团队和DAO社区,以及创建基础设施。

据悉,该协议希望帮助DAO部署治理代币以加深代币流动性,而不必放弃所有权。它将治理代币与来自零售和机构储户的ETH配对。最终,DAO通过其协议获得流动性,储户获得收益作为回报。[2022/2/8 9:38:41]

定义函数

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。

定义格式则是:

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的可变引用。

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

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

水星链

[0:15ms0-0:994ms