@golemio/energetics 1.4.9-dev.1632309400 → 1.4.9-rc.1648069376
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/db/migrations/postgresql/20250120141804-ptas-selected-meters.js +53 -0
- package/db/migrations/postgresql/sqls/20250120141804-ptas-selected-meters-down.sql +1 -0
- package/db/migrations/postgresql/sqls/20250120141804-ptas-selected-meters-up.sql +3 -0
- package/dist/input-gateway/pre/PreCsvInputController.js +4 -13
- package/dist/input-gateway/pre/PreCsvInputController.js.map +1 -1
- package/dist/input-gateway/pre/PreInputRouter.js +6 -15
- package/dist/input-gateway/pre/PreInputRouter.js.map +1 -1
- package/dist/input-gateway/pre/PreJsonInputController.js +4 -13
- package/dist/input-gateway/pre/PreJsonInputController.js.map +1 -1
- package/dist/input-gateway/ptas/PtasRouter.js +3 -12
- package/dist/input-gateway/ptas/PtasRouter.js.map +1 -1
- package/dist/input-gateway/ptas/PtasWebScrapingController.js +4 -13
- package/dist/input-gateway/ptas/PtasWebScrapingController.js.map +1 -1
- package/dist/integration-engine/commodity-providers/datasources/ppas-ave-api/helpers/PpasAveApiHelper.js +9 -18
- package/dist/integration-engine/commodity-providers/datasources/ppas-ave-api/helpers/PpasAveApiHelper.js.map +1 -1
- package/dist/integration-engine/commodity-providers/datasources/pre-elektro-api/helpers/PreElectroHelper.js +29 -40
- package/dist/integration-engine/commodity-providers/datasources/pre-elektro-api/helpers/PreElectroHelper.js.map +1 -1
- package/dist/integration-engine/commodity-providers/ioc/Di.js +1 -1
- package/dist/integration-engine/commodity-providers/ioc/Di.js.map +1 -1
- package/dist/integration-engine/commodity-providers/repositories/MeasurementRepository.js +15 -26
- package/dist/integration-engine/commodity-providers/repositories/MeasurementRepository.js.map +1 -1
- package/dist/integration-engine/commodity-providers/repositories/StaticMeterSettingsRepository.js +24 -38
- package/dist/integration-engine/commodity-providers/repositories/StaticMeterSettingsRepository.js.map +1 -1
- package/dist/integration-engine/commodity-providers/workers/tasks/AbstractFetchMeasurementsTask.js +13 -24
- package/dist/integration-engine/commodity-providers/workers/tasks/AbstractFetchMeasurementsTask.js.map +1 -1
- package/dist/integration-engine/commodity-providers/workers/tasks/FetchMeasurementOptionsStaticDataTask.js +14 -25
- package/dist/integration-engine/commodity-providers/workers/tasks/FetchMeasurementOptionsStaticDataTask.js.map +1 -1
- package/dist/integration-engine/commodity-providers/workers/tasks/FetchMeasurementsFromEEProvidersTask.js +18 -29
- package/dist/integration-engine/commodity-providers/workers/tasks/FetchMeasurementsFromEEProvidersTask.js.map +1 -1
- package/dist/integration-engine/commodity-providers/workers/tasks/FetchMeasurementsFromProvidersTask.js +30 -41
- package/dist/integration-engine/commodity-providers/workers/tasks/FetchMeasurementsFromProvidersTask.js.map +1 -1
- package/dist/integration-engine/commodity-providers/workers/tasks/FetchPpasEEMeasurementsTask.js +33 -61
- package/dist/integration-engine/commodity-providers/workers/tasks/FetchPpasEEMeasurementsTask.js.map +1 -1
- package/dist/integration-engine/commodity-providers/workers/tasks/FetchPpasMeasurementsTask.js +50 -92
- package/dist/integration-engine/commodity-providers/workers/tasks/FetchPpasMeasurementsTask.js.map +1 -1
- package/dist/integration-engine/commodity-providers/workers/tasks/FetchPreMeasurementDataTask.js +20 -31
- package/dist/integration-engine/commodity-providers/workers/tasks/FetchPreMeasurementDataTask.js.map +1 -1
- package/dist/integration-engine/commodity-providers/workers/tasks/FetchPtasWebScrapedMeasurementsTask.d.ts +1 -3
- package/dist/integration-engine/commodity-providers/workers/tasks/FetchPtasWebScrapedMeasurementsTask.js +27 -38
- package/dist/integration-engine/commodity-providers/workers/tasks/FetchPtasWebScrapedMeasurementsTask.js.map +1 -1
- package/dist/integration-engine/commodity-providers/workers/tasks/FetchVeoliaMeasurementsTask.js +46 -87
- package/dist/integration-engine/commodity-providers/workers/tasks/FetchVeoliaMeasurementsTask.js.map +1 -1
- package/dist/integration-engine/commodity-providers/workers/tasks/ProcessPreEanMeasurementsTask.js +13 -24
- package/dist/integration-engine/commodity-providers/workers/tasks/ProcessPreEanMeasurementsTask.js.map +1 -1
- package/dist/integration-engine/datasources/vpalace/BaseVpalaceFactory.js +8 -12
- package/dist/integration-engine/datasources/vpalace/BaseVpalaceFactory.js.map +1 -1
- package/dist/integration-engine/datasources/vpalace/VpalaceMeasurementDataSource.js +3 -14
- package/dist/integration-engine/datasources/vpalace/VpalaceMeasurementDataSource.js.map +1 -1
- package/dist/integration-engine/datasources/vpalace/VpalaceMeasuringEquipmentDataSource.js +3 -14
- package/dist/integration-engine/datasources/vpalace/VpalaceMeasuringEquipmentDataSource.js.map +1 -1
- package/dist/integration-engine/datasources/vpalace/VpalaceMeterTypeDataSource.js +3 -14
- package/dist/integration-engine/datasources/vpalace/VpalaceMeterTypeDataSource.js.map +1 -1
- package/dist/integration-engine/datasources/vpalace/VpalaceTypeMeasuringEquipmentDataSource.js +3 -14
- package/dist/integration-engine/datasources/vpalace/VpalaceTypeMeasuringEquipmentDataSource.js.map +1 -1
- package/dist/integration-engine/datasources/vpalace/VpalaceUnitsDataSource.js +3 -14
- package/dist/integration-engine/datasources/vpalace/VpalaceUnitsDataSource.js.map +1 -1
- package/dist/integration-engine/helpers/ParserHelpers.js +1 -1
- package/dist/integration-engine/helpers/ParserHelpers.js.map +1 -1
- package/dist/integration-engine/helpers/UnimonitorCemApiHelper.js +7 -17
- package/dist/integration-engine/helpers/UnimonitorCemApiHelper.js.map +1 -1
- package/dist/integration-engine/repositories/oict-energetika/AccessLimitationRepository.js +24 -36
- package/dist/integration-engine/repositories/oict-energetika/AccessLimitationRepository.js.map +1 -1
- package/dist/integration-engine/repositories/oict-energetika/ConsumptionRepository.js +3 -12
- package/dist/integration-engine/repositories/oict-energetika/ConsumptionRepository.js.map +1 -1
- package/dist/integration-engine/repositories/vpalace/VpalacUnitsRepository.js +4 -13
- package/dist/integration-engine/repositories/vpalace/VpalacUnitsRepository.js.map +1 -1
- package/dist/integration-engine/repositories/vpalace/VpalaceMeasurementRepository.js +4 -13
- package/dist/integration-engine/repositories/vpalace/VpalaceMeasurementRepository.js.map +1 -1
- package/dist/integration-engine/repositories/vpalace/VpalaceMeasuringEquipmentRepository.js +4 -13
- package/dist/integration-engine/repositories/vpalace/VpalaceMeasuringEquipmentRepository.js.map +1 -1
- package/dist/integration-engine/repositories/vpalace/VpalaceMeterTypeRepository.js +4 -13
- package/dist/integration-engine/repositories/vpalace/VpalaceMeterTypeRepository.js.map +1 -1
- package/dist/integration-engine/repositories/vpalace/VpalaceTypeMeasuringEquipmentRepository.js +4 -13
- package/dist/integration-engine/repositories/vpalace/VpalaceTypeMeasuringEquipmentRepository.js.map +1 -1
- package/dist/integration-engine/tasks/oict-energetika/FetchAccessConfigurationTask.js +3 -14
- package/dist/integration-engine/tasks/oict-energetika/FetchAccessConfigurationTask.js.map +1 -1
- package/dist/integration-engine/tasks/oict-energetika/FetchConsumptionTask.js +12 -23
- package/dist/integration-engine/tasks/oict-energetika/FetchConsumptionTask.js.map +1 -1
- package/dist/integration-engine/tasks/oict-energetika/FetchDataTask.js +4 -15
- package/dist/integration-engine/tasks/oict-energetika/FetchDataTask.js.map +1 -1
- package/dist/integration-engine/tasks/vpalace/FetchDateFactory.js +15 -26
- package/dist/integration-engine/tasks/vpalace/FetchDateFactory.js.map +1 -1
- package/dist/integration-engine/tasks/vpalace/FetchXDaysDataTask.js +18 -29
- package/dist/integration-engine/tasks/vpalace/FetchXDaysDataTask.js.map +1 -1
- package/dist/integration-engine/tasks/vpalace/FetchXHoursDataTask.js +15 -26
- package/dist/integration-engine/tasks/vpalace/FetchXHoursDataTask.js.map +1 -1
- package/dist/integration-engine/tasks/vpalace/MeasurementDataFetcher.js +5 -14
- package/dist/integration-engine/tasks/vpalace/MeasurementDataFetcher.js.map +1 -1
- package/dist/integration-engine/tasks/vpalace/MeasuringEquipmentFetcher.js +5 -14
- package/dist/integration-engine/tasks/vpalace/MeasuringEquipmentFetcher.js.map +1 -1
- package/dist/integration-engine/tasks/vpalace/MeterTypeFetcher.js +5 -14
- package/dist/integration-engine/tasks/vpalace/MeterTypeFetcher.js.map +1 -1
- package/dist/integration-engine/tasks/vpalace/TypeMeasuringEquipmentFetcher.js +5 -14
- package/dist/integration-engine/tasks/vpalace/TypeMeasuringEquipmentFetcher.js.map +1 -1
- package/dist/integration-engine/tasks/vpalace/UnitDataFetcher.js +5 -14
- package/dist/integration-engine/tasks/vpalace/UnitDataFetcher.js.map +1 -1
- package/dist/integration-engine/transformations/oict-energetika/ConsumptionTransformation.js +2 -11
- package/dist/integration-engine/transformations/oict-energetika/ConsumptionTransformation.js.map +1 -1
- package/dist/integration-engine/transformations/vpalace/VpalacMeasuringEquipmentTransformation.js +2 -11
- package/dist/integration-engine/transformations/vpalace/VpalacMeasuringEquipmentTransformation.js.map +1 -1
- package/dist/integration-engine/transformations/vpalace/VpalacMeterTypeTransformation.js +2 -11
- package/dist/integration-engine/transformations/vpalace/VpalacMeterTypeTransformation.js.map +1 -1
- package/dist/integration-engine/transformations/vpalace/VpalacTypeMeasuringEquipmentTransformation.js +2 -11
- package/dist/integration-engine/transformations/vpalace/VpalacTypeMeasuringEquipmentTransformation.js.map +1 -1
- package/dist/integration-engine/transformations/vpalace/VpalacUnitsTransformation.js +2 -11
- package/dist/integration-engine/transformations/vpalace/VpalacUnitsTransformation.js.map +1 -1
- package/dist/output-gateway/controllers/v2/AbstractController.js +6 -17
- package/dist/output-gateway/controllers/v2/AbstractController.js.map +1 -1
- package/dist/output-gateway/controllers/v2/BuildingsController.js +15 -24
- package/dist/output-gateway/controllers/v2/BuildingsController.js.map +1 -1
- package/dist/output-gateway/controllers/v2/V2DevicesController.js +8 -17
- package/dist/output-gateway/controllers/v2/V2DevicesController.js.map +1 -1
- package/dist/output-gateway/controllers/v2/V2MeasurementsController.js +18 -19
- package/dist/output-gateway/controllers/v2/V2MeasurementsController.js.map +1 -1
- package/dist/output-gateway/controllers/v2/V2OrganizationsController.js +9 -18
- package/dist/output-gateway/controllers/v2/V2OrganizationsController.js.map +1 -1
- package/dist/output-gateway/repositories/AccessLimitationRepository.js +13 -24
- package/dist/output-gateway/repositories/AccessLimitationRepository.js.map +1 -1
- package/dist/output-gateway/repositories/DevicesRepository.js +26 -39
- package/dist/output-gateway/repositories/DevicesRepository.js.map +1 -1
- package/dist/output-gateway/repositories/MeasurementRepository.js +49 -66
- package/dist/output-gateway/repositories/MeasurementRepository.js.map +1 -1
- package/dist/output-gateway/repositories/OrganizationBuildingsRepository.js +4 -17
- package/dist/output-gateway/repositories/OrganizationBuildingsRepository.js.map +1 -1
- package/dist/output-gateway/repositories/OrganizationResponsibleUsersRepository.js +4 -17
- package/dist/output-gateway/repositories/OrganizationResponsibleUsersRepository.js.map +1 -1
- package/dist/output-gateway/repositories/OrganizationsRepository.js +67 -82
- package/dist/output-gateway/repositories/OrganizationsRepository.js.map +1 -1
- package/dist/output-gateway/repositories/PrimaryBuildingsRepository.js +37 -52
- package/dist/output-gateway/repositories/PrimaryBuildingsRepository.js.map +1 -1
- package/dist/output-gateway/transformations/BuildingTransformationFull.js +114 -115
- package/dist/output-gateway/transformations/BuildingTransformationFull.js.map +1 -1
- package/dist/output-gateway/transformations/BuildingsTransformation.js +2 -3
- package/dist/output-gateway/transformations/BuildingsTransformation.js.map +1 -1
- package/dist/output-gateway/transformations/OrganizationDetailDtoTransformation.js +1 -2
- package/dist/output-gateway/transformations/OrganizationDetailDtoTransformation.js.map +1 -1
- package/dist/schema-definitions/datasources/interfaces/IStaticMeterSettings.d.ts +3 -0
- package/dist/schema-definitions/models/helpers/StaticDataResourceTypeEnum.d.ts +2 -1
- package/dist/schema-definitions/models/helpers/StaticDataResourceTypeEnum.js +1 -0
- package/dist/schema-definitions/models/helpers/StaticDataResourceTypeEnum.js.map +1 -1
- package/dist/schema-definitions/models/interfaces/IStaticDataOutputDto.d.ts +2 -1
- package/docs/implementation_documentation.md +1 -0
- package/package.json +4 -4
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"V2DevicesController.js","sourceRoot":"","sources":["../../../../src/output-gateway/controllers/v2/V2DevicesController.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"V2DevicesController.js","sourceRoot":"","sources":["../../../../src/output-gateway/controllers/v2/V2DevicesController.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;AAAA,4EAAsF;AAEtF,yEAAoE;AACpE,8FAAyF;AACzF,4EAAuE;AACvE,2FAAsF;AAEtF,6EAAwE;AACxE,iEAAwE;AACxE,6DAA0D;AAGnD,IAAM,mBAAmB,iCAAzB,MAAM,mBAAoB,SAAQ,uCAAkB;IACvD,YACoD,iBAA4C,EAE5F,cAA+C,EACU,0BAAsD;QAE/G,KAAK,CAAC,0BAA0B,CAAC,CAAC;QALsB,sBAAiB,GAAjB,iBAAiB,CAAmB;QAEpF,mBAAc,GAAd,cAAc,CAAyB;QAM5C,WAAM,GAAG,KAAK,EAAE,GAAY,EAAE,GAAa,EAAE,IAAkB,EAAE,EAAE;YACtE,IAAI;gBACA,MAAM,oBAAoB,GAAG,MAAM,IAAI,CAAC,yBAAyB,CAAC,GAAG,CAAC,CAAC;gBACvE,MAAM,MAAM,GAAsB,IAAA,6CAAqB,EAAC,GAAG,CAAC,CAAC;gBAC7D,MAAM,MAAM,GAAG,MAAM,IAAI,CAAC,iBAAiB,CAAC,MAAM,CAAC,MAAM,EAAE,oBAAoB,CAAC,CAAC;gBACjF,OAAO,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC,cAAc,CAAC,cAAc,CAAC,MAAM,CAAC,CAAC,CAAC;aAC/D;YAAC,OAAO,GAAG,EAAE;gBACV,OAAO,IAAI,CAAC,GAAG,CAAC,CAAC;aACpB;QACL,CAAC,CAAC;QAEK,WAAM,GAAG,KAAK,EAAE,GAAY,EAAE,GAAa,EAAE,IAAkB,EAAE,EAAE;YACtE,IAAI;gBACA,MAAM,oBAAoB,GAAG,MAAM,IAAI,CAAC,yBAAyB,CAAC,GAAG,CAAC,CAAC;gBACvE,MAAM,EAAE,GAAG,GAAG,CAAC,MAAM,CAAC,EAAE,CAAC;gBACzB,MAAM,MAAM,GAAG,MAAM,IAAI,CAAC,iBAAiB,CAAC,MAAM,CAAC,EAAE,EAAE,oBAAoB,CAAC,CAAC;gBAE7E,IAAI,CAAC,MAAM,EAAE;oBACT,OAAO,IAAI,CACP,IAAI,6BAAY,CAAC,WAAW,EAAE,IAAI,CAAC,WAAW,CAAC,IAAI,EAAE,kBAAkB,GAAG,CAAC,MAAM,CAAC,EAAE,YAAY,EAAE,GAAG,CAAC,CACzG,CAAC;iBACL;gBAED,OAAO,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC,cAAc,CAAC,gBAAgB,CAAC,MAAM,CAAC,CAAC,CAAC;aACjE;YAAC,OAAO,GAAG,EAAE;gBACV,OAAO,IAAI,CAAC,GAAG,CAAC,CAAC;aACpB;QACL,CAAC,CAAC;IA7BF,CAAC;CA8BJ,CAAA;8BAtCY,mBAAmB;IAD/B,IAAA,qBAAU,GAAE;IAGJ,WAAA,IAAA,iBAAM,EAAC,2CAAoB,CAAC,iBAAiB,CAAC,CAAA;IAC9C,WAAA,IAAA,iBAAM,EAAC,2CAAoB,CAAC,uBAAuB,CAAC,CAAA;IAEpD,WAAA,IAAA,iBAAM,EAAC,2CAAoB,CAAC,0BAA0B,CAAC,CAAA;qCAHmB,qCAAiB;QAEpE,iDAAuB;QACsC,uDAA0B;GAL1G,mBAAmB,CAsC/B"}
|
|
@@ -11,15 +11,6 @@ var __metadata = (this && this.__metadata) || function (k, v) {
|
|
|
11
11
|
var __param = (this && this.__param) || function (paramIndex, decorator) {
|
|
12
12
|
return function (target, key) { decorator(target, key, paramIndex); }
|
|
13
13
|
};
|
|
14
|
-
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
15
|
-
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
16
|
-
return new (P || (P = Promise))(function (resolve, reject) {
|
|
17
|
-
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
18
|
-
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
19
|
-
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
20
|
-
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
21
|
-
});
|
|
22
|
-
};
|
|
23
14
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
24
15
|
exports.V2MeasurementsController = void 0;
|
|
25
16
|
const parsePaginationParams_1 = require("../helpers/parsePaginationParams");
|
|
@@ -33,20 +24,28 @@ let V2MeasurementsController = exports.V2MeasurementsController = class V2Measur
|
|
|
33
24
|
constructor(measurementRepository, accessLimitationRepository) {
|
|
34
25
|
super(accessLimitationRepository);
|
|
35
26
|
this.measurementRepository = measurementRepository;
|
|
36
|
-
this.getMeasurements = (req, res, next) =>
|
|
27
|
+
this.getMeasurements = async (req, res, next) => {
|
|
37
28
|
try {
|
|
38
|
-
const allowedOrganizations =
|
|
39
|
-
const params =
|
|
40
|
-
|
|
29
|
+
const allowedOrganizations = await this.getAllowedOrganizationIds(req);
|
|
30
|
+
const params = {
|
|
31
|
+
variable: req.query.variable,
|
|
32
|
+
type: req.query.type,
|
|
33
|
+
addr1: req.query.addr1,
|
|
34
|
+
addr2: req.query.addr2,
|
|
35
|
+
dateFrom: req.query.dateFrom,
|
|
36
|
+
dateTo: req.query.dateTo,
|
|
37
|
+
...(0, parsePaginationParams_1.parsePaginationParams)(req),
|
|
38
|
+
};
|
|
39
|
+
const result = await this.measurementRepository.getMeasurements(params, allowedOrganizations);
|
|
41
40
|
return res.json(result);
|
|
42
41
|
}
|
|
43
42
|
catch (err) {
|
|
44
43
|
return next(err);
|
|
45
44
|
}
|
|
46
|
-
}
|
|
47
|
-
this.getMonthlyReadings = (req, res, next) =>
|
|
45
|
+
};
|
|
46
|
+
this.getMonthlyReadings = async (req, res, next) => {
|
|
48
47
|
try {
|
|
49
|
-
const allowedOrganizations =
|
|
48
|
+
const allowedOrganizations = await this.getAllowedOrganizationIds(req);
|
|
50
49
|
const month = parseInt(req.query.month);
|
|
51
50
|
const year = parseInt(req.query.year);
|
|
52
51
|
const startDateUtc = luxon_1.DateTime.fromJSDate(new Date(year, month - 1, 1), { zone: "Europe/Prague" });
|
|
@@ -58,13 +57,13 @@ let V2MeasurementsController = exports.V2MeasurementsController = class V2Measur
|
|
|
58
57
|
from: fromDate,
|
|
59
58
|
to: toDate,
|
|
60
59
|
};
|
|
61
|
-
const result =
|
|
62
|
-
return res.json(result.map((el) => (
|
|
60
|
+
const result = await this.measurementRepository.getMonthlyReadings(params, allowedOrganizations);
|
|
61
|
+
return res.json(result.map((el) => ({ time: fromDate, ...el })));
|
|
63
62
|
}
|
|
64
63
|
catch (err) {
|
|
65
64
|
return next(err);
|
|
66
65
|
}
|
|
67
|
-
}
|
|
66
|
+
};
|
|
68
67
|
}
|
|
69
68
|
};
|
|
70
69
|
exports.V2MeasurementsController = V2MeasurementsController = __decorate([
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"V2MeasurementsController.js","sourceRoot":"","sources":["../../../../src/output-gateway/controllers/v2/V2MeasurementsController.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"V2MeasurementsController.js","sourceRoot":"","sources":["../../../../src/output-gateway/controllers/v2/V2MeasurementsController.ts"],"names":[],"mappings":"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"}
|
|
@@ -11,15 +11,6 @@ var __metadata = (this && this.__metadata) || function (k, v) {
|
|
|
11
11
|
var __param = (this && this.__param) || function (paramIndex, decorator) {
|
|
12
12
|
return function (target, key) { decorator(target, key, paramIndex); }
|
|
13
13
|
};
|
|
14
|
-
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
15
|
-
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
16
|
-
return new (P || (P = Promise))(function (resolve, reject) {
|
|
17
|
-
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
18
|
-
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
19
|
-
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
20
|
-
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
21
|
-
});
|
|
22
|
-
};
|
|
23
14
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
24
15
|
exports.V2OrganizationsController = void 0;
|
|
25
16
|
const parsePaginationParams_1 = require("../helpers/parsePaginationParams");
|
|
@@ -38,29 +29,29 @@ let V2OrganizationsController = exports.V2OrganizationsController = class V2Orga
|
|
|
38
29
|
this.organizationsRepository = organizationsRepository;
|
|
39
30
|
this.transformation = transformation;
|
|
40
31
|
this.transformationDetail = transformationDetail;
|
|
41
|
-
this.getAll = (req, res, next) =>
|
|
32
|
+
this.getAll = async (req, res, next) => {
|
|
42
33
|
try {
|
|
43
|
-
const allowedOrganizations =
|
|
34
|
+
const allowedOrganizations = await this.getAllowedOrganizationIds(req);
|
|
44
35
|
const params = (0, parsePaginationParams_1.parsePaginationParams)(req);
|
|
45
36
|
const full = (0, Utils_1.parseBooleanQueryParam)(req.query.full) || false;
|
|
46
37
|
let result = [];
|
|
47
38
|
if (!full) {
|
|
48
|
-
result = this.transformation.transformArray(
|
|
39
|
+
result = this.transformation.transformArray(await this.organizationsRepository.GetAllPublic(params, allowedOrganizations));
|
|
49
40
|
}
|
|
50
41
|
else {
|
|
51
|
-
result = this.transformationDetail.transformArray(
|
|
42
|
+
result = this.transformationDetail.transformArray(await this.organizationsRepository.GetAll(params, allowedOrganizations));
|
|
52
43
|
}
|
|
53
44
|
return res.json(result);
|
|
54
45
|
}
|
|
55
46
|
catch (err) {
|
|
56
47
|
return next(err);
|
|
57
48
|
}
|
|
58
|
-
}
|
|
59
|
-
this.getOne = (req, res, next) =>
|
|
49
|
+
};
|
|
50
|
+
this.getOne = async (req, res, next) => {
|
|
60
51
|
try {
|
|
61
|
-
const allowedOrganizations =
|
|
52
|
+
const allowedOrganizations = await this.getAllowedOrganizationIds(req);
|
|
62
53
|
const id = req.params.id;
|
|
63
|
-
const result =
|
|
54
|
+
const result = await this.organizationsRepository.GetOne(id, allowedOrganizations);
|
|
64
55
|
if (!result) {
|
|
65
56
|
return next(new golemio_errors_1.GeneralError("not_found", this.constructor.name, `Organization with id ${req.params.id} not found`, 404));
|
|
66
57
|
}
|
|
@@ -69,7 +60,7 @@ let V2OrganizationsController = exports.V2OrganizationsController = class V2Orga
|
|
|
69
60
|
catch (err) {
|
|
70
61
|
return next(err);
|
|
71
62
|
}
|
|
72
|
-
}
|
|
63
|
+
};
|
|
73
64
|
}
|
|
74
65
|
};
|
|
75
66
|
exports.V2OrganizationsController = V2OrganizationsController = __decorate([
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"V2OrganizationsController.js","sourceRoot":"","sources":["../../../../src/output-gateway/controllers/v2/V2OrganizationsController.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"V2OrganizationsController.js","sourceRoot":"","sources":["../../../../src/output-gateway/controllers/v2/V2OrganizationsController.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,13 +1,4 @@
|
|
|
1
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
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
12
3
|
exports.AccessLimitationRepository = void 0;
|
|
13
4
|
const _sch_1 = require("../../schema-definitions");
|
|
@@ -28,23 +19,21 @@ class AccessLimitationRepository extends AbstractCachedRepository_1.AbstractCach
|
|
|
28
19
|
getAllInternal() {
|
|
29
20
|
return AccessLimitationModel_1.AccessLimitationModel.findAll({ raw: true });
|
|
30
21
|
}
|
|
31
|
-
getOrganizationsByGroupName(groupName) {
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
throw new golemio_errors_1.GeneralError(`Access limitation for group ${groupName} not found`, this.constructor.name, undefined, 500);
|
|
38
|
-
}
|
|
39
|
-
return limitation.organization_ids;
|
|
22
|
+
async getOrganizationsByGroupName(groupName) {
|
|
23
|
+
try {
|
|
24
|
+
const data = await this.getAll();
|
|
25
|
+
const limitation = data.find((d) => d.group_name === groupName);
|
|
26
|
+
if (!limitation) {
|
|
27
|
+
throw new golemio_errors_1.GeneralError(`Access limitation for group ${groupName} not found`, this.constructor.name, undefined, 500);
|
|
40
28
|
}
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
throw
|
|
29
|
+
return limitation.organization_ids;
|
|
30
|
+
}
|
|
31
|
+
catch (err) {
|
|
32
|
+
if (err instanceof golemio_errors_1.GeneralError) {
|
|
33
|
+
throw err;
|
|
46
34
|
}
|
|
47
|
-
|
|
35
|
+
throw new golemio_errors_1.GeneralError("Database error - getOrganizationsByGroupName", this.constructor.name, err, 500);
|
|
36
|
+
}
|
|
48
37
|
}
|
|
49
38
|
}
|
|
50
39
|
exports.AccessLimitationRepository = AccessLimitationRepository;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"AccessLimitationRepository.js","sourceRoot":"","sources":["../../../src/output-gateway/repositories/AccessLimitationRepository.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"AccessLimitationRepository.js","sourceRoot":"","sources":["../../../src/output-gateway/repositories/AccessLimitationRepository.ts"],"names":[],"mappings":";;;AAAA,mDAAwC;AACxC,iGAA0E;AAG1E,oIAAiI;AAEjI,6EAAwE;AAExE,MAAa,0BAA2B,SAAQ,mDAA2C;IAIvF,YAAY,SAA6B,EAAE,GAAY,EAAE,oBAA4B,EAAE,GAAG,CAAC;QACvF,KAAK,CAAC,SAAS,EAAE,GAAG,EAAE,iBAAiB,CAAC,CAAC;QAJ7C,WAAM,GAAG,uBAAgB,CAAC,QAAQ,CAAC;QACnC,cAAS,GAAG,6CAAqB,CAAC,UAAU,CAAC;QAIzC,6CAAqB,CAAC,IAAI,CAAC,6CAAqB,CAAC,cAAc,EAAE;YAC7D,SAAS,EAAE,6CAAqB,CAAC,UAAU;YAC3C,MAAM,EAAE,uBAAgB,CAAC,QAAQ;YACjC,SAAS,EAAE,IAAI,CAAC,SAAS,CAAC,aAAa,EAAE;SAC5C,CAAC,CAAC;IACP,CAAC;IAES,cAAc;QACpB,OAAO,6CAAqB,CAAC,OAAO,CAAC,EAAE,GAAG,EAAE,IAAI,EAAE,CAAC,CAAC;IACxD,CAAC;IAEM,KAAK,CAAC,2BAA2B,CAAC,SAAiB;QACtD,IAAI;YACA,MAAM,IAAI,GAAG,MAAM,IAAI,CAAC,MAAM,EAAE,CAAC;YACjC,MAAM,UAAU,GAAG,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,UAAU,KAAK,SAAS,CAAC,CAAC;YAChE,IAAI,CAAC,UAAU,EAAE;gBACb,MAAM,IAAI,6BAAY,CAClB,+BAA+B,SAAS,YAAY,EACpD,IAAI,CAAC,WAAW,CAAC,IAAI,EACrB,SAAS,EACT,GAAG,CACN,CAAC;aACL;YAED,OAAO,UAAU,CAAC,gBAAgB,CAAC;SACtC;QAAC,OAAO,GAAG,EAAE;YACV,IAAI,GAAG,YAAY,6BAAY,EAAE;gBAC7B,MAAM,GAAG,CAAC;aACb;YAED,MAAM,IAAI,6BAAY,CAAC,8CAA8C,EAAE,IAAI,CAAC,WAAW,CAAC,IAAI,EAAE,GAAG,EAAE,GAAG,CAAC,CAAC;SAC3G;IACL,CAAC;CACJ;AAvCD,gEAuCC"}
|
|
@@ -8,15 +8,6 @@ var __decorate = (this && this.__decorate) || function (decorators, target, key,
|
|
|
8
8
|
var __metadata = (this && this.__metadata) || function (k, v) {
|
|
9
9
|
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
10
10
|
};
|
|
11
|
-
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
12
|
-
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
13
|
-
return new (P || (P = Promise))(function (resolve, reject) {
|
|
14
|
-
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
15
|
-
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
16
|
-
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
17
|
-
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
18
|
-
});
|
|
19
|
-
};
|
|
20
11
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
21
12
|
exports.DevicesRepository = void 0;
|
|
22
13
|
const _sch_1 = require("../../schema-definitions");
|
|
@@ -38,37 +29,33 @@ where organization_id = any('{${allowedOrganizations.join(",")}}'::integer[]))`)
|
|
|
38
29
|
};
|
|
39
30
|
};
|
|
40
31
|
}
|
|
41
|
-
GetAll(params, allowedOrganizations = []) {
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
}
|
|
54
|
-
});
|
|
32
|
+
async GetAll(params, allowedOrganizations = []) {
|
|
33
|
+
try {
|
|
34
|
+
return await this.sequelizeModel.findAll({
|
|
35
|
+
where: allowedOrganizations === null ? {} : { building_id: this.getWhereAccessLimitation(allowedOrganizations) },
|
|
36
|
+
order: [["id", "ASC"]],
|
|
37
|
+
limit: params.limit,
|
|
38
|
+
offset: params.offset,
|
|
39
|
+
});
|
|
40
|
+
}
|
|
41
|
+
catch (err) {
|
|
42
|
+
throw new golemio_errors_1.GeneralError("Database error - GetAll", this.name, err, 500);
|
|
43
|
+
}
|
|
55
44
|
}
|
|
56
|
-
GetOne(id, allowedOrganizations = []) {
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
}
|
|
71
|
-
});
|
|
45
|
+
async GetOne(id, allowedOrganizations = []) {
|
|
46
|
+
try {
|
|
47
|
+
return await this.sequelizeModel.findOne({
|
|
48
|
+
where: {
|
|
49
|
+
[sequelize_1.Op.and]: [
|
|
50
|
+
{ id: id },
|
|
51
|
+
allowedOrganizations === null ? {} : { building_id: this.getWhereAccessLimitation(allowedOrganizations) },
|
|
52
|
+
],
|
|
53
|
+
},
|
|
54
|
+
});
|
|
55
|
+
}
|
|
56
|
+
catch (err) {
|
|
57
|
+
throw new golemio_errors_1.GeneralError("Database error - GetOne", this.name, err, 500);
|
|
58
|
+
}
|
|
72
59
|
}
|
|
73
60
|
};
|
|
74
61
|
exports.DevicesRepository = DevicesRepository = __decorate([
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"DevicesRepository.js","sourceRoot":"","sources":["../../../src/output-gateway/repositories/DevicesRepository.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"DevicesRepository.js","sourceRoot":"","sources":["../../../src/output-gateway/repositories/DevicesRepository.ts"],"names":[],"mappings":";;;;;;;;;;;;AACA,mDAAwC;AACxC,kEAA2C;AAC3C,4DAA2C;AAE3C,sEAAmE;AACnE,6EAAwE;AACxE,mEAAkE;AAClE,iEAAgE;AAGzD,IAAM,iBAAiB,+BAAvB,MAAM,iBAAkB,SAAQ,+BAAc;IACjD;QACI,KAAK,CAAC,mBAAmB,EAAE,qBAAY,CAAC,UAAU,EAAE,qBAAY,CAAC,cAAc,EAAE;YAC7E,MAAM,EAAE,uBAAgB,CAAC,QAAQ;SACpC,CAAC,CAAC;QA+BC,6BAAwB,GAAG,CAAC,oBAA8B,EAAE,EAAE;YAClE,OAAO;gBACH,CAAC,cAAE,CAAC,EAAE,CAAC,EAAE,IAAA,mBAAO,EAAC,qCAAqC,qBAAS;gCAC3C,oBAAoB,CAAC,IAAI,CAAC,GAAG,CAAC,iBAAiB,CAAC;aACvE,CAAC;QACN,CAAC,CAAC;IAnCF,CAAC;IAEM,KAAK,CAAC,MAAM,CAAC,MAAyB,EAAE,uBAAwC,EAAE;QACrF,IAAI;YACA,OAAO,MAAM,IAAI,CAAC,cAAc,CAAC,OAAO,CAAC;gBACrC,KAAK,EAAE,oBAAoB,KAAK,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,WAAW,EAAE,IAAI,CAAC,wBAAwB,CAAC,oBAAoB,CAAC,EAAE;gBAChH,KAAK,EAAE,CAAC,CAAC,IAAI,EAAE,KAAK,CAAC,CAAC;gBACtB,KAAK,EAAE,MAAM,CAAC,KAAK;gBACnB,MAAM,EAAE,MAAM,CAAC,MAAM;aACxB,CAAC,CAAC;SACN;QAAC,OAAO,GAAG,EAAE;YACV,MAAM,IAAI,6BAAY,CAAC,yBAAyB,EAAE,IAAI,CAAC,IAAI,EAAE,GAAG,EAAE,GAAG,CAAC,CAAC;SAC1E;IACL,CAAC;IAEM,KAAK,CAAC,MAAM,CAAC,EAAU,EAAE,uBAAwC,EAAE;QACtE,IAAI;YACA,OAAO,MAAM,IAAI,CAAC,cAAc,CAAC,OAAO,CAAC;gBACrC,KAAK,EAAE;oBACH,CAAC,cAAE,CAAC,GAAG,CAAC,EAAE;wBACN,EAAE,EAAE,EAAE,EAAE,EAAE;wBACV,oBAAoB,KAAK,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,WAAW,EAAE,IAAI,CAAC,wBAAwB,CAAC,oBAAoB,CAAC,EAAE;qBAC5G;iBACJ;aACJ,CAAC,CAAC;SACN;QAAC,OAAO,GAAG,EAAE;YACV,MAAM,IAAI,6BAAY,CAAC,yBAAyB,EAAE,IAAI,CAAC,IAAI,EAAE,GAAG,EAAE,GAAG,CAAC,CAAC;SAC1E;IACL,CAAC;CAQJ,CAAA;4BAzCY,iBAAiB;IAD7B,IAAA,qBAAU,GAAE;;GACA,iBAAiB,CAyC7B"}
|
|
@@ -8,15 +8,6 @@ var __decorate = (this && this.__decorate) || function (decorators, target, key,
|
|
|
8
8
|
var __metadata = (this && this.__metadata) || function (k, v) {
|
|
9
9
|
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
10
10
|
};
|
|
11
|
-
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
12
|
-
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
13
|
-
return new (P || (P = Promise))(function (resolve, reject) {
|
|
14
|
-
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
15
|
-
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
16
|
-
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
17
|
-
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
18
|
-
});
|
|
19
|
-
};
|
|
20
11
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
21
12
|
exports.MeasurementRepository = void 0;
|
|
22
13
|
const _sch_1 = require("../../schema-definitions");
|
|
@@ -39,66 +30,58 @@ let MeasurementRepository = exports.MeasurementRepository = class MeasurementRep
|
|
|
39
30
|
};
|
|
40
31
|
};
|
|
41
32
|
}
|
|
42
|
-
getMeasurements(options, allowedOrganizations) {
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
[sequelize_1.Op.
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
:
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
}
|
|
70
|
-
});
|
|
33
|
+
async getMeasurements(options, allowedOrganizations) {
|
|
34
|
+
try {
|
|
35
|
+
const where = {
|
|
36
|
+
[sequelize_1.Op.and]: [
|
|
37
|
+
...(options.variable ? [{ var: { [sequelize_1.Op.eq]: options.variable } }] : []),
|
|
38
|
+
...(options.type ? [{ type: { [sequelize_1.Op.eq]: options.type } }] : []),
|
|
39
|
+
...(options.addr1 && options.addr2 ? [{ addr: { [sequelize_1.Op.eq]: `/${options.addr1}/${options.addr2}` } }] : []),
|
|
40
|
+
...(options.dateFrom ? [{ timestamp: { [sequelize_1.Op.gte]: options.dateFrom } }] : []),
|
|
41
|
+
...(options.dateTo ? [{ timestamp: { [sequelize_1.Op.lte]: options.dateTo } }] : []),
|
|
42
|
+
allowedOrganizations === null
|
|
43
|
+
? {}
|
|
44
|
+
: {
|
|
45
|
+
addr: this.getWhereAccessLimitation(allowedOrganizations),
|
|
46
|
+
},
|
|
47
|
+
],
|
|
48
|
+
};
|
|
49
|
+
return await this.sequelizeModel.findAll({
|
|
50
|
+
attributes: [["timestamp", "time"], "value", "addr", "meter", "type", "var"],
|
|
51
|
+
where,
|
|
52
|
+
order: [["timestamp", "DESC"]],
|
|
53
|
+
limit: options.limit,
|
|
54
|
+
offset: options.offset,
|
|
55
|
+
});
|
|
56
|
+
}
|
|
57
|
+
catch (err) {
|
|
58
|
+
throw new golemio_errors_1.GeneralError("MeasurementsRepository error - getMeasurements", this.name, err, 500);
|
|
59
|
+
}
|
|
71
60
|
}
|
|
72
|
-
getMonthlyReadings(options, allowedOrganizations) {
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
}
|
|
91
|
-
});
|
|
61
|
+
async getMonthlyReadings(options, allowedOrganizations) {
|
|
62
|
+
try {
|
|
63
|
+
const result = await this.sequelizeModel.sequelize.query(`SELECT * from ${constants_1.PG_SCHEMA}.monthly_report($address, $variable, $date_from, $date_to, $org_ids);`, {
|
|
64
|
+
bind: {
|
|
65
|
+
address: options.address,
|
|
66
|
+
variable: options.variable,
|
|
67
|
+
date_from: options.from,
|
|
68
|
+
date_to: options.to,
|
|
69
|
+
org_ids: allowedOrganizations ? allowedOrganizations.join(",") : null,
|
|
70
|
+
},
|
|
71
|
+
raw: true,
|
|
72
|
+
type: sequelize_1.QueryTypes.SELECT,
|
|
73
|
+
});
|
|
74
|
+
return result;
|
|
75
|
+
}
|
|
76
|
+
catch (err) {
|
|
77
|
+
throw new golemio_errors_1.GeneralError("MeasurementsRepository error - getMonthlyReadings", this.name, err, 500);
|
|
78
|
+
}
|
|
92
79
|
}
|
|
93
|
-
GetAll() {
|
|
94
|
-
|
|
95
|
-
throw new Error("MeasurementsRepository - GetOne not implemented");
|
|
96
|
-
});
|
|
80
|
+
async GetAll() {
|
|
81
|
+
throw new Error("MeasurementsRepository - GetOne not implemented");
|
|
97
82
|
}
|
|
98
|
-
GetOne() {
|
|
99
|
-
|
|
100
|
-
throw new Error("MeasurementsRepository - GetOne not implemented");
|
|
101
|
-
});
|
|
83
|
+
async GetOne() {
|
|
84
|
+
throw new Error("MeasurementsRepository - GetOne not implemented");
|
|
102
85
|
}
|
|
103
86
|
};
|
|
104
87
|
exports.MeasurementRepository = MeasurementRepository = __decorate([
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"MeasurementRepository.js","sourceRoot":"","sources":["../../../src/output-gateway/repositories/MeasurementRepository.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"MeasurementRepository.js","sourceRoot":"","sources":["../../../src/output-gateway/repositories/MeasurementRepository.ts"],"names":[],"mappings":"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"}
|
|
@@ -8,15 +8,6 @@ var __decorate = (this && this.__decorate) || function (decorators, target, key,
|
|
|
8
8
|
var __metadata = (this && this.__metadata) || function (k, v) {
|
|
9
9
|
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
10
10
|
};
|
|
11
|
-
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
12
|
-
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
13
|
-
return new (P || (P = Promise))(function (resolve, reject) {
|
|
14
|
-
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
15
|
-
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
16
|
-
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
17
|
-
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
18
|
-
});
|
|
19
|
-
};
|
|
20
11
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
21
12
|
exports.OrganizationBuildingsRepository = void 0;
|
|
22
13
|
const _sch_1 = require("../../schema-definitions");
|
|
@@ -29,15 +20,11 @@ let OrganizationBuildingsRepository = exports.OrganizationBuildingsRepository =
|
|
|
29
20
|
schema: _sch_1.EnergeticsSchema.pgSchema,
|
|
30
21
|
});
|
|
31
22
|
}
|
|
32
|
-
GetAll() {
|
|
33
|
-
|
|
34
|
-
throw new Error("OrganizationBuildingsRepository - GetAll not implemented");
|
|
35
|
-
});
|
|
23
|
+
async GetAll() {
|
|
24
|
+
throw new Error("OrganizationBuildingsRepository - GetAll not implemented");
|
|
36
25
|
}
|
|
37
|
-
GetOne() {
|
|
38
|
-
|
|
39
|
-
throw new Error("OrganizationBuildingsRepository - GetOne not implemented");
|
|
40
|
-
});
|
|
26
|
+
async GetOne() {
|
|
27
|
+
throw new Error("OrganizationBuildingsRepository - GetOne not implemented");
|
|
41
28
|
}
|
|
42
29
|
};
|
|
43
30
|
exports.OrganizationBuildingsRepository = OrganizationBuildingsRepository = __decorate([
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"OrganizationBuildingsRepository.js","sourceRoot":"","sources":["../../../src/output-gateway/repositories/OrganizationBuildingsRepository.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"OrganizationBuildingsRepository.js","sourceRoot":"","sources":["../../../src/output-gateway/repositories/OrganizationBuildingsRepository.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,mDAAwC;AACxC,sEAAmE;AACnE,iEAAgE;AAChE,yGAAkF;AAG3E,IAAM,+BAA+B,6CAArC,MAAM,+BAAgC,SAAQ,+BAAc;IAC/D;QACI,KAAK,CAAC,iCAAiC,EAAE,qDAAyB,CAAC,UAAU,EAAE,qDAAyB,CAAC,cAAc,EAAE;YACrH,MAAM,EAAE,uBAAgB,CAAC,QAAQ;SACpC,CAAC,CAAC;IACP,CAAC;IAEM,KAAK,CAAC,MAAM;QACf,MAAM,IAAI,KAAK,CAAC,0DAA0D,CAAC,CAAC;IAChF,CAAC;IAEM,KAAK,CAAC,MAAM;QACf,MAAM,IAAI,KAAK,CAAC,0DAA0D,CAAC,CAAC;IAChF,CAAC;CACJ,CAAA;0CAdY,+BAA+B;IAD3C,IAAA,qBAAU,GAAE;;GACA,+BAA+B,CAc3C"}
|
|
@@ -8,15 +8,6 @@ var __decorate = (this && this.__decorate) || function (decorators, target, key,
|
|
|
8
8
|
var __metadata = (this && this.__metadata) || function (k, v) {
|
|
9
9
|
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
10
10
|
};
|
|
11
|
-
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
12
|
-
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
13
|
-
return new (P || (P = Promise))(function (resolve, reject) {
|
|
14
|
-
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
15
|
-
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
16
|
-
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
17
|
-
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
18
|
-
});
|
|
19
|
-
};
|
|
20
11
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
21
12
|
exports.OrganizationResponsibleUsersRepository = void 0;
|
|
22
13
|
const _sch_1 = require("../../schema-definitions");
|
|
@@ -29,15 +20,11 @@ let OrganizationResponsibleUsersRepository = exports.OrganizationResponsibleUser
|
|
|
29
20
|
schema: _sch_1.EnergeticsSchema.pgSchema,
|
|
30
21
|
});
|
|
31
22
|
}
|
|
32
|
-
GetAll() {
|
|
33
|
-
|
|
34
|
-
throw new Error("OrganizationResponsibleUsersRepository - GetAll not implemented");
|
|
35
|
-
});
|
|
23
|
+
async GetAll() {
|
|
24
|
+
throw new Error("OrganizationResponsibleUsersRepository - GetAll not implemented");
|
|
36
25
|
}
|
|
37
|
-
GetOne() {
|
|
38
|
-
|
|
39
|
-
throw new Error("OrganizationResponsibleUsersRepository - GetOne not implemented");
|
|
40
|
-
});
|
|
26
|
+
async GetOne() {
|
|
27
|
+
throw new Error("OrganizationResponsibleUsersRepository - GetOne not implemented");
|
|
41
28
|
}
|
|
42
29
|
};
|
|
43
30
|
exports.OrganizationResponsibleUsersRepository = OrganizationResponsibleUsersRepository = __decorate([
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"OrganizationResponsibleUsersRepository.js","sourceRoot":"","sources":["../../../src/output-gateway/repositories/OrganizationResponsibleUsersRepository.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"OrganizationResponsibleUsersRepository.js","sourceRoot":"","sources":["../../../src/output-gateway/repositories/OrganizationResponsibleUsersRepository.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,mDAAwC;AACxC,sEAAmE;AACnE,iEAAgE;AAChE,yHAAkG;AAG3F,IAAM,sCAAsC,oDAA5C,MAAM,sCAAuC,SAAQ,+BAAc;IACtE;QACI,KAAK,CACD,wCAAwC,EACxC,qEAAiC,CAAC,UAAU,EAC5C,qEAAiC,CAAC,cAAc,EAChD;YACI,MAAM,EAAE,uBAAgB,CAAC,QAAQ;SACpC,CACJ,CAAC;IACN,CAAC;IAEM,KAAK,CAAC,MAAM;QACf,MAAM,IAAI,KAAK,CAAC,iEAAiE,CAAC,CAAC;IACvF,CAAC;IAEM,KAAK,CAAC,MAAM;QACf,MAAM,IAAI,KAAK,CAAC,iEAAiE,CAAC,CAAC;IACvF,CAAC;CACJ,CAAA;iDAnBY,sCAAsC;IADlD,IAAA,qBAAU,GAAE;;GACA,sCAAsC,CAmBlD"}
|