This is the documentation of the forest-express-sequelize
and forest-express-mongoose
Node.js agents that will soon reach end-of-support.
forest-express-sequelize
v9 and forest-express-mongoose
v9 are replaced by @forestadmin/agent
v1.
Please check your agent type and version and read on or switch to the right documentation.
This is still the latest Ruby on Rails documentation of the forest_liana
agent, you’re at the right place, please read on.
This is the documentation of the django-forestadmin
Django agent that will soon reach end-of-support.
If you’re using a Django agent, notice that django-forestadmin
v1 is replaced by forestadmin-agent-django
v1.
If you’re using a Flask agent, go to the forestadmin-agent-flask
v1 documentation.
Please check your agent type and version and read on or switch to the right documentation.
This is the documentation of the forestadmin/laravel-forestadmin
Laravel agent that will soon reach end-of-support.
If you’re using a Laravel agent, notice that forestadmin/laravel-forestadmin
v1 is replaced by forestadmin/laravel-forestadmin
v3.
If you’re using a Symfony agent, go to the forestadmin/symfony-forestadmin
v1 documentation.
Please check your agent type and version and read on or switch to the right documentation.
Display Dwolla funding sources
1. Define the smart collection
// forest/dwolla-funding-sources.js
const { collection } = require('forest-express-sequelize');
collection('dwollaFundingSources', {
onlyForRelationships: true,
actions: [],
fields: [
{
field: 'id',
type: 'String',
},
{
field: 'status',
type: 'Enum',
enums: ['unverified', 'verified'],
},
{
field: 'type',
type: 'Enum',
enums: ['bank', 'balance'],
},
{
field: 'bankAccountType',
type: 'Enum',
enums: ['checking', 'savings', 'general-ledger', 'loan'],
},
{
field: 'name',
type: 'String',
},
{
field: 'balance',
type: 'Json',
},
{
field: 'balanceReadable',
type: 'String',
get: (fundingSource) => {
if (!fundingSource.balance) return null;
var formatter = new Intl.NumberFormat('en-US', {
style: 'currency',
currency: fundingSource.balance.currency,
});
return formatter.format(fundingSource.balance.value);
},
},
{
field: 'removed',
type: 'Boolean',
},
{
field: 'channels',
type: ['String'],
},
{
field: 'bankName',
type: 'String',
},
{
field: 'fingerprint',
type: 'String',
},
{
field: 'created', //created_at
type: 'Date',
},
],
segments: [],
});
// routes/funding-sources.js
const express = require('express');
const {
PermissionMiddlewareCreator,
RecordSerializer,
} = require('forest-express-sequelize');
const DwollaService = require('../services/dwolla-service');
let dwollaService = new DwollaService(
process.env.DWOLLA_APP_KEY,
process.env.DWOLLA_APP_SECRET,
process.env.DWOLLA_ENVIRONMENT
);
const MODEL_NAME = 'dwollaFundingSources';
const router = express.Router();
const permissionMiddlewareCreator = new PermissionMiddlewareCreator(
`${MODEL_NAME}`
);
// Get a FundingSource
router.get(
`/${MODEL_NAME}/:recordId`,
permissionMiddlewareCreator.details(),
(request, response, next) => {
const recordId = request.params.recordId;
dwollaService
.getFundingSource(recordId)
.then(async (record) => {
const recordSerializer = new RecordSerializer({ name: MODEL_NAME });
const recordSerialized = await recordSerializer.serialize(record);
response.send(recordSerialized);
})
.catch(next);
}
);
module.exports = router;