Complaints
Overview
The complaints registry allows employees to lodge complaints regarding health campaigns. An employee can track the complaint, upload an image related to it, and reopen the complaint if they are dissatisfied, as well as rate the service. This document details how to set up the complaints registry (pgr-service) and outlines the functionalities it offers.
Pre-requisites
Before you proceed with the configuration, make sure the following pre-requisites are met:
Java 8.
Kafka server is up and running.
The egov-persister service is running and has the pgr-services persister config path added in it.
The PSQL server is running, and the database is created to store complaint data.
(Optional) Indexer config for pgr-services is added in the egov-indexer yaml paths to index the generated data. The index is required for data visualisation in Kibana or DSS.
(Optional) Report config for pgr-services is added in the Report service config paths. Required if reports are to be provided to the user.
The following services should be up and running:
egov-user
egov-workflow-v2
egov-perister
egov-localization
egov-notification-sms
egov-mdms
egov-idgen
egov-url-shortening
egov-hrms
Key Functionalities
Citizens/employees can file, track and rate the complaint.
Citizens/employees can add images and comments related to the complaint.
Citizens/employees can reopen the complaint within a certain period after resolution.
Campaign supervisors can set up the complaint workflow according to their requirements and staff capacity.
Can track the SLA for resolving each complaint, and can use it as a metric to streamline the process for resolving complaints.
Department-wise assignment of the complaint to the LME.
Setup
Clone or download the code from the GitHub repository
The source code for the Complaints registry is located in the Git repository here. Clone or download the code from this repository before proceeding.
API Details
Refer to the Swagger API for YAML file details: Complaints.yaml
Application.properties file information:
Kafka topics for eGov persister
pgr.kafka.create.topic=save-pgr-request
pgr.kafka.update.topic=update-pgr-request
Configuration Details
Follow the details outlined below to configure and enable complaints registry API actions and access control using MDMS, role-action mapping, persister, and indexer configurations.
MDMS Configurations
Add the master data in the MDMS service with the module name as RAINMAKER-PGR
. Below is a sample master data for the service:
{
"tenantId": "default",
"moduleName": "RAINMAKER-PGR",
"ServiceDefs": [
{
"serviceCode": "SyncNotWorking",
"name": "Sync Not Working",
"keywords": "sync, not, working",
"department": "TECH",
"slaHours": 336,
"menuPath": "Sync",
"active": true,
"order": 1
},
{
"serviceCode": "NotEnoughStock",
"name": "Not Enough Stock",
"keywords": "not, enough, stock",
"department": "WAREHOUSE",
"slaHours": 336,
"menuPath": "Sync",
"active": true,
"order": 1
},
{
"serviceCode": "Other",
"name": "Other",
"keywords": "other",
"department": "ADM",
"slaHours": 336,
"menuPath": "Sync",
"active": true,
"order": 1
}
]
}
Workflow Configurations
Create businessService (workflow configuration) using the /businessservice/_create
. Following is the product configuration for PGR:
{
"RequestInfo": {
"apiId": "Rainmaker",
"action": "",
"did": 1,
"key": "",
"msgId": "20170310130900|en_IN",
"requesterId": "",
"ts": 1513579888683,
"ver": ".01",
"authToken": "{{devAuth}}",
"userInfo": {
"id": 73,
"userName": null,
"name": null,
"type": "EMPLOYEE",
"mobileNumber": null,
"emailId": null,
"roles": [
{
"id": 2,
"name": "Customer Support Representative",
"code": null,
"tenantId": null
}
],
"tenantId": null,
"uuid": "uuid"
}
},
"BusinessServices": [
{
"tenantId": "default",
"businessService": "PGR",
"business": "pgr-services",
"businessServiceSla": 432000000,
"states": [
{
"sla": null,
"state": null,
"applicationStatus": null,
"docUploadRequired": false,
"isStartState": true,
"isTerminateState": false,
"isStateUpdatable": true,
"actions": [
{
"action": "CREATE",
"nextState": "PENDING_ASSIGNMENT",
"roles": [
"REGISTRAR",
"DISTRIBUTOR",
"WAREHOUSE_MANAGER",
"HELPDESK_USER",
"SYSTEM_ADMINISTRATOR"
]
}
]
},
{
"sla": null,
"state": "PENDING_ASSIGNMENT",
"applicationStatus": "PENDING_ASSIGNMENT",
"docUploadRequired": false,
"isStartState": false,
"isTerminateState": false,
"isStateUpdatable": false,
"actions": [
{
"action": "RESOLVE",
"nextState": "RESOLVED",
"roles": [
"HELPDESK_USER",
"L2_SUPPORT",
"SYSTEM_ADMINISTRATOR"
]
},
{
"action": "ASSIGN",
"nextState": "PENDING_ASSIGNMENT",
"roles": [
"HELPDESK_USER",
"L2_SUPPORT",
"SYSTEM_ADMINISTRATOR"
]
},
{
"action": "REJECT",
"nextState": "REJECTED",
"roles": [
"HELPDESK_USER",
"SYSTEM_ADMINISTRATOR"
]
}
]
},
{
"sla": null,
"state": "RESOLVED",
"applicationStatus": "RESOLVED",
"isStateUpdatable": false,
"docUploadRequired": false,
"isStartState": false,
"isTerminateState": true
},
{
"sla": null,
"state": "REJECTED",
"applicationStatus": "REJECTED",
"isStateUpdatable": false,
"docUploadRequired": false,
"isStartState": false,
"isTerminateState": true
}
]
}
]
}
Define Action URLs
Add new actions in the MDMS actions configuration (e.g., action-test.json
). Each action represents an API endpoint you wish to secure and manage: Action-test.json
{
{
"id": {{ID_PLACEHOLDER}},
"name": "Create PGR Request",
"url": "/pgr-services/v2/request/_create",
"parentModule": "",
"displayName": "Create PGR Request",
"orderNumber": 0,
"enabled": false,
"serviceCode": "pgr-services",
"code": "null",
"path": ""
},
{
"id": {{ID_PLACEHOLDER}},
"name": "Update PGR Request",
"url": "/pgr-services/v2/request/_update",
"parentModule": "",
"displayName": "Update PGR Request",
"orderNumber": 0,
"enabled": false,
"serviceCode": "pgr-services",
"code": "null",
"path": ""
},
{
"id": {{ID_PLACEHOLDER}},
"name": "Search PGR Request",
"url": "/pgr-services/v2/request/_search",
"parentModule": "",
"displayName": "Search PGR Request",
"orderNumber": 0,
"enabled": false,
"serviceCode": "pgr-services",
"code": "null",
"path": ""
},
{
"id": {{ID_PLACEHOLDER}},
"name": "Search PGR Request",
"url": "/pgr-services/v2/request/_count",
"parentModule": "",
"displayName": "Count PGR Request",
"orderNumber": 0,
"enabled": false,
"serviceCode": "pgr-services",
"code": "null",
"path": ""
}
Persister Configuration
Configure the persister service for the Complaints registry. This is typically done by adding/updating a YAML file (e.g., pg-service-persister.yml
) - pg-service-persister Yaml. This YAML maps API operations to database persistence logic (topics, queries, etc.).
Indexer Configuration
Configure the indexer for the Complaints registry (e.g., individual-indexer.yml
) -Complaints Indexer Config. This will ensure individual data is indexed and searchable as per business requirements.
Postman Collection
Last updated
Was this helpful?