FSM Calculator
Details for setting up FSM calculator sevice
Overview
FSM calculator is a system that enables the FSM admin to create billing slabs for the FSM application(s) with different combinations of property type, slum, tank and capacity.
It generates the demand after calculating the charges for the given application using the billing slab already configured. This document contains the details on how to set up the FSM calculator service, describes the functionalities it provides, and details the enhancements made to the FSM calculator service.
Pre-requisites
Before you proceed with the configuration, make sure the following pre-requisites are met:
Java 8
Kafka server is up and running
egov-persister service is running and has fsm-calculator-persister config path added in it
PSQL server is running and database is created to store FSM Application data
The following services should be up and running-
- egov-perister
- egov-mdms
- fsm
- billing-service
Key Functionalities
FSM Admin an Employee of ULB with FSM Admin role can create, update billing slab(s)
ULB Employee with FSM_CREATOR and FSM_EDITOR can search billing slab(s)
ULB Employee Citizen can file, track and rate the application for cleaning septic tank
ULB Employee can get the estimate for FSM Application
FSM service internally call fsm-calculator to generate a demand
Vehicle type check has been removed from calculator service and bill amount is calculated based on the number of trips entered while submitting the FSM application.
Bill amount is calculated based on the number of trips entered while updating the number of trips on the FSM application.
Added validation for advance payment with the configuration.
Added validation for max total advance payment.
Added cancellation charges for canceling the application .
Validation before completing the request with the payment.
Minimum part payment is configural, that is, it should be fixed or it should be percentage calculation. The calculation should be done based on the MDMS configuration value.
Minimum cancellation fee is configural, that is, it should be fixed or percentage calculation. The calculation should be done based on the MDMS configuration value.
Deployment Details
Deploy the latest version of FSM.
Add fsm-calculator-persister.yml file in the config folder in GIT, and add that path in persister (the file path is to be added in environment yaml file in param called persist-yml-path):
https://github.com/egovernments/configs/blob/DEV/egov-persister/fsm-calculator-persister.yaml
Configuration Details
MDMS Configuration
FSM MDMS Configuration is sufficient.
Business Service / Workflow Configuration
NA
Actions & Role Action Mapping
Actions
Role Action Mapping
Infra Ops Configuration
Configurations that we can manage through values.yml fsm-calculator in infraops repo are as follows. values.yml for fms-calculator can be found here.
Description | name in values.yml | Current Value |
contextPath of the api’s | SERVER_CONTEXTPATH | /fsm-calculator |
Kafka Consumer Group | SPRING_KAFKA_CONSUMER_GROUP_ID | fsm-calculator |
kafka topic to which service push data to save new billing slab | PERSISTER_SAVE_BILLING_SLAB_TOPIC | save-fsm-billing-slab |
kafka topic to which service push data to update the existing billing slab | PERSISTER_UPDATE_BILLING_SLAB_TOPIC | update-fsm-billing-slab |
mdms service host | EGOV_MDMS_HOST | egov-mdms-service from egov-service-host |
billing-service host | EGOV_BILLINGSERVICE_HOST | billing-service from egov-service-host |
fsm service host | EGOV_FSM_HOST | fsm from egov-service-host |
Configurations sample in Values.yml
Data Setup
Billing Slab Setup
Create billing slab with combination of PropertyType refer values form PropertyType Mdms, Slum (YES/NO), capacityFrom and capacityTo refers to Vehicle Tank Capacity.
Sample Curl
Integration
Integration Scope
The FSM-calculator will be integrated with the FSM application. The FSM application internally will invoke the fsm-calculator service to calculate and generate demand for the charges.
Integration Benefits
The calculation and demand generation logic will be separated from the FSM service. For each implementation, the calculation implementation can be changed, if required, without modifying the FSM service.
Steps to Integration
FSM application to call fsm-calulator/v1/_calculate to calculate and generate the demand for the fsm application.
ULB employee can call fsm-calculator/v1/_estimate to get the estimates for the fsm application.
ULB Employee can create billing slab calling fsm-calculator/v1/billingSlab/_create
ULB employee can update billing slab calling fsm-calculator/v1/billingSlab/_update
ULB Employee can search billing slab calling fsm-calculator/v1/billingSlab/_search
FSM application to call fsm-calculator/v1/_cancellationFee to calculate cancellation charge based on the configuration data, that is, either it will be fixed or it will be a percentage.
FSM application to call fsm-calculator/v1/_advanceBalanceCalculate to calculate advance charge based on the configuration data, that is, either it will be fixed or a percentage.
Interaction Diagram
TBD
Reference Docs
Doc Links
Workflow Technical Document | |
User Technical Document | |
MDMS Technical Document | NEEDS TO BE UPDATED |
IDGen Technical Document | NEEDS TO BE UPDATED |
Localization Technical Document | NEEDS TO BE UPDATED |
Persister Technical Document | NEEDS TO BE UPDATED |
SMS Notification Technical Document | NEEDS TO BE UPDATED |
API Contract | |
Postman Scripts |
API List
Title | Link |
fsm-calulator/v1/_calculate | |
fsm-calculator/v1/_estimate | |
fsm-calculator/v1/billingSlab/_create | |
fsm-calculator/v1/billingSlab/_update | |
fsm-calculator/v1/billingSlab/_search | |
fsm-calculator/v1/_cancellationfee | |
fsm-calculator/v1/_advancebalancecalculate |
Last updated