Legacy compatibility mode for 2.8 services
ArangoDB 3 continues to support Foxx services written for ArangoDB 2.8 by running them in a special legacy compatibility mode that provides access to some of the modules and APIs no longer provided in 3.0 and beyond.
Note: Legacy compatibility mode is strictly intended as a temporary stop gap solution for supporting existing services while upgrading to ArangoDB 3.0 and should not be considered a permanent feature of ArangoDB or Foxx.
In order to mark an existing service as a legacy service, just make sure the following attribute is defined in the service manifest:
"engines": {
"arangodb": "^2.8.0"
}
This semantic version range denotes that the service is known to work with ArangoDB 2.8.0 and supports all newer versions of ArangoDB up to but not including 3.0.0 (nor any development version of 3.0.0 and greater).
Any similar version range the does not include 3.0.0 or greater will have the same effect (e.g. ^2.5.0
will also trigger the legacy compatibility mode, as will 1.2.3
, but >=2.8.0
will not as it indicates compatibility with all versions greater or equal 2.8.0, not just those within the 2.x version range).
Features supported in legacy compatibility mode
Legacy compatibility mode supports the old manifest format, specifically:
main
is ignoredcontrollers
will be mounted as in 2.8exports
will be executed as in 2.8Additionally theisSystem
attribute will be ignored if present but does not result in a warning in legacy compatibility mode.
The Foxx console is available as the console
pseudo-global variable (shadowing the global console object).
The service context is available as the applicationContext
pseudo-global variable in the controllers
, exports
, scripts
and tests
as in 2.8. The following additional properties are available on the service context in legacy compatibility mode:
path()
is an alias for 3.xfileName()
(usingpath.join
to build file paths)fileName()
behaves as in 2.x (usingfs.safeJoin
to build file paths)foxxFileName()
is an alias for 2.xfileName
version
exposes the service manifest’sversion
attributename
exposes the service manifest’sname
attributeoptions
exposes the service’s raw optionsThe following methods are removed on the service context in legacy compatibility mode:use()
— use@arangodb/foxx/controller
insteadapiDocumentation()
— usecontroller.apiDocumentation()
insteadregisterType()
— not supported in legacy compatibility modeThe following modules that have been removed or replaced in 3.0.0 are available in legacy compatibility mode:@arangodb/foxx/authentication
@arangodb/foxx/console
@arangodb/foxx/controller
@arangodb/foxx/model
@arangodb/foxx/query
@arangodb/foxx/repository
@arangodb/foxx/schema
@arangodb/foxx/sessions
@arangodb/foxx/template_middleware
The@arangodb/foxx
module also provides the same exports as in 2.8, namely:Controller
from@arangodb/foxx/controller
createQuery
from@arangodb/foxx/query
Model
from@arangodb/foxx/model
Repository
from@arangodb/foxx/repository
toJSONSchema
from@arangodb/foxx/schema
getExports
andrequireApp
from@arangodb/foxx/manager
queues
from@arangodb/foxx/queues
Any feature not supported in 2.8 will also not work in legacy compatibility mode. When migrating from an older version of ArangoDB it is a good idea to migrate to ArangoDB 2.8 first for an easier upgrade path.
Additionally please note the differences laid out in the chapter Migrating from pre-2.8 in the migration guide.