以太幣交易所 以太幣交易所
Ctrl+D 以太幣交易所
ads

The Graph 入門教程:如何索引合約事件_Graph

Author:

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

編寫智能合約時,通常狀態的變化是通過觸發一個事件來表達,TheGraph則是捕捉區塊鏈事件并提供一個查詢事件的GraphQL接口,讓我們可以方便的跟蹤數據的變化。實際上很多DEFI協議及都是TheGraph來基于查詢數據。

這篇TheGraph教程在官方的教程基礎上,進行了一些補充擴展主要包含以下內容:

在Ropsten部署一個合約,并調用觸發事件。

創建定義數據索引的Subgraph。

部署Subgraph到TheGraph,實現數據索引。

在前端DApp中查詢索引數據。

本教程的完整代碼已上傳到GitHub:https://github

Gravatarpublicgravatars;mapping(uint=>address)publicgravatarToOwner;mapping(address=>uint)publicownerToGravatar;functioncreateGravatar(string_displayName,string_imageUrl)public{require(ownerToGravatar==0);uintid=gravatars

functionupdateGravatarName(string_displayName)public{require(ownerToGravatar!=0);require(msg

}

可以看到合約里在創建和更新時分別觸發了NewGravatar和UpdatedGravatar事件,稍后再subgraph里,將跟蹤這兩個事件,但是需要我們先把合約部署到網絡上,這里使用以太坊測試網Ropsten:

The Toxics項目Discord服務器遭到攻擊:金色財經報道,據CertiK監測,The Toxics項目Discord服務器遭到攻擊。請社區用戶在服務器修復之前不要點擊任何鏈接。[2023/2/7 11:51:20]

module.exports={networks:{ropsten:{provider:function(){returnnewHDWalletProvider(process.env.MNEMONIC,`https://ropsten.infura.io/v3/${process.env.ROPSTEN_INFURA_API_KEY}`。,network_id:'3',},}}

這里為了安全考慮,把助記詞和APIKEY保存在.env文件中

添加部署腳本2_deploy_contract.js:

constGravatarRegistry=artifacts.require('./GravatarRegistry.sol')module.exports=asyncfunction(deployer){awaitdeployer.deploy(GravatarRegistry。

添加執行交易腳本,以便觸發事件3_create_gravatars.js:

constGravatarRegistry=artifacts.require('./GravatarRegistry.sol')module.exports=asyncfunction(deployer,network,accounts){constregistry=awaitGravatarRegistry.deployed()console.log('Accountaddress:',registry.address)awaitregistry.createGravatar('Carl','https://thegraph.com/img/team/team_04.png',{from:accounts,}。

合成資產協議Synthetix發布Diphda版本:金色財經系消息,合成資產協議Synthetix發布Diphda版本,包含永續合約市場、債務池合并等更新,債務池合并期間Layer1與Layer2存取款已暫停,債務池合并已開始,Layer1與Layer2之間的存取款已暫停,合成資產協議Synthetix發布Diphda版本,包含永續合約市場、債務池合并等更新,債務池合并期間Layer1與Layer2存取款已暫停,北京時間3月19日1:00債務池完成合并。[2022/3/19 14:06:30]

然后執行trufflemigrate--networkropsten以便完成部署和執行createGravatar交易,控制臺里會打印出GravatarRegistry合約部署的地址,復制這個合約地址,后面在編寫subgraph需要使用到。

2.創建定義數據索引的Subgraph

TheGraph中定義如何為數據建立索引,稱為Subgraph,它包含三個組件:

Manifest清單(subgraph.yaml)-定義配置項

Schema模式(schema.graphql)-定義數據

Mapping映射(mapping.ts)-定義事件到數據的轉換

后面我們將逐一介紹他們的作用及如何來編寫。

在TheGraph創建一個Subgraph空間

因為需要借助TheGraph的節點來完成數據的索引,因此我們需要在TheGraph網站)上創建一個Subgraph。

如果你有自己的私有鏈,這可以克隆Graph節點代碼,自己運行Graph節點來完成數據的索引。

THETA突破7美元關口 日內漲幅為20.28%:歐易OKEx數據顯示,THETA短線上漲,突破7美元關口,現報7.0385美元,日內漲幅達到20.28%,行情波動較大,請做好風險控制。[2021/5/23 22:33:57]

如果沒有TheGraph的賬戶,可以用GitHub注冊。創建賬戶之后,進入儀表盤就可以開始通過界面創建subgraph,進入你的儀表板,并點擊AddSubgraph:

image-20210428095928210

可以為你的subgraph選擇一個圖像,定義一個名稱。完成后點擊保存,一個新的、未部署的subgraph將顯示在儀表板上。

開發和部署subgraph

先使用Yarn或NPM在全局安裝GraphCLI:

$npminstall-g

ID,Bytes及String是GraphQL數據類型,!表示該值不能為空。模式的定義文檔可以在這里找到:https://thegraph.com/docs/define-a-subgraph#the-graphql-schema。

定義映射(mapping.ts)

TheGraph中的映射文件定義了如何將傳入事件轉換為實體的函數。它用TypeScript的子集AssemblyScript編寫。因此可以將其編譯為WASM(WebAssembly),以更高效,更便攜式地執行映射。

需要定義_subgraph.yaml_文件中每個handler函數,因此在我們的例子中,我們需要實現函數:handleNewGravatar及handleUpdatedGravatar。

聲音 | The TIE首席執行官:加密貨幣的市場情緒和價格走勢之間有著驚人的相關性:據AMBcrypto消息,The TIE首席執行官Joshua Frank在接受采訪時指出,與其他資產類別不同,加密貨幣價格在很大程度上取決于市場情緒。他表示:“在加密市場,唯一影響價格的因素是大眾的智慧或人們的想法。我們已經發現加密貨幣的市場情緒和價格走勢之間有著驚人的相關性。”[2019/7/13]

TheGraph提供了一個命令:graphcodegen可以生成解析事件的代碼及模式實體代碼,因此只需要基于生成的代碼編寫映射函數,mapping.ts定義如下:

import{NewGravatar,UpdatedGravatar}from'../generated/Gravity/Gravity'import{Gravatar}from'../generated/schema'exportfunctionhandleNewGravatar(event:NewGravatar):void{letgravatar=newGravatar(event.params.id.toHex())gravatar.owner=event.params.ownergravatar.displayName=event.params.displayNamegravatar.imageUrl=event.params.imageUrlgravatar.save(。exportfunctionhandleUpdatedGravatar(event:UpdatedGravatar):void{letid=event.params.id.toHex()letgravatar=Gravatar.load(id)if(gravatar==null){gravatar=newGravatar(id。gravatar.owner=event.params.ownergravatar.displayName=event.params.displayNamegravatar.imageUrl=event.params.imageUrlgravatar.save(。

MyEtherWallet創始人:沒有計劃償還釣魚受害者:據cryptovest報道,MyEtherWallet的創始人Kosala Hemachandra指出,襲擊發生并不是MyEtherWallet的錯,也沒有計劃償還受害者。[2018/5/3]

在handler函數,我們使用事件的ID創建Gravatar實體。并使用相應的字段填充數據,最后需要.save()來存儲實體。

如何編寫映射函數,還可以參考文檔:https://thegraph.com/docs/define-a-subgraph#writing-mappings。

接下來就是把編寫好的Subgraph部署到TheGraph

3.部署Subgraph

在控制臺先用graphauth進行授權:

graphauthhttps://api.thegraph.com/deploy/

請使用你在創建Subgraph空間提示的Accesstoken。

然后使用graphdeploy進行部署:

graphdeploy--debug--nodehttps://api.thegraph.com/deploy/--ipfshttps://api.thegraph.com/ipfs/

使用完成的Subgraph名稱,我們這里是:xilibi2003/Gameplayer。

如果順利的話,可以在TheGraph的面板上觀察到subgraph索引過程,初始索引可能需要等待幾分鐘,如下圖:

subgraph索引

當索引完成后,通過GraphExplorer中的GraphQLplayground進行交互查詢:

GraphQL查詢

4.DApp前端查詢索引數據

在我們的代碼庫中,front目錄中,已經提供一個示例DApp,用來訪問數據。進入應用程序目錄,配置查詢subgraph的GraphQL端點地址:

$cdfront$echo'REACT_APP_GRAPHQL_ENDPOINT=https://api.thegraph.com/subgraphs/name//'>.env

最后,安裝DApp的依賴并啟動項目。

$yarn&&yarnstart

可以看到通過GraphQL查詢出來了3條數據:

image-20210429183042997

在React前端使用了ApolloClient來集成GraphQL查詢,如果是Vue可以使用VueApollo。

GraphQL查詢的代碼可以在front/App.js找到,這里不做詳細介紹。

參考資料

智能合約:https://learnblockchain.cn/article/1717

DEFI:https://learnblockchain.cn/article/570

TheGraph:https://thegraph.com/explorer/

儀表板:https://thegraph.com/explorer/dashboard/

定義subgraph.yaml的詳細文檔:https://thegraph.com/docs/define-a-subgraph#the-subgraph-manifest

https://thegraph.com/docs/define-a-subgraph#the-graphql-schema:_https://thegraph.com/docs/define-a-subgraph#the-graphql-schema_

AssemblyScript:https://www.assemblyscript.org/

WebAssembly:https://webassembly.org/

https://thegraph.com/docs/define-a-subgraph#writing-mappings:_https://thegraph.com/docs/define-a-subgraph#writing-mappings_

VueApollo:https://apollo.vuejs.org/guide/#become-a-sponsor

免責聲明:作為區塊鏈信息平臺,本站所發布文章僅代表作者個人觀點,與鏈聞ChainNews立場無關。文章內的信息、意見等均僅供參考,并非作為或被視為實際投資建議。

本文來源于非小號媒體平臺:

登鏈社區

現已在非小號資訊平臺發布105篇作品,

非小號開放平臺歡迎幣圈作者入駐

入駐指南:

/apply_guide/

本文網址:

/news/9921988.html

免責聲明:

1.資訊內容不構成投資建議,投資者應獨立決策并自行承擔風險

2.本文版權歸屬原作所有,僅代表作者本人觀點,不代表非小號的觀點或立場

上一篇:

Bitfinex一周簡報

Tags:GraphRAPAPHGRAPThe Moontography ProjectWrapped MinimaethnographyCryptographic Ultra Money

比特幣價格今日行情
今日精選項目簡評|區塊少數派 5.02_HTT

區塊少數派:區塊鏈投資教育與創投孵化社區。區塊少數派專注區塊鏈行業投資教育,同時聚焦挖掘全球優質項目,歡迎加入社區,共享財富密碼.

1900/1/1 0:00:00
BHEX關于ETC3S、DASH3S、DOGE3S、WAVES3S杠桿ETF產品份額合并的公告_HEX

尊敬的社區用戶: BHEX杠桿ETF產品7x24小時交易,并且市場波動較大,本著對市場影響最小原則,在不影響用戶體驗的情況下,我們將按次數最少化原則對ETF份額進行合并操作.

1900/1/1 0:00:00
金色早報|以太坊24小時空頭頭寸清算量創歷史新高_以太坊

頭條▌以太坊24小時空頭頭寸清算量創歷史新高金色財經報道,5月4日,以太坊再創歷史新高,空頭清算也創下了新紀錄.

1900/1/1 0:00:00
以太坊市值超越PayPal,數字貨幣產業價值飛躍_以太坊

距離“比特幣市值單挑全球五百強企業”還不到一年的時間,近日一則“以太坊市值超越PayPal”的新聞再度出圈.

1900/1/1 0:00:00
各 Rollup 解決方案的權衡研究_ROLL

隨著以太坊生態的發展拉動人們對區塊空間的需求增長,以太坊基礎層上的交易變得極其昂貴。然而,區塊空間供應量仍保持不變。與DeFi應用交互需要支付價值數百美元的gas費,讓許多終端用戶望而卻步.

1900/1/1 0:00:00
CoinBene上線 DogeSwap (DOG) 的公告_COI

尊敬的用戶: CoinBene將上線DOG/USDT幣幣交易,邀您體驗。DOG充值時間:2021年5月6日14:30DOG交易時間:2021年5月6日15:00DOG提幣時間:2021年5月6日.

1900/1/1 0:00:00
ads