@gateway.fm/gtw-dvf-client-js
Version:
DVF client js lib with gateway.fm rpc endpoints
50 lines (39 loc) • 1.5 kB
JavaScript
#!/usr/bin/env node
const HDWalletProvider = require('@truffle/hdwallet-provider')
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,
apiKey: envVars.API_KEY
// Add more variables to override default values
}
;(async () => {
const dvf = await DVF(web3, dvfConfig)
const publicPermissionsDescriptor = await dvf.publicUserPermissions()
logExampleResult(publicPermissionsDescriptor)
// Get currently set permissions for a user, authenticated endpoint
const currentUerPermissions = await dvf.account.getPermissions()
logExampleResult(currentUerPermissions)
// Enable all of the permissions
Object.keys(currentUerPermissions).map(async (permissionKey) => {
const updatedPermissions = await dvf.account.setPermissions({ key: permissionKey, value: true })
logExampleResult(updatedPermissions)
})
})()
.catch(error => {
console.error(error)
process.exit(1)
})