-
Notifications
You must be signed in to change notification settings - Fork 1
Quick Starts: Interact with SSRI Contract with @ckb‐ccc
The following guide uses UDT and Pausable UDT as example and assume you're using the playground environment which provides the signer. Your signer would be different based on your project setup.
-
Create or setup your project with CCC (see guide here)
-
Start up your local SSRI server through docker:
docker run -p 9090:9090 hanssen0/ckb-ssri-server
- Prepare the
OutPoint
of your SSRI-compliant UDT script.
import { ccc } from "@ckb-ccc/ccc";
import { signer } from "@ckb-ccc/playground";
// Note: Your signer would be different based on your project setup.
const usdiOutPoint = {
txHash: "0xaec423c2af7fe844b476333190096b10fc5726e6d9ac58a9b71f71ffac204fee",
index: 0,
};
If your UDT script is deployed with Type ID, the following way would allow you to get the OutPoint
programmatically even if the script gets upgraded:
const scriptCell = await signer.client.findSingletonCellByType({
codeHash:
"0x00000000000000000000000000000000000000000000000000545950455f4944",
hashType: "type",
args: "0xf0bad0541211603bf14946e09ceac920dd7ed4f862f0ffd53d0d477d6e1d0f0b",
});
if (!scriptCell) {
throw new Error("USDI script cell not found");
}
const usdiOutPoint: ccc.OutPointLike = {
txHash: scriptCell.outPoint.txHash,
index: scriptCell.outPoint.index,
};
- Prepare the Type script object of your UDT. You can provide the code hash yourself by copying from the explorer, or get it programmatically from the
OutPoint
of your UDT script.
const usdiCodeCell = await signer.client.getCell(usdiOutPoint);
const usdiContractCellType = usdiCodeCell?.cellOutput.type;
if (!usdiContractCellType) {
throw new Error("usdi script cell type not found");
}
const ownerScript = (await signer.getRecommendedAddressObj()).script;
const usdiType = ccc.Script.from({
codeHash: usdiContractCellType?.hash(),
hashType: "type",
args: "0x71fd1985b2971a9903e4d8ed0d59e6710166985217ca0681437883837b86162f",
});
- You have everything ready, now you can create an instance of your UDT and interact with it.
const executor = new ccc.ssri.ExecutorJsonRpc("http://localhost:9090");
const usdi = new ccc.udt.Udt(usdiOutPoint, usdiType, { executor });
const usdiName = await usdi.name();
const usdiIcon = await usdi.icon();
console.log(usdiName);
// {"res":"USDI Token","cellDeps":[]}
console.log(usdiIcon);
// {"res":" ......
The same script might have implemented multiple SSRI traits or sub-traits at the same time, but you can instantiate the same script arbitrarily with different traits as long as the script implemented the traits you want.
const usdi = new ccc.udt.UdtPausable(usdiOutPoint, usdiType, { executor });
const usdiEnumeratePaused = await usdi.enumeratePaused();
console.log(usdiEnumeratePaused);
// {"res":["0xb5202efa0f2d250af66f0f571e4b8be8b272572663707a052907f8760112fe35","0xa320a09489791af2e5e1fe84927eda84f71afcbd2c7a65cb419464fe46e75085"],"cellDeps":[{"txHash":"0x98c37eabc1672c4a0a30c0bb284ed49308f0cb58b0d8791f44cca168c973e7da","index":"0"}]}
- Some of the methods allows you to generate a transaction object directly while taking care of most of the details for you. You just need to follow the guidance of the docs provided via your IDE.
const receiverA =
"ckt1qzda0cr08m85hc8jlnfp3zer7xulejywt49kt2rr0vthywaa50xwsq2jk6pyw9vlnfakx7vp4t5lxg0lzvvsp3c5adflu";
const { script: lockA } = await ccc.Address.fromString(
receiverA,
signer.client
);
const usdiTransferTx = (await usdi.transfer(signer, [
{
to: lockA,
amount: 10000,
},
])).res;
Many of these methods also allow you to pass in a previous ccc.TransactionLike
object as the second argument, which allows you for example to transfer multiple UDT cells in a single transaction.
const receiverB =
"ckt1qzda0cr08m85hc8jlnfp3zer7xulejywt49kt2rr0vthywaa50xwsqflz4emgssc6nqj4yv3nfv2sca7g9dzhscgmg28x";
const { script: lockB } = await ccc.Address.fromString(
receiverB,
signer.client
);
const combinedTransferTx = (await usdi.transfer(
signer,
[
{
to: lockB,
amount: 20000,
},
],
usdiTransferTx
)).res;
- You only need to complete the inputs of the transaction just like processing any other transactions with CCC.
// Note: You need to connect your wallet for the following parts. You also need to have enough balance of USDI in your wallet.
await usdi.completeBy(combinedTransferTx, signer);
await combinedTransferTx.completeFeeBy(signer);
const combinedTransferTxHash = await signer.sendTransaction(combinedTransferTx);
console.log(combinedTransferTxHash);
Full runnable example can be found at here