Directus is the content management system used for the website, as well as a few other services. It is ran in a separate Docker container.
The services requiring it use git submodules, this directly importing the directus-config repository into their own.
Important
If you are running directus as part of another service, the shell script will be located in the directus submodule, or as aliases in the npm run ---
. The command to boot the instance will also be different, see this document.
First, use docker compose up
to boot up a local instance. Then, you can import the data schema using sh load.sh
and populate it using sample data with sh populate.sh
. You only need to do this once, or if you have deleted Directus' data volume.
You can access the admin panel at http://localhost/directus (username: clic@epfl.ch
, password: 1234
). There, you can update the data, or modify the schema (see below).
If you wish to change the schema, you can do it on your local instance admin panel, then export it using sh save.sh
. It will create a snapshot.yaml
file in the directus/
folder. You should then upload this file to the infrastructure repo through a PR. You will also need to commit app/src/types/schema.d.ts
and you may add aliases for useful types in app/src/types/aliases.ts
.
You may also want to update the sample data: the files are automatically saved in directus/uploads/
, and you can generate a dump of Directus' database using sh save-data.sh
, which will write into directus/new-dump.sql
. Then, copy the relevant insertions in the directus/dump.sql
(take care of the order, to avoid constraint error during populate).
If you wish to integrate Directus into a new project, you need to:
-
Add the submodule:
git submodule add https://github.com/clicepfl/directus-config.git directus
-
Add the following scripts to the
package.json
:{ "scripts": { "prepare": "git submodule update --init", "load-directus": "sh directus/load.sh", "save-directus": "sh directus/save.sh", "save-directus-data": "sh directus/save-data.sh", "populate-directus": "sh directus/populate.sh" } }
-
Include the local instance in the developpment Docker Compose file:
include: - path: directus/docker-compose.yaml
-
Create a symbolic link for the types declarations (from your
src/
folder):ln -sr <relative-path-of-directus-submodule>/types types