@zetra/citrineos-data 1.8.3-fork.1
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/index.d.ts +9 -0
- package/dist/index.js +12 -0
- package/dist/index.js.map +1 -0
- package/dist/interfaces/dtos/GenerateCertificateChainRequest.d.ts +13 -0
- package/dist/interfaces/dtos/GenerateCertificateChainRequest.js +30 -0
- package/dist/interfaces/dtos/GenerateCertificateChainRequest.js.map +1 -0
- package/dist/interfaces/dtos/InstallRootCertificateRequest.d.ts +9 -0
- package/dist/interfaces/dtos/InstallRootCertificateRequest.js +22 -0
- package/dist/interfaces/dtos/InstallRootCertificateRequest.js.map +1 -0
- package/dist/interfaces/dtos/RegenerateExistingCertificate.d.ts +4 -0
- package/dist/interfaces/dtos/RegenerateExistingCertificate.js +8 -0
- package/dist/interfaces/dtos/RegenerateExistingCertificate.js.map +1 -0
- package/dist/interfaces/dtos/TlsCertificatesRequest.d.ts +7 -0
- package/dist/interfaces/dtos/TlsCertificatesRequest.js +17 -0
- package/dist/interfaces/dtos/TlsCertificatesRequest.js.map +1 -0
- package/dist/interfaces/dtos/UploadExistingCertificate.d.ts +6 -0
- package/dist/interfaces/dtos/UploadExistingCertificate.js +10 -0
- package/dist/interfaces/dtos/UploadExistingCertificate.js.map +1 -0
- package/dist/interfaces/index.d.ts +35 -0
- package/dist/interfaces/index.js +28 -0
- package/dist/interfaces/index.js.map +1 -0
- package/dist/interfaces/projections/AuthorizationRestrictions.d.ts +18 -0
- package/dist/interfaces/projections/AuthorizationRestrictions.js +5 -0
- package/dist/interfaces/projections/AuthorizationRestrictions.js.map +1 -0
- package/dist/interfaces/projections/schemas/AuthorizationRestrictionsSchema.json +20 -0
- package/dist/interfaces/projections/schemas/TariffSchema.json +37 -0
- package/dist/interfaces/queries/Authorization.d.ts +5 -0
- package/dist/interfaces/queries/Authorization.js +17 -0
- package/dist/interfaces/queries/Authorization.js.map +1 -0
- package/dist/interfaces/queries/ChargingStation.d.ts +5 -0
- package/dist/interfaces/queries/ChargingStation.js +18 -0
- package/dist/interfaces/queries/ChargingStation.js.map +1 -0
- package/dist/interfaces/queries/Connection.d.ts +5 -0
- package/dist/interfaces/queries/Connection.js +17 -0
- package/dist/interfaces/queries/Connection.js.map +1 -0
- package/dist/interfaces/queries/Model.d.ts +5 -0
- package/dist/interfaces/queries/Model.js +18 -0
- package/dist/interfaces/queries/Model.js.map +1 -0
- package/dist/interfaces/queries/NetworkProfile.d.ts +11 -0
- package/dist/interfaces/queries/NetworkProfile.js +36 -0
- package/dist/interfaces/queries/NetworkProfile.js.map +1 -0
- package/dist/interfaces/queries/RootCertificate.d.ts +4 -0
- package/dist/interfaces/queries/RootCertificate.js +100 -0
- package/dist/interfaces/queries/RootCertificate.js.map +1 -0
- package/dist/interfaces/queries/Subscription.d.ts +1 -0
- package/dist/interfaces/queries/Subscription.js +37 -0
- package/dist/interfaces/queries/Subscription.js.map +1 -0
- package/dist/interfaces/queries/Tariff.d.ts +5 -0
- package/dist/interfaces/queries/Tariff.js +17 -0
- package/dist/interfaces/queries/Tariff.js.map +1 -0
- package/dist/interfaces/queries/Tenant.d.ts +5 -0
- package/dist/interfaces/queries/Tenant.js +41 -0
- package/dist/interfaces/queries/Tenant.js.map +1 -0
- package/dist/interfaces/queries/TlsCertificate.d.ts +5 -0
- package/dist/interfaces/queries/TlsCertificate.js +32 -0
- package/dist/interfaces/queries/TlsCertificate.js.map +1 -0
- package/dist/interfaces/queries/TransactionEvent.d.ts +6 -0
- package/dist/interfaces/queries/TransactionEvent.js +23 -0
- package/dist/interfaces/queries/TransactionEvent.js.map +1 -0
- package/dist/interfaces/queries/UpdateChargingStationPasswordQuery.d.ts +5 -0
- package/dist/interfaces/queries/UpdateChargingStationPasswordQuery.js +17 -0
- package/dist/interfaces/queries/UpdateChargingStationPasswordQuery.js.map +1 -0
- package/dist/interfaces/queries/VariableAttribute.d.ts +21 -0
- package/dist/interfaces/queries/VariableAttribute.js +71 -0
- package/dist/interfaces/queries/VariableAttribute.js.map +1 -0
- package/dist/interfaces/queries/Websocket.d.ts +17 -0
- package/dist/interfaces/queries/Websocket.js +115 -0
- package/dist/interfaces/queries/Websocket.js.map +1 -0
- package/dist/interfaces/repositories.d.ts +164 -0
- package/dist/interfaces/repositories.js +5 -0
- package/dist/interfaces/repositories.js.map +1 -0
- package/dist/layers/sequelize/index.d.ts +51 -0
- package/dist/layers/sequelize/index.js +58 -0
- package/dist/layers/sequelize/index.js.map +1 -0
- package/dist/layers/sequelize/mapper/1.6/AuthorizationMapper.d.ts +6 -0
- package/dist/layers/sequelize/mapper/1.6/AuthorizationMapper.js +37 -0
- package/dist/layers/sequelize/mapper/1.6/AuthorizationMapper.js.map +1 -0
- package/dist/layers/sequelize/mapper/1.6/BootMapper.d.ts +4 -0
- package/dist/layers/sequelize/mapper/1.6/BootMapper.js +19 -0
- package/dist/layers/sequelize/mapper/1.6/BootMapper.js.map +1 -0
- package/dist/layers/sequelize/mapper/1.6/ChargingProfileMapper.d.ts +66 -0
- package/dist/layers/sequelize/mapper/1.6/ChargingProfileMapper.js +82 -0
- package/dist/layers/sequelize/mapper/1.6/ChargingProfileMapper.js.map +1 -0
- package/dist/layers/sequelize/mapper/1.6/LocationMapper.d.ts +6 -0
- package/dist/layers/sequelize/mapper/1.6/LocationMapper.js +69 -0
- package/dist/layers/sequelize/mapper/1.6/LocationMapper.js.map +1 -0
- package/dist/layers/sequelize/mapper/1.6/MeterValueMapper.d.ts +65 -0
- package/dist/layers/sequelize/mapper/1.6/MeterValueMapper.js +431 -0
- package/dist/layers/sequelize/mapper/1.6/MeterValueMapper.js.map +1 -0
- package/dist/layers/sequelize/mapper/1.6/index.d.ts +5 -0
- package/dist/layers/sequelize/mapper/1.6/index.js +9 -0
- package/dist/layers/sequelize/mapper/1.6/index.js.map +1 -0
- package/dist/layers/sequelize/mapper/2.0.1/AuthorizationMapper.d.ts +14 -0
- package/dist/layers/sequelize/mapper/2.0.1/AuthorizationMapper.js +153 -0
- package/dist/layers/sequelize/mapper/2.0.1/AuthorizationMapper.js.map +1 -0
- package/dist/layers/sequelize/mapper/2.0.1/BootMapper.d.ts +5 -0
- package/dist/layers/sequelize/mapper/2.0.1/BootMapper.js +29 -0
- package/dist/layers/sequelize/mapper/2.0.1/BootMapper.js.map +1 -0
- package/dist/layers/sequelize/mapper/2.0.1/ChargingProfileMapper.d.ts +84 -0
- package/dist/layers/sequelize/mapper/2.0.1/ChargingProfileMapper.js +152 -0
- package/dist/layers/sequelize/mapper/2.0.1/ChargingProfileMapper.js.map +1 -0
- package/dist/layers/sequelize/mapper/2.0.1/LocationMapper.d.ts +5 -0
- package/dist/layers/sequelize/mapper/2.0.1/LocationMapper.js +23 -0
- package/dist/layers/sequelize/mapper/2.0.1/LocationMapper.js.map +1 -0
- package/dist/layers/sequelize/mapper/2.0.1/MeterValueMapper.d.ts +45 -0
- package/dist/layers/sequelize/mapper/2.0.1/MeterValueMapper.js +375 -0
- package/dist/layers/sequelize/mapper/2.0.1/MeterValueMapper.js.map +1 -0
- package/dist/layers/sequelize/mapper/2.0.1/TransactionMapper.d.ts +5 -0
- package/dist/layers/sequelize/mapper/2.0.1/TransactionMapper.js +18 -0
- package/dist/layers/sequelize/mapper/2.0.1/TransactionMapper.js.map +1 -0
- package/dist/layers/sequelize/mapper/2.0.1/index.d.ts +6 -0
- package/dist/layers/sequelize/mapper/2.0.1/index.js +10 -0
- package/dist/layers/sequelize/mapper/2.0.1/index.js.map +1 -0
- package/dist/layers/sequelize/model/AsyncJob/AsyncJobStatus.d.ts +45 -0
- package/dist/layers/sequelize/model/AsyncJob/AsyncJobStatus.js +137 -0
- package/dist/layers/sequelize/model/AsyncJob/AsyncJobStatus.js.map +1 -0
- package/dist/layers/sequelize/model/AsyncJob/index.d.ts +1 -0
- package/dist/layers/sequelize/model/AsyncJob/index.js +5 -0
- package/dist/layers/sequelize/model/AsyncJob/index.js.map +1 -0
- package/dist/layers/sequelize/model/Authorization/Authorization.d.ts +29 -0
- package/dist/layers/sequelize/model/Authorization/Authorization.js +122 -0
- package/dist/layers/sequelize/model/Authorization/Authorization.js.map +1 -0
- package/dist/layers/sequelize/model/Authorization/LocalListAuthorization.d.ts +39 -0
- package/dist/layers/sequelize/model/Authorization/LocalListAuthorization.js +141 -0
- package/dist/layers/sequelize/model/Authorization/LocalListAuthorization.js.map +1 -0
- package/dist/layers/sequelize/model/Authorization/LocalListVersion.d.ts +15 -0
- package/dist/layers/sequelize/model/Authorization/LocalListVersion.js +74 -0
- package/dist/layers/sequelize/model/Authorization/LocalListVersion.js.map +1 -0
- package/dist/layers/sequelize/model/Authorization/LocalListVersionAuthorization.d.ts +11 -0
- package/dist/layers/sequelize/model/Authorization/LocalListVersionAuthorization.js +69 -0
- package/dist/layers/sequelize/model/Authorization/LocalListVersionAuthorization.js.map +1 -0
- package/dist/layers/sequelize/model/Authorization/SendLocalList.d.ts +17 -0
- package/dist/layers/sequelize/model/Authorization/SendLocalList.js +108 -0
- package/dist/layers/sequelize/model/Authorization/SendLocalList.js.map +1 -0
- package/dist/layers/sequelize/model/Authorization/SendLocalListAuthorization.d.ts +11 -0
- package/dist/layers/sequelize/model/Authorization/SendLocalListAuthorization.js +69 -0
- package/dist/layers/sequelize/model/Authorization/SendLocalListAuthorization.js.map +1 -0
- package/dist/layers/sequelize/model/Authorization/index.d.ts +6 -0
- package/dist/layers/sequelize/model/Authorization/index.js +10 -0
- package/dist/layers/sequelize/model/Authorization/index.js.map +1 -0
- package/dist/layers/sequelize/model/AuthorizationTenant.d.ts +5 -0
- package/dist/layers/sequelize/model/AuthorizationTenant.js +32 -0
- package/dist/layers/sequelize/model/AuthorizationTenant.js.map +1 -0
- package/dist/layers/sequelize/model/BaseModelWithTenant.d.ts +8 -0
- package/dist/layers/sequelize/model/BaseModelWithTenant.js +50 -0
- package/dist/layers/sequelize/model/BaseModelWithTenant.js.map +1 -0
- package/dist/layers/sequelize/model/Boot.d.ts +29 -0
- package/dist/layers/sequelize/model/Boot.js +112 -0
- package/dist/layers/sequelize/model/Boot.js.map +1 -0
- package/dist/layers/sequelize/model/Cdrs/Cdrs.d.ts +105 -0
- package/dist/layers/sequelize/model/Cdrs/Cdrs.js +180 -0
- package/dist/layers/sequelize/model/Cdrs/Cdrs.js.map +1 -0
- package/dist/layers/sequelize/model/Cdrs/index.d.ts +1 -0
- package/dist/layers/sequelize/model/Cdrs/index.js +2 -0
- package/dist/layers/sequelize/model/Cdrs/index.js.map +1 -0
- package/dist/layers/sequelize/model/Certificate/Certificate.d.ts +27 -0
- package/dist/layers/sequelize/model/Certificate/Certificate.js +128 -0
- package/dist/layers/sequelize/model/Certificate/Certificate.js.map +1 -0
- package/dist/layers/sequelize/model/Certificate/DeleteCertificateAttempt.d.ts +17 -0
- package/dist/layers/sequelize/model/Certificate/DeleteCertificateAttempt.js +95 -0
- package/dist/layers/sequelize/model/Certificate/DeleteCertificateAttempt.js.map +1 -0
- package/dist/layers/sequelize/model/Certificate/InstallCertificateAttempt.d.ts +17 -0
- package/dist/layers/sequelize/model/Certificate/InstallCertificateAttempt.js +98 -0
- package/dist/layers/sequelize/model/Certificate/InstallCertificateAttempt.js.map +1 -0
- package/dist/layers/sequelize/model/Certificate/InstalledCertificate.d.ts +18 -0
- package/dist/layers/sequelize/model/Certificate/InstalledCertificate.js +108 -0
- package/dist/layers/sequelize/model/Certificate/InstalledCertificate.js.map +1 -0
- package/dist/layers/sequelize/model/Certificate/index.d.ts +11 -0
- package/dist/layers/sequelize/model/Certificate/index.js +17 -0
- package/dist/layers/sequelize/model/Certificate/index.js.map +1 -0
- package/dist/layers/sequelize/model/ChangeConfiguration.d.ts +13 -0
- package/dist/layers/sequelize/model/ChangeConfiguration.js +80 -0
- package/dist/layers/sequelize/model/ChangeConfiguration.js.map +1 -0
- package/dist/layers/sequelize/model/ChargingProfile/ChargingNeeds.d.ts +27 -0
- package/dist/layers/sequelize/model/ChargingProfile/ChargingNeeds.js +99 -0
- package/dist/layers/sequelize/model/ChargingProfile/ChargingNeeds.js.map +1 -0
- package/dist/layers/sequelize/model/ChargingProfile/ChargingProfile.d.ts +31 -0
- package/dist/layers/sequelize/model/ChargingProfile/ChargingProfile.js +141 -0
- package/dist/layers/sequelize/model/ChargingProfile/ChargingProfile.js.map +1 -0
- package/dist/layers/sequelize/model/ChargingProfile/ChargingSchedule.d.ts +28 -0
- package/dist/layers/sequelize/model/ChargingProfile/ChargingSchedule.js +118 -0
- package/dist/layers/sequelize/model/ChargingProfile/ChargingSchedule.js.map +1 -0
- package/dist/layers/sequelize/model/ChargingProfile/CompositeSchedule.d.ts +16 -0
- package/dist/layers/sequelize/model/ChargingProfile/CompositeSchedule.js +86 -0
- package/dist/layers/sequelize/model/ChargingProfile/CompositeSchedule.js.map +1 -0
- package/dist/layers/sequelize/model/ChargingProfile/SalesTariff.d.ts +24 -0
- package/dist/layers/sequelize/model/ChargingProfile/SalesTariff.js +91 -0
- package/dist/layers/sequelize/model/ChargingProfile/SalesTariff.js.map +1 -0
- package/dist/layers/sequelize/model/ChargingProfile/index.d.ts +5 -0
- package/dist/layers/sequelize/model/ChargingProfile/index.js +9 -0
- package/dist/layers/sequelize/model/ChargingProfile/index.js.map +1 -0
- package/dist/layers/sequelize/model/ChargingStationSecurityInfo.d.ts +14 -0
- package/dist/layers/sequelize/model/ChargingStationSecurityInfo.js +76 -0
- package/dist/layers/sequelize/model/ChargingStationSecurityInfo.js.map +1 -0
- package/dist/layers/sequelize/model/ChargingStationSequence/ChargingStationSequence.d.ts +14 -0
- package/dist/layers/sequelize/model/ChargingStationSequence/ChargingStationSequence.js +85 -0
- package/dist/layers/sequelize/model/ChargingStationSequence/ChargingStationSequence.js.map +1 -0
- package/dist/layers/sequelize/model/ChargingStationSequence/index.d.ts +1 -0
- package/dist/layers/sequelize/model/ChargingStationSequence/index.js +5 -0
- package/dist/layers/sequelize/model/ChargingStationSequence/index.js.map +1 -0
- package/dist/layers/sequelize/model/DeviceModel/Component.d.ts +26 -0
- package/dist/layers/sequelize/model/DeviceModel/Component.js +99 -0
- package/dist/layers/sequelize/model/DeviceModel/Component.js.map +1 -0
- package/dist/layers/sequelize/model/DeviceModel/ComponentVariable.d.ts +11 -0
- package/dist/layers/sequelize/model/DeviceModel/ComponentVariable.js +69 -0
- package/dist/layers/sequelize/model/DeviceModel/ComponentVariable.js.map +1 -0
- package/dist/layers/sequelize/model/DeviceModel/EvseType.d.ts +17 -0
- package/dist/layers/sequelize/model/DeviceModel/EvseType.js +83 -0
- package/dist/layers/sequelize/model/DeviceModel/EvseType.js.map +1 -0
- package/dist/layers/sequelize/model/DeviceModel/Variable.d.ts +27 -0
- package/dist/layers/sequelize/model/DeviceModel/Variable.js +96 -0
- package/dist/layers/sequelize/model/DeviceModel/Variable.js.map +1 -0
- package/dist/layers/sequelize/model/DeviceModel/VariableAttribute.d.ts +38 -0
- package/dist/layers/sequelize/model/DeviceModel/VariableAttribute.js +242 -0
- package/dist/layers/sequelize/model/DeviceModel/VariableAttribute.js.map +1 -0
- package/dist/layers/sequelize/model/DeviceModel/VariableCharacteristics.d.ts +25 -0
- package/dist/layers/sequelize/model/DeviceModel/VariableCharacteristics.js +90 -0
- package/dist/layers/sequelize/model/DeviceModel/VariableCharacteristics.js.map +1 -0
- package/dist/layers/sequelize/model/DeviceModel/VariableStatus.d.ts +19 -0
- package/dist/layers/sequelize/model/DeviceModel/VariableStatus.js +75 -0
- package/dist/layers/sequelize/model/DeviceModel/VariableStatus.js.map +1 -0
- package/dist/layers/sequelize/model/DeviceModel/index.d.ts +6 -0
- package/dist/layers/sequelize/model/DeviceModel/index.js +10 -0
- package/dist/layers/sequelize/model/DeviceModel/index.js.map +1 -0
- package/dist/layers/sequelize/model/Location/ChargingStation.d.ts +56 -0
- package/dist/layers/sequelize/model/Location/ChargingStation.js +178 -0
- package/dist/layers/sequelize/model/Location/ChargingStation.js.map +1 -0
- package/dist/layers/sequelize/model/Location/ChargingStationNetworkProfile.d.ts +27 -0
- package/dist/layers/sequelize/model/Location/ChargingStationNetworkProfile.js +93 -0
- package/dist/layers/sequelize/model/Location/ChargingStationNetworkProfile.js.map +1 -0
- package/dist/layers/sequelize/model/Location/Connector.d.ts +32 -0
- package/dist/layers/sequelize/model/Location/Connector.js +166 -0
- package/dist/layers/sequelize/model/Location/Connector.js.map +1 -0
- package/dist/layers/sequelize/model/Location/Evse.d.ts +28 -0
- package/dist/layers/sequelize/model/Location/Evse.js +122 -0
- package/dist/layers/sequelize/model/Location/Evse.js.map +1 -0
- package/dist/layers/sequelize/model/Location/LatestStatusNotification.d.ts +16 -0
- package/dist/layers/sequelize/model/Location/LatestStatusNotification.js +74 -0
- package/dist/layers/sequelize/model/Location/LatestStatusNotification.js.map +1 -0
- package/dist/layers/sequelize/model/Location/Location.d.ts +44 -0
- package/dist/layers/sequelize/model/Location/Location.js +182 -0
- package/dist/layers/sequelize/model/Location/Location.js.map +1 -0
- package/dist/layers/sequelize/model/Location/ServerNetworkProfile.d.ts +26 -0
- package/dist/layers/sequelize/model/Location/ServerNetworkProfile.js +120 -0
- package/dist/layers/sequelize/model/Location/ServerNetworkProfile.js.map +1 -0
- package/dist/layers/sequelize/model/Location/SetNetworkProfile.d.ts +52 -0
- package/dist/layers/sequelize/model/Location/SetNetworkProfile.js +120 -0
- package/dist/layers/sequelize/model/Location/SetNetworkProfile.js.map +1 -0
- package/dist/layers/sequelize/model/Location/StatusNotification.d.ts +20 -0
- package/dist/layers/sequelize/model/Location/StatusNotification.js +100 -0
- package/dist/layers/sequelize/model/Location/StatusNotification.js.map +1 -0
- package/dist/layers/sequelize/model/Location/index.d.ts +9 -0
- package/dist/layers/sequelize/model/Location/index.js +13 -0
- package/dist/layers/sequelize/model/Location/index.js.map +1 -0
- package/dist/layers/sequelize/model/MessageInfo/MessageInfo.d.ts +29 -0
- package/dist/layers/sequelize/model/MessageInfo/MessageInfo.js +126 -0
- package/dist/layers/sequelize/model/MessageInfo/MessageInfo.js.map +1 -0
- package/dist/layers/sequelize/model/MessageInfo/index.d.ts +1 -0
- package/dist/layers/sequelize/model/MessageInfo/index.js +5 -0
- package/dist/layers/sequelize/model/MessageInfo/index.js.map +1 -0
- package/dist/layers/sequelize/model/OCPPMessage.d.ts +21 -0
- package/dist/layers/sequelize/model/OCPPMessage.js +110 -0
- package/dist/layers/sequelize/model/OCPPMessage.js.map +1 -0
- package/dist/layers/sequelize/model/Reservation.d.ts +29 -0
- package/dist/layers/sequelize/model/Reservation.js +116 -0
- package/dist/layers/sequelize/model/Reservation.js.map +1 -0
- package/dist/layers/sequelize/model/SecurityEvent.d.ts +18 -0
- package/dist/layers/sequelize/model/SecurityEvent.js +78 -0
- package/dist/layers/sequelize/model/SecurityEvent.js.map +1 -0
- package/dist/layers/sequelize/model/Subscription/Subscription.d.ts +16 -0
- package/dist/layers/sequelize/model/Subscription/Subscription.js +94 -0
- package/dist/layers/sequelize/model/Subscription/Subscription.js.map +1 -0
- package/dist/layers/sequelize/model/Subscription/index.d.ts +1 -0
- package/dist/layers/sequelize/model/Subscription/index.js +5 -0
- package/dist/layers/sequelize/model/Subscription/index.js.map +1 -0
- package/dist/layers/sequelize/model/Tariff/TariffElements.d.ts +12 -0
- package/dist/layers/sequelize/model/Tariff/TariffElements.js +57 -0
- package/dist/layers/sequelize/model/Tariff/TariffElements.js.map +1 -0
- package/dist/layers/sequelize/model/Tariff/Tariffs.d.ts +37 -0
- package/dist/layers/sequelize/model/Tariff/Tariffs.js +181 -0
- package/dist/layers/sequelize/model/Tariff/Tariffs.js.map +1 -0
- package/dist/layers/sequelize/model/Tariff/index.d.ts +1 -0
- package/dist/layers/sequelize/model/Tariff/index.js +5 -0
- package/dist/layers/sequelize/model/Tariff/index.js.map +1 -0
- package/dist/layers/sequelize/model/Tenant.d.ts +96 -0
- package/dist/layers/sequelize/model/Tenant.js +268 -0
- package/dist/layers/sequelize/model/Tenant.js.map +1 -0
- package/dist/layers/sequelize/model/TenantPartner.d.ts +14 -0
- package/dist/layers/sequelize/model/TenantPartner.js +70 -0
- package/dist/layers/sequelize/model/TenantPartner.js.map +1 -0
- package/dist/layers/sequelize/model/TransactionEvent/MeterValue.d.ts +18 -0
- package/dist/layers/sequelize/model/TransactionEvent/MeterValue.js +98 -0
- package/dist/layers/sequelize/model/TransactionEvent/MeterValue.js.map +1 -0
- package/dist/layers/sequelize/model/TransactionEvent/StartTransaction.d.ts +19 -0
- package/dist/layers/sequelize/model/TransactionEvent/StartTransaction.js +96 -0
- package/dist/layers/sequelize/model/TransactionEvent/StartTransaction.js.map +1 -0
- package/dist/layers/sequelize/model/TransactionEvent/StopTransaction.d.ts +20 -0
- package/dist/layers/sequelize/model/TransactionEvent/StopTransaction.js +100 -0
- package/dist/layers/sequelize/model/TransactionEvent/StopTransaction.js.map +1 -0
- package/dist/layers/sequelize/model/TransactionEvent/Transaction.d.ts +48 -0
- package/dist/layers/sequelize/model/TransactionEvent/Transaction.js +216 -0
- package/dist/layers/sequelize/model/TransactionEvent/Transaction.js.map +1 -0
- package/dist/layers/sequelize/model/TransactionEvent/TransactionEvent.d.ts +30 -0
- package/dist/layers/sequelize/model/TransactionEvent/TransactionEvent.js +129 -0
- package/dist/layers/sequelize/model/TransactionEvent/TransactionEvent.js.map +1 -0
- package/dist/layers/sequelize/model/TransactionEvent/index.d.ts +5 -0
- package/dist/layers/sequelize/model/TransactionEvent/index.js +9 -0
- package/dist/layers/sequelize/model/TransactionEvent/index.js.map +1 -0
- package/dist/layers/sequelize/model/VariableMonitoring/EventData.d.ts +33 -0
- package/dist/layers/sequelize/model/VariableMonitoring/EventData.js +137 -0
- package/dist/layers/sequelize/model/VariableMonitoring/EventData.js.map +1 -0
- package/dist/layers/sequelize/model/VariableMonitoring/VariableMonitoring.d.ts +28 -0
- package/dist/layers/sequelize/model/VariableMonitoring/VariableMonitoring.js +113 -0
- package/dist/layers/sequelize/model/VariableMonitoring/VariableMonitoring.js.map +1 -0
- package/dist/layers/sequelize/model/VariableMonitoring/VariableMonitoringStatus.d.ts +18 -0
- package/dist/layers/sequelize/model/VariableMonitoring/VariableMonitoringStatus.js +71 -0
- package/dist/layers/sequelize/model/VariableMonitoring/VariableMonitoringStatus.js.map +1 -0
- package/dist/layers/sequelize/model/VariableMonitoring/index.d.ts +3 -0
- package/dist/layers/sequelize/model/VariableMonitoring/index.js +7 -0
- package/dist/layers/sequelize/model/VariableMonitoring/index.js.map +1 -0
- package/dist/layers/sequelize/model/index.d.ts +22 -0
- package/dist/layers/sequelize/model/index.js +27 -0
- package/dist/layers/sequelize/model/index.js.map +1 -0
- package/dist/layers/sequelize/repository/AsyncJobStatus.d.ts +24 -0
- package/dist/layers/sequelize/repository/AsyncJobStatus.js +39 -0
- package/dist/layers/sequelize/repository/AsyncJobStatus.js.map +1 -0
- package/dist/layers/sequelize/repository/Authorization.d.ts +18 -0
- package/dist/layers/sequelize/repository/Authorization.js +51 -0
- package/dist/layers/sequelize/repository/Authorization.js.map +1 -0
- package/dist/layers/sequelize/repository/Base.d.ts +28 -0
- package/dist/layers/sequelize/repository/Base.js +135 -0
- package/dist/layers/sequelize/repository/Base.js.map +1 -0
- package/dist/layers/sequelize/repository/BaseJunction.d.ts +33 -0
- package/dist/layers/sequelize/repository/BaseJunction.js +178 -0
- package/dist/layers/sequelize/repository/BaseJunction.js.map +1 -0
- package/dist/layers/sequelize/repository/Boot.d.ts +20 -0
- package/dist/layers/sequelize/repository/Boot.js +78 -0
- package/dist/layers/sequelize/repository/Boot.js.map +1 -0
- package/dist/layers/sequelize/repository/Certificate.d.ts +11 -0
- package/dist/layers/sequelize/repository/Certificate.js +39 -0
- package/dist/layers/sequelize/repository/Certificate.js.map +1 -0
- package/dist/layers/sequelize/repository/ChangeConfiguration.d.ts +10 -0
- package/dist/layers/sequelize/repository/ChangeConfiguration.js +36 -0
- package/dist/layers/sequelize/repository/ChangeConfiguration.js.map +1 -0
- package/dist/layers/sequelize/repository/ChargingProfile.d.ts +25 -0
- package/dist/layers/sequelize/repository/ChargingProfile.js +156 -0
- package/dist/layers/sequelize/repository/ChargingProfile.js.map +1 -0
- package/dist/layers/sequelize/repository/ChargingStationSecurityInfo.d.ts +12 -0
- package/dist/layers/sequelize/repository/ChargingStationSecurityInfo.js +28 -0
- package/dist/layers/sequelize/repository/ChargingStationSecurityInfo.js.map +1 -0
- package/dist/layers/sequelize/repository/ChargingStationSequence.d.ts +21 -0
- package/dist/layers/sequelize/repository/ChargingStationSequence.js +52 -0
- package/dist/layers/sequelize/repository/ChargingStationSequence.js.map +1 -0
- package/dist/layers/sequelize/repository/DeleteCertificateAttempt.d.ts +10 -0
- package/dist/layers/sequelize/repository/DeleteCertificateAttempt.js +13 -0
- package/dist/layers/sequelize/repository/DeleteCertificateAttempt.js.map +1 -0
- package/dist/layers/sequelize/repository/DeviceModel.d.ts +36 -0
- package/dist/layers/sequelize/repository/DeviceModel.js +417 -0
- package/dist/layers/sequelize/repository/DeviceModel.js.map +1 -0
- package/dist/layers/sequelize/repository/InstallCertificateAttempt.d.ts +10 -0
- package/dist/layers/sequelize/repository/InstallCertificateAttempt.js +13 -0
- package/dist/layers/sequelize/repository/InstallCertificateAttempt.js.map +1 -0
- package/dist/layers/sequelize/repository/InstalledCertificate.d.ts +10 -0
- package/dist/layers/sequelize/repository/InstalledCertificate.js +13 -0
- package/dist/layers/sequelize/repository/InstalledCertificate.js.map +1 -0
- package/dist/layers/sequelize/repository/LocalAuthList.d.ts +20 -0
- package/dist/layers/sequelize/repository/LocalAuthList.js +192 -0
- package/dist/layers/sequelize/repository/LocalAuthList.js.map +1 -0
- package/dist/layers/sequelize/repository/Location.d.ts +30 -0
- package/dist/layers/sequelize/repository/Location.js +263 -0
- package/dist/layers/sequelize/repository/Location.js.map +1 -0
- package/dist/layers/sequelize/repository/MessageInfo.d.ts +13 -0
- package/dist/layers/sequelize/repository/MessageInfo.js +55 -0
- package/dist/layers/sequelize/repository/MessageInfo.js.map +1 -0
- package/dist/layers/sequelize/repository/OCPPMessage.d.ts +12 -0
- package/dist/layers/sequelize/repository/OCPPMessage.js +65 -0
- package/dist/layers/sequelize/repository/OCPPMessage.js.map +1 -0
- package/dist/layers/sequelize/repository/RepositoryStore.d.ts +34 -0
- package/dist/layers/sequelize/repository/RepositoryStore.js +79 -0
- package/dist/layers/sequelize/repository/RepositoryStore.js.map +1 -0
- package/dist/layers/sequelize/repository/Reservation.d.ts +15 -0
- package/dist/layers/sequelize/repository/Reservation.js +68 -0
- package/dist/layers/sequelize/repository/Reservation.js.map +1 -0
- package/dist/layers/sequelize/repository/SecurityEvent.d.ts +18 -0
- package/dist/layers/sequelize/repository/SecurityEvent.js +46 -0
- package/dist/layers/sequelize/repository/SecurityEvent.js.map +1 -0
- package/dist/layers/sequelize/repository/ServerNetworkProfile.d.ts +14 -0
- package/dist/layers/sequelize/repository/ServerNetworkProfile.js +40 -0
- package/dist/layers/sequelize/repository/ServerNetworkProfile.js.map +1 -0
- package/dist/layers/sequelize/repository/Subscription.d.ts +20 -0
- package/dist/layers/sequelize/repository/Subscription.js +32 -0
- package/dist/layers/sequelize/repository/Subscription.js.map +1 -0
- package/dist/layers/sequelize/repository/Tariff.d.ts +15 -0
- package/dist/layers/sequelize/repository/Tariff.js +64 -0
- package/dist/layers/sequelize/repository/Tariff.js.map +1 -0
- package/dist/layers/sequelize/repository/Tenant.d.ts +11 -0
- package/dist/layers/sequelize/repository/Tenant.js +21 -0
- package/dist/layers/sequelize/repository/Tenant.js.map +1 -0
- package/dist/layers/sequelize/repository/TransactionEvent.d.ts +46 -0
- package/dist/layers/sequelize/repository/TransactionEvent.js +597 -0
- package/dist/layers/sequelize/repository/TransactionEvent.js.map +1 -0
- package/dist/layers/sequelize/repository/VariableMonitoring.d.ts +20 -0
- package/dist/layers/sequelize/repository/VariableMonitoring.js +168 -0
- package/dist/layers/sequelize/repository/VariableMonitoring.js.map +1 -0
- package/dist/layers/sequelize/util.d.ts +18 -0
- package/dist/layers/sequelize/util.js +143 -0
- package/dist/layers/sequelize/util.js.map +1 -0
- package/dist/util/CryptoUtils.d.ts +6 -0
- package/dist/util/CryptoUtils.js +14 -0
- package/dist/util/CryptoUtils.js.map +1 -0
- package/dist/util/PasswordHashAlgorithm.d.ts +15 -0
- package/dist/util/PasswordHashAlgorithm.js +2 -0
- package/dist/util/PasswordHashAlgorithm.js.map +1 -0
- package/dist/util/Pbkdf2.d.ts +9 -0
- package/dist/util/Pbkdf2.js +20 -0
- package/dist/util/Pbkdf2.js.map +1 -0
- package/package.json +36 -0
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
// SPDX-FileCopyrightText: 2025 Contributors to the CitrineOS Project
|
|
2
|
+
//
|
|
3
|
+
// SPDX-License-Identifier: Apache-2.0
|
|
4
|
+
// Barrel export for all models
|
|
5
|
+
export * from './AsyncJob/index.js';
|
|
6
|
+
export * from './Authorization/index.js';
|
|
7
|
+
export * from './BaseModelWithTenant.js';
|
|
8
|
+
export * from './Boot.js';
|
|
9
|
+
export * from './Certificate/index.js';
|
|
10
|
+
export * from './ChangeConfiguration.js';
|
|
11
|
+
export * from './ChargingProfile/index.js';
|
|
12
|
+
export * from './ChargingStationSecurityInfo.js';
|
|
13
|
+
export * from './ChargingStationSequence/index.js';
|
|
14
|
+
export * from './DeviceModel/index.js';
|
|
15
|
+
export * from './Location/index.js';
|
|
16
|
+
export * from './MessageInfo/index.js';
|
|
17
|
+
export * from './OCPPMessage.js';
|
|
18
|
+
export * from './Reservation.js';
|
|
19
|
+
export * from './SecurityEvent.js';
|
|
20
|
+
export * from './Subscription/index.js';
|
|
21
|
+
export * from './Tariff/index.js';
|
|
22
|
+
export * from './Tenant.js';
|
|
23
|
+
export * from './TransactionEvent/index.js';
|
|
24
|
+
export * from './VariableMonitoring/index.js';
|
|
25
|
+
export * from './TenantPartner.js';
|
|
26
|
+
export * from './AuthorizationTenant.js';
|
|
27
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/layers/sequelize/model/index.ts"],"names":[],"mappings":"AAAA,qEAAqE;AACrE,EAAE;AACF,sCAAsC;AACtC,+BAA+B;AAC/B,cAAc,qBAAqB,CAAC;AACpC,cAAc,0BAA0B,CAAC;AACzC,cAAc,0BAA0B,CAAC;AACzC,cAAc,WAAW,CAAC;AAC1B,cAAc,wBAAwB,CAAC;AACvC,cAAc,0BAA0B,CAAC;AACzC,cAAc,4BAA4B,CAAC;AAC3C,cAAc,kCAAkC,CAAC;AACjD,cAAc,oCAAoC,CAAC;AACnD,cAAc,wBAAwB,CAAC;AACvC,cAAc,qBAAqB,CAAC;AACpC,cAAc,wBAAwB,CAAC;AACvC,cAAc,kBAAkB,CAAC;AACjC,cAAc,kBAAkB,CAAC;AACjC,cAAc,oBAAoB,CAAC;AACnC,cAAc,yBAAyB,CAAC;AACxC,cAAc,mBAAmB,CAAC;AAClC,cAAc,aAAa,CAAC;AAC5B,cAAc,6BAA6B,CAAC;AAC5C,cAAc,+BAA+B,CAAC;AAC9C,cAAc,oBAAoB,CAAC;AACnC,cAAc,0BAA0B,CAAC"}
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
import { SequelizeRepository } from './Base.js';
|
|
2
|
+
import type { BootstrapConfig } from '@citrineos/base';
|
|
3
|
+
import { Sequelize } from 'sequelize-typescript';
|
|
4
|
+
import type { ILogObj } from 'tslog';
|
|
5
|
+
import { Logger } from 'tslog';
|
|
6
|
+
import { AsyncJobStatus } from '../model/index.js';
|
|
7
|
+
export declare class SequelizeAsyncJobStatusRepository extends SequelizeRepository<AsyncJobStatus> {
|
|
8
|
+
constructor(config: BootstrapConfig, logger?: Logger<ILogObj>, sequelizeInstance?: Sequelize);
|
|
9
|
+
createAsyncJobStatus(asyncJobStatus: AsyncJobStatus): Promise<AsyncJobStatus>;
|
|
10
|
+
updateAsyncJobStatus(updateData: {
|
|
11
|
+
jobId: string;
|
|
12
|
+
paginationParams?: any;
|
|
13
|
+
totalObjects?: number;
|
|
14
|
+
finishedAt?: Date;
|
|
15
|
+
stoppedAt?: Date | null;
|
|
16
|
+
stopScheduled?: boolean;
|
|
17
|
+
isFailed?: boolean;
|
|
18
|
+
}): Promise<AsyncJobStatus>;
|
|
19
|
+
readByJobId(jobId: string): Promise<AsyncJobStatus | undefined>;
|
|
20
|
+
findAllByQuery(query: {
|
|
21
|
+
where: any;
|
|
22
|
+
}): Promise<AsyncJobStatus[]>;
|
|
23
|
+
deleteByJobId(jobId: string): Promise<AsyncJobStatus | undefined>;
|
|
24
|
+
}
|
|
@@ -0,0 +1,39 @@
|
|
|
1
|
+
// SPDX-FileCopyrightText: 2025 Contributors to the CitrineOS Project
|
|
2
|
+
//
|
|
3
|
+
// SPDX-License-Identifier: Apache-2.0
|
|
4
|
+
import { SequelizeRepository } from './Base.js';
|
|
5
|
+
import { Sequelize } from 'sequelize-typescript';
|
|
6
|
+
import { Logger } from 'tslog';
|
|
7
|
+
import { AsyncJobStatus } from '../model/index.js';
|
|
8
|
+
export class SequelizeAsyncJobStatusRepository extends SequelizeRepository {
|
|
9
|
+
constructor(config, logger, sequelizeInstance) {
|
|
10
|
+
super(config, AsyncJobStatus.MODEL_NAME, logger, sequelizeInstance);
|
|
11
|
+
}
|
|
12
|
+
async createAsyncJobStatus(asyncJobStatus) {
|
|
13
|
+
return await this._create(asyncJobStatus.tenantId, asyncJobStatus);
|
|
14
|
+
}
|
|
15
|
+
async updateAsyncJobStatus(updateData) {
|
|
16
|
+
const { jobId, ...data } = updateData;
|
|
17
|
+
// Use the base class method for updating
|
|
18
|
+
const updated = await this._updateByKey(0, data, jobId);
|
|
19
|
+
if (!updated) {
|
|
20
|
+
throw new Error(`Failed to update AsyncJobStatus with id ${jobId}`);
|
|
21
|
+
}
|
|
22
|
+
return updated;
|
|
23
|
+
}
|
|
24
|
+
// Method for finding by jobId as string (expected by OCPI service)
|
|
25
|
+
async readByJobId(jobId) {
|
|
26
|
+
return ((await this.s.models[this.namespace].findOne({
|
|
27
|
+
where: { jobId },
|
|
28
|
+
})) ?? undefined);
|
|
29
|
+
}
|
|
30
|
+
// Method for querying with custom options (expected by OCPI service)
|
|
31
|
+
async findAllByQuery(query) {
|
|
32
|
+
return await super.readAllByQuery(0, query);
|
|
33
|
+
}
|
|
34
|
+
// Method for deleting by jobId as string (expected by OCPI service)
|
|
35
|
+
async deleteByJobId(jobId) {
|
|
36
|
+
return await this._deleteByKey(0, jobId);
|
|
37
|
+
}
|
|
38
|
+
}
|
|
39
|
+
//# sourceMappingURL=AsyncJobStatus.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"AsyncJobStatus.js","sourceRoot":"","sources":["../../../../src/layers/sequelize/repository/AsyncJobStatus.ts"],"names":[],"mappings":"AAAA,qEAAqE;AACrE,EAAE;AACF,sCAAsC;AAEtC,OAAO,EAAE,mBAAmB,EAAE,MAAM,WAAW,CAAC;AAEhD,OAAO,EAAE,SAAS,EAAE,MAAM,sBAAsB,CAAC;AAGjD,OAAO,EAAE,MAAM,EAAE,MAAM,OAAO,CAAC;AAC/B,OAAO,EAAE,cAAc,EAAE,MAAM,mBAAmB,CAAC;AAEnD,MAAM,OAAO,iCAAkC,SAAQ,mBAAmC;IACxF,YAAY,MAAuB,EAAE,MAAwB,EAAE,iBAA6B;QAC1F,KAAK,CAAC,MAAM,EAAE,cAAc,CAAC,UAAU,EAAE,MAAM,EAAE,iBAAiB,CAAC,CAAC;IACtE,CAAC;IAED,KAAK,CAAC,oBAAoB,CAAC,cAA8B;QACvD,OAAO,MAAM,IAAI,CAAC,OAAO,CAAC,cAAc,CAAC,QAAQ,EAAE,cAAc,CAAC,CAAC;IACrE,CAAC;IAED,KAAK,CAAC,oBAAoB,CAAC,UAQ1B;QACC,MAAM,EAAE,KAAK,EAAE,GAAG,IAAI,EAAE,GAAG,UAAU,CAAC;QAEtC,yCAAyC;QACzC,MAAM,OAAO,GAAG,MAAM,IAAI,CAAC,YAAY,CAAC,CAAC,EAAE,IAA+B,EAAE,KAAK,CAAC,CAAC;QACnF,IAAI,CAAC,OAAO,EAAE,CAAC;YACb,MAAM,IAAI,KAAK,CAAC,2CAA2C,KAAK,EAAE,CAAC,CAAC;QACtE,CAAC;QACD,OAAO,OAAO,CAAC;IACjB,CAAC;IAED,mEAAmE;IACnE,KAAK,CAAC,WAAW,CAAC,KAAa;QAC7B,OAAO,CACJ,CAAC,MAAM,IAAI,CAAC,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,OAAO,CAAC;YAC5C,KAAK,EAAE,EAAE,KAAK,EAAE;SACF,CAAC,CAA2B,IAAI,SAAS,CAC1D,CAAC;IACJ,CAAC;IAED,qEAAqE;IACrE,KAAK,CAAC,cAAc,CAAC,KAAqB;QACxC,OAAO,MAAM,KAAK,CAAC,cAAc,CAAC,CAAC,EAAE,KAAK,CAAC,CAAC;IAC9C,CAAC;IAED,oEAAoE;IACpE,KAAK,CAAC,aAAa,CAAC,KAAa;QAC/B,OAAO,MAAM,IAAI,CAAC,YAAY,CAAC,CAAC,EAAE,KAAK,CAAC,CAAC;IAC3C,CAAC;CACF"}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import type { BootstrapConfig } from '@citrineos/base';
|
|
2
|
+
import type { ILogObj } from 'tslog';
|
|
3
|
+
import type { Model, ModelStatic, Sequelize } from 'sequelize-typescript';
|
|
4
|
+
import { Logger } from 'tslog';
|
|
5
|
+
import { type AuthorizationQuerystring, type IAuthorizationRepository } from '../../../interfaces/index.js';
|
|
6
|
+
import { Authorization } from '../model/index.js';
|
|
7
|
+
import { SequelizeTenantJunctionRepository } from './BaseJunction.js';
|
|
8
|
+
export declare class SequelizeAuthorizationRepository extends SequelizeTenantJunctionRepository<Authorization> implements IAuthorizationRepository {
|
|
9
|
+
constructor(config: BootstrapConfig, logger?: Logger<ILogObj>, sequelizeInstance?: Sequelize);
|
|
10
|
+
protected getJunctionModel(): ModelStatic<Model>;
|
|
11
|
+
protected getJunctionForeignKey(): string;
|
|
12
|
+
readAllByQuerystring(tenantId: number, query: AuthorizationQuerystring): Promise<Authorization[]>;
|
|
13
|
+
readOnlyOneByQuerystring(tenantId: number, query: AuthorizationQuerystring): Promise<Authorization | undefined>;
|
|
14
|
+
/**
|
|
15
|
+
* Private Methods
|
|
16
|
+
*/
|
|
17
|
+
private _constructQuery;
|
|
18
|
+
}
|
|
@@ -0,0 +1,51 @@
|
|
|
1
|
+
// SPDX-FileCopyrightText: 2025 Contributors to the CitrineOS Project
|
|
2
|
+
//
|
|
3
|
+
// SPDX-License-Identifier: Apache-2.0
|
|
4
|
+
import { Logger } from 'tslog';
|
|
5
|
+
import {} from '../../../interfaces/index.js';
|
|
6
|
+
import { Authorization } from '../model/index.js';
|
|
7
|
+
import { AuthorizationTenant } from '../model/AuthorizationTenant.js';
|
|
8
|
+
import { SequelizeTenantJunctionRepository } from './BaseJunction.js';
|
|
9
|
+
export class SequelizeAuthorizationRepository extends SequelizeTenantJunctionRepository {
|
|
10
|
+
constructor(config, logger, sequelizeInstance) {
|
|
11
|
+
super(config, Authorization.MODEL_NAME, logger, sequelizeInstance);
|
|
12
|
+
}
|
|
13
|
+
getJunctionModel() {
|
|
14
|
+
return AuthorizationTenant;
|
|
15
|
+
}
|
|
16
|
+
getJunctionForeignKey() {
|
|
17
|
+
return 'authorizationId';
|
|
18
|
+
}
|
|
19
|
+
async readAllByQuerystring(tenantId, query) {
|
|
20
|
+
return await super.readAllByQuery(tenantId, this._constructQuery(query, tenantId));
|
|
21
|
+
}
|
|
22
|
+
async readOnlyOneByQuerystring(tenantId, query) {
|
|
23
|
+
return await super.readOnlyOneByQuery(tenantId, this._constructQuery(query, tenantId));
|
|
24
|
+
}
|
|
25
|
+
/**
|
|
26
|
+
* Private Methods
|
|
27
|
+
*/
|
|
28
|
+
_constructQuery(queryParams, tenantId) {
|
|
29
|
+
const where = {};
|
|
30
|
+
if (queryParams.idToken) {
|
|
31
|
+
where.idToken = queryParams.idToken;
|
|
32
|
+
}
|
|
33
|
+
// 1.6 doesn't have the concept of token type. But we need to support token type for 2.0.1 messages.
|
|
34
|
+
if (queryParams.type) {
|
|
35
|
+
where.idTokenType = queryParams.type;
|
|
36
|
+
}
|
|
37
|
+
return {
|
|
38
|
+
where,
|
|
39
|
+
include: [
|
|
40
|
+
{
|
|
41
|
+
model: AuthorizationTenant,
|
|
42
|
+
as: 'tenants',
|
|
43
|
+
required: true,
|
|
44
|
+
where: { tenantId },
|
|
45
|
+
attributes: [],
|
|
46
|
+
},
|
|
47
|
+
],
|
|
48
|
+
};
|
|
49
|
+
}
|
|
50
|
+
}
|
|
51
|
+
//# sourceMappingURL=Authorization.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Authorization.js","sourceRoot":"","sources":["../../../../src/layers/sequelize/repository/Authorization.ts"],"names":[],"mappings":"AAAA,qEAAqE;AACrE,EAAE;AACF,sCAAsC;AAMtC,OAAO,EAAE,MAAM,EAAE,MAAM,OAAO,CAAC;AAC/B,OAAO,EAGN,MAAM,8BAA8B,CAAC;AACtC,OAAO,EAAE,aAAa,EAAE,MAAM,mBAAmB,CAAC;AAClD,OAAO,EAAE,mBAAmB,EAAE,MAAM,iCAAiC,CAAC;AACtE,OAAO,EAAE,iCAAiC,EAAE,MAAM,mBAAmB,CAAC;AAEtE,MAAM,OAAO,gCACX,SAAQ,iCAAgD;IAGxD,YAAY,MAAuB,EAAE,MAAwB,EAAE,iBAA6B;QAC1F,KAAK,CAAC,MAAM,EAAE,aAAa,CAAC,UAAU,EAAE,MAAM,EAAE,iBAAiB,CAAC,CAAC;IACrE,CAAC;IAES,gBAAgB;QACxB,OAAO,mBAAmB,CAAC;IAC7B,CAAC;IAES,qBAAqB;QAC7B,OAAO,iBAAiB,CAAC;IAC3B,CAAC;IAED,KAAK,CAAC,oBAAoB,CACxB,QAAgB,EAChB,KAA+B;QAE/B,OAAO,MAAM,KAAK,CAAC,cAAc,CAAC,QAAQ,EAAE,IAAI,CAAC,eAAe,CAAC,KAAK,EAAE,QAAQ,CAAC,CAAC,CAAC;IACrF,CAAC;IAED,KAAK,CAAC,wBAAwB,CAC5B,QAAgB,EAChB,KAA+B;QAE/B,OAAO,MAAM,KAAK,CAAC,kBAAkB,CAAC,QAAQ,EAAE,IAAI,CAAC,eAAe,CAAC,KAAK,EAAE,QAAQ,CAAC,CAAC,CAAC;IACzF,CAAC;IAED;;OAEG;IAEK,eAAe,CAAC,WAAqC,EAAE,QAAgB;QAC7E,MAAM,KAAK,GAAQ,EAAE,CAAC;QACtB,IAAI,WAAW,CAAC,OAAO,EAAE,CAAC;YACxB,KAAK,CAAC,OAAO,GAAG,WAAW,CAAC,OAAO,CAAC;QACtC,CAAC;QACD,oGAAoG;QACpG,IAAI,WAAW,CAAC,IAAI,EAAE,CAAC;YACrB,KAAK,CAAC,WAAW,GAAG,WAAW,CAAC,IAAI,CAAC;QACvC,CAAC;QAED,OAAO;YACL,KAAK;YACL,OAAO,EAAE;gBACP;oBACE,KAAK,EAAE,mBAAmB;oBAC1B,EAAE,EAAE,SAAS;oBACb,QAAQ,EAAE,IAAI;oBACd,KAAK,EAAE,EAAE,QAAQ,EAAE;oBACnB,UAAU,EAAE,EAAE;iBACf;aACF;SACF,CAAC;IACJ,CAAC;CACF"}
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
import { type BootstrapConfig, CrudRepository } from '@citrineos/base';
|
|
2
|
+
import type { Attributes, FindAndCountOptions } from 'sequelize';
|
|
3
|
+
import { type Model, type Sequelize } from 'sequelize-typescript';
|
|
4
|
+
import { type ILogObj, Logger } from 'tslog';
|
|
5
|
+
export declare class SequelizeRepository<T extends Model<any, any>> extends CrudRepository<T> {
|
|
6
|
+
protected s: Sequelize;
|
|
7
|
+
protected namespace: string;
|
|
8
|
+
protected logger: Logger<ILogObj>;
|
|
9
|
+
constructor(config: BootstrapConfig, namespace: string, logger?: Logger<ILogObj>, sequelizeInstance?: Sequelize);
|
|
10
|
+
readByKey(tenantId: number, key: string | number, namespace?: string): Promise<T | undefined>;
|
|
11
|
+
readAllByQuery(tenantId: number, query: object, namespace?: string): Promise<T[]>;
|
|
12
|
+
readAllBySqlString(tenantId: number, sqlString: string, _namespace?: string): Promise<object[]>;
|
|
13
|
+
readNextValue(tenantId: number, columnName: string, query?: object, startValue?: number, namespace?: string): Promise<number>;
|
|
14
|
+
existsByKey(tenantId: number, key: string, namespace?: string): Promise<boolean>;
|
|
15
|
+
existByQuery(tenantId: number, query: object, namespace?: string): Promise<number>;
|
|
16
|
+
findAndCount(tenantId: number, options: Omit<FindAndCountOptions<Attributes<T>>, 'group'>, namespace?: string): Promise<{
|
|
17
|
+
rows: T[];
|
|
18
|
+
count: number;
|
|
19
|
+
}>;
|
|
20
|
+
protected _create(tenantId: number, value: T, _namespace?: string): Promise<T>;
|
|
21
|
+
protected _bulkCreate(tenantId: number, values: T[], namespace?: string): Promise<T[]>;
|
|
22
|
+
protected _createByKey(tenantId: number, value: T, key: string, namespace?: string): Promise<T>;
|
|
23
|
+
protected _readOrCreateByQuery(tenantId: number, query: object, namespace?: string): Promise<[T, boolean]>;
|
|
24
|
+
protected _updateByKey(tenantId: number, value: Partial<T>, key: string, namespace?: string): Promise<T | undefined>;
|
|
25
|
+
protected _updateAllByQuery(tenantId: number, value: Partial<T>, query: object, namespace?: string): Promise<T[]>;
|
|
26
|
+
protected _deleteByKey(tenantId: number, key: string, namespace?: string): Promise<T | undefined>;
|
|
27
|
+
protected _deleteAllByQuery(tenantId: number, query: object, namespace?: string): Promise<T[]>;
|
|
28
|
+
}
|
|
@@ -0,0 +1,135 @@
|
|
|
1
|
+
// SPDX-FileCopyrightText: 2025 Contributors to the CitrineOS Project
|
|
2
|
+
//
|
|
3
|
+
// SPDX-License-Identifier: Apache-2.0
|
|
4
|
+
import { CrudRepository } from '@citrineos/base';
|
|
5
|
+
import { QueryTypes } from 'sequelize';
|
|
6
|
+
import {} from 'sequelize-typescript';
|
|
7
|
+
import { Logger } from 'tslog';
|
|
8
|
+
import { DefaultSequelizeInstance } from '../util.js';
|
|
9
|
+
export class SequelizeRepository extends CrudRepository {
|
|
10
|
+
s;
|
|
11
|
+
namespace;
|
|
12
|
+
logger;
|
|
13
|
+
constructor(config, namespace, logger, sequelizeInstance) {
|
|
14
|
+
super();
|
|
15
|
+
this.s = sequelizeInstance ?? DefaultSequelizeInstance.getInstance(config, logger);
|
|
16
|
+
this.namespace = namespace;
|
|
17
|
+
this.logger = logger
|
|
18
|
+
? logger.getSubLogger({ name: this.constructor.name })
|
|
19
|
+
: new Logger({ name: this.constructor.name });
|
|
20
|
+
}
|
|
21
|
+
async readByKey(tenantId, key, namespace = this.namespace) {
|
|
22
|
+
return await this.s.models[namespace].findByPk(key).then((row) => row);
|
|
23
|
+
}
|
|
24
|
+
async readAllByQuery(tenantId, query, namespace = this.namespace) {
|
|
25
|
+
return await this.s.models[namespace]
|
|
26
|
+
.findAll(query)
|
|
27
|
+
.then((row) => row);
|
|
28
|
+
}
|
|
29
|
+
async readAllBySqlString(tenantId, sqlString, _namespace = this.namespace) {
|
|
30
|
+
return await this.s.query(`${sqlString}`, { type: QueryTypes.SELECT });
|
|
31
|
+
}
|
|
32
|
+
async readNextValue(tenantId, columnName, query, startValue, namespace = this.namespace) {
|
|
33
|
+
const options = query ? query : undefined;
|
|
34
|
+
const maxValue = await this.s.models[namespace].max(columnName, options);
|
|
35
|
+
if (maxValue === null || maxValue === undefined) {
|
|
36
|
+
// maxValue can be 0, so we need to specifically check for null or undefined
|
|
37
|
+
return startValue ?? 1;
|
|
38
|
+
}
|
|
39
|
+
if (typeof maxValue !== 'number' || isNaN(maxValue)) {
|
|
40
|
+
throw new Error(`Max value ${maxValue} on ${columnName} is invalid.`);
|
|
41
|
+
}
|
|
42
|
+
return maxValue + 1;
|
|
43
|
+
}
|
|
44
|
+
async existsByKey(tenantId, key, namespace = this.namespace) {
|
|
45
|
+
return await this.s.models[namespace].findByPk(key).then((row) => row !== null);
|
|
46
|
+
}
|
|
47
|
+
async existByQuery(tenantId, query, namespace = this.namespace) {
|
|
48
|
+
return await this.s.models[namespace].findAll(query).then((row) => row.length);
|
|
49
|
+
}
|
|
50
|
+
async findAndCount(tenantId, options, namespace = this.namespace) {
|
|
51
|
+
return this.s.models[namespace].findAndCountAll(options);
|
|
52
|
+
}
|
|
53
|
+
async _create(tenantId, value, _namespace = this.namespace) {
|
|
54
|
+
return await value.save();
|
|
55
|
+
}
|
|
56
|
+
async _bulkCreate(tenantId, values, namespace = this.namespace) {
|
|
57
|
+
return await this.s.models[namespace].bulkCreate(values);
|
|
58
|
+
}
|
|
59
|
+
async _createByKey(tenantId, value, key, namespace = this.namespace) {
|
|
60
|
+
const primaryKey = this.s.models[namespace].primaryKeyAttribute;
|
|
61
|
+
value.setDataValue(primaryKey, key);
|
|
62
|
+
return (await this.s.models[namespace].create(value.toJSON()));
|
|
63
|
+
}
|
|
64
|
+
async _readOrCreateByQuery(tenantId, query, namespace = this.namespace) {
|
|
65
|
+
return await this.s.models[namespace]
|
|
66
|
+
.findOrCreate(query)
|
|
67
|
+
.then((result) => [result[0], result[1]]);
|
|
68
|
+
}
|
|
69
|
+
async _updateByKey(tenantId, value, key, namespace = this.namespace) {
|
|
70
|
+
const model = this.s.models[namespace];
|
|
71
|
+
const pk = model.primaryKeyAttribute;
|
|
72
|
+
const { tenantId: _ignored, ...safeValue } = value;
|
|
73
|
+
const where = {
|
|
74
|
+
[pk]: key,
|
|
75
|
+
tenantId,
|
|
76
|
+
};
|
|
77
|
+
const row = await model.findOne({ where });
|
|
78
|
+
if (!row)
|
|
79
|
+
return undefined;
|
|
80
|
+
await row.update(safeValue);
|
|
81
|
+
return row.reload();
|
|
82
|
+
}
|
|
83
|
+
async _updateAllByQuery(tenantId, value, query, namespace = this.namespace) {
|
|
84
|
+
const model = this.s.models[namespace];
|
|
85
|
+
const where = {
|
|
86
|
+
...query.where,
|
|
87
|
+
tenantId,
|
|
88
|
+
};
|
|
89
|
+
const rows = await model.findAll({
|
|
90
|
+
...query,
|
|
91
|
+
where,
|
|
92
|
+
});
|
|
93
|
+
if (rows.length === 0)
|
|
94
|
+
return [];
|
|
95
|
+
for (const row of rows) {
|
|
96
|
+
await row.update(value);
|
|
97
|
+
}
|
|
98
|
+
return Promise.all(rows.map((r) => r.reload()));
|
|
99
|
+
}
|
|
100
|
+
async _deleteByKey(tenantId, key, namespace = this.namespace) {
|
|
101
|
+
return this.s.transaction(async (transaction) => {
|
|
102
|
+
const entryToDelete = await this.s.models[namespace]
|
|
103
|
+
.findByPk(key, { transaction })
|
|
104
|
+
.then((row) => row);
|
|
105
|
+
if (entryToDelete) {
|
|
106
|
+
await this.s.models[namespace].destroy({
|
|
107
|
+
where: { [this.s.models[namespace].primaryKeyAttribute]: key },
|
|
108
|
+
transaction,
|
|
109
|
+
});
|
|
110
|
+
return entryToDelete;
|
|
111
|
+
}
|
|
112
|
+
else {
|
|
113
|
+
return undefined;
|
|
114
|
+
}
|
|
115
|
+
});
|
|
116
|
+
}
|
|
117
|
+
async _deleteAllByQuery(tenantId, query, namespace = this.namespace) {
|
|
118
|
+
return this.s.transaction(async (transaction) => {
|
|
119
|
+
const entriesToDelete = await this.s.models[namespace]
|
|
120
|
+
.findAll({
|
|
121
|
+
...query,
|
|
122
|
+
transaction,
|
|
123
|
+
})
|
|
124
|
+
.then((rows) => rows);
|
|
125
|
+
const deletedCount = await this.s.models[namespace].destroy({ ...query, transaction });
|
|
126
|
+
if (entriesToDelete.length === deletedCount) {
|
|
127
|
+
return entriesToDelete;
|
|
128
|
+
}
|
|
129
|
+
else {
|
|
130
|
+
throw new Error(`Deleted ${deletedCount} entries, expected ${entriesToDelete.length}`);
|
|
131
|
+
}
|
|
132
|
+
});
|
|
133
|
+
}
|
|
134
|
+
}
|
|
135
|
+
//# sourceMappingURL=Base.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Base.js","sourceRoot":"","sources":["../../../../src/layers/sequelize/repository/Base.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
import { type BootstrapConfig, CrudRepository } from '@citrineos/base';
|
|
2
|
+
import type { Attributes, FindAndCountOptions } from 'sequelize';
|
|
3
|
+
import { type Model, type ModelStatic, type Sequelize } from 'sequelize-typescript';
|
|
4
|
+
import { type ILogObj, Logger } from 'tslog';
|
|
5
|
+
export declare abstract class SequelizeTenantJunctionRepository<T extends Model<any, any>> extends CrudRepository<T> {
|
|
6
|
+
protected s: Sequelize;
|
|
7
|
+
protected namespace: string;
|
|
8
|
+
protected logger: Logger<ILogObj>;
|
|
9
|
+
constructor(config: BootstrapConfig, namespace: string, logger?: Logger<ILogObj>, sequelizeInstance?: Sequelize);
|
|
10
|
+
protected abstract getJunctionModel(): ModelStatic<Model>;
|
|
11
|
+
protected abstract getJunctionForeignKey(): string;
|
|
12
|
+
private _model;
|
|
13
|
+
private _junctionModel;
|
|
14
|
+
private _injectJunctionInclude;
|
|
15
|
+
readByKey(tenantId: number, key: string | number, namespace?: string): Promise<T | undefined>;
|
|
16
|
+
readAllByQuery(tenantId: number, query: object, namespace?: string): Promise<T[]>;
|
|
17
|
+
readAllBySqlString(tenantId: number, sqlString: string, _namespace?: string): Promise<object[]>;
|
|
18
|
+
readNextValue(tenantId: number, columnName: string, query?: object, startValue?: number, namespace?: string): Promise<number>;
|
|
19
|
+
existsByKey(tenantId: number, key: string, namespace?: string): Promise<boolean>;
|
|
20
|
+
existByQuery(tenantId: number, query: object, namespace?: string): Promise<number>;
|
|
21
|
+
findAndCount(tenantId: number, options: Omit<FindAndCountOptions<Attributes<T>>, 'group'>, namespace?: string): Promise<{
|
|
22
|
+
rows: T[];
|
|
23
|
+
count: number;
|
|
24
|
+
}>;
|
|
25
|
+
protected _create(tenantId: number, value: T, _namespace?: string): Promise<T>;
|
|
26
|
+
protected _bulkCreate(tenantId: number, values: T[], namespace?: string): Promise<T[]>;
|
|
27
|
+
protected _createByKey(tenantId: number, value: T, key: string, namespace?: string): Promise<T>;
|
|
28
|
+
protected _readOrCreateByQuery(tenantId: number, query: object, namespace?: string): Promise<[T, boolean]>;
|
|
29
|
+
protected _updateByKey(tenantId: number, value: Partial<T>, key: string, namespace?: string): Promise<T | undefined>;
|
|
30
|
+
protected _updateAllByQuery(tenantId: number, value: Partial<T>, query: object, namespace?: string): Promise<T[]>;
|
|
31
|
+
protected _deleteByKey(tenantId: number, key: string, namespace?: string): Promise<T | undefined>;
|
|
32
|
+
protected _deleteAllByQuery(tenantId: number, query: object, namespace?: string): Promise<T[]>;
|
|
33
|
+
}
|
|
@@ -0,0 +1,178 @@
|
|
|
1
|
+
// SPDX-FileCopyrightText: 2025 Contributors to the CitrineOS Project
|
|
2
|
+
//
|
|
3
|
+
// SPDX-License-Identifier: Apache-2.0
|
|
4
|
+
import { CrudRepository } from '@citrineos/base';
|
|
5
|
+
import { QueryTypes } from 'sequelize';
|
|
6
|
+
import {} from 'sequelize-typescript';
|
|
7
|
+
import { Logger } from 'tslog';
|
|
8
|
+
import { DefaultSequelizeInstance } from '../util.js';
|
|
9
|
+
export class SequelizeTenantJunctionRepository extends CrudRepository {
|
|
10
|
+
s;
|
|
11
|
+
namespace;
|
|
12
|
+
logger;
|
|
13
|
+
constructor(config, namespace, logger, sequelizeInstance) {
|
|
14
|
+
super();
|
|
15
|
+
this.s = sequelizeInstance ?? DefaultSequelizeInstance.getInstance(config, logger);
|
|
16
|
+
this.namespace = namespace;
|
|
17
|
+
this.logger = logger
|
|
18
|
+
? logger.getSubLogger({ name: this.constructor.name })
|
|
19
|
+
: new Logger({ name: this.constructor.name });
|
|
20
|
+
}
|
|
21
|
+
_model(namespace) {
|
|
22
|
+
return this.s.models[namespace];
|
|
23
|
+
}
|
|
24
|
+
_junctionModel() {
|
|
25
|
+
return this.getJunctionModel();
|
|
26
|
+
}
|
|
27
|
+
_injectJunctionInclude(query, tenantId) {
|
|
28
|
+
const existing = query.include ?? [];
|
|
29
|
+
return {
|
|
30
|
+
...query,
|
|
31
|
+
include: [
|
|
32
|
+
...(Array.isArray(existing) ? existing : [existing]),
|
|
33
|
+
{
|
|
34
|
+
model: this.getJunctionModel(),
|
|
35
|
+
required: true,
|
|
36
|
+
where: { tenantId },
|
|
37
|
+
attributes: [],
|
|
38
|
+
},
|
|
39
|
+
],
|
|
40
|
+
};
|
|
41
|
+
}
|
|
42
|
+
async readByKey(tenantId, key, namespace = this.namespace) {
|
|
43
|
+
const row = (await this._model(namespace).findByPk(key));
|
|
44
|
+
if (!row)
|
|
45
|
+
return undefined;
|
|
46
|
+
const fk = this.getJunctionForeignKey();
|
|
47
|
+
const junctionRow = await this._junctionModel().findOne({ where: { [fk]: key, tenantId } });
|
|
48
|
+
return junctionRow ? row : undefined;
|
|
49
|
+
}
|
|
50
|
+
async readAllByQuery(tenantId, query, namespace = this.namespace) {
|
|
51
|
+
return await this._model(namespace)
|
|
52
|
+
.findAll(this._injectJunctionInclude(query, tenantId))
|
|
53
|
+
.then((rows) => rows);
|
|
54
|
+
}
|
|
55
|
+
async readAllBySqlString(tenantId, sqlString, _namespace = this.namespace) {
|
|
56
|
+
return await this.s.query(`${sqlString}`, { type: QueryTypes.SELECT });
|
|
57
|
+
}
|
|
58
|
+
async readNextValue(tenantId, columnName, query, startValue, namespace = this.namespace) {
|
|
59
|
+
const options = query ? query : undefined;
|
|
60
|
+
const maxValue = await this._model(namespace).max(columnName, options);
|
|
61
|
+
if (maxValue === null || maxValue === undefined) {
|
|
62
|
+
return startValue ?? 1;
|
|
63
|
+
}
|
|
64
|
+
if (typeof maxValue !== 'number' || isNaN(maxValue)) {
|
|
65
|
+
throw new Error(`Max value ${maxValue} on ${columnName} is invalid.`);
|
|
66
|
+
}
|
|
67
|
+
return maxValue + 1;
|
|
68
|
+
}
|
|
69
|
+
async existsByKey(tenantId, key, namespace = this.namespace) {
|
|
70
|
+
const fk = this.getJunctionForeignKey();
|
|
71
|
+
const junctionRow = await this._junctionModel().findOne({ where: { [fk]: key, tenantId } });
|
|
72
|
+
return junctionRow !== null;
|
|
73
|
+
}
|
|
74
|
+
async existByQuery(tenantId, query, namespace = this.namespace) {
|
|
75
|
+
return await this._model(namespace)
|
|
76
|
+
.findAll(query)
|
|
77
|
+
.then((rows) => rows.length);
|
|
78
|
+
}
|
|
79
|
+
async findAndCount(tenantId, options, namespace = this.namespace) {
|
|
80
|
+
return this._model(namespace).findAndCountAll(options);
|
|
81
|
+
}
|
|
82
|
+
async _create(tenantId, value, _namespace = this.namespace) {
|
|
83
|
+
console.log('!!! _create', tenantId, value, _namespace);
|
|
84
|
+
const saved = await value.save();
|
|
85
|
+
const pk = this._model(_namespace).primaryKeyAttribute;
|
|
86
|
+
const fk = this.getJunctionForeignKey();
|
|
87
|
+
await this._junctionModel().create({ [fk]: saved.get(pk), tenantId });
|
|
88
|
+
return saved;
|
|
89
|
+
}
|
|
90
|
+
async _bulkCreate(tenantId, values, namespace = this.namespace) {
|
|
91
|
+
return (await this._model(namespace).bulkCreate(values));
|
|
92
|
+
}
|
|
93
|
+
async _createByKey(tenantId, value, key, namespace = this.namespace) {
|
|
94
|
+
const model = this._model(namespace);
|
|
95
|
+
const primaryKey = model.primaryKeyAttribute;
|
|
96
|
+
value.setDataValue(primaryKey, key);
|
|
97
|
+
return (await model.create(value.toJSON()));
|
|
98
|
+
}
|
|
99
|
+
async _readOrCreateByQuery(tenantId, query, namespace = this.namespace) {
|
|
100
|
+
return await this._model(namespace)
|
|
101
|
+
.findOrCreate(query)
|
|
102
|
+
.then((result) => [result[0], result[1]]);
|
|
103
|
+
}
|
|
104
|
+
async _updateByKey(tenantId, value, key, namespace = this.namespace) {
|
|
105
|
+
const fk = this.getJunctionForeignKey();
|
|
106
|
+
const junctionRow = await this._junctionModel().findOne({ where: { [fk]: key, tenantId } });
|
|
107
|
+
if (!junctionRow)
|
|
108
|
+
return undefined;
|
|
109
|
+
const model = this._model(namespace);
|
|
110
|
+
const pk = model.primaryKeyAttribute;
|
|
111
|
+
const { tenantId: _ignored, ...safeValue } = value;
|
|
112
|
+
const where = { [pk]: key };
|
|
113
|
+
const row = await model.findOne({ where });
|
|
114
|
+
if (!row)
|
|
115
|
+
return undefined;
|
|
116
|
+
await row.update(safeValue);
|
|
117
|
+
return row.reload();
|
|
118
|
+
}
|
|
119
|
+
async _updateAllByQuery(tenantId, value, query, namespace = this.namespace) {
|
|
120
|
+
const model = this._model(namespace);
|
|
121
|
+
const rows = (await model.findAll(this._injectJunctionInclude(query, tenantId)));
|
|
122
|
+
if (rows.length === 0)
|
|
123
|
+
return [];
|
|
124
|
+
for (const row of rows) {
|
|
125
|
+
await row.update(value);
|
|
126
|
+
}
|
|
127
|
+
return Promise.all(rows.map((r) => r.reload()));
|
|
128
|
+
}
|
|
129
|
+
async _deleteByKey(tenantId, key, namespace = this.namespace) {
|
|
130
|
+
return this.s.transaction(async (transaction) => {
|
|
131
|
+
const fk = this.getJunctionForeignKey();
|
|
132
|
+
const junctionRow = await this._junctionModel().findOne({
|
|
133
|
+
where: { [fk]: key, tenantId },
|
|
134
|
+
transaction,
|
|
135
|
+
});
|
|
136
|
+
if (!junctionRow)
|
|
137
|
+
return undefined;
|
|
138
|
+
await junctionRow.destroy({ transaction });
|
|
139
|
+
const model = this._model(namespace);
|
|
140
|
+
const entryToDelete = (await model.findByPk(key, { transaction }));
|
|
141
|
+
if (entryToDelete) {
|
|
142
|
+
await model.destroy({
|
|
143
|
+
where: { [model.primaryKeyAttribute]: key },
|
|
144
|
+
transaction,
|
|
145
|
+
});
|
|
146
|
+
return entryToDelete;
|
|
147
|
+
}
|
|
148
|
+
else {
|
|
149
|
+
return undefined;
|
|
150
|
+
}
|
|
151
|
+
});
|
|
152
|
+
}
|
|
153
|
+
async _deleteAllByQuery(tenantId, query, namespace = this.namespace) {
|
|
154
|
+
return this.s.transaction(async (transaction) => {
|
|
155
|
+
const model = this._model(namespace);
|
|
156
|
+
const pk = model.primaryKeyAttribute;
|
|
157
|
+
const fk = this.getJunctionForeignKey();
|
|
158
|
+
const entriesToDelete = await model
|
|
159
|
+
.findAll({ ...this._injectJunctionInclude(query, tenantId), transaction })
|
|
160
|
+
.then((rows) => rows);
|
|
161
|
+
if (entriesToDelete.length === 0)
|
|
162
|
+
return [];
|
|
163
|
+
const ids = entriesToDelete.map((e) => e.get(pk));
|
|
164
|
+
await this._junctionModel().destroy({ where: { [fk]: ids }, transaction });
|
|
165
|
+
const deletedCount = await model.destroy({
|
|
166
|
+
where: { [pk]: ids },
|
|
167
|
+
transaction,
|
|
168
|
+
});
|
|
169
|
+
if (entriesToDelete.length === deletedCount) {
|
|
170
|
+
return entriesToDelete;
|
|
171
|
+
}
|
|
172
|
+
else {
|
|
173
|
+
throw new Error(`Deleted ${deletedCount} entries, expected ${entriesToDelete.length}`);
|
|
174
|
+
}
|
|
175
|
+
});
|
|
176
|
+
}
|
|
177
|
+
}
|
|
178
|
+
//# sourceMappingURL=BaseJunction.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"BaseJunction.js","sourceRoot":"","sources":["../../../../src/layers/sequelize/repository/BaseJunction.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import type { BootConfig, BootstrapConfig } from '@citrineos/base';
|
|
2
|
+
import { CrudRepository, OCPP2_0_1 } from '@citrineos/base';
|
|
3
|
+
import type { IBootRepository } from '../../../interfaces/index.js';
|
|
4
|
+
import { Boot } from '../model/Boot.js';
|
|
5
|
+
import { VariableAttribute } from '../model/index.js';
|
|
6
|
+
import { SequelizeRepository } from '../index.js';
|
|
7
|
+
import type { ILogObj } from 'tslog';
|
|
8
|
+
import { Logger } from 'tslog';
|
|
9
|
+
import { Sequelize } from 'sequelize-typescript';
|
|
10
|
+
export declare class SequelizeBootRepository extends SequelizeRepository<Boot> implements IBootRepository {
|
|
11
|
+
variableAttributes: CrudRepository<VariableAttribute>;
|
|
12
|
+
constructor(config: BootstrapConfig, logger?: Logger<ILogObj>, sequelizeInstance?: Sequelize, variableAttributes?: CrudRepository<VariableAttribute>);
|
|
13
|
+
createOrUpdateByKey(tenantId: number, value: BootConfig, key: string): Promise<Boot | undefined>;
|
|
14
|
+
updateStatusByKey(tenantId: number, status: OCPP2_0_1.RegistrationStatusEnumType, statusInfo: OCPP2_0_1.StatusInfoType | undefined, key: string): Promise<Boot | undefined>;
|
|
15
|
+
updateLastBootTimeByKey(tenantId: number, lastBootTime: string, key: string): Promise<Boot | undefined>;
|
|
16
|
+
/**
|
|
17
|
+
* Private Methods
|
|
18
|
+
*/
|
|
19
|
+
private manageSetVariables;
|
|
20
|
+
}
|