Low Level Design

Overview

Urban Local Bodies (ULB) and other government agencies provide citizen centric services. Some of these services involve/require movement of people or assets(eg : vehicle, equipment etc). Below is a sample list of such services:

  • Pickup of Fecal sludge from a citizen’s premises and offloading at a designated place

  • Garbage pickup truck visits multiple collection points and deposits the load at a designated waste segregation yard

  • ULB assigns a drinking water tanker to supply water to schools in a particular area. The water tanker visits the assigned schools and supplies the required amount of water.

  • Fumigation to contain mosquitoes spread involves an operator moving in a 2-wheeler from one street to another.

  • Medicines have to be moved from district headquarters to mandal level villages.

Key challenges in the above scenarios are :

  1. Ensuring the vehicle / person took the designated route

  2. Checking if all pickup/dropoff locations are visited

  3. Monitoring if a restricted location is visited

  4. Tracking of live location

Challenges listed above are solved with a new tracking service component. This document captures the technical design of such a tracking service. For functional use cases related to a specific citizen service (Fecal Sludge Management), please refer to this doc.

Design guidelines

Tech design for Tracking service addresses following key design goals. These goals are derived from DIGIT’s view of how a service should evolve and also the constraints arising from the usage of client side application.

  1. Client side devices may have network bandwidth constraints, hence the communication between client and Tracking service should be optimized on data.

  2. Tracking service should be generic enough to handle any kind of citizen services that involve movement of assets or service delivery by an operator on move. Type of service being rendered decides the monitoring rules (alerts, notifications) that are applied to the trip.

  3. Within the DIGIT platform, event based models processing should be used so that newer applications can be plugged in by consuming the event messages.

Tech design

Components

Below is the list of entities, actors and tech components involved in tracking service.

Entities

  • Point of Interest (POI) - Latitude, longitude coordinates of various locations. Types of locations include citizen pickup point, intermediate points, destination location, polygons to identify larger areas and tags to identify anomalies (like illegal dump yards).

  • Designated route - A sequence of POIs which indicate the route an operator should take.

  • Trip - Created for each service delivery involving an operator. It is either created based on request or through an automatic scheduler. Trip is made up of operator details and designated routes. Actual route taken by the operator is also associated with the trip.

Actors

  • Supervisor - Individual is responsible for making configuration level changes. These can be two separate roles or just one

  • Operator - Travels from source to destination of a trip as part of service delivery.

  • System - Tracking service has the intelligence to take some actions on its own.

Tech components

  • Mobile App - User facing application to manage routes, trips and POIs

  • Tracking service - Stores entities, applies automated rules and generates alerts.

Low level design

Tracking service

Controller classes

  • ConfigController, PoiController, RouteController, TripController

Service classes

  • ConfigService, POIService, RouteService, TripAlertService, TripService

Data access

  • ConfigDao, PoiDao, RouteDao, TripAlertDao, TripDao, TripProgressDao

Service access

  • POISao, TripSao

Model

  • FsmApplication, FsmVehicleTrip, TripAlert

Trip monitoring module

Monitoring logic

Trip data store

Database schema

PlanUML link with source

Rule management schema

PlantUML link with source

3.4.6 Use case to API mapping (with FSM integration)

Vehicle tracking system (VTS) and FMS are the two systems that provide these APIs

Driver use cases (mobile app)

PlantUML link

Appendix

Appendix A - REST APIs for client applications

Note -

(i) Additional attributes will be added to cater to integration with other entities within the DIGIT ecosystem. For example, Tenant Id, User Id, ULB id/name, auth token etc

(ii) All API requests will include timestamps and other information necessary for auditing.

a.1. /poi/_create (Implemented)

Request message

Response message

a.2. /poi/_update (Implemented)

Request

Response

a.3. /poi/_search

** Additional search filters will be added to restrict the results to ULB, user role and other related restrictions.

Request

Response

An array of below objects will be returned for the POIs matching with search criteria.

b.1. /designated_route/_create

Request

Response message

b.2. /designated_route/_update

Request

Response

b.3. /designated_route/_search

** Additional search filters will be added to restrict the results to ULB, user role and other related restrictions.

Request

Response

An array of below objects will be returned for the designated routes matching with search criteria.

c.1. /trip/_create (Implemented)

Request

Response

c.2. /trip/_update

Request

Response

c.3. /trip/_progress

Request

Response

c.4. /trip/_search

** Additional search filters will be added to restrict the results to ULB, user role and other related restrictions.

Request

Response

Array of trips is returned

c.5. /trip/_search/{tripId} (Implemented)

Request

Appendix B - Event data examples

Event type = LocationUpdate

Event data

{

“latitude” :

“longitude” :

“update_time” :

“trip_id” :

}

Event type = TripAnomaly

Event data

{

“anomaly_poi_id” :

“duration_at_poi” :

“update_time” :

“trip_id” :

}

Event type = TripComplete

Event data

{

“update_time” :

“completion_time” :

“trip_id” :

}

Appendix C - API to Database mapping

Mobile app

FSM portal

Last updated

All content on this page by eGov Foundation is licensed under a Creative Commons Attribution 4.0 International License.