Upgrade to v7

The purpose of this note is to help developers to upgrade their agent from v6 to v7. Please read carefully and integrate the following breaking changes to ensure a smooth upgrade.​

Upgrade to v7

Please follow the recommended procedure to upgrade your agent version by following this note.

Upgrading to v7

This upgrade unlocks the following feature:

  • easier addition of additional databases

  • no need to re-authenticate when switching between projects/environments/team

  • dynamic smart action forms

  • automatic model update

To upgrade to v7, simply run:

In case of a regression introduced in Production after the upgrade, a rollback to your previous agent is the fastest way to restore your admin panel.

Breaking changes

Agent initialization

In the file middlewares/forestadmin.js, the parameters of Liana.init have been updated. A few parameters have been deprecated and will either be ignored or throw an error.

Two new parameters have also been introduced to ease the addition and management of multiple databases.

The below tables list all these parameters:

Deprecated parameters
Behavior
Replace by

onlyCrudModule

Ignored

modelsDir

Ignored

sequelize

Ignored

mongoose

Ignored

secretKey

Error

envSecret

authKey

Error

authSecret

New parameters
Description

objectMapping

static instance of your object mapper (require('sequelize') or require('mongoose'))

connections

map of your existing connections, indexed by a unique name for each connections

Here is an example of an updated middlewares/forestadmin.js file after the migration:

Models index

The models/index.js file should be updated as well, in order to export objectMapping & connections

Introducing database configuration

A config/databases.js file should be added as follows in order to declare the different database connections:

Mongoose specific changes

If you made the above recommended changes in your models/index.js file, your Mongoose model files should now be written this way:

Authentication

One of the changes introduced by the v7 is that you no longer need to re-authenticate when switching between projects/environments/team. In order to support this easier authentication flow, the changes described below need to be made.

New environment variable

A new environment variable called APPLICATION_URL is required and must be added to your .env file.

http://localhost:3310 is the default value to be set for the APPLICATION_URL. If you specified a specific url for your application in place of the default one (for example for an install on a remote machine), this url should be the value set.

New CORS condition

A change in your app.js is required to modify how CORS are handled. The value 'null' must be accepted for authentication endpoints (lines 11-17).

Running up multiple server instances

If you're running multiple instances of your agent (with a load balancer for example), you will need to set up a static client id.

First you will need to obtain a client id for your environment by running the following command:

Then assign the client_id value from the response (it's a JWT) to a FOREST_CLIENT_ID variable in your .env file.

Important Notice

Changelogs

This release note covers only the major changes. To learn more, please refer to the changelogs in our different repositories:

Last updated

Was this helpful?