The 121-Service is the backend where 121-programs can be created and monitored, etc.
See instructions to get started in the main README
.
This service uses a fork of TypeORM with a PostgreSQL database.
You can seed the database by using the api/reset
endpoint from the Swagger UI.
- If you have no users in your database yet, start with running one of the reset/seed-scripts above.
- If you have already created the above user earlier, make a request:
POST /users/login
'. Change the example-value where necessary, and execute. - The 121-service will respond with a (httpOnly-)Cookie containing the users's details and permissions, the cookie will be used automatically on subsequent requests.
- This will give access to each API-endpoint for which a
Permission
is specified and a matchingPermission
is present in the users' token/cookie.
- Access the Swagger UI via: http://localhost:3000/docs/
- A JSON document will be generated at
swagger.json
. You can use it to get a 'diff' view in github of API changes between different version of the platform. - A graph will be generated when run in 'development' mode at
module-dependencies.md
. It can be viewed with https://mermaid.live/ or the VSCode-extension: Markdown Preview Mermaid Support
Make sure to update any dependencies from within the Docker-container, with:
docker compose exec 121-service npm install --save <package-name>
The only exception to this is TypeORM.
To test changes in the TypeORM fork (before releasing them):
- Clone the forked repo https://github.com/global-121/typeorm/
- Change the
"name"
in"typeorm/package.json"
from"@global121/typeorm"
to"typeorm"
- This is a temporary change that you should revert before pushing any code to the remote.
- It is necessary because of how the typeorm fork is installed in the 121-service.
- Make your desired changes to your local clone of the fork
- From the cloned fork folder, run
npm run compile
- From your local 121-service folder, run
npm link FORK_PATH
whereFORK_PATH
is a full path to your cloned version of the fork- eg.
npm link ~/git/typeorm
- eg.
- You might need to restart the 121-service at this point for your changes to take effect.
- Repeat steps 3 to 6 until your changes are ready, then proceed to make a PR to the fork.
To update TypeORM:
- Go to the forked repo and create a new version as described in the README
- Change the version number of typeorm
"typeorm": "npm:@global121/typeorm@<version-number>",
inservices/121-service/package.json
according to the new release.- We cannot use
"@global121/typeorm": "<version-number>",
in thepackage.json
because the typeorm package is also a dependency in other packages. This configuration "tricks" npm into treating our fork as if it were the originaltypeorm
so that, anywhere in our codebase (including in thenode_modules
),import ... from 'typeorm'
will use our fork instead of the originaltypeorm
- We cannot use
- Run
npm i
and commit both the changes to theservices/121-service/package.json
and theservices/121-service/package-lock.json
For FSP-specific instructions, see the README.md in each individual FSP-folder, e.g. for Intersolve
To run the Unit-tests: (replace :all
with :watch
to run during development)
docker exec 121-service npm run test:unit:all
To run the API/Integration tests: (replace :all
with :watch
to run during development)
docker exec 121-service npm run test:integration:all
To run a single test suite, amend the name of the test file, for example:
docker exec 121-service npm run test:integration:all update-program.test.ts
To update snapshots, amend the -- -u
option, for example:
docker exec 121-service npm run test:integration:all -- -u
To enter the 121-service in the terminal use: (Or use the "Exec"-tab inside Docker Desktop)
docker exec -it 121-service /bin/sh
To start a debugger using Chrome, follow these steps:
- Add port mapping to the
docker-compose.development.yml
so that internal port 9229 is mapped to external port 9229. Note that all port settings from the main file are overridden. - In the start:dev script in the package.json of the 121-service, add =0.0.0.0 to the -- inspect flag, so it becomes --inspect=0.0.0.0
- Start the services with npm run start:services.
- In the code of the 121 Service where you want to break, add a line with debugger;
- Check if the application indeed started on a debugger address 0.0.0.0 with
npm run logs:services 121-services
, and see something like: "Debugger listening on ws://0.0.0.0:9229 02384d3e-4d1f-40ef-b8d5-be3da792fe71
" - Open the Swagger Docs in the Chrome Web Browser: http://localhost:3000/docs/
- Open the Inspector in Chrome with CTRL-SHIFT-I or right mouse click and select Inspect. Now there should be a green hexagon on the top left of the Inspector window.
- Click the green hexagon item in the top left of the Inspector window (Open dedicated DevTools for Node.js).
- This opens a new window called DevTools. Leave it open.
- In the logs of the 121 Service it should say: Debugger attached.
- Use Swagger API to call the endpoint that will run into the code where you set the debugger; statement (see point 4 above.)
- The DevTools window now should show your code and Debugger functionality so you can watch variables, step over code, etc.
- In the left margin of the code, you can also right mouse click and for example select: continue to here.
- If you want to set the theme to dark, go to Settings in DevTools and under Preferences you have Theme, there select Dark. For more info: https://stackoverflow.com/questions/20777454/google-chrome-customize-developer-tools-theme-color-schema
To start the debugger from Visual Studio Code, follow these steps:
- Probably some steps from above, starting debugger in Chrome, are also needed here, but not sure which. Maybe items 1, and 2.
- The contents of launch.json in the root folder of the repository enable the possibility to attach the Debugger in Visual Studio Code to the Node.js process running in the 121-service Docker container.
- Start the services with npm run start:services, probably need to do this from a Terminal inside Visual Studio Code.
- Open the Run and Debug section in Visual Studio Code by clicking the play arrow with bug icon in the left vertical bar of icons.
- Press the green play icon left besides the "Docker: Attach to Node" text which is selected by default in the dropdown. This attaches the Debugger.
- Now you can for example set a breakpoint in your code by right mouse clicking to the left of the line number and select Add breakpoint.
Steps to rename a database table:
- Rename table name in the Entity decorator: @Entity('new_table_name')
- Generate migrate script.
- Change generated migration script:
- Use the generated DROP FK CONSTRAINTS queries.
- Manually add a query to change the name of the table.
- Remove the query that creates a new table.
- Use the generated CREATE FK CONSTRAINTS queries.
- Caveats: if there is a related "cross table" that TypeORM automatically generated, then there is a bit of manual editing of the generated query involved.
- See for an example: https://github.com/global-121/121-platform/pull/4985/files#diff-9d32e210b9db0795ae71d28aaad421f3bb58bc8e3b263bbf54be13429239397c
- In principle there is no renaming of table name in queries in the code needed, as they are dynamically filled by TypeORM. However, we do have some hard-coded SQL scripts for creating mock data. Check if it is needed to update these queries: they are in .sql files.
- Test the migration script:
- Incremental, given an existing (filled) database, like on production.
- New instance, like when installing a fresh local dev environment.
- Run unit tests and API tests. Any problems/bugs are likely due to an incomplete/incorrect migration script.
- Generate a "test" migration script.
- In case this actually creates a script with queries, it means the migration script you created earlier is not yet complete.
- Copy/paste (mindfully) the created queries into your migration script, edit them if needed, and re-do from step 11.
- Caveat: TypeORM "randomly" names things like indexes and constraints, and these names need to be changed as well as TypeORM expects these new names, even though technically for PostgreSQL it does not matter. Just copy-paste the generated drop and create queries.
- Rinse and repeat until step 15 does not create a migration script anymore (it will "complain" that there are no changes).
- Do a smoke test on local dev: walk through happy flow main functions via the Portal.
- We chose not to implement the down function of the migration script for table renames.
Compodoc can generate static code diagrams and documentation and serve that as a website locally:
- From the 121-service folder run this command:
npx @compodoc/compodoc -p tsconfig.json -s
- This creates a folder called 'documentation' and starts a website that is typically available under: http://localhost:8080/
- Most useful is the per-module diagram and documentation available under: http://localhost:8080/modules.html
- For more information, see: https://docs.nestjs.com/recipes/documentation
AppMap is a very extensive static and dynamic code analysis tool which can be run as a Visual Studio Extension. It has many features, options, and comes with an AI chat bot to converse with:
- Install the AppMap Extension in Visual Studio Code. Reference: https://marketplace.visualstudio.com/items?itemName=appland.appmap
- Start the 121 Service node process under the
appmap-node
npx script by using:npm run start:services:appmap
on your development environment. - Create recordings by calling an API endpoint, or running test suites, or interacting via the 121 Portal. These recordings are stored in the
tmp/appmap
folder under the 121-service. - Open these recordings from the
APPMAPS
-pane in the AppMap Extension in VS Code. - Note: Docker creates new files as root. At least on Linux you need to run
sudo chown -R <your-username> .
in the 121-service folder so that the AppMap Extension can access the files of the recordings. - AppMap creates Dependency Diagrams, Sequence Diagrams, Flame Graphs and more to get insight of the code's behavior.
- AppMap also as an AI bot called Navie AI to ask questions to.
- For more information: https://appmap.io/docs/appmap-overview.html or access the Slack channel: https://appmap.io/community
Released under the Apache 2.0 License. See LICENSE.