@trafficgroup/knex-rel 0.1.2 → 0.1.4
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/dao/VideoMinuteResultDAO.d.ts +0 -4
- package/dist/dao/VideoMinuteResultDAO.js +7 -48
- package/dist/dao/VideoMinuteResultDAO.js.map +1 -1
- package/dist/dao/report-configuration/report-configuration.dao.d.ts +94 -0
- package/dist/dao/report-configuration/report-configuration.dao.js +352 -0
- package/dist/dao/report-configuration/report-configuration.dao.js.map +1 -0
- package/dist/dao/video/video.dao.js +4 -4
- package/dist/index.d.ts +2 -0
- package/dist/index.js +3 -1
- package/dist/index.js.map +1 -1
- package/dist/interfaces/report-configuration/report-configuration.interfaces.d.ts +26 -0
- package/dist/interfaces/report-configuration/report-configuration.interfaces.js +3 -0
- package/dist/interfaces/report-configuration/report-configuration.interfaces.js.map +1 -0
- package/migrations/20250930200521_migration.ts +52 -0
- package/package.json +1 -1
- package/plan.md +950 -204
- package/src/dao/VideoMinuteResultDAO.ts +7 -64
- package/src/dao/report-configuration/report-configuration.dao.ts +402 -0
- package/src/dao/video/video.dao.ts +4 -4
- package/src/index.ts +8 -0
- package/src/interfaces/report-configuration/report-configuration.interfaces.ts +30 -0
- package/cameras_analysis.md +0 -199
- package/folder_cameraid_analysis.md +0 -167
- package/migrations/20250924000000_camera_name_search_index.ts +0 -22
|
@@ -137,10 +137,6 @@ export declare class VideoMinuteResultDAO implements IBaseDAO<IVideoMinuteResult
|
|
|
137
137
|
* Deep clone a result structure, setting all numeric values to 0
|
|
138
138
|
*/
|
|
139
139
|
private deepCloneStructure;
|
|
140
|
-
/**
|
|
141
|
-
* Normalize ATR vehicle class names to standard format for frontend compatibility
|
|
142
|
-
*/
|
|
143
|
-
private normalizeATRVehicleClass;
|
|
144
140
|
/**
|
|
145
141
|
* Format time label for display (HH:MM:SS format)
|
|
146
142
|
*/
|
|
@@ -462,9 +462,11 @@ class VideoMinuteResultDAO {
|
|
|
462
462
|
const results = minute; // minute is already the results object from array_agg
|
|
463
463
|
// Aggregate vehicle counts by class and lane
|
|
464
464
|
if (results.vehicles) {
|
|
465
|
-
for (const [
|
|
466
|
-
//
|
|
467
|
-
|
|
465
|
+
for (const [vehicleClass, lanes] of Object.entries(results.vehicles)) {
|
|
466
|
+
// Skip 'total' pseudo-class if present
|
|
467
|
+
if (vehicleClass === "total") {
|
|
468
|
+
continue;
|
|
469
|
+
}
|
|
468
470
|
if (!aggregated.vehicles[vehicleClass]) {
|
|
469
471
|
aggregated.vehicles[vehicleClass] = {};
|
|
470
472
|
}
|
|
@@ -484,10 +486,9 @@ class VideoMinuteResultDAO {
|
|
|
484
486
|
}
|
|
485
487
|
// Aggregate total count
|
|
486
488
|
aggregated.total_count += results.total_count || 0;
|
|
487
|
-
// Aggregate detected classes
|
|
489
|
+
// Aggregate detected classes (use raw detection labels)
|
|
488
490
|
if (results.detected_classes) {
|
|
489
|
-
for (const [
|
|
490
|
-
const cls = this.normalizeATRVehicleClass(rawCls);
|
|
491
|
+
for (const [cls, count] of Object.entries(results.detected_classes)) {
|
|
491
492
|
aggregated.detected_classes[cls] =
|
|
492
493
|
(aggregated.detected_classes[cls] || 0) + (count || 0);
|
|
493
494
|
}
|
|
@@ -542,48 +543,6 @@ class VideoMinuteResultDAO {
|
|
|
542
543
|
}
|
|
543
544
|
return cloned;
|
|
544
545
|
}
|
|
545
|
-
/**
|
|
546
|
-
* Normalize ATR vehicle class names to standard format for frontend compatibility
|
|
547
|
-
*/
|
|
548
|
-
normalizeATRVehicleClass(rawVehicleClass) {
|
|
549
|
-
const normalized = rawVehicleClass.toLowerCase().replace(/[_\s-]/g, "");
|
|
550
|
-
// Map raw vehicle classes to standard classes
|
|
551
|
-
if (normalized.includes("car") ||
|
|
552
|
-
normalized === "vehicle" ||
|
|
553
|
-
normalized === "automobiles") {
|
|
554
|
-
return "cars";
|
|
555
|
-
}
|
|
556
|
-
if (normalized.includes("medium") ||
|
|
557
|
-
normalized.includes("pickup") ||
|
|
558
|
-
(normalized.includes("truck") && !normalized.includes("heavy"))) {
|
|
559
|
-
return "mediums";
|
|
560
|
-
}
|
|
561
|
-
if (normalized.includes("heavy") ||
|
|
562
|
-
normalized.includes("largetruck") ||
|
|
563
|
-
normalized.includes("bigtruck")) {
|
|
564
|
-
return "heavy_trucks";
|
|
565
|
-
}
|
|
566
|
-
if (normalized.includes("pedestrian") ||
|
|
567
|
-
normalized.includes("person") ||
|
|
568
|
-
normalized.includes("people")) {
|
|
569
|
-
return "pedestrians";
|
|
570
|
-
}
|
|
571
|
-
if (normalized.includes("bicycle") ||
|
|
572
|
-
normalized.includes("bike") ||
|
|
573
|
-
normalized.includes("cyclist")) {
|
|
574
|
-
return "bicycles";
|
|
575
|
-
}
|
|
576
|
-
if (normalized.includes("total") || normalized.includes("all")) {
|
|
577
|
-
return "total";
|
|
578
|
-
}
|
|
579
|
-
// Handle specific known ATR classes
|
|
580
|
-
if (rawVehicleClass === "mediums")
|
|
581
|
-
return "mediums";
|
|
582
|
-
if (rawVehicleClass === "heavy_trucks")
|
|
583
|
-
return "heavy_trucks";
|
|
584
|
-
// Default fallback for unknown classes
|
|
585
|
-
return "cars";
|
|
586
|
-
}
|
|
587
546
|
/**
|
|
588
547
|
* Format time label for display (HH:MM:SS format)
|
|
589
548
|
*/
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"VideoMinuteResultDAO.js","sourceRoot":"","sources":["../../src/dao/VideoMinuteResultDAO.ts"],"names":[],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"VideoMinuteResultDAO.js","sourceRoot":"","sources":["../../src/dao/VideoMinuteResultDAO.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,94 @@
|
|
|
1
|
+
import { IBaseDAO, IDataPaginator } from "../../d.types";
|
|
2
|
+
import { IReportConfiguration, IReportConfigurationData, IReportConfigurationInput, IValidationResult } from "../../interfaces/report-configuration/report-configuration.interfaces";
|
|
3
|
+
export declare class ReportConfigurationDAO implements IBaseDAO<IReportConfiguration> {
|
|
4
|
+
private _knex;
|
|
5
|
+
private tableName;
|
|
6
|
+
/**
|
|
7
|
+
* Create a new report configuration
|
|
8
|
+
*/
|
|
9
|
+
create(item: IReportConfigurationInput): Promise<IReportConfiguration>;
|
|
10
|
+
/**
|
|
11
|
+
* Get configuration by numeric ID
|
|
12
|
+
*/
|
|
13
|
+
getById(id: number): Promise<IReportConfiguration | null>;
|
|
14
|
+
/**
|
|
15
|
+
* Get configuration by UUID
|
|
16
|
+
*/
|
|
17
|
+
getByUuid(uuid: string): Promise<IReportConfiguration | null>;
|
|
18
|
+
/**
|
|
19
|
+
* Get configuration by name
|
|
20
|
+
*/
|
|
21
|
+
getByName(name: string): Promise<IReportConfiguration | null>;
|
|
22
|
+
/**
|
|
23
|
+
* Update a configuration
|
|
24
|
+
*/
|
|
25
|
+
update(id: number, item: Partial<IReportConfigurationInput>): Promise<IReportConfiguration | null>;
|
|
26
|
+
/**
|
|
27
|
+
* Delete a configuration
|
|
28
|
+
* Prevents deletion of the last configuration (business logic protection)
|
|
29
|
+
*/
|
|
30
|
+
delete(id: number): Promise<boolean>;
|
|
31
|
+
/**
|
|
32
|
+
* Get all configurations with pagination
|
|
33
|
+
*/
|
|
34
|
+
getAll(page: number, limit: number): Promise<IDataPaginator<IReportConfiguration>>;
|
|
35
|
+
/**
|
|
36
|
+
* Validate a report configuration
|
|
37
|
+
*
|
|
38
|
+
* Rules:
|
|
39
|
+
* - Minimum 2, maximum 7 custom classes
|
|
40
|
+
* - Custom class names must be 1-30 characters
|
|
41
|
+
* - FHWA classes must be in range 1-13
|
|
42
|
+
* - Each FHWA class can only be mapped to one custom class (no duplicates)
|
|
43
|
+
* - Each custom class must have at least one FHWA class
|
|
44
|
+
*/
|
|
45
|
+
validateConfiguration(config: IReportConfigurationData): IValidationResult;
|
|
46
|
+
/**
|
|
47
|
+
* Apply configuration transformation to detection results
|
|
48
|
+
*
|
|
49
|
+
* Two-step transformation:
|
|
50
|
+
* 1. Detection labels → FHWA classes (using DETECTION_LABEL_TO_FHWA mapping)
|
|
51
|
+
* 2. FHWA classes → Custom classes (using configuration)
|
|
52
|
+
*
|
|
53
|
+
* @param detectionResults - Raw detection results with labels as keys and counts as values
|
|
54
|
+
* Example: { 'car': 150, 'articulated_truck': 23, 'motorcycle': 5 }
|
|
55
|
+
* @param config - The report configuration to apply
|
|
56
|
+
* @returns Transformed results with custom class names as keys and counts as values
|
|
57
|
+
* Example: { 'Cars': 155, 'Heavy Trucks': 23 }
|
|
58
|
+
*/
|
|
59
|
+
applyConfiguration(detectionResults: Record<string, number>, config: IReportConfiguration): Record<string, number>;
|
|
60
|
+
/**
|
|
61
|
+
* Transform nested vehicle structure with custom class mapping
|
|
62
|
+
*
|
|
63
|
+
* Handles both ATR (lane-based) and TMC (direction/turn-based) formats
|
|
64
|
+
* Preserves all nesting levels while transforming detection labels to custom classes
|
|
65
|
+
*
|
|
66
|
+
* @param vehiclesStructure - Nested vehicles object with detection labels as keys
|
|
67
|
+
* ATR: { "car": { "0": 45, "1": 50 }, ... }
|
|
68
|
+
* TMC: { "car": { "NORTH": { "straight": 10 }, ... }, ... }
|
|
69
|
+
* @param config - Report configuration with custom class mappings
|
|
70
|
+
* @returns Transformed structure with custom class names as keys
|
|
71
|
+
*/
|
|
72
|
+
applyConfigurationToNestedStructure(vehiclesStructure: Record<string, any>, config: IReportConfiguration): Record<string, any>;
|
|
73
|
+
/**
|
|
74
|
+
* Deep merge numeric data at arbitrary nesting levels
|
|
75
|
+
*
|
|
76
|
+
* Recursively merges two nested structures, summing numeric leaf values
|
|
77
|
+
* Handles ATR format (2 levels: vehicle → lane → count)
|
|
78
|
+
* Handles TMC format (3 levels: vehicle → direction → turn → count)
|
|
79
|
+
*
|
|
80
|
+
* @param target - Target accumulator object
|
|
81
|
+
* @param source - Source data to merge into target
|
|
82
|
+
* @returns Merged object with summed numeric values
|
|
83
|
+
*/
|
|
84
|
+
private _deepMergeNumericData;
|
|
85
|
+
/**
|
|
86
|
+
* Get the FHWA mapping constant (for reference/debugging)
|
|
87
|
+
*/
|
|
88
|
+
getDetectionLabelToFhwaMapping(): Record<string, number[]>;
|
|
89
|
+
/**
|
|
90
|
+
* Deserialize database row to IReportConfiguration interface
|
|
91
|
+
* Converts snake_case to camelCase and parses JSONB
|
|
92
|
+
*/
|
|
93
|
+
private _deserialize;
|
|
94
|
+
}
|
|
@@ -0,0 +1,352 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
3
|
+
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
4
|
+
return new (P || (P = Promise))(function (resolve, reject) {
|
|
5
|
+
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
6
|
+
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
7
|
+
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
8
|
+
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
9
|
+
});
|
|
10
|
+
};
|
|
11
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
12
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
13
|
+
};
|
|
14
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
15
|
+
exports.ReportConfigurationDAO = void 0;
|
|
16
|
+
const KnexConnection_1 = __importDefault(require("../../KnexConnection"));
|
|
17
|
+
/**
|
|
18
|
+
* Mapping from detection labels to FHWA vehicle classes (1-13)
|
|
19
|
+
*
|
|
20
|
+
* FHWA Classes:
|
|
21
|
+
* - Class 1: Motorcycles
|
|
22
|
+
* - Class 2: Cars (passenger cars)
|
|
23
|
+
* - Class 3: Pickup trucks, vans, motorized vehicles
|
|
24
|
+
* - Class 4: Buses
|
|
25
|
+
* - Class 5: Work vans (2-axle, 6-tire single units)
|
|
26
|
+
* - Classes 6-8: Single unit trucks
|
|
27
|
+
* - Classes 9-13: Articulated trucks (semi-trailers, multi-trailers)
|
|
28
|
+
*
|
|
29
|
+
* Non-motorized vehicles (pedestrian, bicycle, non_motorized_vehicle) are EXCLUDED
|
|
30
|
+
*/
|
|
31
|
+
const DETECTION_LABEL_TO_FHWA = {
|
|
32
|
+
motorcycle: [1],
|
|
33
|
+
car: [2],
|
|
34
|
+
pickup_truck: [3],
|
|
35
|
+
motorized_vehicle: [3], // Maps to Class 3 (same as pickup_truck)
|
|
36
|
+
bus: [4],
|
|
37
|
+
work_van: [5],
|
|
38
|
+
single_unit_truck: [6, 7, 8], // Classes 6-8
|
|
39
|
+
articulated_truck: [9, 10, 11, 12, 13], // Classes 9-13
|
|
40
|
+
// pedestrian, bicycle, non_motorized_vehicle are EXCLUDED
|
|
41
|
+
};
|
|
42
|
+
class ReportConfigurationDAO {
|
|
43
|
+
constructor() {
|
|
44
|
+
this._knex = KnexConnection_1.default.getConnection();
|
|
45
|
+
this.tableName = "report_configurations";
|
|
46
|
+
}
|
|
47
|
+
/**
|
|
48
|
+
* Create a new report configuration
|
|
49
|
+
*/
|
|
50
|
+
create(item) {
|
|
51
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
52
|
+
// Validate configuration before creating
|
|
53
|
+
const validation = this.validateConfiguration(item.configuration);
|
|
54
|
+
if (!validation.valid) {
|
|
55
|
+
throw new Error(`Invalid configuration: ${validation.errors.join(", ")}`);
|
|
56
|
+
}
|
|
57
|
+
const [createdConfig] = yield this._knex(this.tableName)
|
|
58
|
+
.insert({
|
|
59
|
+
name: item.name,
|
|
60
|
+
description: item.description,
|
|
61
|
+
configuration: JSON.stringify(item.configuration),
|
|
62
|
+
})
|
|
63
|
+
.returning("*");
|
|
64
|
+
return this._deserialize(createdConfig);
|
|
65
|
+
});
|
|
66
|
+
}
|
|
67
|
+
/**
|
|
68
|
+
* Get configuration by numeric ID
|
|
69
|
+
*/
|
|
70
|
+
getById(id) {
|
|
71
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
72
|
+
const config = yield this._knex(this.tableName).where({ id }).first();
|
|
73
|
+
return config ? this._deserialize(config) : null;
|
|
74
|
+
});
|
|
75
|
+
}
|
|
76
|
+
/**
|
|
77
|
+
* Get configuration by UUID
|
|
78
|
+
*/
|
|
79
|
+
getByUuid(uuid) {
|
|
80
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
81
|
+
const config = yield this._knex(this.tableName).where({ uuid }).first();
|
|
82
|
+
return config ? this._deserialize(config) : null;
|
|
83
|
+
});
|
|
84
|
+
}
|
|
85
|
+
/**
|
|
86
|
+
* Get configuration by name
|
|
87
|
+
*/
|
|
88
|
+
getByName(name) {
|
|
89
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
90
|
+
const config = yield this._knex(this.tableName)
|
|
91
|
+
.whereRaw("LOWER(name) = LOWER(?)", [name])
|
|
92
|
+
.first();
|
|
93
|
+
return config ? this._deserialize(config) : null;
|
|
94
|
+
});
|
|
95
|
+
}
|
|
96
|
+
/**
|
|
97
|
+
* Update a configuration
|
|
98
|
+
*/
|
|
99
|
+
update(id, item) {
|
|
100
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
101
|
+
// If configuration is being updated, validate it
|
|
102
|
+
if (item.configuration) {
|
|
103
|
+
const validation = this.validateConfiguration(item.configuration);
|
|
104
|
+
if (!validation.valid) {
|
|
105
|
+
throw new Error(`Invalid configuration: ${validation.errors.join(", ")}`);
|
|
106
|
+
}
|
|
107
|
+
}
|
|
108
|
+
const updateData = {};
|
|
109
|
+
if (item.name !== undefined)
|
|
110
|
+
updateData.name = item.name;
|
|
111
|
+
if (item.description !== undefined)
|
|
112
|
+
updateData.description = item.description;
|
|
113
|
+
if (item.configuration !== undefined)
|
|
114
|
+
updateData.configuration = JSON.stringify(item.configuration);
|
|
115
|
+
const [updatedConfig] = yield this._knex(this.tableName)
|
|
116
|
+
.where({ id })
|
|
117
|
+
.update(updateData)
|
|
118
|
+
.returning("*");
|
|
119
|
+
return updatedConfig ? this._deserialize(updatedConfig) : null;
|
|
120
|
+
});
|
|
121
|
+
}
|
|
122
|
+
/**
|
|
123
|
+
* Delete a configuration
|
|
124
|
+
* Prevents deletion of the last configuration (business logic protection)
|
|
125
|
+
*/
|
|
126
|
+
delete(id) {
|
|
127
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
128
|
+
// Count total configurations
|
|
129
|
+
const [{ count }] = yield this._knex(this.tableName).count("* as count");
|
|
130
|
+
if (parseInt(count) <= 1) {
|
|
131
|
+
throw new Error("Cannot delete the last configuration. At least one configuration must exist.");
|
|
132
|
+
}
|
|
133
|
+
const result = yield this._knex(this.tableName).where({ id }).del();
|
|
134
|
+
return result > 0;
|
|
135
|
+
});
|
|
136
|
+
}
|
|
137
|
+
/**
|
|
138
|
+
* Get all configurations with pagination
|
|
139
|
+
*/
|
|
140
|
+
getAll(page, limit) {
|
|
141
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
142
|
+
const offset = (page - 1) * limit;
|
|
143
|
+
const [countResult] = yield this._knex(this.tableName).count("* as count");
|
|
144
|
+
const totalCount = +countResult.count;
|
|
145
|
+
const configs = yield this._knex(this.tableName)
|
|
146
|
+
.limit(limit)
|
|
147
|
+
.offset(offset)
|
|
148
|
+
.orderBy("created_at", "desc");
|
|
149
|
+
return {
|
|
150
|
+
success: true,
|
|
151
|
+
data: configs.map((c) => this._deserialize(c)),
|
|
152
|
+
page,
|
|
153
|
+
limit,
|
|
154
|
+
count: configs.length,
|
|
155
|
+
totalCount,
|
|
156
|
+
totalPages: Math.ceil(totalCount / limit),
|
|
157
|
+
};
|
|
158
|
+
});
|
|
159
|
+
}
|
|
160
|
+
/**
|
|
161
|
+
* Validate a report configuration
|
|
162
|
+
*
|
|
163
|
+
* Rules:
|
|
164
|
+
* - Minimum 2, maximum 7 custom classes
|
|
165
|
+
* - Custom class names must be 1-30 characters
|
|
166
|
+
* - FHWA classes must be in range 1-13
|
|
167
|
+
* - Each FHWA class can only be mapped to one custom class (no duplicates)
|
|
168
|
+
* - Each custom class must have at least one FHWA class
|
|
169
|
+
*/
|
|
170
|
+
validateConfiguration(config) {
|
|
171
|
+
const errors = [];
|
|
172
|
+
// Validate version exists
|
|
173
|
+
if (!config.version) {
|
|
174
|
+
errors.push("Configuration version is required");
|
|
175
|
+
}
|
|
176
|
+
// Validate custom classes array
|
|
177
|
+
if (!config.customClasses || !Array.isArray(config.customClasses)) {
|
|
178
|
+
errors.push("customClasses must be an array");
|
|
179
|
+
return { valid: false, errors };
|
|
180
|
+
}
|
|
181
|
+
// Min 2, max 7 custom classes
|
|
182
|
+
if (config.customClasses.length < 2) {
|
|
183
|
+
errors.push("Minimum 2 custom classes required");
|
|
184
|
+
}
|
|
185
|
+
if (config.customClasses.length > 7) {
|
|
186
|
+
errors.push("Maximum 7 custom classes allowed");
|
|
187
|
+
}
|
|
188
|
+
// Check name length (max 30 chars) and FHWA classes validity
|
|
189
|
+
const allFhwaClasses = [];
|
|
190
|
+
config.customClasses.forEach((cls, idx) => {
|
|
191
|
+
if (!cls.name || cls.name.length === 0) {
|
|
192
|
+
errors.push(`Custom class ${idx + 1}: name cannot be empty`);
|
|
193
|
+
}
|
|
194
|
+
if (cls.name && cls.name.length > 30) {
|
|
195
|
+
errors.push(`Custom class ${idx + 1}: name exceeds 30 characters`);
|
|
196
|
+
}
|
|
197
|
+
if (!Array.isArray(cls.fhwaClasses) || cls.fhwaClasses.length === 0) {
|
|
198
|
+
errors.push(`Custom class ${idx + 1}: must have at least one FHWA class`);
|
|
199
|
+
}
|
|
200
|
+
else {
|
|
201
|
+
cls.fhwaClasses.forEach((fhwa) => {
|
|
202
|
+
if (!Number.isInteger(fhwa) || fhwa < 1 || fhwa > 13) {
|
|
203
|
+
errors.push(`Custom class ${idx + 1}: FHWA class ${fhwa} is invalid (must be 1-13)`);
|
|
204
|
+
}
|
|
205
|
+
allFhwaClasses.push(fhwa);
|
|
206
|
+
});
|
|
207
|
+
}
|
|
208
|
+
});
|
|
209
|
+
// Check for duplicate FHWA classes (many-to-one only)
|
|
210
|
+
const uniqueFhwaClasses = new Set(allFhwaClasses);
|
|
211
|
+
if (uniqueFhwaClasses.size !== allFhwaClasses.length) {
|
|
212
|
+
const duplicates = allFhwaClasses.filter((item, index) => allFhwaClasses.indexOf(item) !== index);
|
|
213
|
+
errors.push(`Duplicate FHWA classes detected: ${[...new Set(duplicates)].join(", ")}. Each FHWA class can only be mapped to one custom class.`);
|
|
214
|
+
}
|
|
215
|
+
return { valid: errors.length === 0, errors };
|
|
216
|
+
}
|
|
217
|
+
/**
|
|
218
|
+
* Apply configuration transformation to detection results
|
|
219
|
+
*
|
|
220
|
+
* Two-step transformation:
|
|
221
|
+
* 1. Detection labels → FHWA classes (using DETECTION_LABEL_TO_FHWA mapping)
|
|
222
|
+
* 2. FHWA classes → Custom classes (using configuration)
|
|
223
|
+
*
|
|
224
|
+
* @param detectionResults - Raw detection results with labels as keys and counts as values
|
|
225
|
+
* Example: { 'car': 150, 'articulated_truck': 23, 'motorcycle': 5 }
|
|
226
|
+
* @param config - The report configuration to apply
|
|
227
|
+
* @returns Transformed results with custom class names as keys and counts as values
|
|
228
|
+
* Example: { 'Cars': 155, 'Heavy Trucks': 23 }
|
|
229
|
+
*/
|
|
230
|
+
applyConfiguration(detectionResults, config) {
|
|
231
|
+
// Step 1: Detection labels → FHWA classes
|
|
232
|
+
const fhwaClassCounts = {};
|
|
233
|
+
for (const [label, count] of Object.entries(detectionResults)) {
|
|
234
|
+
const fhwaClasses = DETECTION_LABEL_TO_FHWA[label];
|
|
235
|
+
if (fhwaClasses && fhwaClasses.length > 0) {
|
|
236
|
+
fhwaClasses.forEach((fhwaClass) => {
|
|
237
|
+
fhwaClassCounts[fhwaClass] =
|
|
238
|
+
(fhwaClassCounts[fhwaClass] || 0) + count;
|
|
239
|
+
});
|
|
240
|
+
}
|
|
241
|
+
// Labels not in DETECTION_LABEL_TO_FHWA are silently ignored (e.g., pedestrian, bicycle)
|
|
242
|
+
}
|
|
243
|
+
// Step 2: FHWA classes → Custom classes
|
|
244
|
+
const customClassCounts = {};
|
|
245
|
+
config.configuration.customClasses.forEach((customClass) => {
|
|
246
|
+
let total = 0;
|
|
247
|
+
customClass.fhwaClasses.forEach((fhwaClass) => {
|
|
248
|
+
total += fhwaClassCounts[fhwaClass] || 0;
|
|
249
|
+
});
|
|
250
|
+
customClassCounts[customClass.name] = total;
|
|
251
|
+
});
|
|
252
|
+
return customClassCounts;
|
|
253
|
+
}
|
|
254
|
+
/**
|
|
255
|
+
* Transform nested vehicle structure with custom class mapping
|
|
256
|
+
*
|
|
257
|
+
* Handles both ATR (lane-based) and TMC (direction/turn-based) formats
|
|
258
|
+
* Preserves all nesting levels while transforming detection labels to custom classes
|
|
259
|
+
*
|
|
260
|
+
* @param vehiclesStructure - Nested vehicles object with detection labels as keys
|
|
261
|
+
* ATR: { "car": { "0": 45, "1": 50 }, ... }
|
|
262
|
+
* TMC: { "car": { "NORTH": { "straight": 10 }, ... }, ... }
|
|
263
|
+
* @param config - Report configuration with custom class mappings
|
|
264
|
+
* @returns Transformed structure with custom class names as keys
|
|
265
|
+
*/
|
|
266
|
+
applyConfigurationToNestedStructure(vehiclesStructure, config) {
|
|
267
|
+
// Build reverse mapping: detection label → custom class name
|
|
268
|
+
const detectionToCustomClass = {};
|
|
269
|
+
for (const customClass of config.configuration.customClasses) {
|
|
270
|
+
// For each FHWA class in this custom class
|
|
271
|
+
for (const fhwaClass of customClass.fhwaClasses) {
|
|
272
|
+
// Find all detection labels that map to this FHWA class
|
|
273
|
+
for (const [label, fhwaClasses] of Object.entries(DETECTION_LABEL_TO_FHWA)) {
|
|
274
|
+
if (fhwaClasses.includes(fhwaClass)) {
|
|
275
|
+
detectionToCustomClass[label] = customClass.name;
|
|
276
|
+
}
|
|
277
|
+
}
|
|
278
|
+
}
|
|
279
|
+
}
|
|
280
|
+
// Initialize empty structure for each custom class
|
|
281
|
+
const result = {};
|
|
282
|
+
for (const customClass of config.configuration.customClasses) {
|
|
283
|
+
result[customClass.name] = {};
|
|
284
|
+
}
|
|
285
|
+
// Iterate through detection labels in input structure
|
|
286
|
+
for (const [detectionLabel, nestedData] of Object.entries(vehiclesStructure)) {
|
|
287
|
+
const customClassName = detectionToCustomClass[detectionLabel];
|
|
288
|
+
// Skip labels not mapped to any custom class (e.g., pedestrian, bicycle)
|
|
289
|
+
if (!customClassName) {
|
|
290
|
+
continue;
|
|
291
|
+
}
|
|
292
|
+
// Deep merge nested data into custom class accumulator
|
|
293
|
+
result[customClassName] = this._deepMergeNumericData(result[customClassName], nestedData);
|
|
294
|
+
}
|
|
295
|
+
return result;
|
|
296
|
+
}
|
|
297
|
+
/**
|
|
298
|
+
* Deep merge numeric data at arbitrary nesting levels
|
|
299
|
+
*
|
|
300
|
+
* Recursively merges two nested structures, summing numeric leaf values
|
|
301
|
+
* Handles ATR format (2 levels: vehicle → lane → count)
|
|
302
|
+
* Handles TMC format (3 levels: vehicle → direction → turn → count)
|
|
303
|
+
*
|
|
304
|
+
* @param target - Target accumulator object
|
|
305
|
+
* @param source - Source data to merge into target
|
|
306
|
+
* @returns Merged object with summed numeric values
|
|
307
|
+
*/
|
|
308
|
+
_deepMergeNumericData(target, source) {
|
|
309
|
+
// Base case: if source is a number, add it to target
|
|
310
|
+
if (typeof source === "number") {
|
|
311
|
+
return (typeof target === "number" ? target : 0) + source;
|
|
312
|
+
}
|
|
313
|
+
// If source is not an object, return target unchanged
|
|
314
|
+
if (typeof source !== "object" || source === null) {
|
|
315
|
+
return target;
|
|
316
|
+
}
|
|
317
|
+
// Ensure target is an object
|
|
318
|
+
if (typeof target !== "object" || target === null) {
|
|
319
|
+
target = {};
|
|
320
|
+
}
|
|
321
|
+
// Recursively merge each key in source
|
|
322
|
+
for (const [key, value] of Object.entries(source)) {
|
|
323
|
+
target[key] = this._deepMergeNumericData(target[key], value);
|
|
324
|
+
}
|
|
325
|
+
return target;
|
|
326
|
+
}
|
|
327
|
+
/**
|
|
328
|
+
* Get the FHWA mapping constant (for reference/debugging)
|
|
329
|
+
*/
|
|
330
|
+
getDetectionLabelToFhwaMapping() {
|
|
331
|
+
return Object.assign({}, DETECTION_LABEL_TO_FHWA);
|
|
332
|
+
}
|
|
333
|
+
/**
|
|
334
|
+
* Deserialize database row to IReportConfiguration interface
|
|
335
|
+
* Converts snake_case to camelCase and parses JSONB
|
|
336
|
+
*/
|
|
337
|
+
_deserialize(row) {
|
|
338
|
+
return {
|
|
339
|
+
id: row.id,
|
|
340
|
+
uuid: row.uuid,
|
|
341
|
+
name: row.name,
|
|
342
|
+
description: row.description,
|
|
343
|
+
configuration: typeof row.configuration === "string"
|
|
344
|
+
? JSON.parse(row.configuration)
|
|
345
|
+
: row.configuration,
|
|
346
|
+
created_at: row.created_at,
|
|
347
|
+
updated_at: row.updated_at,
|
|
348
|
+
};
|
|
349
|
+
}
|
|
350
|
+
}
|
|
351
|
+
exports.ReportConfigurationDAO = ReportConfigurationDAO;
|
|
352
|
+
//# sourceMappingURL=report-configuration.dao.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"report-configuration.dao.js","sourceRoot":"","sources":["../../../src/dao/report-configuration/report-configuration.dao.ts"],"names":[],"mappings":"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"}
|
|
@@ -189,13 +189,13 @@ class VideoDAO {
|
|
|
189
189
|
// Check if metadata has at least one key with pt1 and pt2 properties
|
|
190
190
|
query = query.whereRaw(`
|
|
191
191
|
EXISTS (
|
|
192
|
-
SELECT 1
|
|
192
|
+
SELECT 1
|
|
193
193
|
FROM jsonb_each(metadata) as entry(key, value)
|
|
194
|
-
WHERE key != 'lanes'
|
|
194
|
+
WHERE key != 'lanes'
|
|
195
195
|
AND key != 'finish_line'
|
|
196
196
|
AND jsonb_typeof(value) = 'object'
|
|
197
|
-
AND value
|
|
198
|
-
AND value
|
|
197
|
+
AND jsonb_exists(value, 'pt1')
|
|
198
|
+
AND jsonb_exists(value, 'pt2')
|
|
199
199
|
AND jsonb_typeof(value->'pt1') = 'array'
|
|
200
200
|
AND jsonb_typeof(value->'pt2') = 'array'
|
|
201
201
|
AND jsonb_array_length(value->'pt1') = 2
|