@kynesyslabs/demosdk

Demos SDK

A JavaScript/TypeScript SDK providing a unified interface for interacting with the Demos network and cross-chain operations.

  • Node.js 18.0 or higher
  • TypeScript 5.0 or higher (for TypeScript projects)
npm install @kynesyslabs/demosdk
# or
yarn add @kynesyslabs/demosdk
  • WebSDK: Browser-compatible SDK for web applications
  • Cross-chain Core: Unified interface for multiple blockchain networks
  • DemosWork: Workflow execution engine
  • Wallet: Wallet management and cryptographic operations
  • Bridge: Cross-chain asset bridging via Rubic protocol
  • Abstraction: Chain-agnostic transaction and balance queries
  • Encryption: Post-quantum cryptography and zero-knowledge proofs
  • EVM-compatible: Ethereum, BSC, Polygon, Arbitrum, Optimism
  • Non-EVM: Solana, Bitcoin, TON, Near, MultiversX, Cosmos IBC, XRP
import { Demos } from "@kynesyslabs/demosdk/websdk"
import { prepareXMPayload } from "@kynesyslabs/demosdk/xm-websdk"
import { DemosWork } from "@kynesyslabs/demosdk/demoswork"

The SDK provides multiple entry points:

  • @kynesyslabs/demosdk - Main entry point
  • @kynesyslabs/demosdk/websdk - Web SDK components
  • @kynesyslabs/demosdk/xm-websdk - Cross-chain web SDK
  • @kynesyslabs/demosdk/xm-localsdk - Cross-chain local SDK
  • @kynesyslabs/demosdk/xmcore - Cross-chain core functionality
  • @kynesyslabs/demosdk/demoswork - Workflow engine
  • @kynesyslabs/demosdk/wallet - Wallet utilities
  • @kynesyslabs/demosdk/abstraction - Chain abstraction layer
  • @kynesyslabs/demosdk/bridge - Bridging functionality
  • @kynesyslabs/demosdk/encryption - Cryptographic utilities
  • @kynesyslabs/demosdk/utils - Common utilities
  • @kynesyslabs/demosdk/types - TypeScript type definitions
  • @kynesyslabs/demosdk/l2ps - Layer 2 payment solutions
import { Demos } from "@kynesyslabs/demosdk/websdk"

// 1. Initialize Demos SDK (no parameters)
const demos = new Demos()

// 2. Connect to the network
const rpc = "https://demosnode.discus.sh"
await demos.connect(rpc)

// 3. Generate a new mnemonic or use existing one
const mnemonic = demos.newMnemonic() // Generates 12-word mnemonic
// const mnemonic = "your existing mnemonic phrase..." // Or use existing

// 4. Connect your wallet
await demos.connectWallet(mnemonic)

// 5. Get your wallet address
const address = demos.getAddress()
console.log("Wallet address:", address)
// Send native DEM tokens
const tx = await demos.transfer(
"0x6690580a02d2da2fefa86e414e92a1146ad5357fd71d594cc561776576857ac5",
100 // amount in DEM
)

// Confirm and broadcast transaction
const validityData = await demos.confirm(tx)
const result = await demos.broadcast(validityData)
import { 
prepareXMPayload,
prepareXMScript
} from "@kynesyslabs/demosdk/websdk"
import { EVM } from "@kynesyslabs/demosdk/xm-websdk"

// 1. Create cross-chain payload (e.g., Ethereum Sepolia)
const evm = await EVM.create("https://rpc.ankr.com/eth_sepolia")
await evm.connectWallet("your_ethereum_private_key")

const evmTx = await evm.preparePay(
"0xRecipientAddress",
"0.001" // 0.001 ETH
)

// 2. Create XMScript
const xmscript = prepareXMScript({
chain: "eth",
subchain: "sepolia",
signedPayloads: [evmTx],
type: "pay"
})

// 3. Convert to Demos transaction
const tx = await prepareXMPayload(xmscript, demos)

// 4. Confirm and broadcast
const validityData = await demos.confirm(tx)
const result = await demos.broadcast(validityData)
yarn build

To use the SDK from a local source:

# Build the SDK
yarn build

# In your project
yarn add file:../path/to/sdks

Run specific test suites:

yarn test:multichain    # Cross-chain SDK payload generation
yarn test:tx # Cross-chain transaction tests
yarn test:demoswork # DemosWork operations
yarn test:native # Native payment transactions
yarn test:identities # Identity management
yarn test:web2 # Web2 proxy functionality
yarn test:bridge # Bridge service tests
yarn test:btc # Bitcoin-specific tests
yarn test:evm # EVM chain tests
yarn test:pqc # Post-quantum cryptography

Ensure code quality before pushing:

yarn setup:pre-push

The SDK is automatically published to NPM when:

  1. The version in package.json is incremented
  2. Changes are committed with a message starting with "release"
  3. The commit is pushed to GitHub

Example:

git commit -m "release v2.3.9"
git push

We welcome contributions to the Demos SDK. Please ensure:

  1. All tests pass before submitting a PR
  2. Code follows the existing style and conventions
  3. New features include appropriate test coverage
  4. Documentation is updated for API changes

MIT