Appearance
Custom Migrations
Directus allows adding custom migration files that run whenever the
directus database migrate:*
commands are executed. All migrations must reside in theextensions/migrations
folder.
File Name
The file name follows the following structure:
[identifier]-[name].js
for example:
20201202A-my-custom-migration.js
Structure
Migrations have to export an up
and a down
function. These functions get a Knex instance that can be used to do virtually whatever.
js
module.exports = {
async up(knex) {
await knex.schema.createTable('test', (table) => {
table.increments();
table.string('rijk');
});
},
async down(knex) {
await knex.schema.dropTable('test');
},
};
Danger
Seeing that these migrations are a bit of a free-for-all, you can really harm your database. Please make sure you know what you're doing and backup your database before adding these migrations.
Migrations and Directus schema
Migrations can be used for managing contents of Directus collections (e.g. initial hydration). In order to do it, you must ensure that schema is up to date before running migrations. One way of achieving it is opting out of default directus bootstrap
process and running:
bash
npx directus database install
# notice that schema is applied before running migrations
npx directus schema apply ./path/to/snapshot.yaml
npx directus database migrate:latest
You may want to add additional steps to reflect other responsibilities of directus bootstrap
.