{% hint style="warning" %} Please be sure of your agent type and version and pick the right documentation accordingly. {% endhint %}
{% tabs %}
{% tab title="Node.js" %}
{% hint style="danger" %}
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. {% endhint %} {% endtab %}
{% tab title="Ruby on Rails" %}
{% hint style="success" %}
This is still the latest Ruby on Rails documentation of the forest_liana
agent, you’re at the right place, please read on.
{% endhint %}
{% endtab %}
{% tab title="Python" %}
{% hint style="danger" %}
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. {% endhint %} {% endtab %}
{% tab title="PHP" %}
{% hint style="danger" %}
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. {% endhint %} {% endtab %} {% endtabs %}
This example shows you how to create a smart collection to list the transfers of your Dwolla account.
Filterable fields are flagged using isFilterable: true
. You will need to enable this option using the collection settings in the Layout Editor.
Transfers have the onlyForRelationships
enabled: it means that these 2 collections are only accessible via the Dwolla customer relationships.
// forest/dwolla-transfers.js
const { collection } = require('forest-express-sequelize');
collection('dwollaTransfers', {
onlyForRelationships: true,
isSearchable: true,
actions: [],
fields: [
{
field: 'id',
type: 'String',
isSortable: true,
},
{
field: 'status',
type: 'Enum',
enums: ['processed', 'pending', 'cancelled', 'failed'],
isFilterable: true,
},
{
field: 'amount',
type: 'Json',
},
{
field: 'amountReadable',
type: 'String',
get: (transfer) => {
if (!transfer.amount) return null;
var formatter = new Intl.NumberFormat('en-US', {
style: 'currency',
currency: transfer.amount.currency,
// These options are needed to round to whole numbers if that's what you want.
//minimumFractionDigits: 0, // (this suffices for whole numbers, but will print 2500.10 as $2,500.1)
//maximumFractionDigits: 0, // (causes 2500.99 to be printed as $2,501)
});
return formatter.format(transfer.amount.value);
},
},
{
field: 'metadata',
type: 'Json',
},
{
field: 'clearing',
type: 'Json',
},
{
field: 'clearing',
type: 'Json',
},
{
field: 'achDetails',
type: 'Json',
},
{
field: 'correlationId',
type: 'String',
isFilterable: true,
},
{
field: 'individualAchId',
type: 'String',
},
{
field: 'bankName',
type: 'String',
},
{
field: 'fingerprint',
type: 'String',
},
{
field: 'created', //created_at
type: 'Date',
},
],
segments: [],
});
This route use the Dwolla service described in another section.
// routes/transfers.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 = 'dwollaTransfers';
const router = express.Router();
const permissionMiddlewareCreator = new PermissionMiddlewareCreator(
`${MODEL_NAME}`
);
// Get a Transfer
router.get(
`/${MODEL_NAME}/:recordId`,
permissionMiddlewareCreator.details(),
(request, response, next) => {
const recordId = request.params.recordId;
dwollaService
.getTransfer(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;