Skip to content

Commit

Permalink
fixes & datatokens class
Browse files Browse the repository at this point in the history
  • Loading branch information
alexcos20 committed May 31, 2020
1 parent 131aa74 commit 8031e01
Show file tree
Hide file tree
Showing 10 changed files with 147 additions and 38 deletions.
18 changes: 5 additions & 13 deletions package-lock.json

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

1 change: 1 addition & 0 deletions package.json
Original file line number Diff line number Diff line change
Expand Up @@ -36,6 +36,7 @@
"@ethereum-navigator/navigator": "^0.5.0",
"bignumber.js": "^9.0.0",
"deprecated-decorator": "^0.1.6",
"fs": "0.0.1-security",
"node-fetch": "^2.6.0",
"save-file": "^2.3.1",
"uuid": "^8.0.0",
Expand Down
2 changes: 0 additions & 2 deletions src/Instantiable.abstract.ts
Original file line number Diff line number Diff line change
Expand Up @@ -2,8 +2,6 @@ import Web3 from 'web3'
import Config from './models/Config'
import { Logger, LoggerInstance, LogLevel } from './utils'
import { Ocean } from './ocean/Ocean'
import { OceanFactoryABI } from './datatokens/FactoryABI'
import { OceanDataTokenABI } from './datatokens/DatatokensABI'

export interface InstantiableConfig {
ocean: Ocean
Expand Down
150 changes: 134 additions & 16 deletions src/datatokens/Datatokens.ts
Original file line number Diff line number Diff line change
@@ -1,5 +1,8 @@
import Account from '../ocean/Account'

const defaultFactoryABI = require('../datatokens/FactoryABI.json')
const defaultDatatokensABI = require('../datatokens/DatatokensABI.json')

/**
* Provides a interface to DataTokens
Expand All @@ -25,20 +28,47 @@ export class DataTokens {
web3: any
) {
this.factoryAddress = factoryAddress
this.factoryABI = factoryABI
this.datatokensABI = datatokensABI

this.factoryABI = factoryABI || defaultFactoryABI
this.datatokensABI = datatokensABI || defaultDatatokensABI
this.web3 = web3
}

/**
* Create new datatoken
* @param {String} metaDataStoreURI
* @param {Account} account
* @param {String} name
* @param {String} symbol
* @param {Number} cap
* @return {Promise<string>} datatoken address
*/
public async create(metaDataStoreURI: string, account: Account): Promise<string> {
// TO DO
return ''
public async create(
metaDataStoreURI: string,
account: Account,
name?: string,
symbol?: string,
cap?: number
): Promise<string> {
// TODO - Autogenerate name, symbol & cap if missing
if (!name) name = 'DTTest1'
if (!symbol) symbol = 'DT1'
if (!cap) cap = 1000000
// Create factory contract object
const factory = new this.web3.eth.Contract(this.factoryABI, this.factoryAddress, {
from: account.getId()
})
// Invoke createToken function of the contract
const trxReceipt = await factory.methods
.createToken(name, symbol, cap, metaDataStoreURI, account.getId())
.send()
let tokenAddress = null
try {
tokenAddress = trxReceipt.events.TokenCreated.returnValues[0]
} catch (e) {
console.error(e)
}
return tokenAddress
}

/**
Expand All @@ -51,12 +81,17 @@ export class DataTokens {
*/
public async approve(
dataTokenAddress: string,
toAddress: string,
spender: string,
amount: number,
account: Account
): Promise<string> {
// TO DO
return ''
const datatoken = new this.web3.eth.Contract(
this.datatokensABI,
dataTokenAddress,
{ from: account.getId() }
)
const trxReceipt = await datatoken.methods.approve(spender, amount).send()
return trxReceipt
}

/**
Expand Down Expand Up @@ -93,8 +128,14 @@ export class DataTokens {
amount: number,
toAddress?: string
): Promise<string> {
// TO DO
return ''
const address = toAddress || account.getId()
const datatoken = new this.web3.eth.Contract(
this.datatokensABI,
dataTokenAddress,
{ from: account.getId() }
)
const trxReceipt = await datatoken.methods.mint(address, amount).send()
return trxReceipt
}

/**
Expand All @@ -111,8 +152,13 @@ export class DataTokens {
amount: number,
account: Account
): Promise<string> {
// TO DO
return ''
const datatoken = new this.web3.eth.Contract(
this.datatokensABI,
dataTokenAddress,
{ from: account.getId() }
)
const trxReceipt = await datatoken.methods.transfer(toAddress, amount).send()
return trxReceipt
}

/**
Expand All @@ -129,8 +175,15 @@ export class DataTokens {
amount: number,
account: Account
): Promise<string> {
// TO DO
return ''
const datatoken = new this.web3.eth.Contract(
this.datatokensABI,
dataTokenAddress,
{ from: account.getId() }
)
const trxReceipt = await datatoken.methods
.transferFrom(fromAddress, account.getId(), amount)
.send()
return trxReceipt
}

/**
Expand All @@ -140,7 +193,72 @@ export class DataTokens {
* @return {Promise<number>} balance
*/
public async balance(dataTokenAddress: string, account: Account): Promise<number> {
// TO DO
return 0
const datatoken = new this.web3.eth.Contract(
this.datatokensABI,
dataTokenAddress,
{ from: account.getId() }
)
const trxReceipt = await datatoken.methods.balanceOf(account.getId()).call()
return trxReceipt
}

/** Get Blob
* @param {String} dataTokenAddress
* @param {Account} account
* @return {Promise<string>} string
*/
public async getBlob(dataTokenAddress: string, account: Account): Promise<string> {
const datatoken = new this.web3.eth.Contract(
this.datatokensABI,
dataTokenAddress,
{ from: account.getId() }
)
const trxReceipt = await datatoken.methods.blob().call()
return trxReceipt
}

/** Get Name
* @param {String} dataTokenAddress
* @param {Account} account
* @return {Promise<string>} string
*/
public async getName(dataTokenAddress: string, account: Account): Promise<string> {
const datatoken = new this.web3.eth.Contract(
this.datatokensABI,
dataTokenAddress,
{ from: account.getId() }
)
const trxReceipt = await datatoken.methods.name().call()
return trxReceipt
}

/** Get Symbol
* @param {String} dataTokenAddress
* @param {Account} account
* @return {Promise<string>} string
*/
public async getSymbol(dataTokenAddress: string, account: Account): Promise<string> {
const datatoken = new this.web3.eth.Contract(
this.datatokensABI,
dataTokenAddress,
{ from: account.getId() }
)
const trxReceipt = await datatoken.methods.symbol().call()
return trxReceipt
}

/** Get Cap
* @param {String} dataTokenAddress
* @param {Account} account
* @return {Promise<string>} string
*/
public async getCap(dataTokenAddress: string, account: Account): Promise<string> {
const datatoken = new this.web3.eth.Contract(
this.datatokensABI,
dataTokenAddress,
{ from: account.getId() }
)
const trxReceipt = await datatoken.methods.cap().call()
return trxReceipt
}
}
1 change: 1 addition & 0 deletions src/datatokens/DatatokensABI.json
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
[{"constant":false,"inputs":[{"name":"spender","type":"address"},{"name":"value","type":"uint256"}],"name":"approve","outputs":[{"name":"","type":"bool"}],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":true,"inputs":[],"name":"totalSupply","outputs":[{"name":"","type":"uint256"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":false,"inputs":[{"name":"from","type":"address"},{"name":"to","type":"address"},{"name":"value","type":"uint256"}],"name":"transferFrom","outputs":[{"name":"","type":"bool"}],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":false,"inputs":[{"name":"spender","type":"address"},{"name":"addedValue","type":"uint256"}],"name":"increaseAllowance","outputs":[{"name":"","type":"bool"}],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":true,"inputs":[{"name":"account","type":"address"}],"name":"balanceOf","outputs":[{"name":"","type":"uint256"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":false,"inputs":[{"name":"spender","type":"address"},{"name":"subtractedValue","type":"uint256"}],"name":"decreaseAllowance","outputs":[{"name":"","type":"bool"}],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":false,"inputs":[{"name":"to","type":"address"},{"name":"value","type":"uint256"}],"name":"transfer","outputs":[{"name":"","type":"bool"}],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":true,"inputs":[{"name":"owner","type":"address"},{"name":"spender","type":"address"}],"name":"allowance","outputs":[{"name":"","type":"uint256"}],"payable":false,"stateMutability":"view","type":"function"},{"inputs":[{"name":"name","type":"string"},{"name":"symbol","type":"string"},{"name":"minter","type":"address"},{"name":"cap","type":"uint256"},{"name":"blob","type":"string"},{"name":"feeManager","type":"address"}],"payable":false,"stateMutability":"nonpayable","type":"constructor"},{"anonymous":false,"inputs":[{"indexed":true,"name":"from","type":"address"},{"indexed":true,"name":"to","type":"address"},{"indexed":false,"name":"value","type":"uint256"}],"name":"Transfer","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"name":"owner","type":"address"},{"indexed":true,"name":"spender","type":"address"},{"indexed":false,"name":"value","type":"uint256"}],"name":"Approval","type":"event"},{"constant":false,"inputs":[{"name":"name","type":"string"},{"name":"symbol","type":"string"},{"name":"minter","type":"address"},{"name":"cap","type":"uint256"},{"name":"blob","type":"string"},{"name":"feeManager","type":"address"}],"name":"initialize","outputs":[{"name":"","type":"bool"}],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":false,"inputs":[{"name":"account","type":"address"},{"name":"value","type":"uint256"}],"name":"mint","outputs":[],"payable":true,"stateMutability":"payable","type":"function"},{"constant":false,"inputs":[],"name":"pause","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":false,"inputs":[],"name":"unpause","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":false,"inputs":[{"name":"minter","type":"address"}],"name":"setMinter","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":true,"inputs":[],"name":"name","outputs":[{"name":"","type":"string"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[],"name":"symbol","outputs":[{"name":"","type":"string"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[],"name":"blob","outputs":[{"name":"","type":"string"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[],"name":"decimals","outputs":[{"name":"","type":"uint256"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[],"name":"cap","outputs":[{"name":"","type":"uint256"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[{"name":"account","type":"address"}],"name":"isMinter","outputs":[{"name":"","type":"bool"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[],"name":"isInitialized","outputs":[{"name":"","type":"bool"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[],"name":"isPaused","outputs":[{"name":"","type":"bool"}],"payable":false,"stateMutability":"view","type":"function"}]
1 change: 0 additions & 1 deletion src/datatokens/DatatokensABI.ts

This file was deleted.

1 change: 1 addition & 0 deletions src/datatokens/FactoryABI.json
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
[{"inputs":[{"name":"_template","type":"address"},{"name":"_feeManager","type":"address"}],"payable":false,"stateMutability":"nonpayable","type":"constructor"},{"anonymous":false,"inputs":[{"indexed":false,"name":"newTokenAddress","type":"address"},{"indexed":false,"name":"templateAddress","type":"address"},{"indexed":false,"name":"tokenName","type":"string"}],"name":"TokenCreated","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"name":"tokenAddress","type":"address"},{"indexed":true,"name":"tokenName","type":"string"},{"indexed":true,"name":"tokenSymbol","type":"string"},{"indexed":false,"name":"tokenCap","type":"uint256"},{"indexed":false,"name":"RegisteredBy","type":"address"},{"indexed":false,"name":"RegisteredAt","type":"uint256"},{"indexed":false,"name":"blob","type":"string"}],"name":"TokenRegistered","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"name":"instance","type":"address"}],"name":"InstanceDeployed","type":"event"},{"constant":false,"inputs":[{"name":"_name","type":"string"},{"name":"_symbol","type":"string"},{"name":"_cap","type":"uint256"},{"name":"_blob","type":"string"},{"name":"_minter","type":"address"}],"name":"createToken","outputs":[{"name":"token","type":"address"}],"payable":false,"stateMutability":"nonpayable","type":"function"}]
1 change: 0 additions & 1 deletion src/datatokens/FactoryABI.ts

This file was deleted.

8 changes: 4 additions & 4 deletions src/models/Config.ts
Original file line number Diff line number Diff line change
Expand Up @@ -6,13 +6,13 @@ export class Config {
* Aquarius URL.
* @type {string}
*/
public aquariusUri: string
public aquariusUri?: string

/**
* Brizo URL.
* @type {string}
*/
public brizoUri: string
public brizoUri?: string

/**
* Web3 Provider.
Expand All @@ -30,13 +30,13 @@ export class Config {
* Factory ABI
* @type {string}
*/
public factoryABI: object
public factoryABI?: object

/**
* datatokens ABI
* @type {string}
*/
public datatokensABI: object
public datatokensABI?: object

/**
* Log level.
Expand Down
2 changes: 1 addition & 1 deletion src/ocean/utils/WebServiceConnector.ts
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
import { BodyInit, RequestInit, Response } from 'node-fetch'
import fs from 'fs'
import * as fs from 'fs'
import { Logger } from '../../utils'

const fetch = require('node-fetch')
Expand Down

0 comments on commit 8031e01

Please sign in to comment.