比特幣交易所 比特幣交易所
Ctrl+D 比特幣交易所
ads
首頁 > 聚幣 > Info

Libra硬剛微信、支付寶?教你如何在Libra上發布金融資產_KEN

Author:

Time:1900/1/1 0:00:00

本月17日,當Marcus被問到Libra未來是否會成為支付寶、微信的競爭對手時,Marcus對此表示了默認,“是的,議員。”但無論Libra未來的命運如何,也無論Libra將如何與微信、支付寶競爭,焦點都會回歸到金融資產發行的問題上,那如何用代碼實現?今天,營長手把手教你如何基于ERC20標準在Libra上發布金融資產。本文是「Libra編程」系列文章的第3篇,也是最后一篇。在之前的兩篇文章,我們分別探討了Libra項目的技術意義以及LibraClient與Validator內部處理與執行交易。Part1:被Libra刷屏的你絕對不知道,也許這才是它最大的"核武器"...Part2:關于Libra幣交易,你需要了解的一切...Libra作為法幣穩定幣,成為一個金融系統還需要具有債券股票以及各種證券資產與衍生品,本文將從技術角度入手,使用ERC20標準在Libra區塊鏈上發布金融資產。主要分為以下兩部分:編寫tokenmoudule編譯、部署tokenmoudule希望這個教程可以讓你對Libra的技術細節有更深刻的了解。編寫tokenmoudule如何使用MoveIR編寫一個簡單的tokenmodule?為方便理解,我們選擇Ethereum的ERC20token作為范例,分別執行mint、balanceOf和transfer三個功能。開始前,我們需要了解Libra與以太坊在處理resource的邏輯方面有什么不同。與Ethereumglobalstate不同的是,Libra并不設置統一集中存儲的globalresource,而是將resource分散在各個賬戶存放。因此,以太坊智能合約撰寫"addressstorageowner=0x"這類變量需要用不同的邏輯來實現。每個人擁有多少token也分別存放在各自賬戶的resource下,而不是采用"mapping(address=>uint256)"這樣的統一存儲方式處理。1、Capability

目前Libra開發團隊推薦的處理globalvariable的方式是使用一個singletonpattern的module來進行模擬。因此,我們將事件擁有所有者的(owner)權限定義為一種只能被發布一次的resource,比如"resourceT{}"。針對這個T進行的操作有兩個方法,一是在初始化時執行"grant()"用來確保TokenCapability被移交給所有者;而"borrow_sender_capability()"則是檢查操作者是否擁有所有者的權限。1moduleTokenCapability{2resourceT{}3//GrantTokenCapabilitytotheowner4publicgrant(){}5//ReturnanimmutablereferencetotheTokenCapabilityofthesenderifitexists.Thiswillonlysucceedifthetransactionsenderistheowner.6publicborrow_sender_capability():&mutR#Self.T{}7}grant()如何執行"grant()"?首先,我們需要定義兩個角色,調用這個函數的交易發起者與實際上的所有者owner。很可惜的是目前MoveIR并沒有提供類似"Self.published_address"的方式來讓我們獲得發布該module的賬戶,因此我們只能在代碼中寫死module所有者的地址,代碼如下:1//GrantTokenCapabilitytotheowner2publicgrant(){3letsender:address;4letowner:address;5lett:R#Self.T;67sender=get_txn_sender();89owner=0x1234;10//假設0x1234是所有者的地址11assert(move(sender)==move(owner),77);12//檢查交易發起者是否為所有者1314t=T{};15//為所有者建立新的TokenCapability16move_to_sender<T>(move(t));17//將TokenCapability.T轉移給所有者。18return;19}從上面的代碼中我們可以發現,只有通過"sender==owner"檢查才能取得所有者的resourceT,因此我們可以確保resourceT只會被所有者所擁有,其他的賬戶都沒有機會獲得這個resourceT。此外,"move_to_sender<structuretype>(resource)"是MoveIR提供的內建函數,它代表了將resource移交給交易發起者的賬戶。Borrow_sender_capability()如何檢查并確認交易發起者擁有所有者的resource?借助MoveIR提供的輔助函數"borrow_global<structuretype>(resourceaccount)"處理。borrow_global會去該賬戶下面調取出resource,如果該賬戶下沒有持有這個resource則會觸發意外情況,交易也會失敗。若成功則會返回可變的resourcereference。1//如果存在,則返回對交易發起者的TokenCapability的不可變引用。2//只有在交易發起者是所有者才會執行成功。3publicborrow_sender_capability():&mutR#Self.T{4letsender:address;5lett_ref:&mutR#Self.T;67sender=get_txn_sender();8t_ref=borrow_global<T>(move(sender));910returnmove(t_ref);11}2、Token

動態 | 摩根大通和高盛拒絕了加入Libra協會的邀請:據《商業內幕》報道,摩根大通和高盛已拒絕了Facebook邀請其加入Libra協會的請求。兩家公司最大的擔憂是,Libra最終將被用于洗錢和犯罪活動。另一方面,Facebook沒有就摩根大通和高盛的不參與發表評論。Facebook區塊鏈負責人此前曾否認關于高盛等銀行拒絕加入Libra協會的報道。[2019/10/18]

Libra的權限管理方式比較特別,上文已著重介紹,接下來撰寫Tokenmodule!1moduleToken{23importTransaction.TokenCapability;45//Tokenresource,代表一個賬戶的總余額.6resourceT{7value:u64,8}910//建立一個新的Token.T,value值為011publiczero():R#Self.T{12returnT{value:0};13}1415//返回Token的值16publicvalue(token_ref:&R#Self.T):u64{17return*&move(token_ref).value;18}1920//為交易發起者發布初始余額為0的Token21publicpublish(){}2223//`mint_to_address`只能由所有者調用.24//這會給收款人一個新的Token,價值是amount25publicmint_to_address(payee:address,amount:u64){}2627//Mint一個新的Token,價值是`value`.28mint(value:u64,capability:&mutR#TokenCapability.T):R#Self.T{}29//返回Token余額`account`.30publicbalanceOf(account:address):u64{}3132//返回交易發起者的Token余額.33publicbalance():u64{}3435//將`to_deposit`的token存入the`payee`\\'s賬戶36publicdeposit(payee:address,to_deposit:R#Self.T){}37publicwithdraw(to_withdraw:&mutR#Self.T,amount:u64):R#Self.T{}38//將Token從交易發起者轉到收款人39publictransfer(payee:address,amount:u64){}40}TokenResource整個Tokenmodule的結構如上。定義這個Token的resourceT{value:u64}代表了未來每個賬戶將會持有多少數量(T.value)的token,也要定義兩個跟T相關的輔助函數zero()制作一個數量為零的Token.T,value()回傳該Token.T的實際數值。Publish如同Capability一樣,每個賬戶都是分別持有自己的resource。Libra的設計邏輯中并不允許在沒經過某賬戶的同意下為其增加額外的resource,不像以太坊中只要有地址就可以收到別人的轉賬。因此,我們需要一個輔助函數供Token的所有者調用,為他們建立Token.T的resource。這是Publish負責的事情。1//為交易發起者publish一個初始余額為0的token23publicpublish(){4lett:R#Self.T;5//建立一個新的數值為0的Token.T6t=Self.zero();7//將Token.T轉移到交易發起者的賬戶下8move_to_sender<T>(move(t));9return;10}Minting讓賬戶擁有resourceToken.T的下一步便是發送一些token,因此接下來將具體解釋mint功能如何實現!1publicmint_to_address(payee:address,amount:u64){2letcapability_ref:&mutR#TokenCapability.T;3letmint_token:R#Self.T;45//使用TokenCapability來確保只有所有者有權限可以增發token6capability_ref=TokenCapability.borrow_sender_capability();78//呼叫下方的mint()來建立數量為amount的Token.T9mint_token=Self.mint(copy(amount),move(capability_ref));1011//將mint出來的Token.T合并到收款人的名下,這個函數我們在下面解釋。12Self.deposit(move(payee),move(mint_token));13return;14}1516mint(amount:u64,capability:&mutR#TokenCapability.T):R#Self.T{17//為確保只有交易發起者擁有TokenCapability.T,直接發布resource即可。18release(move(capability));1920//建立一個有amount數量的Token.T21returnT{value:move(amount。;22}增發token時,我們應先確保sender有增發的權限,如果沒有這個權限,transaction便會失效;然后建立要增發給payee的Token.T,最后通過Token.deposit函數將新建的Token.T與payeeaccount下的resourceToken.T合并。Balance增發token后,還缺乏查詢名下Token數量的方法,這就需要撰寫balance了!1publicbalanceOf(account:address):u64{2lettoken_ref:&mutR#Self.T;3lettoken_const_ref:&R#Self.T;4lettoken_val:u64;56//從該賬戶下取得resourcereference7token_ref=borrow_global<T>(move(account));89//因為我們沒有計劃改動resource的數值,因此把可變的reference凍結,改成不可變的reference10token_const_ref=freeze(move(token_ref));1112//調用value()來取得實際的余額13token_val=Self.value(move(token_const_ref));14returnmove(token_val);15}161718//這個balance()是直接包裝balanceOf(),提供交易發起者一個簡單的接口可以查詢。19publicbalance():u64{20letsender:address;21letbalance_val:u64;22sender=get_txn_sender();23balance_val=Self.balanceOf(move(sender));24returnmove(balance_val);25}轉賬Transfer重頭戲當然是轉賬,transfer一共分為三個步驟:從交易發起者借用resourceToken.T;將交易發起者的resourceToken.T分割成要轉賬的部分與余額(由withdraw函數負責);將交易發起者轉賬的部分與付款人的resourceToken.T合并(deposit函數負責)。因此整個transfer函數如下:1publictransfer(payee:address,amount:u64){2letto_pay:&mutR#Self.T;3letsender:address;4letto_withdraw:R#Self.T;56sender=get_txn_sender();78//借用交易發起者的resourceToken.T9to_pay=borrow_global<T>(move(sender));1011//分割出要給收款人的部分12to_withdraw=Self.withdraw(move(to_pay),move(amount));1314//將要給收款人的部分與收款人賬戶下原有的Token.T合并15Self.deposit(move(payee),move(to_withdraw));1617return;18}而Withdraw與Deposit實現如下:1publicdeposit(payee:address,to_deposit:R#Self.T){2letdeposit_value:u64;3letpayee_token_ref:&mutR#Self.T;4letpayee_token_const_ref:&R#Self.T;5letpayee_token_value:u64;67//取出要合并的數值8T{value:deposit_value}=move(to_deposit);910//獲得付款人的Token.Treference與現有的數值11payee_token_ref=borrow_global<T>(move(payee));12payee_token_const_ref=freeze(copy(payee_token_ref));13payee_token_value=Self.value(move(payee_token_const_ref));1415//修改付款人的Token.T的數值16*(&mutmove(payee_token_ref).value)=move(payee_token_value)+17move(deposit_value);18return;19}2021publicwithdraw(to_withdraw:&mutR#Self.T,amount:u64):R#Self.T{22letvalue:u64;2324//取得交易發起者的Token.T數量,并確認是否足夠支付這次轉賬25value=*(&mutcopy(to_withdraw).value);26assert(copy(value)>=copy(amount),10);2728//修改交易發起者的Token.T數量,并將分割后的Token.T轉出去29*(&mutmove(to_withdraw).value)=move(value)-copy(amount);30returnT{value:move(amount。;31}測試module

聲音 | 歐盟財政專員:將提議制定新規則來規范Libra這樣的加密資產:歐盟財政專員Dombrovskis表示,將提議制定新規則來規范像Facebook(FB.O)旗下加密貨幣Libra這樣的加密資產。[2019/10/8]

一個mvir的檔案含有兩個區塊,分別是modules與script,在modules中會撰寫交易中需要部署的所有modules,script是在這次交易中我們想執行的程序。TestScript在我們的范例中,通過使用交易script的區塊來進行測試。在這個測試中,我們把交易發起者作為所有者,并且mint1314個token給交易發起者,最后檢查交易發起者的余額是否跟mint的數值:1314一致。1script:2importTransaction.TokenCapability;3importTransaction.Token;4main(){5letsender:address;6letbalance_val:u64;7letsender_balance:u64;8sender=get_txn_sender();910//Grantowner\\'scapability11TokenCapability.grant();1213//PublishanTokenaccount14Token.publish();1516//Mint1314tokenstotheowner17Token.mint_to_address(copy(sender),1314);1819//Checkbalance==131420balance_val=Token.balanceOf(copy(sender));21assert(copy(balance_val)==1314,2);22sender_balance=Token.balance();23assert(move(sender_balance)==move(balance_val),1);24return;25}測試在撰寫完modules與script后,依據Libra團隊的建議,需將檔案放入"language/functional_tests/tests/testsuite/modules/"下,并執行"cargotest-pfunctional_tests<filename>",Libra就會加載并將執行剛才所撰寫的合約,結果如下圖:編譯、部署到localtestnet

如今Libratestnet尚未開放直接部署modules,只能通過建立自己的localtestnet來進行測試。現在部署的工具還在非常早期的階段,對開發者的使用上也不是十分友好,以下是整理后的部署流程。1、編譯Libra后,可以在"targe/debug/"資料夾下找到compiler和transaciton_builder兩個工具;2、通過使用compiler將撰寫的mvir編譯成program,"./target/debug/compiler-o<output_file_name><input.mvir>";3、通過transaction_builder把sender,program、argument等封裝成rawtransaction,"./target/debug/transaction_builder<sender_address><sequence_number><path_to_program_file><output_transaction_file_name>--args";4、最后進到libracli中使用submit<sender_address/sender_account_ref><path_to_transaction_file>對Libracli發出交易。注:我們也編寫了幾筆交易的scripts用來操作Token請參考此鏈接:https://github.com/second-state/libra-research/tree/master/examples/ERC20Token/transaction_scripts部署與使用Token的順序1、先將token.mvir(含有Token、TokenCapability的module)部署到Libra;2、要想使用該token賬戶,必須先調用init.mvir將Token.T發布到賬戶的resource中;3、所有者可通過mint.mvir給其他擁有resourceToken.T的賬戶增發token;4、兩個擁有resourceToken.T的account可以通過transfer.mvir進行token轉移。開啟允許部署modules的權限

動態 | 就Libra相關問題造訪瑞士后,美國監管機構仍然對其表示擔心:據彭博報道稱,美國眾議院金融服務委員會主席Maxine Waters將領導一個六人小組的訪問團造訪瑞士,并與瑞士聯邦數據保護和信息專員Adrian Lobsiger就Facebook數字貨幣Libra相關問題進行會談。8月25日,Maxine Waters發表聲明稱,美國眾議院金融服務委員會代表團會見了多個監管機構和立法者,其中包括國際金融事務國家秘書處(SIF)、聯邦數據保護和信息專員(FDPIC)、金融市場監管局(FINMA)等。其表示,雖然我很感謝瑞士政府官員抽出時間與我們進行會面,但我仍然擔心允許一家大型科技公司創建一種私人控制的替代性全球貨幣。我期待國會代表團在委員會的管轄范圍內繼續審查這些問題,包括洗錢等其他事項。[2019/8/26]

Libra在編譯時期(compilation-time)時從genesisfile里面讀取是否可以設定部署modules的權限。因此,為把modules部署到localtestnet,我們需要在編譯前修改這項設定。在"language/vm/vm_genesis/genesis/vm_config.toml"這個檔案,只需將""中的"type=Locked"改為"type=Open"即可。更改完以后,一定要重新編譯使設定生效。參考鏈接:1、SingletonPatternCapability:https://community.libra.org/t/any-notion-of-global-variables/355/22、TokenCapability:https://github.com/second-state/libra-research/blob/master/examples/ERC20Token/token.mvir#L33、TokenSourceCode:https://github.com/second-state/libra-research/tree/master/examples/ERC20Token

聲音 | 北京師范大學金融學博士:1:1的儲備發行方式對書Libra協會成為難解的悖論:8月7日,北京師范大學金融學博士趙鷂在財新網發表專欄文章《從貨幣與支付史看臉書Libra的“返祖現象”》,文章表示,正如Keynes(1914)等人指出的,硬幣的面值總是高于制造硬幣的金屬的市場價格,否則硬幣的持有者就會有動機將手中的硬幣熔化鑄成金屬商品并出售。因此,對Libra也好,還是對其他的已經出現的或即將發行的所謂穩定代幣也好,只要它們背后的抵押品價值(或者儲備金)不低于代幣的價格,并且可通過代幣自由贖回,那么市場有足夠動機將其“熔化”掉,Libra就只能成為持有者用于交換儲備貨幣(特別是美元)的換匯媒介,難以成為貨幣交換媒介進入市場流通。另一方面,這又會引起連鎖反應,至少會導致代幣發行量的“不足”,也即當代幣發行量小于一個閾值時(以市場占有率的增函數),成員機構將不會接受Libra這樣的代幣充作內部結算資產。因而1:1的儲備發行方式對于臉書Libra協會成為一個難解的悖論。[2019/8/7]

聲音 | 紐約時報記者:Libra協會成員尚無一家出資,是否參與項目仍未最終確定:《紐約時報》記者Nathaniel Popper6月26日發文稱,除了監管機構對Facebook的加密貨幣心存疑慮,其合作伙伴也是如此。Popper表示,Facebook的加密貨幣項目Libra的最大賣點之一是這家社交媒體公司擁有27個合作伙伴,其中包括Visa、萬事達卡(Mastercard)和優步(Uber)等知名機構,它們都參與了這個項目。但Libra協會中的一些合作伙伴仍在以謹慎的態度接近Libra。其中七家公司的高管表示,他們通過簽署并不具有約束力的協議加入了該項目,部分原因是他們知道自己沒有義務使用或推廣數字代幣(Libra),如果他們不喜歡代幣的發展,可以很容易地退出。由于談判的敏感性,上述高管們以匿名的方式進行了發言。[2019/6/26]

Tags:TOKETOKENKENTOKABCC TokenTrabzonspor Fan TokenDiw TokenRizz Token

聚幣
Facebook、Bakkt、富達迅猛布局加密領域,促美國加快監管步伐_ACE

七月,讓美國的立法者們分外忙碌。Facebook發布Libra白皮書后一個月,美國眾議院金融服務委員會舉行了聽證會.

1900/1/1 0:00:00
幣大師兵法之:“獨善其身,不如兼濟天下”_數字貨幣

孫子兵法有云:“顧不知諸侯之謀者,不能豫交;不知山林險阻沮澤之形者,不能行軍;不用向導者,不能得地利”。作為投資者,如果不能了解區塊鏈發展的特點和所處的階段,極有可能陷入盲人瞎馬的危險境地.

1900/1/1 0:00:00
OK情報局周報:央行數字貨幣風雨欲出,為何選定“雙層運營體系”_數字貨幣

一周情報速遞,熱點資訊不停,在比特幣甚至整個幣圈的震蕩中走過了一周,又迎來了新的一周,在過去的一周也是新動向不斷,我們一起來看一下這周的行業最前線.

1900/1/1 0:00:00
區塊鏈安全入門筆記(五)_加密貨幣

雖然有著越來越多的人參與到區塊鏈的行業之中,然而由于很多人之前并沒有接觸過區塊鏈,也沒有相關的安全知識,安全意識薄弱,這就很容易讓攻擊者們有空可鉆.

1900/1/1 0:00:00
Eth 2.0 AMA 第二期 | Vitalik:Eth 2.0 沒有未解決的研究挑戰_ETH2

以太坊2.0研究團隊于2019年7月15日在Reddit上做了一個持續時間長達12小時的AMA活動,本次AMA主要由以太坊創始人VitalikButerin.

1900/1/1 0:00:00
周杰倫和蔡徐坤的“超話大戰”,和區塊鏈有啥關系?_INVI

前幾天最熱的娛樂新聞莫過于坤倫超話大戰,而此次的超話大戰甚至于引起了全民的數據大戰,上周對于夕陽粉來說,最重要的事不是打游戲、做家務或者陪娃上補習班,而是放下一切,為周杰倫“刷榜”.

1900/1/1 0:00:00
ads