Package Exports
- @jpyc/sdk-core
- @jpyc/sdk-core/dist/src/index.js
This package does not declare an exports field, so the exports above have been automatically detected and optimized by JSPM instead. If any package subpath is missing, it is recommended to post an issue to the original package (@jpyc/sdk-core) to support the "exports" field. If that is not possible, create a JSPM override to customize the exports field for this package.
Readme
JPYC Core SDK
JPYC core SDK implements interfaces to interact with JPYCv2 contracts on different chains. Supported chains are Ethereum, Polygon, Gnosis, Avalanche, Astar and Shiden.
💡 How to Use
Please follow the following steps to configure the SDK.
1. Install Packages
Install packages.
# yarn
$ yarn add @jpyc/sdk-core
# npm
$ npm i @jpyc/sdk-core2. Set Environment Variables
Some data, such as configuration variables (e.g., chain name) or sensitive data (e.g., private key), are embedded as environment variables. You need to set the following environment variables.
| Variable | Description & Instructions |
|---|---|
SDK_ENV |
SDK environment. Set to local for local environment or any other sensible string for production environment. |
CHAIN_NAME |
Chain name. Set to one of the following: local, ethereum, polygon, gnosis, avalanche, astar or shiden. |
NETWORK_NAME |
Network name within the specified chain. Set to one of the following: mainnet, goerli, sepolia, amoy, chiado or fuji |
RPC_ENDPOINT |
RPC endpoint to send transactions. |
PRIVATE_KEY |
Private key of an account. |
LOCAL_PROXY_ADDRESS |
Proxy contract address in local environment. |
3. Instantiate SDK
Initialize an SDK instance that implements abstracted interfaces to the JPYCv2 contracts.
import {
ChainName,
Endpoint,
IJPYC,
ISdkClient,
JPYC,
NetworkName,
SdkClient,
} from '@jpyc/sdk-core';
// 1. Initialize an SdkClient instance
const sdkClient: ISdkClient = new SdkClient({
chainName: process.env.CHAIN_NAME as ChainName,
networkName: process.env.NETWORK_NAME as NetworkName,
rpcEndpoint: process.env.RPC_ENDPOINT as Endpoint,
});
// 2. Generate an account from a private key
export const account = sdkClient.createPrivateKeyAccount({});
// 3. Generate a client with the account
export const client = sdkClient.createLocalClient({
account: account,
});
// 4. Initialize an SDK instance
export const jpyc: IJPYC = new JPYC({
client: client,
});4. Use SDK
Use the initialized SDK wherever you would like.
import { jpyc } from './YOUR/PATH/TO/INITIALIZATION/FILE';
// Fetch `totalSupply` from `JPYCv2` contract
const totalSupply = await jpyc.totalSupply();
console.log(`totalSupply: ${totalSupply.toString()}`);✨ Code Examples
For your reference, we provide code examples in the separate sdk-examples repository. Please follow the instructions specified in README files.
🤖 Available Commands
The following commands are available as yarn scripts for local development & testing.
| Command | Description |
|---|---|
compile |
Compile (transpile) SDK |
test |
Run unit tests (using jest) |
lint |
Run Eslint |
lint:dry-run |
Run Eslint without fixing |
format |
Run Prettier |
format:dry-run |
Run Prettier without fixing |
docs |
Generate Markdown documents from TSDoc-style comments |
📚 Documentation
You can find the auto-generated documentation of this SDK here.