/
Data & Grammar Processing

Objective

This document provides the details of how the grammar and data processing is carried out using specific commands. This will explain the process of data ingestion into dataset tables which will be further used by the UI to visualise the data.

Purpose: The purpose of this document is to provide the details of how to generate dataset tables and ingest the data into those tables. It also provides information regarding dimension grammar processing and data ingestion into the dimension tables.

Grammar Processing using processing-ms CLI commands

Processing-ms has different commands to process the grammar and ingest the data into the dataset tables. The following commands are responsible for the above specified functionality.

yarn cli ingest: This command will execute the following steps

  • It will read the config.json file of specific state present inside the ingest folder.

  • Then it will process all the dimension grammar present in the dimensions folder.

  • The dimension grammars are stored in the “spec.dimensionGrammar” table and the dimensions tables are created in the dimensions schema.

  • It will also look for data files respective to each dimension grammar file name and ingest all the dimension data to the respective tables.

  • After the dimensions are ingested the programs array present in config.json is read and the event grammars are process from the corresponding <program-name> folder. The event grammars are stored in the spec.”EventGrammars” table.

  • The dataset grammars are also stored in the spec.”datasetGrammars” table and the dataset tables are created based on the combination of timeDimension, dimension and metric present in the event grammars.

  • In addition to the above combination of datasets created the user can also specify the combination of datasets that can be created in the whitelist array.

Config.json file

1{ 2 "globals": { 3 "onlyCreateWhitelisted": true 4 }, 5 "dimensions": { 6 "namespace": "dimensions", 7 "fileNameFormat": "${dimensionName}.${index}.dimensions.data.csv", 8 "input": { 9 "files": "./ingest/JH/dimensions" 10 } 11 }, 12 "programs": [ 13 { 14 "name": "DIKSHA", 15 "namespace": "diksha", 16 "description": "DIKSHA", 17 "shouldIngestToDB": true, 18 "input": { 19 "files": "./ingest/JH/programs/diksha" 20 }, 21 "./output": { 22 "location": "./output/programs/diksha" 23 }, 24 "dimensions": { 25 "whitelisted": [ 26 "state,grade,subject,medium,board", 27 "textbookdiksha,grade,subject,medium", 28 "textbookdiksha,grade,subject,medium" 29 ], 30 "blacklisted": [] 31 } 32 }, 33 { 34 "name": "School Attendance", 35 "namespace": "sch_att", 36 "description": "School Attendance", 37 "shouldIngestToDB": true, 38 "input": { 39 "files": "./ingest/JH/programs/school-attendance" 40 }, 41 "./output": { 42 "location": "././output/programs/school-attendance" 43 }, 44 "dimensions": { 45 "whitelisted": [ 46 "gender,district", 47 "gender,block", 48 "gender,cluster", 49 "school,grade", 50 "gender,school", 51 "gender,school,grade", 52 "schoolcategory,district", 53 "schoolcategory,block", 54 "schoolcategory,cluster" 55 ], 56 "blacklisted": [] 57 } 58 }, 59 { 60 "name": "PM Poshan", 61 "namespace": "pm_poshan", 62 "description": "PM Poshan", 63 "shouldIngestToDB": true, 64 "input": { 65 "files": "./ingest/JH/programs/pm-poshan" 66 }, 67 "./output": { 68 "location": "./output/programs/pm-poshan" 69 }, 70 "dimensions": { 71 "whitelisted": [ 72 "district,categorypm" 73 ], 74 "blacklisted": [] 75 } 76 }, 77 { 78 "name": "NAS", 79 "namespace": "nas", 80 "description": "NAS", 81 "shouldIngestToDB": true, 82 "input": { 83 "files": "./ingest/JH/programs/nas" 84 }, 85 "./output": { 86 "location": "./output/programs/nas" 87 }, 88 "dimensions": { 89 "whitelisted": [ 90 "district,lo,subject,grade", 91 "state,lo,subject,grade" 92 ], 93 "blacklisted": [] 94 } 95 }, 96 { 97 "name": "UDISE", 98 "namespace": "udise", 99 "description": "UDISE", 100 "shouldIngestToDB": true, 101 "input": { 102 "files": "./ingest/JH/programs/udise" 103 }, 104 "./output": { 105 "location": "./output/programs/udise" 106 }, 107 "dimensions": { 108 "whitelisted": [ 109 "district,categoryudise", 110 "state,categoryudise" 111 ], 112 "blacklisted": [] 113 } 114 }, 115 { 116 "name": "PGI", 117 "namespace": "pgi", 118 "description": "PGI", 119 "shouldIngestToDB": true, 120 "input": { 121 "files": "./ingest/JH/programs/pgi" 122 }, 123 "./output": { 124 "location": "./output/programs/pgi" 125 }, 126 "dimensions": { 127 "whitelisted": [ 128 "state,district,categorypgi", 129 "state,categorypgi" 130 ], 131 "blacklisted": [] 132 } 133 }, 134 { 135 "name": "NISHTHA", 136 "namespace": "nishtha", 137 "description": "NISHTHA", 138 "shouldIngestToDB": true, 139 "input": { 140 "files": "./ingest/JH/programs/nishtha" 141 }, 142 "./output": { 143 "location": "./output/programs/nishtha" 144 }, 145 "dimensions": { 146 "whitelisted": [ 147 "state,district,programnishtha", 148 "state,programnishtha,coursenishtha", 149 "state,programnishtha", 150 "district,programnishtha" 151 ], 152 "blacklisted": [] 153 } 154 }, 155 { 156 "name": "Student Progression", 157 "namespace": "student_progression", 158 "description": "Student Progression", 159 "shouldIngestToDB": true, 160 "input": { 161 "files": "./ingest/JH/programs/student-progression" 162 }, 163 "./output": { 164 "location": "./output/programs/student-progression" 165 }, 166 "dimensions": { 167 "whitelisted": [ 168 "school,academicyear" 169 ], 170 "blacklisted": [] 171 } 172 }, 173 { 174 "name": "School Infrastructure", 175 "namespace": "school_infra", 176 "description": "School Infrastructure", 177 "shouldIngestToDB": true, 178 "input": { 179 "files": "./ingest/JH/programs/school-infra" 180 }, 181 "./output": { 182 "location": "./output/programs/school-infra" 183 }, 184 "dimensions": { 185 "whitelisted": [ 186 "school,academicyear" 187 ], 188 "blacklisted": [] 189 } 190 }, 191 { 192 "name": "Student Assessment", 193 "namespace": "assessment", 194 "description": "Student Assessment", 195 "shouldIngestToDB": true, 196 "input": { 197 "files": "./ingest/JH/programs/student-assessment" 198 }, 199 "./output": { 200 "location": "./output/programs/student-assessment" 201 }, 202 "dimensions": { 203 "whitelisted": [ 204 "exam,grade,academicyear,subject,lo,school", 205 "state,lo,subject,grade", 206 "district,subject,grade" 207 ], 208 "blacklisted": [] 209 } 210 } 211 212 ] 213}



yarn cli ingest-data: This command will ingest the data to the dataset tables for all the programs. It also provides an option to ingest the data for the particular program.

yarn cli ingest-data ---filter=<program_name>

The program name passed should be the same as namespace specified the config file.

  • It will read all the programs present in the config.json file.

  • It will check for the data files inside the programs folder and process the data.

  • Then the process dataset update request is created.

  • The transformer process the request and updates the data to the dataset tables created. These datasets are used for visualisation in the UI.

Delete the data in the database

yarn cli nuke-db: This command will delete all the data present in the database.