@gluwa/creditcoin-dex-router-sdk
v0.9.1
Published
Creditcoin DEX Router SDK
Downloads
826
Keywords
Readme
creditcoin-dex-router-sdk
Introduction
This repository adapts the smart-order-router to be used in Gluwa's Creditcoin ecosystem.
Getting Started
1. Installation process
The package can be found at @gluwa/creditcoin-dex-router-sdk. Run the following command to install it in your project:
npm install @gluwa/creditcoin-dex-router-sdk
2. Software dependencies
It is recommended that you install ethers v5.7 in your project.
DexRouter (client side) Example
Here is are the basic steps to initialize the DexRouter:
import { DexRouter, DexRouterConfiguration, DexRouterParams } from "@gluwa/creditcoin-dex-router-sdk";
import { ethers } from "ethers";
const CC3_DEX_FACTORY_ADDRESS = '0xEcc68469F9c015A217215E19Fb6a183FE27aD1E9';
// Initialize the DexRouterConfiguration with URLs of backend services, chain ID, and factory address of CC3 DEX
// There are several optional properties that will fallback to defaults. See technical reference doc for more info on these.
const config: DexRouterConfiguration = {
chainId: 102031,
factoryAddress: CC3_DEX_FACTORY_ADDRESS,
indexerGraphqlUrl: "http://localhost:8080/graphql",
blockedTokenServiceUrl: "http://localhost:5243/"
};
// Initialize the provider to communicate with the block chain.
const baseProvider = new ethers.providers.JsonRpcProvider('https://rpc.cc3-testnet.creditcoin.network');
// Initialize DexRouterParams with config and base provider
const dexRouterParams: DexRouterParams = {
config,
baseProvider
};
// Construct a new instance of DexRouter using the above params.
const dexRouter = new DexRouter(dexRouterParams);
DexRouter (server side) Example
Here is are the basic steps to initialize the ServerSideRouter:
import { ServerSideRouter, DexRouterConfiguration, ServerSideRouterParams } from "@gluwa/creditcoin-dex-router-sdk";
import { ethers } from "ethers";
const CC3_DEX_FACTORY_ADDRESS = '0xEcc68469F9c015A217215E19Fb6a183FE27aD1E9';
// Initialize the DexRouterConfiguration with URLs of backend services, chain ID, and factory address of CC3 DEX
// There are several optional properties that will fallback to defaults. See technical reference doc for more info on these.
const config: DexRouterConfiguration = {
chainId: 102031,
factoryAddress: CC3_DEX_FACTORY_ADDRESS,
indexerGraphqlUrl: "http://localhost:8080/graphql",
blockedTokenServiceUrl: "http://localhost:5243/",
routerServiceUrl: "https://dex-dev.creditcoin.org/router-service" // <--- This is the important piece that differs from standard DexRouter
};
// Initialize the provider to communicate with the block chain.
const baseProvider = new ethers.providers.JsonRpcProvider('https://rpc.cc3-testnet.creditcoin.network');
// Initialize ServerSideRouterParams with config and base provider
const dexRouterParams: ServerSideRouterParams = {
config,
baseProvider
};
// Construct a new instance of ServerSideRouter using the above params.
const serverSideRouter = new ServerSideRouter(dexRouterParams);