Please be aware that while Forest make every effort to ensure that our platform updates are broadly compatible and offer detailed instructions for upgrading, Forest cannot guarantee that custom code developed by the developers will always be compatible with new versions of our software. This includes any custom modifications or extensions to core functionalities, such as method overrides or custom integrations. It is the responsibility of the developers to review and test their custom code to ensure compatibility with each new version. Our team provides comprehensive upgrade guides to assist in this process, but these cannot encompass the unique customizations that may be present in each customer’s environment. Therefore, Forest strongly recommend establishing a thorough testing protocol for your specific customizations to safeguard against potential issues during the upgrade process.
Breaking changes
Cors configuration
Set CORS credentials: true if you’re using custom CORS configuration. See how to configure CORS headers.
Rails
We use the Rack CORS Gem for this purpose.
# Gemfile
source 'https://rubygems.org'
# ...
gem 'forest_liana'
gem 'rack-cors'
module LiveDemoRails
class Application < Rails::Application
# ...
# For Rails 5, use the class Rack::Cors. For Rails 4, you MUST use the string 'Rack::Cors'.
config.middleware.insert_before 0, Rack::Cors do
allow do
origins 'app.forestadmin.com'
resource '*',
headers: :any,
methods: :any,
expose: ['Content-Disposition'],
credentials: true
end
end
end
end
Global smart action
Smart actions defined as follows global: true will no longer be considered as global.
Please now use type: 'global'.
Rails
Before
class Forest::Product
include ForestLiana::Collection
collection :Product
action 'Import data',
global: true
# ...
end
After
class Forest::Product
include ForestLiana::Collection
collection :Product
action 'Import data',
type: 'global'
# ...
end
Schema versioning
On server start - only in development environments - the agent will generate a .forestadmin-schema.json file reflecting your Forest schema.
If you change your models or database, Forest will automatically load a new schema to keep the layout up to date.
Do not edit this file. It will be automatically generated on server start only in development environments.This file must be deployed for any remote environment (staging, production, etc.), as it will be used to generate your Forest UI.
Version this file. It will give you more visibility on the changes detected by Forest.
In the following example, we have added two fields on the invoices table:
Versioning the.forestadmin-schema.json file allows you to easily visualize the changes.
Changelogs
This release note covers only the major changes. To learn more, please refer to the changelogs in our different repositories: