Skip to content

Latest commit

 

History

History
148 lines (98 loc) · 9.21 KB

README.md

File metadata and controls

148 lines (98 loc) · 9.21 KB

SwissCovid CrowdNotifier Backend

License: MPL 2.0 Build Quality Gate Status

SwissCovid is the official contact tracing app of Switzerland. The app can be installed from the App Store or the Google Play Store. The SwissCovid 2.0 app uses two types of contact tracing to prevent the spread of COVID-19.

With proximity tracing close contacts are detected using the bluetooth technology. For this the dp3t-sdk-backend, DP3T iOS SDK and DP3T Android SDK are used that build on top of the Google & Apple Exposure Notifications. This feature is called SwissCovid encounters.

With presence tracing people that are at the same venue at the same time are detected. For this the swisscovid-cn-backend, CrowdNotifier iOS SDK and CrowdNotifier Android SDK are used that provide a secure, decentralized, privacy-preserving presence tracing system. This feature is called SwissCovid Check-in.

Further Documentation

The full set of documents for CrowdNotifier is at https://github.com/CrowdNotifier/documents. Please refer to the technical documents and whitepapers for a description of the implementation.

Repositories

Dependencies

Database

For development purposes a hsqldb can be used to run the webservice locally. For production systems, it is recommended to connect to a PostgreSQL dabatase (cluster if possible). There is a table for storing submitted trace keys. The schema is the following:

Environments

To control different behaviors, SpringBoot profiles are used. The idea is to provide an abstract base class, which defines everything needed. Such properties can be defined as abstract, and their implementation can be provided in an extended class.

WSCloud*Config/WSProdConfig/WSDevConfig

Currently four non-abstract configs (dev, test, abn and prod) are provided. Those are the CloudConfigs and they are optimized to work with an environment using KeyCloak and CloudFoundry.

Furthermore, two non-abstract configs (dev, prod) are provided, which implement a basic configuration, and which should work out-of-the-box.

Note that the dev config uses a HSQLDB, which is non-persistent, whereas prod needs a running instance of PostgreSQL, either in a docker (a docker-compose file is provided) or native.

If you plan to provide new extensions or make adjustments and want to provide those to the general public, it is recommended to add a new configuration for your specific case. This can be e.g. an abstract class (e.g. WSCloudBaseConfig), which extends the base class providing certain needed keys or functions. If you provide an abstract class, please make sure to add at least one non-abstract class showing the implementation needed.

Configuration Properties

  • userupload.mpkHex: the master public key used for user upload hex encoded. REQUIRED
  • userupload.mskHex: the master secret key used for user upload hex encoded. REQUIRED
  • traceKey.bucketSizeInMs: trace keys are served in buckets. the bucket size can be configured by this property. For production two hours is a reasonable value REQUIRED
  • userupload.requestTime: uploads times are normalized for privacy purposes. REQUIRED
  • traceKey.traceKeysCacheControlInMs: cache control (max-age) for trace key request. REQUIRED
  • push.ios.signingkey: apns signing key, .p8 base64 encoded. OPTIONAL (if not configured, background push notifications are disabled)
  • push.ios.teamid: apns teamid
  • push.ios.keyid: apns keyid
  • push.ios.topic: apns push topic
  • traceKey.retentionDays: the retention period, e.g. how long are keys stored in the database. DEFAULT: 14 days

API Requests

There are three endpoints, one for uploading VenueInfo objects, one for downloading trace keys and one for registering for push notifications. How long trace keys are stored in the database can be configured via the db.removeAfterDays property in the properties file. Please check the proto folder for the corresponding protobuf schemas.

  • /v3/traceKeys?lastBundleTag=<lastSync>: GET Returns a list of trace keys in a ProblematicEventWrapper protobuf. The optional lastBundleTag is returned in each response as response header x-key-bundle-tag from the backend and should be used by clients for the following request. If set, only keys added since the last download are retrieved.

  • /v3/register: POST Register for push notifications. The request body should consist of a PushRegistration protobuf.

  • /v3/userupload: POST Upload a list of VenueInfo objects as a UserUploadPayload to be transformed into and stored as trace keys. Note that the request should include a valid JWT token, which can be obtained in exchange for a valid authentication code.

Swagger

We use Springboot-Swagger-3 to generate a YAML based on settings and controllers found in the project. We include a up-to-date version in each release. Currently they are lacking the documentation, but should provide enough information to use them in Swagger Editor.

Build

To build you need to install Maven.

cd swisscovid-cn-sdk-backend
mvn install

Run

java -jar swisscovid-cn-sdk-backend-ws/target/swisscovid-cn-sdk-backend-ws.jar

Dockerfiles

The dockerfile includes a base jdk image to run the jar. To actually build the docker container, you need to place the generated jar in the bin folder.

cp swisscovid-cn-sdk-backend/swisscovid-cn-sdk-backend-ws/target/swisscovid-cn-sdk-backend-ws.jar swisscovid-cn-ws/ws/bin/swisscovid-cn-sdk-backend-ws-2.0.0.jar
cd swisscovid-cn-ws && docker build -t <the-tag-we-use> .
docker run -p 80:8080 -v <path_to_logbackxml>:/home/ws/conf/swisscovid-cn-sdk-backend-ws-logback.xml -v <path_to_application_properties>:/home/ws/conf/swisscovid-cn-sdk-backend-ws.properties <the-tag-we-use>

Makefile

You can use the provided makefile to build the backend, build a docker image and generate the documentation.

Without a target, the makefile will generate everything except the docker image.

make

To build the docker image run

make docker-build

This will build the jar and copy it into the swisscovid-cn-ws/ws/bin folder, from where it is then added to the container image. The image will be tagged as swisscovid-cn-docker.

An example logback.xml is found in the resources folder for the swisscovid-cn-sdk-backend-ws Java module.

An example application.properties file is found at the same location. Just make sure the configuration matches with your deployment (c.f. WSBaseConfig for possible properties and WSCloudBaseConfig for some CloudFoundry specific properties)

License

This project is licensed under the terms of the MPL 2 license. See the LICENSE file.