橋接復雜鏈上協議與鏈下世界,賦予開發者構建生態之自由
Ergo 無頭 dApp框架(簡稱Ergo HDF)是開發Ergo無頭dApp(去中心化應用)的首選Rust框架。Ergo HDF給開發者提供了首個可移植、基于UTXO(未花費交易輸出)的無頭dApp開發框架,此框架可應用于任何區塊鏈。(譯注:Rust是一款并發安全,支持函數式、命令式以及泛型等編程范式的多范式編程語言,語法和C++類似)
什么是無頭dApp?
無頭dApp是用于開發dApp的全新技術和商業模型,它剛開始在更廣泛的區塊鏈領域中占據一席之地。簡而言之,無頭dApp是讀取和參與鏈上智能合約協議的純粹可移植自包含邏輯。
換句話說,無頭dApp是一款可讓復雜鏈上協議接觸鏈下世界的軟件,它精簡的接口使任何人都可以在其上進行構建。此處的關鍵是,顧名思義,無頭dApp沒有構建于其上的前端(故稱“無頭”)。
無頭dApp提供的是在其上構建整個去中心化生態系統的自由。由于在默認情況下,無頭dApp是純粹的,可移植的,因此可以將它們編譯為任何桌面設備操作系統、移動設備操作系統或者瀏覽器。因為它們具有精簡的接口,所以可以輕松將其集成到腳本和機器人中;因為它們具有可組合性,所以可以在應用程序中一起使用,從而可以輕松地在不同協議之間套利,或者可以形成全新的用戶體驗,而無需了解每個受支持的無頭dApp的核心工作方式。
新入行的開發者對于開發智能合約協議的經驗有限,而無頭dApp在未來可以使他們仍然對dApp領域產生真正的影響。這種關注點分離(Separation of Concerns)的設計允許開發者在無頭dApp的基礎上進行構建,而無需花費大量時間來了解開發dApp的繁冗細節。(譯注:Separation of Concerns,關注點分離,是將計算機程序分隔為不同部分的設計原則,每一部分會有各自關注的焦點,也就是可以影響程序代碼的信息集合。)
此外,無頭dApp開啟了全新商業模式的生態系統。 無頭dApp并沒有讓智能合約協議的創建者從成功的協議中攫取所有潛在的利潤/價值,反而為前端開發者揭示了截至目前尚未利用的收入來源。 通過僅將協議創建者的潛在收益分散到現在包含已開發的每個前端,我們可以從當今具有單個前端的流行dApp所產生的中心化效果上退一步。 相反,我們可以激勵由各種開發者/公司構建的,由眾多獨立前端組成的穩健生態系統,所有人都可以因改善整個生態系統而獲利。
Vitalik Buterin:賬戶抽象可為以太坊帶來數十億美元的收益:金色財經報道,最近在巴黎舉行的以太坊社區會議(EthCC)上的一次演講中,以太坊創始人Vitalik Buterin詳細介紹了賬戶抽象升級如何讓用戶用用于交易的代幣支付Gas費,從而吸引數十億人使用以太坊。帳戶抽象使用戶能夠從外部擁有的錢包(EOA)切換到基于智能合約的錢包。如果此次升級成功,錢包管理將比現在更加高效和輕松。Buterin和社區相信,這可以使加密技術得到廣泛采用。
此外,加密貨幣領域充斥著丟失助記詞或助記詞被盜的用戶。通過賬戶抽象,用戶可以創建充當可編程智能合約的非托管錢包。據報道,錢包恢復只是此次新升級帶來的眾多功能之一。Buterin相信此次升級可以給以太坊帶來數十億美元的收益。[2023/7/20 11:05:50]
無頭dApp實現了這所有功能,并且同時進一步改善了開發者的體驗。
方案目標
1.讓開發者使用無頭dApp框架寫出自己的鏈下邏輯,從而創建他們自己面向所有平臺(桌面設備、網頁、移動設備)的無頭dApp。
2.為開發者提供從Ergo dApp規范到無頭dApp的輕松體驗,并提供更強大的保證和簡單直接的實現途徑。
3.將dApp的鏈下邏輯與任何前端邏輯分開,從而無論什么應用或前端在集成無頭dApp時都保證了重用性。
4.為前端實現者提供易于使用的方法,以便輕松訪問dApp協議的當前狀態,而無需了解其工作原理。
5.通過使用新穎的設計模式為所需的輸入UTXO指定BoxSpec(譯注:Rust框架中定義盒子規范的結構體),將為無頭dApp定義和獲取輸入UTXO的概念進行了抽象化。
6.使腳本、(套利)機器人和其他軟件輕松地構建在使用無頭dApp框架構建的多個無頭dApp之上,從而提供了標準化的接口和一定程度的可組合性。
理解Ergo無頭dApp框架
在使用無頭dApp框架(HDF)之前,有許多重要的術語和概念需要理解。無頭dApp框架的總體設計基于EIP-6:Ergo智能合約協議規范格式。(譯注:EIP全稱Ergo Improvement Proposal,即Ergo改善方案。EIP-6鏈接為https://github.com/ergoplatform/eips/blob/master/eip-0006.md)
富達高管:對加密貨幣持謹慎態度但可為大客戶提供服務:金色財經報道,富達的一位高管周三對《金融新聞》表示,他們對放棄任何新的加密產品持謹慎態度,并將“謹慎行事”。富達國際歐洲區董事總經理Christian Staub表示,我們不是在敲桌子告訴大家買比特幣。但如果大客戶想要買入,我們現在可以提供。
富達公司曾經涉足過加密貨幣,這家資產管理公司在2021年12月推出了加拿大比特幣現貨ETF,在2022年2月為歐洲機構推出了實物比特幣ETP。
此前2022年4月報道稱,富達將允許與之合作的2.3萬名雇主在其401k投資組合中提供數字資產賬戶。它允許員工通過工作投資比特幣,并于2022年秋季推出。[2023/5/18 15:09:53]
這意味著在最高層級上,dApp被定義為智能合約協議。 如果dApp只有一個階段,則將其定義為“單階段智能合約協議”;如果dApp有多個階段,則它是“多階段智能合約協議”。HDF支持構建單階段和多階段協議dApp。
每個階段都可以被視為協議中的一個狀態,其中帶有ERG、代幣和數據(在寄存器內)的UTXO位于給定的時間點處。 這可能有在整個協議中從一個階段移動到下一個階段的單個盒子(UTXO)、可能并行地通過所有階段的多個盒子或者是異步地在某些階段子集中移動的各種盒子。
無論給定智能合約協議的特定設計/復雜性如何,這些階段中的每個階段都需要“操作”(Action)。這些操作指的是狀態轉換(交易邏輯),它允許:
1.ERG/代幣/數據進入協議(又稱“引導操作(Bootstrap action)”)
2.ERG/代幣/數據從協議中的一個階段轉到另一個階段(或者退出協議)
3.ERG/代幣/數據離開協議
在無頭dApp的背景下,這些操作(Action)中每個都由兩個關鍵部分組成:
1.獲取輸入(UTXO/用戶輸入/來自外部世界的外部數據)
2.使用狀態轉換的結果來創建UTXO輸出
綜上所述,dApp可以是單階段或多階段的智能合約協議。dApp協議中的每個階段都可以執行一個或多個操作(Action)。 然后,開發者可以通過指定給定操作所需的必需輸入并編碼所需的狀態轉換邏輯來定義這些操作,以創建嵌入在新創建的UnsignedTx中的UTXO輸出(譯注:UnsignedTx是無符號交易變量)。
無頭dApp框架提供了指定這些構件的必需工具,以便從頭開始構建無頭dApp。 在以下各節中,我們將詳細介紹無頭dApp框架的構建方式以及如何馬上開始使用它。
去中心化交易平臺Hashflow宣布集成加密支付平臺Moonpay:5月3日消息,去中心化交易平臺 Hashflow 宣布集成加密支付平臺 Moonpay,用戶現在可以使用借記卡/信用卡購買數字資產并在 Hashflow 上進行交易,還可以在 160 多個加密友好的國家之間轉賬。[2023/5/3 14:39:46]
Ergo無頭dApp框架模塊
Box Spec (盒子規范)
本模塊展示了BoxSpec結構體,它可以用來創建UTXO的規范。根據協議中操作(Action)的要求,這被用來定義相關的盒子。
/// 用來制定 `ErgoBox`參數的規范.
/// 本規范用作“真理之源” ,來驗證和尋找和規范匹配的`ErgoBox`
///這經常被用于定義多階段智能合約協議中的階段
/// 但也可用于定義操作(Action)的輸入盒子
/// 所有字段都被包進`Option`,可以不必指定字段
#[wasm_bindgen]
#[derive(Clone)]
pub struct BoxSpec {
/// 盒子地址
address: Option<ErgoAddressString>,
/// nanoErgs被允許的范圍
value_range: Option<Range<NanoErg>>,
/// 排序的 `Constant`列表,定義了`ErgoBox`寄存器
/// 第一個元素當作R4, 第二個當作 R5, 以此類推.
registers: Vec<Option<Constant>>,
/// 排序的 `TokenSpec`列表定義了`ErgoBox`代幣
tokens: Vec<Option<TokenSpec>>,
薩爾瓦多通過數字資產法案:金色財經報道,薩爾瓦多立法議會周三批準了一項關于發行除比特幣以外的數字資產的法律。立法中包括發行比特幣支持債券(也稱為火山債券)的法律框架。62名立法者對該法案投了贊成票,16人投了反對票。[2023/1/12 11:07:09]
/// 可選謂詞,允許定義在驗證盒子時處理的自定義規范邏輯
predicate: Option<fn(&ErgoBox) -> bool>,
}
構造出BoxSpec以后,有許多基本方法來簡化為dApp編寫鏈下代碼的體驗。
例如,verify_box允許測試作為輸入提供的ErgoBox是否與使用BoxSpec創建的規范匹配。
pub fn verify_box(&self, ergo_box: &ErgoBox) -> Result<()> {
Box Traits (盒子 Trait)
(譯注:Trait是Rust語言中為Self類型定義的方法組合,中文里有特征、特點之意。在Rust語言的上下文中一般直接使用而不譯出,以防技術上的歧義)
本模塊包含三種Trait:
1.WrappedBox
2.SpecifiedBox
3.ExplorerFindable
所有的ExplorerFindable結構體也是SpecifiedBox,兩者同時都是WrappedBox。在鏈下代碼中,將為操作(Action)定義所有UTXO輸入作為實現SpecifiedBox的結構體,同時不需額外工作便可自動派生WrappedBox和ExplorerFindable。
WrappedBox提供了簡化的接口來和ErgoBox交互。另一方面,SpecifiedBox指定WrappedBox也通過box_spec()方法實現了BoxSpec。最后,ExplorerFindable在SpecifiedBox trait的頂部提供了一個接口,用于從Ergo Explorer API實例中查找與BoxSpec匹配的盒子。
Specified Boxes (指定盒子)
數據:BTC已實現上限達到16個月低點:金色財經消息,據Glassnode數據顯示,BTC已實現上限剛剛達到16個月低點,數額為382,872,025,705.91美元。[2022/12/26 22:06:56]
此模塊展示了實現“ SpecifiedBox / WrappedBox / ExplorerFindable”trait的通用“ Specified Box”結構。 這些盒子可用作鏈下協議代碼中操作(Action)的輸入,同時還使前端開發者能夠輕松訪問鏈上數據(例如預言機池數據)。
目前已實現的指定盒子有如下幾種:
1.ErgsBox
2.ErgUsdOraclePoolBox
3.AdaUsdOraclePoolBox
ErgBox用于獲取將Erg保留在其中的輸入,這些輸入可在智能合約協議操作(Action)中使用。
ErgUsdOraclePoolBox和AdaUsdOraclePoolBox為無頭dApp開發者和前端實現者提供了極其簡化的接口,以利用來自兩個當前運行的預言機池的數據。 這兩個指定的盒子甚至可以用于需要從預言機池盒子讀取當前匯率的錢包/任何鏈下應用程序中。
下面的代碼塊顯示了如何在4行中從開發者自選的Ergo Explorer API實例中讀取當前的ERG-USD預言機池匯率:
let url = ErgUsdOraclePoolBox::explorer_endpoint("https://api.ergoplatform.com/api").unwrap();let response = get(&url).unwrap().text().unwrap();let oracle_pool_box = ErgUsdOraclePoolBox::process_explorer_response(&response).unwrap().clone();println!( "Erg-USD Oracle Pool: {} nanoErgs per USD", oracle_pool_box.datapoint());
Output Builders 輸出構建器
此模塊給出了一些結構體,它們提供了在操作(Action)中創建通用UTXO輸出的基本接口。 這些通常用于創建保存用戶更改或支付交易手續費的輸出。
一些輸出構建器的例子包括:
1.ChangeBox
2.TokensChangeBox
3.TxFeeBox
Tx Creation 創建交易
該模塊提供了一些基本的函數,這讓開發者更加容易地在操作(Action)中創建UnsignedTransaction(無符號交易)。
Encoding 編碼
該模塊提供了許多有用的函數,這些函數與把值從一種形式轉換為另一種形式的編碼/解碼/包裝/展開有關。
示例:
pub fn erg_to_nano_erg(erg_amount: f64) -> u64;pub fn nano_erg_to_erg(nanoerg_amount: u64) -> f64;pub fn unwrap_long(c: &Constant) -> Result<i64>;pub fn serialize_p2s_from_ergo_tree(ergo_tree: ErgoTree) -> P2SAddressString;
Procedural Macros 過程宏
此模塊提供了三個過程宏,以使開發者的工作變得更加簡單:
1.WrapBox
2.SpecBox
3.WASMBox
WrapBox只是實現了WrappedBox trait;SpecBox實現了使用BoxSpec的自定義new()方法,并且實現了ExplorerFindable trait;WASMBox實現了兩種基本方法(w_new()和w_box_struct ())來讓結構體啟用WASM支持。
開始入門
Math Bounty Headless dApp(數學懸賞 無頭dApp)教程系列已創建,可以指導初學者使用Ergo無頭dApp框架。從項目創建到實現基于命令行的界面,您將得到精確到每一步的指導來逐步開發自己的無頭dApp。
目前可用的部分:
1.數學懸賞無頭dApp-現在開始編寫你的第一個操作(Action)(譯注:鏈接地址
https://github.com/Emurgo/ergo-headless-dapp-framework/blob/main/tutorials/Math_Bounty/1-math-bounty-dApp-getting-started.md)
2.數學懸賞無頭dApp-完成無頭dApp(譯注:鏈接地址
https://github.com/Emurgo/ergo-headless-dapp-framework/blob/main/tutorials/Math_Bounty/2-math-bounty-dApp-finishing-the-headless-dapp.md)
3.數學懸賞無頭dApp-為創建賞金編寫CLI(Command Line Interface,命令行界面)前端(譯注:鏈接地址
https://github.com/Emurgo/ergo-headless-dapp-framework/blob/main/tutorials/Math_Bounty/3-math-bounty-dApp-writing-a-cli-frontend-that-allows-creating-bounties.md)
文檔
運行以下命令來閱讀無頭dApp框架的文檔:
cargo doc --open
Ergo平臺簡介
Ergo平臺/Ergo Platform是一個從頭搭建的安全、適應力強、開放、無需許可、真正去中心化的DeFi應用底層公鏈,主要專注于提供一種高效、安全、簡便的方式去實現金融合約。它基于全新PoW共識機制Autolykos且永守PoW,采用UTXO升級版EUTXO模型構建,沿襲比特幣傳統但又新增許多功能,實現復雜金融合約的能力遠超對手。其原生代幣ERG總供應量為97,739,925枚,永不增發,永不銷毀。Ergo于2017年開始開發,主網于2019年7月1日上線。由Github上大名鼎鼎的kushti(Alexander Chepurnoy)帶領擁有10年區塊鏈理論研究和實戰經驗的頂尖技術團隊傾力打造。團隊成員曾參與開發NXT、Scorex、Cardano和Waves等。kushti是Ergo的聯合創始人兼核心開發者,曾是NXT的核心開發者、smartcontract.com(即Chainlink)的聯合創始人,帶領團隊開發有行業領先的預言機池。詳情請登錄https://www.jinse.com/blockchain/979572.html。
作者簡介
Robert Kornacki是頂級區塊鏈解決方案公司、Cardano創始單位之一EMURGO的研發負責人和智能合約開發者,也是Ergo基金會成員。
Denys Zadorozhnyi是Ergo公鏈平臺Rust軟件工程師、Scala軟件工程師,也是Ergo開發者之一。
作者:Robert Kornacki;Denys Zadorozhnyi
譯者:Ergo公鏈御用翻譯之一,留美計算機博士兼區塊鏈愛好者Pie。
韓國最大區塊鏈項目Terra的生態系統越來越全,此前其擁有合成協議Mirror、DEX TerraSwap、穩定幣UST、LUNA等產品.
1900/1/1 0:00:00過去的這個周末可能是這輪行情以來最平淡的周末了,我這兩天過得實在是毫無波瀾,大行情沒有,小行情也沒有,也沒有出現什么新東西.
1900/1/1 0:00:00今年 3 月 12 日,美國 MicroStrategy 公司宣布以 1500 萬美金,購買了 262 枚比特幣.
1900/1/1 0:00:00不知不覺,DeFi項目已火爆了近一年時間。對于節奏如此之快的區塊鏈行業,DeFi市場似乎已進入了后半段,基本上很難再出現令人眼前一亮的項目.
1900/1/1 0:00:00近來的 NFT 很火,很多項目你根本不知道它為什么漲,一看原來是與 NFT 相關的……如果說去年的許多 Defi 項目至少有數據支撐的話,那么今年 NFT 的很多項目.
1900/1/1 0:00:00價差是一種常見的交易指標,指的是不同類型頭寸之間的價格差額。價差交易是一種同時開倉兩個頭寸的交易策略:一個“多頭”頭寸和一個“空頭”頭寸.
1900/1/1 0:00:00