bfx-api-node-models
Version:
Object models for usage with the Bitfinex node API
68 lines (60 loc) • 1.7 kB
JavaScript
const amountValidator = require('./validators/amount')
const currencyValidator = require('./validators/currency')
const stringValidator = require('./validators/string')
const { WALLET_TYPES } = require('bfx-hf-util')
const Model = require('./model')
const VALID_TYPES = Object.values(WALLET_TYPES)
const fields = {
type: 0,
currency: 1,
balance: 2,
unsettledInterest: 3,
balanceAvailable: 4,
description: 5,
meta: 6
}
/**
* Wallet model
*/
class Wallet extends Model {
/**
* @param {object|Array} data - wallet data
* @param {string} data.type - wallet type (i.e. deposit)
* @param {string} data.currency - wallet currency
* @param {number} data.balance - total balance
* @param {number} data.unsettledInterest - unsettled interest
* @param {number} data.balanceAvailable - available balance
*/
constructor (data = {}) {
super({ data, fields })
}
/**
* @param {object[]|object|Array[]|Array} data - data to convert to POJO
* @returns {object} pojo
*/
static unserialize (data) {
return super.unserialize({ data, fields })
}
/**
* Validates a given wallet instance
*
* @param {object[]|object|Wallet[]|Wallet|Array} data - instance to validate
* @returns {string} error - null if instance is valid
*/
static validate (data) {
return super.validate({
data,
fields,
validators: {
type: v => stringValidator(v, VALID_TYPES),
currency: currencyValidator,
balance: amountValidator,
unsettledInterest: amountValidator,
balanceAvailable: amountValidator,
description: stringValidator
}
})
}
}
module.exports = Wallet