Skip to content
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
8 changes: 8 additions & 0 deletions .changeset/README.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,8 @@
# Changesets

Hello and welcome! This folder has been automatically generated by `@changesets/cli`, a build tool that works
with multi-package repos, or single-package repos to help you version and publish your code. You can
find the full documentation for it [in our repository](https://github.com/changesets/changesets)

We have a quick list of common questions to get you started engaging with this project in
[our documentation](https://github.com/changesets/changesets/blob/main/docs/common-questions.md)
11 changes: 11 additions & 0 deletions .changeset/config.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,11 @@
{
"$schema": "https://unpkg.com/@changesets/config@2.3.0/schema.json",
"changelog": ["@changesets/changelog-github", {"repo": "CasperDash/casperdash-utils"}],
"commit": false,
"fixed": [],
"linked": [],
"access": "public",
"baseBranch": "main",
"updateInternalDependencies": "patch",
"ignore": ["client-js"]
}
2 changes: 2 additions & 0 deletions examples/client-js/.gitignore
Original file line number Diff line number Diff line change
Expand Up @@ -22,3 +22,5 @@ dist-ssr
*.njsproj
*.sln
*.sw?

keys
9 changes: 5 additions & 4 deletions examples/client-js/package.json
Original file line number Diff line number Diff line change
Expand Up @@ -4,14 +4,15 @@
"version": "0.0.0",
"scripts": {
"dev": "vite",
"build": "tsc"
"build": "tsc"
},
"dependencies": {
"@casperdash/cep78-client": "workspace:*",
"casper-js-sdk": "^2.15.2"
"casper-js-sdk": "2.15.0",
"axios": "1.5.0"
},
"devDependencies": {
"typescript": "^5.0.2",
"ts-node": "10.9.1"
"ts-node": "10.9.1",
"typescript": "^5.2.2"
}
}
59 changes: 47 additions & 12 deletions examples/client-js/src/cep78/cep78.ts
Original file line number Diff line number Diff line change
@@ -1,29 +1,64 @@
import { CEP78Contract } from '@casperdash/cep78-client';
import { CLPublicKey} from 'casper-js-sdk';
import { CLPublicKey, Keys } from 'casper-js-sdk';
import axios from 'axios';
import path from 'path';
import { DeployUtil } from 'casper-js-sdk';
import { runDeployFlow } from '../utils/deploy';
import TransferWasm from '../wasm/transfer_call.wasm';

const MINTER = Keys.Ed25519.parseKeyFiles(
path.join(__dirname, `../keys/master_public.pem`),
path.join(__dirname, `../keys/master_private.pem`)
);


const transfer = async () => {
console.log('MINTER.publicKey: ', MINTER.publicKey.toHex());

const transfer = () => {
const cep78Contract = new CEP78Contract(
'casper-test',
'hash-c39ac4b3e174b0dc4063e3b482e8c27ffdc59c9c14591ef7c9738f0b1059a8d6',
'hash-5814ea56a814deb8f4057a5233788b6e87a1b6b9740ca47582772b13c147fea3'
'hash-ce5ab65523312ed33b9f830dee1ec78de73e561caf1a58b5642e9e6a9210c417',
);

const clFromPublicKey = CLPublicKey.fromHex('013f2770f56d8482c6bd38d0ce28e164bbd00a6094445e406c5a0b44a19400a706');
const clToPublicKey = CLPublicKey.fromHex('01ce62c06f9e6739d06c346cd1003ef80949a61d345c3e8293ea23e0f1d7f04035');

const registerDeployTwo = cep78Contract.register(
{
tokenOwner: clToPublicKey,
},
"1000000000",
MINTER.publicKey,
[MINTER],
);

console.log('TransferWasm: ', TransferWasm);

const transferDeploy = cep78Contract.transfer(
{
tokenId: "0",
source: clFromPublicKey,
tokenId: "4",
source: MINTER.publicKey,
target: clToPublicKey,
},
{ useSessionCode: false },
"13000000000",
clFromPublicKey,
{ useSessionCode: true },
"20000000000",
MINTER.publicKey,
[],
TransferWasm
);


return transferDeploy;


console.log('DeployUtil.deployToJson(transferDeploy as any): ', DeployUtil.deployToJson(transferDeploy as any));

// const response = await axios.post('http://localhost:3001/deploy', DeployUtil.deployToJson(transferDeploy as any));

// console.log('response: ', response);

// if (deploy.err) {
// throw Error('Deploy failed');
// }

await runDeployFlow(DeployUtil.signDeploy(transferDeploy, MINTER));
}

transfer();
50 changes: 50 additions & 0 deletions examples/client-js/src/utils/deploy.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,50 @@
import { CasperClient, DeployUtil} from 'casper-js-sdk';

export const NODE_URL = 'http://76.91.193.251:7777/rpc';
export const NETWORK_NAME = 'casper-test';

export const sleep = (ms: number) => {
return new Promise((resolve) => setTimeout(resolve, ms));
};

export const getDeploy = async (nodeURL: string, deployHash: string) => {
const client = new CasperClient(nodeURL);
let i = 300;
while (i !== 0) {
const [deploy, raw] = await client.getDeploy(deployHash);
if (raw.execution_results.length !== 0) {
// @ts-ignore
if (raw.execution_results[0].result.Success) {
return deploy;
} else {
// @ts-ignore
throw Error(
"Contract execution: " +
// @ts-ignore
raw.execution_results[0].result.Failure.error_message
);
}
} else {
i--;
await sleep(1000);
continue;
}
}
throw Error("Timeout after " + i + "s. Something's wrong");
};


export const runDeployFlow = async (deploy: DeployUtil.Deploy, isWaitting = true) => {
console.log('deploy: ', deploy);

const deployHash = await deploy.send(NODE_URL!);

console.log("...... Deploy hash: ", deployHash);
console.log("...... Waiting for the deploy...");
if (isWaitting) {
await getDeploy(NODE_URL!, deployHash);
}


console.log(`...... Deploy ${deployHash} succedeed`);
};
9 changes: 9 additions & 0 deletions examples/client-js/src/wasm/transfer_call.wasm.ts

Large diffs are not rendered by default.

Loading