@gateway.fm/gtw-dvf-client-js
Version:
DVF client js lib with gateway.fm rpc endpoints
55 lines (42 loc) • 1.43 kB
JavaScript
#!/usr/bin/env node
/*
DO NOT EDIT THIS FILE BY HAND!
Examples are generated using helpers/buildExamples.js script.
Check README.md for more details.
*/
const HDWalletProvider = require('@truffle/hdwallet-provider')
const sw = require('starkware_crypto')
const Web3 = require('web3')
const DVF = require('../src/dvf')
const envVars = require('./helpers/loadFromEnvOrConfig')(
process.env.CONFIG_FILE_NAME
)
const logExampleResult = require('./helpers/logExampleResult')(__filename)
const ethPrivKey = envVars.ETH_PRIVATE_KEY
// NOTE: you can also generate a new key using:`
// const starkPrivKey = dvf.stark.createPrivateKey()
const starkPrivKey = envVars.STARK_PRIVATE_KEY
const rpcUrl = envVars.RPC_URL
const provider = new HDWalletProvider(ethPrivKey, rpcUrl)
const web3 = new Web3(provider)
provider.engine.stop()
const dvfConfig = {
api: envVars.API_URL,
dataApi: envVars.DATA_API_URL,
useAuthHeader: true,
apiKey: envVars.API_KEY
// Add more variables to override default values
}
;(async () => {
const dvf = await DVF(web3, dvfConfig)
dvf.config.useTradingKey = true
const nonce = Date.now() / 1000
const keyPair = sw.ec.keyFromPrivate(starkPrivKey, 'hex')
const starkSignature = sw.sign(keyPair, nonce)
const getDepositsResponse = await dvf.getDeposits(null, nonce, starkSignature)
logExampleResult(getDepositsResponse)
})()
.catch(error => {
console.error(error)
process.exit(1)
})