Giter Club home page Giter Club logo

airqo-api's Introduction

AirQo-api

BCH compliance Build Status codecovCodacy Badge

What is AirQo?

The AirQo project aims to measure and quantify the scale of air pollution in and around Kampala City through the design, development and deployment of a network of low-cost air quality sensing devices mounted on either static or mobile objects.

System Architecture

AirQo platform is composed of many microservices written in different languages that talk to each other using Istio.

Architecture of microservices

The AirQo system architecture uses a mono repo for faster shipping. Each service has its own database. Consistency across these databases is maintained using an event driven approach. There is also an API gateway (Nginx) which clients use to access ther rest of the services. The state of the miscroservices is monitored using PM2. Deployment pattern is one service per container using Docker.

Service Language Description
analytics Flask/Python & MongoDB This is the one to be used for all analytics work
app-enable Node.js To enable any application that consumes the services of this platform.
auth-service Node.js Authentication services for this endpoint
data-mgt Node.js & MongoDB A fully-managed service for transforming/processing and enriching data in stream (real time) and batch (historical) modes with equal reliability and expressiveness
device-registry . Node.js Carry out the management of the devices.
incetives Node.js The payment service to incetivise various stakeholders
predict Flask/Python & MongoDB microservice to handle predictions or forecasts of air quality
service-monitoring Node.js Monitoring the health of all the microservices
noitifications Node.js Takes care of all the notification needs of the application.
device-monitoring Flask/Python & MongoDB Monitoring the status of all devices on the network.
locate Flask/Python & MongoDB microservice that consumes the model which recommend locations for placing devices
calibrate Flask/Python & MongoDB microservice that consumes the model which recommend locations for placing devices
location-registry Flask/Python & MongoDB microservice that handles the registration of locations in the network

Features

  • Multi-protocol connectivity (HTTP and MQTT)
  • Device management
  • Access control
  • Incetives
  • Message persistence (MongoDB and PostgresSQL)
  • Container-based deployment using Docker and Kubernetes
  • Microservices architecture, high-quality code and test coverage

Installation and Usage

  1. Running locally with “Docker for Desktop” You will build and deploy microservices images to a single-node Kubernetes cluster running on your development machine.

  2. Running on Google Compute Engine (GCE)” You will build, upload and deploy the container images to a Kubernetes cluster on Google Cloud Engine.

Deployment

To deploy on the AirQo platform cd AirQo-api/src/microservice-name

Build the image docker build -t us.gcr.io/gcp-project-name/microservice-name .

Run the container based on newly created image docker run -d -n best -p host-port:container-port us.gcr.io/gcp-project-name/microservice-name

The flags for running the container

  • p (publish) Asks Docker to forward traffic incoming on the host’s port host-port to the container’s port container-port. Containers have their own private set of ports, so if you want to reach one from the network, you have to forward traffic to it in this way. Otherwise, firewall rules will prevent all network traffic from reaching your container, as a default security posture.
  • d (detach) asks Docker to run this container in the background.
  • n (name) name you can use to specify the newly created container in subsequent commands. Above examples has the name as best.

Visit the application in REST client or Web browser localhost:host-port. You should the application up and running. Now would be the time to run unit tests, for example:

delete container after successful unit tests docker rm --force best.

Share images on DockerHub or Google Container Registry docker push //

  • Example: docker push us.gcr.io/airqo-api/airqo-device-registry-api

Contributing

We invite you to help us build this platform. Please look up the contributing guide for details.

Issues

Before reporting a problem, please check out the issue guide.

airqo-api's People

Contributors

baalmart avatar noahnsimbe avatar danielogen avatar priscilla-al avatar 123mwanjemike avatar ja-odur avatar lilly-muyama avatar sserurich avatar fajemila avatar benjaminssempala avatar dependabot[bot] avatar paulooh007 avatar uman95 avatar bobturneruk avatar airqo avatar codebmk avatar

Watchers

 avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.