1
0
mirror of https://github.com/oceanprotocol-archive/squid-js.git synced 2024-02-02 15:31:51 +01:00
squid-js/src/ocean/OceanAccounts.ts

66 lines
1.9 KiB
TypeScript
Raw Normal View History

import Balance from "../models/Balance"
2019-01-21 17:48:40 +01:00
import Account from "./Account"
import { Instantiable, InstantiableConfig } from "../Instantiable.abstract"
2019-01-21 17:48:40 +01:00
/**
* Account submodule of Ocean Protocol.
*/
export class OceanAccounts extends Instantiable {
2019-01-21 17:48:40 +01:00
/**
* Returns the instance of OceanAccounts.
* @return {Promise<OceanAccounts>}
*/
public static async getInstance(config: InstantiableConfig): Promise<OceanAccounts> {
const instance = new OceanAccounts()
instance.setInstanceConfig(config)
2019-01-21 17:48:40 +01:00
return instance
2019-01-21 17:48:40 +01:00
}
/**
* Returns the list of accounts.
* @return {Promise<Account[]>}
*/
public async list(): Promise<Account[]> {
// retrieve eth accounts
const ethAccounts: string[] = await this.web3.eth.getAccounts()
2019-01-21 17:48:40 +01:00
const accountPromises = ethAccounts
.map(address => new Account(address, this.instanceConfig))
.map(async account => {
const token = await this.ocean.auth.restore(account)
if (token) {
account.setToken(token)
}
return account
})
return Promise.all(accountPromises)
2019-01-21 17:48:40 +01:00
}
/**
* Return account balance.
* @param {Account} account Account instance.
* @return {Promise<Balance>} Ether and Ocean Token balance.
*/
public balance(account: Account): Promise<Balance> {
return account.getBalance()
}
/**
* Request tokens for a account.
* @param {Account} account Account instance.
* @param {number} amount Token amount.
* @return {Promise<boolean>} Success.
*/
public async requestTokens(account: Account, amount: number): Promise<boolean> {
try {
await account.requestTokens(amount)
return true
2019-02-21 18:14:07 +01:00
} catch (e) {
return false
}
}
2019-01-21 17:48:40 +01:00
}