This a library can be used from developers to interract with the ecochain. it is a modification of web3 js to work for ecochain
https://www.npmjs.com/package/ecoweb3
Run the following in your project folder:
npm install ecoweb3 --save
Instantiate a new instance of Ecoweb3
:
const Ecoweb3 = require('ecoweb3');
// set the correct RPC port
// in the node config file set server=1. If not, set rpcbind=0.0.0.0 (or a mask). Also set rpcuser, rpcpassword, rpcport and rpcallowip
config = {
rpcProvider: 'http://ecoc:ecoc@localhost:36562',
networkStr:'Mainnet'
}
const ecocw3 = new Ecocw3(config);
Checks if the attempet connection to eco node was successful or not.
async function isConnected() {
return await ecocw3.rpc.isConnected();
}
Converts an ecochain address to hex format.
async function getHexAddress() {
return await ecocw3.rpc.getHexAddress('eELfUyry7GkMVi7xNjq9zpuYbKbRsa6Hdg');
}
Converts a hex address to ecochain format.
async function fromHexAddress() {
return await ecocw3.rpc.fromHexAddress('864f980d88cdfb44a2e3293ecc01084e6d686e7a');
}
Gets the current block height of the ecochain node.
async function getBlockCount() {
return await ecocw3.rpc.getBlockCount();
}
Gets the transaction details of the transaction id.
async function getTransaction(args) {
const {
transactionId, // string
} = args;
return await ecocw3.rpc.getTransactionReceipt(transactionId);
}
Gets the transaction receipt of the transaction id.
async function getTransactionReceipt(args) {
const {
transactionId, // string
} = args;
return await ecoweb3.rpc.getTransactionReceipt(transactionId);
}
Gets the unspent outputs that can be used.
async function listUnspent() {
return await ecocw3.rpc.listUnspent();
}
Send ECOC to any ECOChain address.
async function sendToAddress() {
return await ecocw3.rpc.sendToAddress("EddvsnTiJDGmkLoFPLHBpMpaJxnHheDjE5", 0.1, "", "", false, "EZjYNo5Rxwkwu3ciBrZYLauAWfJuYeLe1s", false);
}
Send ECOC to one or many ECOChain addressess.
async function sendMany() {
return await ecocw3.rpc.sendMany({"EddvsnTiJDGmkLoFPLHBpMpaJxnHheDjE5":0.5, "EZjYNo5Rxwkwu3ciBrZYLauAWfJuYeLe1s": 0.6});
}
Gets the logs given the params on the blockchain.
The contractMetadata
param contains the contract names and ABI that you would like to parse. An example of one is:
Usage:
const ContractMetadata = require('./contract_metadata');
async function(args) {
let {
fromBlock, // number
toBlock, // number
addresses, // string array
topics // string array
} = args;
if (addresses === undefined) {
addresses = [];
}
if (topics === undefined) {
topics = [];
}
// removeHexPrefix = true removes the '0x' hex prefix from all hex values
return await ecoweb3.rpc.searchLogs(fromBlock, toBlock, addresses, topics, contractMetadata, true);
}
Instantiate a new instance of Contract
:
const { Ecoweb3 } = require('ecoweb3');
const ecoweb3 = new Ecoweb3('http://rpcuser:[email protected]:rpc-port');
// contractAddress = The address of your contract deployed on the blockchain
const contractAddress = 'f7b958eac2bdaca0f225b86d162f263441d23c19';
// contractAbi = The ABI of the contract
const contractAbi = [{
constant: true,
inputs: [
{
name: 'a',
type: 'uint256',
},
{
name: 'b',
type: 'uint256',
},
],
name: 'add',
outputs: [
{
name: '',
type: 'uint256',
},
],
payable: false,
stateMutability: 'pure',
type: 'function',
}]
// Create a Contract instance from the Ecoweb3 instance
const contract = ecoweb3.Contract(contractAddress, contractAbi);
Executes a callcontract
// callcontract on a method named 'bettingEndBlock'
async function exampleCall(args) {
const {
senderAddress, // address
} = args;
return await contract.call('add', {
methodArgs: [5,5],
senderAddress: senderAddress,
});
}
Executes a sendtocontract
// sendtocontract on a method named 'setResult'
async function exampleSend(args) {
const {
resultIndex, // number
senderAddress, // address
} = args;
return await contract.send('setResult', {
methodArgs: [resultIndex],
gasLimit: 1000000, // setting the gas limit to 1 million
senderAddress: senderAddress,
});
}
Encoder
static functions are exposed in Ecoweb3 instances or can be import directly.
const { Encoder } = require('ecoweb3');
Encoder.objToHash(abiObj, isFunction);
Encoder.addressToHex(address);
Encoder.boolToHex(value);
Encoder.intToHex(num);
Encoder.uintToHex(num);
Encoder.stringToHex(string, maxCharLen);
Encoder.stringArrayToHex(strArray, numOfItems);
Encoder.padHexString(hexStr);
Encoder.constructData(abi, methodName, args);
Decoder
static functions are exposed in Ecoweb3 instances or can be import directly.
const { Decoder } = require('ecoweb3');
Decoder.toEcoAddress(hexAddress, isMainnet);
Decoder.removeHexPrefix(value);
Decoder.decodeSearchLog(rawOutput, contractMetadata, removeHexPrefix);
Decoder.decodeCall(rawOutput, contractABI, methodName, removeHexPrefix);
Utils
static functions are exposed in Ecoweb3 instances or can be import directly.
const { Utils } = require('ecoweb3');
Utils.paramsCheck(methodName, params, required, validators);
Utils.appendHexPrefix(value);
Utils.trimHexPrefix(str);
Utils.chunkString(str, length);
Utils.toUtf8(hex);
Utils.fromUtf8(str);
Utils.isJson(str);
Utils.isEcoAddress(address);
{
ecoc: {
messagePrefix: '\x15Ecoc Signed Message:\n',
bech32: 'bc',
bip32: {
public: 0x0488b21e,
private: 0x0488ade4
},
pubKeyHash: 0x21, //ecoc changed to E
scriptHash: 0x32,
wif: 0x80
},
ecoc_testnet: {
messagePrefix: '\x15Ecoc Signed Message:\n',
bech32: 'tb',
bip32: {
public: 0x043587cf,
private: 0x04358394
},
pubKeyHash: 0x5c, //ecoc changed to e
scriptHash: 0x6e,
wif: 0xef
}
}
You must set the following variables inside the test scripts or you can create a .env
file in the root folder of the project.
NODE_RPC
SENDER_ADDRESS
WALLET_PASSPHRASE