src/klaytn: Chứa các tập tin giúp tương tác với chuỗi khối Klaytn.
src/klaytn/caver.js: Khởi tạo caver trong cài đặt đã định cấu hình.
cf) caver-js là thư viện RPC tạo kết nối với nút Klaytn, tương tác với nút hoặc hợp đồng thông minh được triển khai trên Klaytn.
src/klaytn/Klaystagram.js: Tạo một phiên bản hợp đồng bằng cách sử dụng API caver-js. Bạn có thể tương tác với hợp đồng thông qua phiên bản này
caver.js
/** * thư viện caver-js giúp tạo kết nối với nút Klaytn. * Bạn có thể kết nối với một nút Klaytn cụ thể bằng cách cài đặt giá trị 'rpcURL'. * rpcURL mặc định là 'https://public-en-baobab.klaytn.net'. */import Caver from'caver-js'exportconstconfig= { rpcURL:'https://public-en-baobab.klaytn.net'}exportconstcav=newCaver(config.rpcURL)exportdefault cav
Sau khi tạo kết nối, bạn có thể gọi phương pháp trên hợp đồng thông minh bằng caver.
KlaystagramContract.js
Để tương tác với hợp đồng, ta cần một phiên bản hợp đồng.
KlaystagramContract tạo một phiên bản hợp đồng để tương tác với hợp đồng Klaystagram bằng cách cung cấp DEPLOYED_ABI(giao diện nhị phân ứng dụng) và DEPLOYED_ADDRESS cho API cav.klay.Contract.
Khi lập & triển khai hợp đồng Klaystagram.sol (5. Triển khai hợp đồng), ta đã tạo các tập tin deployedABI và deployedAddress. Các tập tin này chứa ABI của hợp đồng Klaystagram và địa chỉ hợp đồng đã triển khai.
Nhờ có cấu hình của webpack, chúng ta có thể truy cập dưới dạng một biến.(DEPLOYED_ADDRESS, DEPLOYED_ABI)
DEPLOYED_ADDRESS trả về địa chỉ đã triển khai
DEPLOYED_ABI trả về ABI hợp đồng Klaystagram
cf) ABI hợp đồng(giao diện nhị phân ứng dụng)ABI hợp đồng là giao diện để gọi các phương pháp hợp đồng. Với giao diện này, ta có thể gọi các phương pháp hợp đồng sau đây
// klaytn/KlaystagramContract.js
import { cav } from "klaytn/caver"
/**
* 1. Tạo phiên bản hợp đồng
* ex:) cav.klay.Contract(DEPLOYED_ABI, DEPLOYED_ADDRESS) mới
* Bạn có thể gọi phương pháp hợp đồng thông qua phiên bản này.
*/
const KlaystagramContract = DEPLOYED_ABI
&& DEPLOYED_ADDRESS
&& new cav.klay.Contract(DEPLOYED_ABI, DEPLOYED_ADDRESS)
export default KlaystagramContract
// src/redux/actions/photos.js
// 1. Nhập phiên bản hợp đồng
import KlaystagramContract from 'klaytn/KlaystagramContract'
const setFeed = (feed) => ({
type: SET_FEED,
payload: { feed },
})
const updateFeed = (tokenId) => (dispatch, getState) => {
// 2. Gọi phương pháp hợp đồng (GỌI): getPhoto()
KlaystagramContract.methods.getPhoto(tokenId).call()
.then((newPhoto) => {
const { photos: { feed } } = getState()
const newFeed = [feedParser(newPhoto), ...feed]
// 3. Lưu trữ dữ liệu từ hợp đồng
dispatch(setFeed(newFeed))
})
}