earthquake-hub-commons

What is the earthquake-hub-commons intended for

This repository integrates all the essential programs necessary for hosting a citizen science network of ground motion sensors[1] It enables data transmission, archiving, and allows feeding the network data to earthquake detection software[2]. A version of this repository is deployed live on earthquake.science.upd.edu.ph.

Server Deployment via Docker Compose

There are two different docker-compose files written for two scenarios, (1) for deploying in a server and (2) for development/testing in your local machine.

  1. Clone the repository: Begin by cloning this repository to your local machine using the git clone command.

  2. Install Docker: Make sure you have Docker installed on your system. Docker Compose is essential for managing multi-container Docker applications.

  3. Configure env variables: Create a file named .env in the root of the repository, and add the necessary configuration variables. You can find an example of these variables in the .env.example file.

  4. Set up nginx certificates: For this, there will be another series of steps to be done. These steps will only be done during development/testing to replicate the deployment server enviroment into your local machine; to ensure that you have valid SSL certificates for Nginx.

    • Create a locally trusted self-signed SSL certificate (you may use mkcert to do this). And store the pem files in https_data/certbot/conf/live/<server-name>/

    • Configure the nginx configuration file

      If you name your pem files as localhost.pem and localhost-key.pem, and then store them in the folder https_data/certbot/conf/live/localhost/, then you shouldn’t have to alter the nginx configuration file.

      • server_name must match the one set for the certificates

      • ssl_certificate and ssl_certificate_key should both correspond to the location and filenames of the previously generated pem files.

  5. Create MongoDB volume: Run the following command to create a docker volume for mongodb data:

    docker volume create earthquake-hub-mongodb-data
    
  6. Run the containers: Once the setup is configured, run the following Docker Compose command to start all the necessary containers:

    docker compose --env-file .dep-test.env up --build
    

Note

  • If ever you encounter an error saying you are unauthorized to pull image, follow this guide on how to authenticate with personal access token from ghcr.io

  • To get the certificates using certbot, First up the nginx-proxy container but with the https server in the nginx.conf file commented out. Second, fill this in via certbot: docker compose run --rm  certbot certonly --webroot --webroot-path /var/www/certbot/ -d <your-webapp-url>.org.

  • Lastly, add the 443 (or https) config for the nginx and restart that container.

  • Within a few months, the certificate will expire. To renew using certbot, use docker compose run --rm certbot renew

The docker compose command will start the following containers:

  • Nginx Proxy: This acts as a reverse proxy server which handles incoming HTTP/HTTPS traffic and distributes it to the corresponding services within the Docker network.

  • Earthquake-hub-frontend: This hosts the front-end application for the earthquake-hub network which serves the user interface and interacts with the backend services to display data and handle user requests.

  • Earthquake-hub-backend: This hosts the back-end application for the earthquake-hub network. It handles various functionalities, such as user authentication, data processing, and database interactions, to support the front-end application and process incoming data from the sensors.

  • MongoDB: This is a NoSQL database used to store and manage data, such as account information, device information, and recorded seismic events, within the earthquake-hub network.

  • Ringserver: This is a TCP-based ring buffer designed for packetized streaming data which utilizes time-series data from various station, archive seismic data, and serve those data (or diagnostics of such data) towards the clients.

  • Certbot: This is a tool used to automatically obtain and manage SSL/TLS certificates from the Let’s Encrypt Certificate Authority that provides valid SSL certificate for the server’s domain which ensures secure communication between the server and its clients. You may refer to this post on how to request SSL certificate using docker compose.

Note

Certbot needs to be renewed every three (3) months to keep the certificates valid and up-to-date. Certificate renewal process can easily be done using the following command: docker compose run --rm certbot renew

  • Geoserve: This is a service that provides geographic information for the earthquake-hub network. It is used to convert latitude and longitude values into names of places, such as their city name, region, and country name.

Note

  • Certbot and Geoserve are not used in local development/testing. The two will only be run using the docker compose which is intended for deploying in a server.

  • Certbot needs to renew the SSL certificates every three (3) months.

  1. Configure ringserver: Make sure that ringserver-configs/auth/secret.key exists (contains brgy token to AuthServer). Then set the AuthServer value in ringserver-configs/ring.conf to the AuthServer API address (i.e. http://172.21.0.3:5000 or https://earthquake.science.upd.edu.ph/api).

    • You may use curl to request an accessToken using:

      curl -X POST -H "Content-Type: application/json" -d '{"username": "<USERNAME>","password": "<PASSWORD>","role": "brgy"}' https://<EARTHQUAKE-HUB-BACKEND-URL>/accounts/authenticate
      
    • or you may use Postman to send a POST request to /accounts/authenticate endpoint of the earthquake-hub-backend url with the the following body:

      {
       "username": <USERNAME>,
       "password": <PASSWORD>,
       "role": "brgy"
      }
      

      Please change the <USERNAME> and <PASSWORD> parameters with your credentials.

Interfacing with a processor

SeisComP

The earthquake-hub-commons repository allows easy interfacing with earthquake processing softwares such as SeisComP (Seismic Communication Processor) which is a widely used earthquake detection and seismic data processing software. SeisComP is a collection of software modules used to for seismic data transmission, processing, analysis, monitoring, and archiving. These functions can be done in both real-time and offline. For further information about SeisComP check this overview on how to get started with SeisComP.

Backend Endpoints and Python Scripts

This repository exposes two Server-Sent-Event endpoints (/messaging/restricted/new-pick and /messaging/restricted/new-event) and run two Python scripts to interact with the processor. The two python scripts are run as systemd services which publish pick events and recorded seismic events from SeisComP to the aforementioned endpoints.

MongoDB and Data Population

We have included scripts to help initialize mongodb’s events collection with SeisComP event data in the scenario that you have an existing record of SeisComP detections that you want to migrate into your instance of EarthquakeHub.