-
Notifications
You must be signed in to change notification settings - Fork 1
Developer manual
π Setup Development Environment
- π Create a Migration
βΆοΈ Execute Migrationsβ οΈ Recreate DB in Development (Do NOT Do This in PRODUCTION)
π Promote a User to Administrator of the Platform
Docker is an open-source platform designed to develop, ship, and run applications in isolated environments called containers. Containers bundle an application with all its dependencies, ensuring consistency across various environments (development, testing, production, etc.).
Documentation: https://docs.docker.com/
Docker Compose is a tool for defining and managing multi-container Docker applications. It uses a YAML file to configure application services, allowing developers to start all the required containers with a single command.
Documentation: https://docs.docker.com/compose/
React is a popular open-source JavaScript library developed by Facebook for building user interfaces (UI), particularly for single-page applications (SPAs). It allows developers to create reusable UI components, ensuring efficient and dynamic rendering of content.
We choose this to match the technology choice made by Mirador.
Documentation: https://react.dev/
NestJS is a progressive, open-source Node.js framework for building scalable and maintainable server-side applications. It is built with TypeScript and heavily inspired by Angular's architecture, making it modular, extensible, and easy to organize.
Documentation:https://docs.nestjs.com/
MariaDB is an open-source, high-performance relational database management system (RDBMS). It is a fork of MySQL, created to remain free and community-driven. Known for its speed, scalability, and security, MariaDB is widely used for web applications, enterprise software, and embedded systems.
Documentation: https://hub.docker.com/_/mariadb
You'll need node 20 to run MMU. You can use nvm (Node Version Management) to handle node versioning : https://github.com/nvm-sh/nvm
You will have access to hot reload thanks to Docker's volume system set up
At the root of the folder, you will find the Dockerfile and the entrypoint.sh file, which contains the startup instructions for the backend container.
You'll find the migrations folder, where all changes made to the entities and applied to the database will be stored. For more informations on this go to this section : https://github.com/SCENE-CE/mirador-multi-user/wiki/Developer-manual#recreate-db-in-development-do-not-do-this-in-production
You will also find the upload folder where all the medias, manifests and mirador configuration will be stored in file system
The src folder contains all the backend code. I will not cover the NestJS-related implementations here; if you want to learn more about that, please refer to the NestJS documentation.
You will find the "basic" entities in the BaseEntities folder and the "link" entities in the linkEntities folder. To learn more about the implementation of "basic" and "link" entities, please refer to this section: https://github.com/SCENE-CE/mirador-multi-user/wiki/Developer-manual#recreate-db-in-development-do-not-do-this-in-production
The purpose of this section is not to cover the implementations related to Vite or React; please refer to their documentation for more information.
Here, as with the backend, you will find the Dockerfile and the entrypoint.sh file at the root of the project.
You will also find the following folders:
- components : Contains all the reusable components of the project.
- features : Contains the code related to the various features of mirador-multi-users.
- routes : Includes two important files:
- protectedRoutes.tsx : Routes accessible once your user is authenticated.
- publicRoutes.tsx : Routes accessible publicly.
We have implement linkTable with one to many relation with over entities, this allow us to define rights for the entity A on entity B But this introduce circular dependency problem. I manage a structure to handle this.But it allow us to import module A and B into the link module but not the linkModule into module A or B. Module A and Module B take care of there own logic and Link Module handle the logic that concern A AND B modules.
We used to avoid this problem by creating a C module. This module imported module A & B & Link but this have for side effect to increese code base a lot, we decided to change this into this branch : https://github.com/SCENE-CE/mirador-multi-user/tree/backend-clear-useless-routes
Here you can see that we import ProjectModule and UserGroupModule into LinkProjectUserGroupModule
It result into this error :
- run the app with
docker compose up
- connect to backend docker with
docker exec -it <name-of-your-backend-container> /bin/sh
- run
npm run typeorm:generate-migration --name=<name-of-the-migration>
docker compose up
- connect to backend docker with
docker exec -it <name-of-your-backend-container> /bin/sh
cd /app
npm run typeorm migration:run -- -d ./src/config/dataSource.ts
[TODO] CommplΓ©ter
Execute this comands into the backend docker :
npm run typeorm:generate-migration --name=db-init
npm run typeorm migration:run -- -d ./src/config/dataSource.ts
You can't promote a user to admin using the API or the UI so you MUST need to directly connect to the db and run this SQL request :
UPDATE multiUsers.`user`
SET `_isAdmin` = 1
WHERE id = <Replace this by the user you want to promote id>;