This is a collaborative project with KF. Innbyggerkontakt makes it possible for the users (municipalities++) to send e-mails and SMSes to all or groups of their citizens that they themselves can specify. It utilizes Folkeregisteret, Kontakt- og Reservasjonsregisteret and Matrikkelen to filter out the specific groups and get the e-mail addresses and phone numbers.
Innbyggerkontakt consists of a frontend and several backend components running on Firebase and Google Cloud Platform (GCP). The frontend is a webapp written in React and hosted on Firebase. Firebase is also used for storage (using Firestore), authentication, access control, and event-oriented, asynchronous interactions with Firebase Functions. Innbyggerkontakt is also integrated with Firebase's Content Delivery Network in order to post pictures and other resources online. The backend components run on GCP through a combination of Cloud Bucket Storage, App Engine, and Cloud Functions. It also has an SQL instance.
A link to install the SDK can be found here.
To authenticate to Google Cloud Platform, write the following into a terminal:
gcloud auth login
How to set up development on the webapp is explained in detail in the README located inside the webapp folder.
This section will include a general description of necessary tools and recommendations.
Depending on what module you are working on in this project, different Python versions are required. The project as a whole is in a process of transitioning from Python 3.7 to Python 3.10 (as of 30. November 2022). Thus, all further development should be implemented in Python 3.10 or higher.
However, in order to execute older modules, Python 3.7 might be required. It is recommended to create a virtual environment for each module required to develop and execute a module in a separate environment.
- FastAPI
- We use FastAPI to develop APIs, but not used much since we tend to use
Cloud Functions
that are triggered onPub/Sub
.
- We use FastAPI to develop APIs, but not used much since we tend to use
- Pydantic
- We use Pydantic to create models. Pydantic makes it easy to evaluate, export and import objects.
- Poetry
- Used to manage, build and publish Python packages.
If you create a virtual environment in the same place as the source code it is important that you call this .venv
to not trigger linters etc. This depends on what virtual environment system you choose to use.
Poetry is a tool for Python packaging and dependency management. It is used in the latest development to keep track of dependencies and may help to prevent dependency issues. For further development, it is recommended to implement such a tool for consistency and improved safety.
- Install the pre-commit package with:
pip install pre-commit
- Install the git hooks with
pre-commit install
- Install flake8 and it's addons
pip install -r lint-requirements.txt
- Black should be set as the default auto-formatter with skip-string-normalization = 1
pip install black
Google Cloud Artifact registry is used to store artifacts in the project.
Innbyggerkontakt repo is a multi-repo, in order to have multiple virtual environments and other containerizations, we have set up a Multi-root Workspaces schema. This is our recommended setup for VSCode
"settings": {
"python.formatting.provider": "black",
"python.linting.enabled": true,
"python.linting.flake8Enabled": true,
"python.linting.flake8Args": ["--baseline", ""],
}
If you want all linting problems, or:
"python.linting.flake8Args": ["--baseline", "/home/full/path/to/Innbyggerkontakt/baseline.txt"],
If you only want new linting problems.
- Install docker-engine
- Install docker-compose