Lara is a tool for writing your "Berichtsheft" digitally. In Germany all trainees have to write these kind of weekly reports. This tool gives you the ability to write and share reports with your trainer, get them approved, commented and signed with a digital signature. Lara also allows you to export all your archived reports in one PDF file ready to be handed over to your "Handelskammer". Furthermore Lara sends E-Mail notifications to inform trainees and trainers about outstanding actions and the status change of reports.
To run the project, ensure the following are installed:
- Node.js (version 18)
- Yarn
- Install Yarn globally using
npm install --global yarn
- Java
- Install Java using Homebrew
brew install --cask temurin
We're using the following dependencies for lara:
yarn
as dependency managerreact
as view librarystyled-components
for stylingjest
&playwright
for testingapollo-react
for fetching GraphQL apiswebpack
as module bundler for buildswebpack-dev-server
for a development server with HMRserverless
for deployment to AWSdynamoDB
as a database
In order to use the frontend, you need an instance of the backend running on port :3000
.
From the root of the project call:
yarn
yarn db:install
yarn compile:watch
yarn start
compile:watch
starts a file watcher and start
starts a dev server which serves the frontend on port :8080
We're linting our files with ESLint in order to achieving a consistent codestyle and preventing simple errors. JavaScript files are linted by ESLint with @typescript-eslint/recommended
config.
# Lint source files
yarn lint:verify
# Fixes minor issues e.g indentation
yarn lint
To write a new test with jest
, add a file to the packages/frontend/src/test
directory with a name like my-new-test.test.ts
. Jest will only recognize tests, which are defined in a file with the filename ending on .test.ts
or .test.tsx
.
To write a new test with playwright
, add a file to the packages/e2e/tests
directory with a name like my-new-test.spec.ts
. Playwright will only recognize tests, wich are defined in a file with the filename ending on .spec.ts
.
There are two packages for developing components in the frontend. packages/frontend
contains the logical structure of components and pages without styling. packages/components
contains all stylings for the components.
We use grapql-codegen
to generate exact typings from the queries and mutations we write. To add a new query/mutation, do the following:
- Create a
.gql
file in themutations
orqueries
folder inside the directorypackages/frontend/src/graphql
. - Give your query/mutation a name. This step is really important as
graphql-codegen
will use this name to create a higher order component for you. Your query should look something like this:query ArchivePageData { ... }
. - Run
yarn generate:types
. - Import your shiny new graphql higher order component from the graphql directory.
There are two directories for developing requests in the backend. packages/api
contains all typings for GraphQL queries and mutations. Extend the GraphQL schema in packages/api/schema.gql
. In order to keep the local types synchronized, we generate types automatically with graphql-codegen
. Run yarn generate:types
to generate the new corresponding typedefinitions. In packages/api/src
add your typescript types to be used in the backend.
In packages/backend/src/resolvers
the resolvers for the GraphQL queries and mutations are written. In addition the database operations themselfs are defined in packages/backend/src/repositories
.
E-Mails are developed inside packages/email
. Run yarn debug
inside this directory to inspect the templates of the mails.
PDF printing is developed inside packages/print
. Run yarn debug
inside this directory to inspect the template of the generated report PDF.
- MICROSOFT_TENANT_ID
- String containing ?
- PROD_MICROSOFT_CLIENT_ID
- String containing ?
- AWS_ACCESS_KEY_ID
- String containing AWS IAM User ID used for deployment
- AWS_SECRET_ACCESS_KEY
- String containing AWS IAM User Secret Key used for deployment
- URL_ORIGIN
- String containing the origin of the environments. Used in emails. E.g.: lara.exampleCompany
- COMPANY_ABBREVIATION
- Shortform of your companies name to create s3-buckets
- OLD_COMPANY_NAME
- NEW_COMPANY_NAME
- Add these two, if you have mails mapped from an old name to a new name. If not provided, no changes will be applied to usage of email addresses.
- AVATAR_URL
- String containing the URL to avatars. In the end a mailhash from the user is added. If not provided random avatars from dicebear are used.
- SES_EMAIL
- String containing the email address of the bot sending notifications e.g.: [email protected]
- SES_REGION
- String of aws region (probably eu-west-1)
- SUPPORT_MAIL
- String containing the email address users can contact in case of problems e.g.: [email protected]
- FRONTEND_URL
- String containing the URL to the production frontend e.g.: https://lara.exampleCompany.com/ or Cloudfront URL
- BACKEND_URL
- String containing the URL to the production backend e.g.: https://api.lara.exampleCompany.com/ or Cloudfront URL
- LARA_SECRET
- Secret used in creating oauth secrets
- STAGE
- for deployment set this to something like: "production"
The following variables can be added to your cloned version of Lara.
- MICROSOFT_TENANT_ID
- String containing tenant id
- PROD_MICROSOFT_CLIENT_ID
- String containing client id
- STAGING_MICROSOFT_CLIENT_ID
- String containing staging client id used in CI/CD Pipelines.
- AWS_ACCESS_KEY_ID
- String containing AWS IAM User ID used for deployment
- AWS_SECRET_ACCESS_KEY
- String containing AWS IAM User Secret Key used for deployment
- AUTH_HEADER
- String containing the value for the authorization header
- URL_ORIGIN
- String containing the origin of the environments. Used in emails. E.g.: lara.exampleCompany
- DEBUG
- More information is shown in the console. Not necessary for production.
- COMPANY_ABBREVIATION
- Shortform of your companies name to create s3-buckets
- OLD_COMPANY_NAME
- NEW_COMPANY_NAME
- Add these two, if you have mails mapped from an old name to a new name. If not provided, no changes will be applied to usage of email addresses.
- AVATAR_URL
- String containing the URL to avatars. In the end a mailhash from the user is added. If not provided random avatars from dicebear are used.
- SES_EMAIL
- String containing the email address of the bot sending notifications e.g.: [email protected]
- SES_REGION
- String of aws region (probably eu-west-1)
- SUPPORT_MAIL
- String containing the email address users can contact in case of problems e.g.: [email protected]
- FRONTEND_URL
- String containing frontend development url
- BACKEND_URL
- String containing backend development url
- ENABLE_FRONTEND_TUNNEL
- Boolean. Tunnel localhost to a publicly available url using ngrok.
- ENABLE_BACKEND_TUNNEL
- Boolean. Tunnel localhost to a publicly available url using ngrok.
- ALEXA_SKILL_ID
- String. Not required
- ALEXA_SKILL_STAGE
- String. Not required.
- ALEXA_AMAZON_CLIENT_ID
- String. Not required
- ALEXA_AMAZON_CLIENT_SECRET
- String. Not required
- LARA_SECRET
- Secret used in creating oauth secrets
- STAGE
- String containing stage (probably: dev/production/staging)
- STAGING_BE_URL
- String containing the URL to the staging backend e.g.: https://staging.api.lara.exampleCompany.com/. Mainly used in CI/CD Pipelines
- STAGING_FE_URL
- String containing the URL to the staging frontend e.g.: https://staging.lara.exampleCompany.com/. Mainly used in CI/CD Pipelines
- PRODUCTION_BE_URL
- String containing the URL to the production backend e.g.: https://api.lara.exampleCompany.com/. Mainly used in CI/CD Pipelines
- PRODUCTION_FE_URL
- String containing the URL to the production frontend e.g.: https://lara.exampleCompany.com/. Mainly used in CI/CD Pipelines
- TEST_TRAINEE_ID
- ID of test trainee on the stating environment for e2e tests. If not provided e2e tests are skipped.
- TEST_TRAINER_ID
- ID of test trainer on the staging environment for e2e tests. If not provided e2e tests are skipped.
- AWS_ACCESS_KEY_ID=S3RVER
- AWS_SECRET_ACCESS_KEY=S3RVER
- Create a IAM deployment user and give him admin rights and save the credentials!
- Fill out the .env file. Everything but FRONTEND_URL and BACKEND_URL (Take a look at "Deployment Environment Variables" for a more detailed description)
- Run
yarn install
- Run
yarn compile
- Run
yarn build
- Run
serverless deploy
command - Copy Cloudfront distribution urls or custom domains and paste them into .env at FRONTEND_URL and BACKEND_URL and append a
/dev
behind the BACKEND_URL value - Run
serverless deploy
again.
- In AWS DynamoDB:
- add a admin user to your user table with:
{
"id": "12345exampleID",
"companyId": "exampleCompanyID",
"createdAt": "2021-11-23T11:52:01.481Z",
"email": "[email protected]",
"firstName": "Lara",
"lastName": "Admin",
"notification": true,
"type": "Admin"
}
- add your company or subcompanies in the company table with:
{
"id": "exampleCompanyID",
"name": "ExampleCompany"
}
Branchname should shortly describe the changes in your branch.
We are using commitlint for consistent commit messages. Example: fix/feat/refactor: -content of commit-
You can run the buildprocess by executing yarn build
. The following environments are currently available:
- development: For local development purpose
- staging: For http://staging.lara.exampleCompany.com
- production: For http://lara.exampleCompany.com
You can add new environments by extending the serverless.yml
and also adjusting the deployment in the .github/workflows
GitHub Actions.
The changelog is located in the changelog.md
. Please add an entry for every change to the next undeployed version. The change should contain the ticket number if there is any.
# Changelog
...
## 1.0.1 (Semantic version)
- Deployed to production: TODO (Date of deployment / TODO if not deployed)
- Changes:
- Introduction of changelog ...
MIT Β© Accenture Song