@spytecgps/nova-orm 0.0.224 → 0.0.226
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/entities/acumaticaAmazonProduct.js +46 -0
- package/dist/entities/acumaticaImeiIccidData.js +91 -0
- package/dist/entities/acumaticaOrderShipmentDetails.js +61 -0
- package/dist/entities/acumaticaShipment.js +31 -0
- package/dist/entities/acumaticaShipmentAmazon.js +26 -0
- package/dist/entities/aempToken.js +47 -0
- package/dist/entities/alert.js +129 -0
- package/dist/entities/alertMigration.js +115 -0
- package/dist/entities/alertMigrationBatch.js +21 -0
- package/dist/entities/alertTimeWindowConfiguration.js +61 -0
- package/dist/entities/alertType.js +83 -0
- package/dist/entities/appFeatureType.js +36 -0
- package/dist/entities/assetCategory.js +32 -0
- package/dist/entities/billing.js +108 -0
- package/dist/entities/billingCustomerBraintree.js +62 -0
- package/dist/entities/billingDeviceHistory.js +61 -0
- package/dist/entities/billingHubspotPaymentLog.js +256 -0
- package/dist/entities/billingKlarnaCustomer.js +76 -0
- package/dist/entities/billingKlarnaOrder.js +114 -0
- package/dist/entities/billingStatusHistoryBraintree.js +63 -0
- package/dist/entities/billingSubscriptionBraintree.js +229 -0
- package/dist/entities/blacklist.js +51 -0
- package/dist/entities/blacklistType.js +31 -0
- package/dist/entities/boundary.js +119 -0
- package/dist/entities/boundaryEvent.js +105 -0
- package/dist/entities/cellTower.js +66 -0
- package/dist/entities/client.js +153 -0
- package/dist/entities/clientAppFeature.js +47 -0
- package/dist/entities/clientConfiguration.js +47 -0
- package/dist/entities/clientDeviceSetting.js +90 -0
- package/dist/entities/clientType.js +36 -0
- package/dist/entities/country.js +90 -0
- package/dist/entities/customerAttribute.js +52 -0
- package/dist/entities/dataSourceType.js +31 -0
- package/dist/entities/deactivation.js +83 -0
- package/dist/entities/deactivationReason.js +40 -0
- package/dist/entities/device.js +160 -0
- package/dist/entities/deviceAlertConfiguration.js +71 -0
- package/dist/entities/deviceBehavior.js +147 -0
- package/dist/entities/deviceCustomConfiguration.js +67 -0
- package/dist/entities/deviceHistory.js +46 -0
- package/dist/entities/deviceModelListener.js +46 -0
- package/dist/entities/devicePairing.js +67 -0
- package/dist/entities/devicePromotion.js +104 -0
- package/dist/entities/deviceReplacement.js +57 -0
- package/dist/entities/deviceTask.js +44 -0
- package/dist/entities/deviceType.js +149 -0
- package/dist/entities/deviceTypeEvent.js +32 -0
- package/dist/entities/deviceTypeFeature.js +32 -0
- package/dist/entities/deviceTypeFirmware.js +117 -0
- package/dist/entities/entityTag.js +48 -0
- package/dist/entities/entityType.js +31 -0
- package/dist/entities/event.js +36 -0
- package/dist/entities/feature.js +36 -0
- package/dist/entities/firmwareAutoUpgradeBlacklist.js +35 -0
- package/dist/entities/firmwareUpgradeTask.js +105 -0
- package/dist/entities/iccidStatus.js +49 -0
- package/dist/entities/imeiIccidCarrier.js +125 -0
- package/dist/entities/imeiIccidHistory.js +43 -0
- package/dist/entities/index.js +99 -0
- package/dist/entities/industry.js +46 -0
- package/dist/entities/latestPosition.js +100 -0
- package/dist/entities/latestPositionMigration.js +96 -0
- package/dist/entities/latestPositionMigrationBatch.js +21 -0
- package/dist/entities/magento2Gps.js +256 -0
- package/dist/entities/magento2Plan.js +41 -0
- package/dist/entities/mobileNetwork.js +51 -0
- package/dist/entities/notificationRecipient.js +100 -0
- package/dist/entities/organization.js +46 -0
- package/dist/entities/plan.js +86 -0
- package/dist/entities/position.js +102 -0
- package/dist/entities/positionMigration.js +96 -0
- package/dist/entities/positionMigrationBatch.js +21 -0
- package/dist/entities/promotion.js +134 -0
- package/dist/entities/securityRole.js +41 -0
- package/dist/entities/serviceProvider.js +41 -0
- package/dist/entities/serviceProviderProduct.js +61 -0
- package/dist/entities/serviceProviderProductNetwork.js +31 -0
- package/dist/entities/serviceProviderProductType.js +31 -0
- package/dist/entities/sim.js +92 -0
- package/dist/entities/task.js +146 -0
- package/dist/entities/taskSchedule.js +141 -0
- package/dist/entities/trip.js +127 -0
- package/dist/entities/tripCompletionStatus.js +36 -0
- package/dist/entities/tripPosition.js +26 -0
- package/dist/entities/user.js +196 -0
- package/dist/entities/userActivation.js +52 -0
- package/dist/entities/userActivationDevice.js +164 -0
- package/dist/entities/userActivationEvent.js +61 -0
- package/dist/entities/userActivationMetric.js +208 -0
- package/dist/entities/userAlertComplain.js +78 -0
- package/dist/entities/userAlertConfiguration.js +109 -0
- package/dist/entities/userAppFeedback.js +52 -0
- package/dist/entities/userAppIncident.js +176 -0
- package/dist/entities/userConfiguration.js +109 -0
- package/dist/entities/userDataDeletionRequest.js +56 -0
- package/dist/entities/userDeviceBehaviorTask.js +80 -0
- package/dist/entities/userInvitation.js +89 -0
- package/dist/entities/userRatingRequest.js +75 -0
- package/dist/entities/userRegistrationAttempt.js +177 -0
- package/dist/entities/userSecurityRole.js +33 -0
- package/dist/index.js +1 -2
- package/dist/migration/1684483704434-addLowerCaseIndex.js +16 -0
- package/dist/novaDataSource.js +111 -0
- package/dist/repositories/acumatica/getAcumaticaImeiIccidData.js +35 -0
- package/dist/repositories/acumatica/getAcumaticaShipmentDetails.js +50 -0
- package/dist/repositories/acumatica/getLastAcumaticaShipmentDetails.js +27 -0
- package/dist/repositories/acumatica/index.js +52 -0
- package/dist/repositories/aempToken/createAempToken.js +26 -0
- package/dist/repositories/aempToken/deleteAempTokens.js +30 -0
- package/dist/repositories/aempToken/getAempTokens.js +27 -0
- package/dist/repositories/aempToken/index.js +53 -0
- package/dist/repositories/alertTypes/getAlertTypes.js +13 -0
- package/dist/repositories/alertTypes/index.js +18 -0
- package/dist/repositories/alerts/createAlert.js +94 -0
- package/dist/repositories/alerts/createUserAlertComplain.js +26 -0
- package/dist/repositories/alerts/getAlertsReportByClient.js +65 -0
- package/dist/repositories/alerts/getAlertsReportByUser.js +127 -0
- package/dist/repositories/alerts/index.js +104 -0
- package/dist/repositories/appFeatures/createAppFeatureType.js +15 -0
- package/dist/repositories/appFeatures/createClientAppFeature.js +15 -0
- package/dist/repositories/appFeatures/getClientAppFeatures.js +39 -0
- package/dist/repositories/appFeatures/index.js +57 -0
- package/dist/repositories/assetCategories/getAssetCategories.js +8 -0
- package/dist/repositories/assetCategories/index.js +16 -0
- package/dist/repositories/baseRepository.js +9 -0
- package/dist/repositories/billing/createBilling.js +37 -0
- package/dist/repositories/billing/createBillingDeviceHistory.js +30 -0
- package/dist/repositories/billing/createBillingHubspotPaymentLog.js +61 -0
- package/dist/repositories/billing/createBillingStatusHistoryBraintree.js +32 -0
- package/dist/repositories/billing/getBillingCustomerBraintreeById.js +18 -0
- package/dist/repositories/billing/getBillingKlarnaOrderByImei.js +18 -0
- package/dist/repositories/billing/getBillingSubscriptionBraintreeByImei.js +18 -0
- package/dist/repositories/billing/getBillingSubscriptionsBraintree.js +25 -0
- package/dist/repositories/billing/getBillings.js +42 -0
- package/dist/repositories/billing/getCanceledImeis.js +84 -0
- package/dist/repositories/billing/getCanceledImeisMatchingMagentoData.js +100 -0
- package/dist/repositories/billing/getChurnStatusByClientId.js +27 -0
- package/dist/repositories/billing/getClientIdFromBraintreeCustomer.js +20 -0
- package/dist/repositories/billing/getMagentoPlan.js +21 -0
- package/dist/repositories/billing/getUserByBraintreeCustomerId.js +22 -0
- package/dist/repositories/billing/index.js +353 -0
- package/dist/repositories/billing/updateBilling.js +43 -0
- package/dist/repositories/billing/updateBillingCustomerBraintree.js +37 -0
- package/dist/repositories/billing/upsertBillingCustomerBraintree.js +39 -0
- package/dist/repositories/billing/upsertBillingKlarnaCustomer.js +52 -0
- package/dist/repositories/billing/upsertBillingKlarnaOrder.js +58 -0
- package/dist/repositories/billing/upsertBillingSubscriptionBraintree.js +20 -0
- package/dist/repositories/blacklist/getBlacklists.js +19 -0
- package/dist/repositories/blacklist/index.js +19 -0
- package/dist/repositories/boundaries/createBoundary.js +52 -0
- package/dist/repositories/boundaries/deleteBoundary.js +23 -0
- package/dist/repositories/boundaries/getBoundariesByClientId.js +17 -0
- package/dist/repositories/boundaries/getBoundariesIdsByClientId.js +19 -0
- package/dist/repositories/boundaries/getBoundariesReport.js +141 -0
- package/dist/repositories/boundaries/getBoundaryById.js +14 -0
- package/dist/repositories/boundaries/index.js +178 -0
- package/dist/repositories/boundaries/processBoundaryEvent.js +211 -0
- package/dist/repositories/boundaries/updateBoundary.js +53 -0
- package/dist/repositories/boundaries/upsertBoundaryEvent.js +23 -0
- package/dist/repositories/clients/createClient.js +35 -0
- package/dist/repositories/clients/createClientConfiguration.js +18 -0
- package/dist/repositories/clients/createCustomerAttribute.js +16 -0
- package/dist/repositories/clients/deleteClientAndConfiguration.js +25 -0
- package/dist/repositories/clients/getClient.js +32 -0
- package/dist/repositories/clients/getClientConfiguration.js +14 -0
- package/dist/repositories/clients/getClients.js +26 -0
- package/dist/repositories/clients/getCustomerAttribute.js +14 -0
- package/dist/repositories/clients/index.js +192 -0
- package/dist/repositories/clients/updateClient.js +52 -0
- package/dist/repositories/clients/updateClientConfiguration.js +31 -0
- package/dist/repositories/clients/updateCustomerAttribute.js +27 -0
- package/dist/repositories/countries/getCountries.js +14 -0
- package/dist/repositories/countries/getCountry.js +23 -0
- package/dist/repositories/countries/index.js +33 -0
- package/dist/repositories/deactivations/createDeactivation.js +16 -0
- package/dist/repositories/deactivations/getDeactivationReasons.js +24 -0
- package/dist/repositories/deactivations/getLatestDeactivationByImei.js +19 -0
- package/dist/repositories/deactivations/index.js +58 -0
- package/dist/repositories/deviceBehaviors/createDeviceBehaviorTask.js +48 -0
- package/dist/repositories/deviceBehaviors/getDeviceBehaviorTasks.js +40 -0
- package/dist/repositories/deviceBehaviors/getDeviceBehaviors.js +41 -0
- package/dist/repositories/deviceBehaviors/getDeviceBehaviorsByIds.js +16 -0
- package/dist/repositories/deviceBehaviors/getDevicesLastBehaviorTask.js +42 -0
- package/dist/repositories/deviceBehaviors/getLatestDeviceBehaviorTasks.js +40 -0
- package/dist/repositories/deviceBehaviors/index.js +147 -0
- package/dist/repositories/deviceBehaviors/updateDeviceBehaviorTask.js +27 -0
- package/dist/repositories/deviceBehaviors/upsertDeviceBehavior.js +20 -0
- package/dist/repositories/devicePairings/createDevicePairing.js +21 -0
- package/dist/repositories/devicePairings/deleteDevicePairing.js +16 -0
- package/dist/repositories/devicePairings/getDevicePairings.js +36 -0
- package/dist/repositories/devicePairings/getDevicePairingsByImei.js +20 -0
- package/dist/repositories/devicePairings/index.js +90 -0
- package/dist/repositories/devicePairings/updateDevicePairing.js +32 -0
- package/dist/repositories/devices/createClientDeviceSetting.js +25 -0
- package/dist/repositories/devices/createDevice.js +30 -0
- package/dist/repositories/devices/createDeviceReplacement.js +34 -0
- package/dist/repositories/devices/createDeviceType.js +15 -0
- package/dist/repositories/devices/deleteDevice.js +16 -0
- package/dist/repositories/devices/generateDeviceIdentifierKey.js +18 -0
- package/dist/repositories/devices/getCanceledDevicesWithActiveSimCards.js +40 -0
- package/dist/repositories/devices/getCarrierStatusUpdatedBefore.js +40 -0
- package/dist/repositories/devices/getClientDeviceSetting.js +20 -0
- package/dist/repositories/devices/getClientDeviceSettings.js +17 -0
- package/dist/repositories/devices/getDevice.js +33 -0
- package/dist/repositories/devices/getDeviceCustomConfig.js +37 -0
- package/dist/repositories/devices/getDeviceTypeByImei.js +18 -0
- package/dist/repositories/devices/getDeviceTypes.js +30 -0
- package/dist/repositories/devices/getDeviceTypesModelsOrderedByDeviceCount.js +27 -0
- package/dist/repositories/devices/getDeviceWithUsersInfo.js +59 -0
- package/dist/repositories/devices/getDevices.js +46 -0
- package/dist/repositories/devices/getFilteredImeisWithStatus.js +20 -0
- package/dist/repositories/devices/getIccidStatus.js +17 -0
- package/dist/repositories/devices/getImeiIccidCarrier.js +23 -0
- package/dist/repositories/devices/getImeiIccidCarriers.js +17 -0
- package/dist/repositories/devices/index.js +464 -0
- package/dist/repositories/devices/updateClientDeviceSetting.js +38 -0
- package/dist/repositories/devices/updateDevice.js +56 -0
- package/dist/repositories/devices/updateDeviceType.js +43 -0
- package/dist/repositories/devices/updateIccidStatus.js +28 -0
- package/dist/repositories/devices/updateImeiIccidCarrier.js +43 -0
- package/dist/repositories/devices/upsertIccidStatus.js +36 -0
- package/dist/repositories/firmwares/createDeviceFirmware.js +37 -0
- package/dist/repositories/firmwares/createFirmwareAutoUpgradeBlacklist.js +16 -0
- package/dist/repositories/firmwares/createFirmwareUpgradeTask.js +36 -0
- package/dist/repositories/firmwares/getDeviceFirmwares.js +21 -0
- package/dist/repositories/firmwares/getFirmwareAutoUpgradeBlacklist.js +23 -0
- package/dist/repositories/firmwares/getFirmwareUpgradeTasks.js +105 -0
- package/dist/repositories/firmwares/getFirmwareUpgradeTasksCount.js +56 -0
- package/dist/repositories/firmwares/index.js +194 -0
- package/dist/repositories/firmwares/updateDeviceFirmware.js +41 -0
- package/dist/repositories/firmwares/updateFirmwareUpgradeTasks.js +37 -0
- package/dist/repositories/index.js +31 -0
- package/dist/repositories/notificationRecipients/createNotificationRecipient.js +37 -0
- package/dist/repositories/notificationRecipients/deleteNotificationRecipients.js +26 -0
- package/dist/repositories/notificationRecipients/deleteNotificationRecipientsByEmailOrPhone.js +28 -0
- package/dist/repositories/notificationRecipients/getNotificationRecipients.js +16 -0
- package/dist/repositories/notificationRecipients/index.js +131 -0
- package/dist/repositories/notificationRecipients/updateNotificationRecipient.js +37 -0
- package/dist/repositories/notificationRecipients/updateUsersNotificationsUnsubscribedInfoStatus.js +98 -0
- package/dist/repositories/notificationRecipients/updateUsersNotificationsUnsuscribedStatus.js +35 -0
- package/dist/repositories/positions/createPosition.js +100 -0
- package/dist/repositories/positions/getLatestPositionByImei.js +26 -0
- package/dist/repositories/positions/getPositionsByImei.js +23 -0
- package/dist/repositories/positions/getPositionsReportByClient.js +87 -0
- package/dist/repositories/positions/index.js +101 -0
- package/dist/repositories/positions/upsertLatestPosition.js +41 -0
- package/dist/repositories/security/createUserRole.js +30 -0
- package/dist/repositories/security/getAllRoles.js +8 -0
- package/dist/repositories/security/getUserRoles.js +15 -0
- package/dist/repositories/security/getUserRolesByClientId.js +17 -0
- package/dist/repositories/security/index.js +111 -0
- package/dist/repositories/security/removeUserRoles.js +21 -0
- package/dist/repositories/security/updateUserRole.js +27 -0
- package/dist/repositories/security/userIsAdminOrOwner.js +20 -0
- package/dist/repositories/security/userIsInRole.js +18 -0
- package/dist/repositories/tasks/addTaskScheduleDevices.js +37 -0
- package/dist/repositories/tasks/completeTask.js +25 -0
- package/dist/repositories/tasks/createTask.js +22 -0
- package/dist/repositories/tasks/createTaskSchedule.js +33 -0
- package/dist/repositories/tasks/deleteTask.js +22 -0
- package/dist/repositories/tasks/deleteTaskSchedule.js +22 -0
- package/dist/repositories/tasks/deleteTaskScheduleDevices.js +17 -0
- package/dist/repositories/tasks/getDeviceTasks.js +28 -0
- package/dist/repositories/tasks/getTaskSchedule.js +31 -0
- package/dist/repositories/tasks/getTaskSchedules.js +75 -0
- package/dist/repositories/tasks/getTaskSchedulesCount.js +23 -0
- package/dist/repositories/tasks/getTasks.js +29 -0
- package/dist/repositories/tasks/getTasksCount.js +20 -0
- package/dist/repositories/tasks/index.js +441 -0
- package/dist/repositories/tasks/setTaskAsPastDue.js +23 -0
- package/dist/repositories/tasks/setTaskScheduleDevices.js +43 -0
- package/dist/repositories/tasks/updateTask.js +21 -0
- package/dist/repositories/tasks/updateTaskSchedule.js +35 -0
- package/dist/repositories/trips/createTrip.js +29 -0
- package/dist/repositories/trips/getTripById.js +15 -0
- package/dist/repositories/trips/getTrips.js +65 -0
- package/dist/repositories/trips/index.js +69 -0
- package/dist/repositories/trips/updateTripEndValues.js +36 -0
- package/dist/repositories/trips/upsertTrip.js +31 -0
- package/dist/repositories/userActivations/createUserActivation.js +26 -0
- package/dist/repositories/userActivations/createUserActivationDevice.js +35 -0
- package/dist/repositories/userActivations/createUserActivationEvent.js +34 -0
- package/dist/repositories/userActivations/createUserActivationMetric.js +28 -0
- package/dist/repositories/userActivations/deleteUserActivation.js +22 -0
- package/dist/repositories/userActivations/getLastActivationDevice.js +26 -0
- package/dist/repositories/userActivations/getUserActivationDevices.js +24 -0
- package/dist/repositories/userActivations/getUserActivationDevicesByClientId.js +26 -0
- package/dist/repositories/userActivations/getUserActivationMetrics.js +24 -0
- package/dist/repositories/userActivations/getUserActivations.js +29 -0
- package/dist/repositories/userActivations/index.js +229 -0
- package/dist/repositories/userActivations/updateUserActivationDevice.js +39 -0
- package/dist/repositories/userActivations/updateUserActivationMetrics.js +61 -0
- package/dist/repositories/userAppFeedback/createUserAppFeedback.js +26 -0
- package/dist/repositories/userAppFeedback/index.js +23 -0
- package/dist/repositories/userAppIncidents/getUserAppIncidents.js +28 -0
- package/dist/repositories/userAppIncidents/index.js +63 -0
- package/dist/repositories/userAppIncidents/upsertUserAppIncident.js +53 -0
- package/dist/repositories/userConfigurations/bulkCreateUserAlertConfigurations.js +46 -0
- package/dist/repositories/userConfigurations/createDeviceAlertTimeWindows.js +36 -0
- package/dist/repositories/userConfigurations/createUserAlertTimeWindows.js +33 -0
- package/dist/repositories/userConfigurations/createUserConfiguration.js +34 -0
- package/dist/repositories/userConfigurations/deleteDeviceAlertTimeWindows.js +17 -0
- package/dist/repositories/userConfigurations/deleteUserAlertConfigurations.js +24 -0
- package/dist/repositories/userConfigurations/deleteUserAlertTimeWindows.js +17 -0
- package/dist/repositories/userConfigurations/deleteUserConfiguration.js +23 -0
- package/dist/repositories/userConfigurations/getDeviceAlertTimeWindows.js +43 -0
- package/dist/repositories/userConfigurations/getUserAlertConfigurations.js +25 -0
- package/dist/repositories/userConfigurations/getUserAlertTimeWindows.js +35 -0
- package/dist/repositories/userConfigurations/getUserConfigurations.js +31 -0
- package/dist/repositories/userConfigurations/index.js +298 -0
- package/dist/repositories/userConfigurations/updateDeviceAlertTimeWindows.js +29 -0
- package/dist/repositories/userConfigurations/updateUserAlertConfigurations.js +46 -0
- package/dist/repositories/userConfigurations/updateUserAlertTimeWindows.js +28 -0
- package/dist/repositories/userConfigurations/updateUserConfiguration.js +49 -0
- package/dist/repositories/userDataDeletionRequests/createUserDataDeletionRequest.js +28 -0
- package/dist/repositories/userDataDeletionRequests/getUserDataDeletionRequest.js +29 -0
- package/dist/repositories/userDataDeletionRequests/index.js +66 -0
- package/dist/repositories/userDataDeletionRequests/removeUserDataDeletionRequest.js +17 -0
- package/dist/repositories/userDataDeletionRequests/updateUserDataDeletionRequest.js +38 -0
- package/dist/repositories/userInvitations/createUserInvitation.js +43 -0
- package/dist/repositories/userInvitations/getUserInvitationById.js +22 -0
- package/dist/repositories/userInvitations/getUserInvitations.js +31 -0
- package/dist/repositories/userInvitations/index.js +82 -0
- package/dist/repositories/userInvitations/updateUserInvitation.js +50 -0
- package/dist/repositories/userRatingRequests/createUserRatingRequest.js +34 -0
- package/dist/repositories/userRatingRequests/getUserRatingRequests.js +23 -0
- package/dist/repositories/userRatingRequests/index.js +41 -0
- package/dist/repositories/userRegistrationAttempts/createUserRegistrationAttempt.js +40 -0
- package/dist/repositories/userRegistrationAttempts/getUserRegistrationAttempts.js +29 -0
- package/dist/repositories/userRegistrationAttempts/index.js +70 -0
- package/dist/repositories/userRegistrationAttempts/updateUserRegistrationAttempt.js +40 -0
- package/dist/repositories/users/createUser.js +47 -0
- package/dist/repositories/users/deleteAccount.js +98 -0
- package/dist/repositories/users/deleteUser.js +22 -0
- package/dist/repositories/users/getUserById.js +22 -0
- package/dist/repositories/users/getUserData.js +66 -0
- package/dist/repositories/users/getUsers.js +49 -0
- package/dist/repositories/users/getUsersConfigurationByImei.js +29 -0
- package/dist/repositories/users/getUsersIdByPhoneAndCountryCode.js +21 -0
- package/dist/repositories/users/getUsersWithRoles.js +32 -0
- package/dist/repositories/users/index.js +195 -0
- package/dist/repositories/users/updateUser.js +109 -0
- package/dist/subscribers/allEntitiesSubscriber.js +52 -0
- package/dist/subscribers/index.js +2 -0
- package/dist/types/acumatica.js +1 -0
- package/dist/types/aempToken.js +1 -0
- package/dist/types/alert.js +1 -0
- package/dist/types/alertTypes.js +1 -0
- package/dist/types/appFeatures.js +1 -0
- package/dist/types/billing.js +1 -0
- package/dist/types/blacklist.js +1 -0
- package/dist/types/boundaries.js +1 -0
- package/dist/types/clients.js +1 -0
- package/dist/types/common.js +1 -0
- package/dist/types/countries.js +1 -0
- package/dist/types/deactivations.js +1 -0
- package/dist/types/deviceBehaviors.js +1 -0
- package/dist/types/devicePairings.js +1 -0
- package/dist/types/devices.js +1 -0
- package/dist/types/enums.js +74 -0
- package/dist/types/firmwares.js +17 -0
- package/dist/types/index.js +30 -0
- package/dist/types/logger.js +9 -0
- package/dist/types/notificationRecipients.js +1 -0
- package/dist/types/position.js +1 -0
- package/dist/types/security.js +1 -0
- package/dist/types/tasks.js +1 -0
- package/dist/types/trip.js +29 -0
- package/dist/types/user.js +1 -0
- package/dist/types/userActivations.js +1 -0
- package/dist/types/userAppFeedback.js +1 -0
- package/dist/types/userAppIncidents.js +1 -0
- package/dist/types/userConfigurations.js +1 -0
- package/dist/types/userDataDeletionRequests.js +1 -0
- package/dist/types/userInvitations.js +1 -0
- package/dist/types/userRatingRequests.js +1 -0
- package/dist/types/userRegistrationAttempts.js +1 -0
- package/dist/utils/anyAttributeHasValue.js +20 -0
- package/dist/utils/anyAttributeIsNull.js +12 -0
- package/dist/utils/boolToNumberTransformer.js +23 -0
- package/dist/utils/consoleLogger.js +42 -0
- package/dist/utils/filterTools.js +299 -0
- package/dist/utils/mapRawEntityToEntity.js +12 -0
- package/dist/utils/queryLogger.js +48 -0
- package/dist/utils/randomizer.js +39 -0
- package/dist/utils/stringToDateTransformer.js +16 -0
- package/dist/utils/uuidHelpers.js +30 -0
- package/package.json +10 -8
- package/dist/index.js.LICENSE.txt +0 -41
|
@@ -0,0 +1,42 @@
|
|
|
1
|
+
import { Billing } from '../../entities';
|
|
2
|
+
export const getBillings = async (novaDataSource, params, logger) => {
|
|
3
|
+
if (!params?.filters?.imei &&
|
|
4
|
+
!params?.filters?.clientId &&
|
|
5
|
+
!params?.filters?.subscriptionId &&
|
|
6
|
+
!params?.filters?.status) {
|
|
7
|
+
logger.warn({ params }, 'BillingRepository::getBillings - missing required parameters');
|
|
8
|
+
return [];
|
|
9
|
+
}
|
|
10
|
+
return novaDataSource.safeQuery(async (dataSource) => {
|
|
11
|
+
const billingRepository = dataSource.getRepository(Billing);
|
|
12
|
+
let queryBuilder = billingRepository.createQueryBuilder('billing');
|
|
13
|
+
if (params.projectionOptions?.withClient) {
|
|
14
|
+
queryBuilder = queryBuilder.innerJoinAndSelect('billing.client', 'client');
|
|
15
|
+
}
|
|
16
|
+
if (params.projectionOptions?.withPlan) {
|
|
17
|
+
queryBuilder = queryBuilder.leftJoinAndSelect('billing.plan', 'plan');
|
|
18
|
+
}
|
|
19
|
+
if (params.filters.imei) {
|
|
20
|
+
queryBuilder = queryBuilder.where(`billing.imei = :imei`, {
|
|
21
|
+
imei: params.filters.imei,
|
|
22
|
+
});
|
|
23
|
+
}
|
|
24
|
+
if (params.filters.clientId) {
|
|
25
|
+
queryBuilder = queryBuilder.where(`billing.clientId = :clientId`, {
|
|
26
|
+
clientId: params.filters.clientId,
|
|
27
|
+
});
|
|
28
|
+
}
|
|
29
|
+
if (params.filters.subscriptionId) {
|
|
30
|
+
queryBuilder = queryBuilder.where(`billing.subscriptionId = :subscriptionId`, {
|
|
31
|
+
subscriptionId: params.filters.subscriptionId,
|
|
32
|
+
});
|
|
33
|
+
}
|
|
34
|
+
if (params.filters.status) {
|
|
35
|
+
queryBuilder = queryBuilder.where(`billing.status = :status`, {
|
|
36
|
+
status: params.filters.status,
|
|
37
|
+
});
|
|
38
|
+
}
|
|
39
|
+
const result = await queryBuilder.getMany();
|
|
40
|
+
return result;
|
|
41
|
+
}, 'BillingRepository::getBillings');
|
|
42
|
+
};
|
|
@@ -0,0 +1,84 @@
|
|
|
1
|
+
import { Enums } from '../..';
|
|
2
|
+
import { Billing, BillingSubscriptionBraintree, Client, Device, IccidStatus, ImeiIccidCarrier, } from '../../entities';
|
|
3
|
+
export const getCanceledImeis = async (novaDataSource, params, logger) => {
|
|
4
|
+
if (!params?.filters?.minCancellationDate ||
|
|
5
|
+
!params?.filters?.maxCancellationDate ||
|
|
6
|
+
!params?.filters?.canceledIn ||
|
|
7
|
+
params?.filters?.excludeB2B == null ||
|
|
8
|
+
params?.filters?.excludeTest == null) {
|
|
9
|
+
logger.warn({ params }, 'BillingRepository::getCanceledImeis - missing required parameters');
|
|
10
|
+
return [];
|
|
11
|
+
}
|
|
12
|
+
return novaDataSource.safeQuery(async (dataSource) => {
|
|
13
|
+
const billingRepository = dataSource.getRepository(Billing);
|
|
14
|
+
let queryBuilder = billingRepository
|
|
15
|
+
.createQueryBuilder('billing')
|
|
16
|
+
.innerJoin(BillingSubscriptionBraintree, 'billingSubscriptionBraintree', 'billingSubscriptionBraintree.subscriptionId = billing.subscriptionId')
|
|
17
|
+
.innerJoin(ImeiIccidCarrier, 'imeiIccidCarrier', 'imeiIccidCarrier.imei = billing.imei')
|
|
18
|
+
.innerJoin(Device, 'device', 'device.imei = billing.imei')
|
|
19
|
+
.innerJoin(Client, 'client', 'client.id = device.clientId')
|
|
20
|
+
.innerJoin(IccidStatus, 'iccidStatus', 'iccidStatus.iccid = imeiIccidCarrier.iccid')
|
|
21
|
+
.where(`iccidStatus.processing = :processing`, {
|
|
22
|
+
processing: false,
|
|
23
|
+
})
|
|
24
|
+
.andWhere(`billingSubscriptionBraintree.updatedAt > :minCancellationDate`, {
|
|
25
|
+
minCancellationDate: params.filters.minCancellationDate,
|
|
26
|
+
})
|
|
27
|
+
.andWhere(`billingSubscriptionBraintree.updatedAt < :maxCancellationDate`, {
|
|
28
|
+
maxCancellationDate: params.filters.maxCancellationDate,
|
|
29
|
+
})
|
|
30
|
+
.andWhere(`billingSubscriptionBraintree.status = :subscriptionStatus`, {
|
|
31
|
+
subscriptionStatus: 'Canceled',
|
|
32
|
+
})
|
|
33
|
+
.andWhere(`billingSubscriptionBraintree.nextBillingDate < :nextBillingDate`, {
|
|
34
|
+
nextBillingDate: new Date(),
|
|
35
|
+
});
|
|
36
|
+
switch (params.filters.canceledIn) {
|
|
37
|
+
case 'carrier': {
|
|
38
|
+
queryBuilder = queryBuilder.andWhere(`iccidStatus.status = :iccidStatus`, {
|
|
39
|
+
iccidStatus: 'active',
|
|
40
|
+
});
|
|
41
|
+
break;
|
|
42
|
+
}
|
|
43
|
+
case 'device': {
|
|
44
|
+
queryBuilder = queryBuilder.andWhere(`device.status = :deviceStatus`, {
|
|
45
|
+
deviceStatus: 'A',
|
|
46
|
+
});
|
|
47
|
+
break;
|
|
48
|
+
}
|
|
49
|
+
default: {
|
|
50
|
+
queryBuilder = queryBuilder.andWhere(`(iccidStatus.status = :iccidStatus OR device.status = :deviceStatus)`, {
|
|
51
|
+
iccidStatus: 'active',
|
|
52
|
+
deviceStatus: 'A',
|
|
53
|
+
});
|
|
54
|
+
break;
|
|
55
|
+
}
|
|
56
|
+
}
|
|
57
|
+
if (params.filters.excludeB2B) {
|
|
58
|
+
queryBuilder = queryBuilder.andWhere(`client.clientTypeId != :b2bClientTypeId`, {
|
|
59
|
+
b2bClientTypeId: Enums.HapnClientType.b2b,
|
|
60
|
+
});
|
|
61
|
+
}
|
|
62
|
+
if (params.filters.excludeTest) {
|
|
63
|
+
queryBuilder = queryBuilder.andWhere(`client.clientTypeId != :testClientTypeId`, {
|
|
64
|
+
testClientTypeId: Enums.HapnClientType.test,
|
|
65
|
+
});
|
|
66
|
+
}
|
|
67
|
+
const result = await queryBuilder
|
|
68
|
+
.orderBy('billingSubscriptionBraintree.updatedAt', 'ASC')
|
|
69
|
+
.limit(params.pagingOptions?.pageSize ?? 100)
|
|
70
|
+
.select([
|
|
71
|
+
'billing.imei as imei',
|
|
72
|
+
'imeiIccidCarrier.iccid as iccid',
|
|
73
|
+
'client.id as clientId',
|
|
74
|
+
'client.clientTypeId as clientTypeId',
|
|
75
|
+
'billing.subscriptionId as subscriptionId',
|
|
76
|
+
'billingSubscriptionBraintree.createdAt as createdAt',
|
|
77
|
+
'billingSubscriptionBraintree.updatedAt as updatedAt',
|
|
78
|
+
'billingSubscriptionBraintree.status as status',
|
|
79
|
+
'imeiIccidCarrier.carrier as carrier',
|
|
80
|
+
])
|
|
81
|
+
.getRawMany();
|
|
82
|
+
return result;
|
|
83
|
+
}, 'BillingRepository::getCanceledImeis');
|
|
84
|
+
};
|
|
@@ -0,0 +1,100 @@
|
|
|
1
|
+
import { Enums } from '../..';
|
|
2
|
+
import { Billing } from '../../entities';
|
|
3
|
+
export const getCanceledImeisMatchingMagentoData = async (novaDataSource, params, logger) => {
|
|
4
|
+
if (!params?.filters?.minCancellationDate ||
|
|
5
|
+
!params?.filters?.maxCancellationDate ||
|
|
6
|
+
!params?.filters?.canceledIn ||
|
|
7
|
+
params?.filters?.excludeB2B == null ||
|
|
8
|
+
params?.filters?.excludeTest == null) {
|
|
9
|
+
logger.warn({ params }, 'BillingRepository::getCanceledImeisMatchingMagentoData - missing required parameters');
|
|
10
|
+
return [];
|
|
11
|
+
}
|
|
12
|
+
return novaDataSource.safeQuery(async (dataSource) => {
|
|
13
|
+
const billingRepository = dataSource.getRepository(Billing);
|
|
14
|
+
let simStatusCondition = '';
|
|
15
|
+
switch (params.filters.canceledIn) {
|
|
16
|
+
case 'carrier': {
|
|
17
|
+
simStatusCondition = ` AND iccidStatus.status = 'active' `;
|
|
18
|
+
break;
|
|
19
|
+
}
|
|
20
|
+
case 'device': {
|
|
21
|
+
simStatusCondition = ` AND device.status = 'A' `;
|
|
22
|
+
break;
|
|
23
|
+
}
|
|
24
|
+
default: {
|
|
25
|
+
simStatusCondition = ` AND (iccidStatus.status = 'active' OR device.status = 'A') `;
|
|
26
|
+
break;
|
|
27
|
+
}
|
|
28
|
+
}
|
|
29
|
+
const excludeB2bCondition = params.filters.excludeB2B
|
|
30
|
+
? `AND client.clientTypeId != ${Enums.HapnClientType.b2b} `
|
|
31
|
+
: '';
|
|
32
|
+
const excludeTestCondition = params.filters.excludeTest
|
|
33
|
+
? `AND client.clientTypeId != ${Enums.HapnClientType.test} `
|
|
34
|
+
: '';
|
|
35
|
+
const query = `SELECT
|
|
36
|
+
billing.imei,
|
|
37
|
+
imeiIccidCarrier.iccid,
|
|
38
|
+
client.id as clientId,
|
|
39
|
+
client.clientTypeId,
|
|
40
|
+
client.email,
|
|
41
|
+
billing.subscriptionId,
|
|
42
|
+
billingSubscriptionBraintree.createdAt,
|
|
43
|
+
billingSubscriptionBraintree.updatedAt,
|
|
44
|
+
billingSubscriptionBraintree.status,
|
|
45
|
+
imeiIccidCarrier.carrier
|
|
46
|
+
FROM
|
|
47
|
+
billing
|
|
48
|
+
INNER JOIN
|
|
49
|
+
billingSubscriptionBraintree ON billing.subscriptionId = billingSubscriptionBraintree.subscriptionId
|
|
50
|
+
INNER JOIN
|
|
51
|
+
imeiIccidCarrier ON imeiIccidCarrier.imei = billing.imei
|
|
52
|
+
INNER JOIN
|
|
53
|
+
device ON device.imei = billing.imei
|
|
54
|
+
INNER JOIN
|
|
55
|
+
client ON client.id = device.clientId
|
|
56
|
+
INNER JOIN
|
|
57
|
+
iccidStatus ON iccidStatus.iccid = imeiIccidCarrier.iccid
|
|
58
|
+
WHERE
|
|
59
|
+
iccidStatus.processing = false AND
|
|
60
|
+
billingSubscriptionBraintree.updatedAt > ? AND
|
|
61
|
+
billingSubscriptionBraintree.updatedAt < ? AND
|
|
62
|
+
billingSubscriptionBraintree.status = 'Canceled' AND
|
|
63
|
+
billingSubscriptionBraintree.nextBillingDate < ? AND
|
|
64
|
+
client.id NOT IN (128, 686142) AND
|
|
65
|
+
(EXISTS (SELECT 1 FROM
|
|
66
|
+
(SELECT
|
|
67
|
+
magento2Gps1.imei,
|
|
68
|
+
billingSubscriptionBraintree2.subscriptionId,
|
|
69
|
+
row_number() OVER (PARTITION BY magento2Gps1.imei ORDER BY billingSubscriptionBraintree2.subscriptionStart DESC) AS row_rank
|
|
70
|
+
FROM magento2Gps magento2Gps1
|
|
71
|
+
INNER JOIN billingSubscriptionBraintree billingSubscriptionBraintree2 ON billingSubscriptionBraintree2.subscriptionId = magento2Gps1.btSubscriptionId) ls
|
|
72
|
+
WHERE ls.imei = billing.imei AND billing.subscriptionId = ls.subscriptionId AND ls.row_rank = 1)
|
|
73
|
+
OR
|
|
74
|
+
NOT EXISTS (SELECT 1 FROM magento2Gps magento2Gps2 WHERE magento2Gps2.imei = billing.imei)
|
|
75
|
+
OR
|
|
76
|
+
EXISTS (SELECT 1 FROM magento2Gps magento2Gps3 WHERE magento2Gps3.imei = billing.imei AND magento2Gps3.btSubscriptionId IS NULL))
|
|
77
|
+
${simStatusCondition}
|
|
78
|
+
${excludeB2bCondition}
|
|
79
|
+
${excludeTestCondition}
|
|
80
|
+
ORDER BY billingSubscriptionBraintree.updatedAt ASC
|
|
81
|
+
LIMIT ?`;
|
|
82
|
+
const result = await billingRepository.query(query, [
|
|
83
|
+
params.filters.minCancellationDate,
|
|
84
|
+
params.filters.maxCancellationDate,
|
|
85
|
+
new Date(),
|
|
86
|
+
params.pagingOptions.pageSize ?? 100,
|
|
87
|
+
]);
|
|
88
|
+
return result.map(item => ({
|
|
89
|
+
imei: item.imei,
|
|
90
|
+
iccid: item.iccid,
|
|
91
|
+
clientId: item.clientId,
|
|
92
|
+
clientTypeId: item.clientTypeId,
|
|
93
|
+
subscriptionId: item.subscriptionId,
|
|
94
|
+
createdAt: item.createdAt,
|
|
95
|
+
updatedAt: item.updatedAt,
|
|
96
|
+
status: item.status,
|
|
97
|
+
carrier: item.carrier,
|
|
98
|
+
}));
|
|
99
|
+
}, 'BillingRepository::getCanceledImeisMatchingMagentoData');
|
|
100
|
+
};
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
import { Billing, BillingCustomerBraintree, BillingSubscriptionBraintree } from '../../entities';
|
|
2
|
+
export const getChurnStatusByClientId = async (novaDataSource, params, logger) => {
|
|
3
|
+
if (!params?.filters?.clientId) {
|
|
4
|
+
logger.warn({ params }, 'BillingRepository::getChurnStatusByClientId - missing required parameters');
|
|
5
|
+
return [];
|
|
6
|
+
}
|
|
7
|
+
return novaDataSource.safeQuery(async (dataSource) => {
|
|
8
|
+
const billingRepository = dataSource.getRepository(Billing);
|
|
9
|
+
const queryBuilder = billingRepository
|
|
10
|
+
.createQueryBuilder('billing')
|
|
11
|
+
.where(`billing.clientId = :clientId`, {
|
|
12
|
+
clientId: params.filters.clientId,
|
|
13
|
+
})
|
|
14
|
+
.innerJoinAndSelect(BillingSubscriptionBraintree, 'billingSubscriptionBraintree', 'billingSubscriptionBraintree.subscriptionId = billing.subscriptionId')
|
|
15
|
+
.innerJoinAndSelect(BillingCustomerBraintree, 'billingCustomerBraintree', 'billingCustomerBraintree.id = billingSubscriptionBraintree.customerId')
|
|
16
|
+
.groupBy('billingCustomerBraintree.id, billingSubscriptionBraintree.status, billingSubscriptionBraintree.subscriptionId')
|
|
17
|
+
.select([
|
|
18
|
+
'billingCustomerBraintree.id as braintreeCustomerId',
|
|
19
|
+
'billingSubscriptionBraintree.status as braintreeSubscriptionStatus',
|
|
20
|
+
'billingSubscriptionBraintree.subscriptionId as subscriptionId',
|
|
21
|
+
'billingCustomerBraintree.churnStatus as churnStatus',
|
|
22
|
+
])
|
|
23
|
+
.distinct();
|
|
24
|
+
const result = await queryBuilder.getRawMany();
|
|
25
|
+
return result;
|
|
26
|
+
}, 'BillingRepository::getChurnStatusByClientId');
|
|
27
|
+
};
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import { Billing, BillingSubscriptionBraintree } from '../../entities';
|
|
2
|
+
export const getClientIdFromBraintreeCustomer = async (novaDataSource, params, logger) => {
|
|
3
|
+
if (!params?.filters?.customerId) {
|
|
4
|
+
logger.warn({ params }, 'BillingRepository::getClientIdFromBraintreeCustomer - missing required parameters');
|
|
5
|
+
return null;
|
|
6
|
+
}
|
|
7
|
+
return novaDataSource.safeQuery(async (dataSource) => {
|
|
8
|
+
const billingRepository = dataSource.getRepository(Billing);
|
|
9
|
+
const queryBuilder = billingRepository
|
|
10
|
+
.createQueryBuilder('billing')
|
|
11
|
+
.innerJoin(BillingSubscriptionBraintree, 'billingSubscriptionBraintree', 'billing.subscriptionId = billingSubscriptionBraintree.subscriptionId')
|
|
12
|
+
.where(`billingSubscriptionBraintree.customerId = :customerId`, {
|
|
13
|
+
customerId: params.filters.customerId,
|
|
14
|
+
})
|
|
15
|
+
.select('distinct billing.clientId', 'clientId')
|
|
16
|
+
.limit(1);
|
|
17
|
+
const result = await queryBuilder.getRawOne();
|
|
18
|
+
return result?.clientId ?? null;
|
|
19
|
+
}, 'BillingRepository::getClientIdFromBraintreeCustomer');
|
|
20
|
+
};
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
import { Magento2Plan } from '../../entities';
|
|
2
|
+
export const getMagentoPlan = async (novaDataSource, params, logger) => {
|
|
3
|
+
if (params?.filters?.annual == null || !params?.filters?.code) {
|
|
4
|
+
logger.warn({ params }, 'BillingRepository::getMagentoPlan - missing required parameters');
|
|
5
|
+
return null;
|
|
6
|
+
}
|
|
7
|
+
return novaDataSource.safeQuery(async (dataSource) => {
|
|
8
|
+
const magento2PlanRepository = dataSource.getRepository(Magento2Plan);
|
|
9
|
+
const queryBuilder = magento2PlanRepository
|
|
10
|
+
.createQueryBuilder('plan')
|
|
11
|
+
.where(`plan.planAnnual = :planAnnual`, {
|
|
12
|
+
planAnnual: params.filters.annual,
|
|
13
|
+
})
|
|
14
|
+
.andWhere(`plan.magentoPlanCode = :magentoPlanCode`, {
|
|
15
|
+
magentoPlanCode: params.filters.code,
|
|
16
|
+
})
|
|
17
|
+
.limit(1);
|
|
18
|
+
const result = await queryBuilder.getOne();
|
|
19
|
+
return result;
|
|
20
|
+
}, 'BillingRepository::getMagentoPlan');
|
|
21
|
+
};
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
import { Billing, BillingCustomerBraintree, BillingSubscriptionBraintree, User, } from '../../entities';
|
|
2
|
+
export const getUserByBraintreeCustomerId = async (novaDataSource, params, logger) => {
|
|
3
|
+
if (!params?.filters?.customerId) {
|
|
4
|
+
logger.warn({ params }, 'BillingRepository::getUserByBraintreeCustomerId - missing required parameters');
|
|
5
|
+
return null;
|
|
6
|
+
}
|
|
7
|
+
return novaDataSource.safeQuery(async (dataSource) => {
|
|
8
|
+
const userRepository = dataSource.getRepository(User);
|
|
9
|
+
const queryBuilder = userRepository
|
|
10
|
+
.createQueryBuilder('user')
|
|
11
|
+
.innerJoin(BillingCustomerBraintree, 'billingCustomerBraintree', 'LOWER(TRIM(billingCustomerBraintree.email)) = LOWER(TRIM(user.email))')
|
|
12
|
+
.innerJoin(BillingSubscriptionBraintree, 'billingSubscriptionBraintree', 'billingCustomerBraintree.id = billingSubscriptionBraintree.customerId')
|
|
13
|
+
.innerJoin(Billing, 'billing', 'billing.subscriptionId = billingSubscriptionBraintree.subscriptionId')
|
|
14
|
+
.where(`billingCustomerBraintree.id = :id`, {
|
|
15
|
+
id: params.filters.customerId,
|
|
16
|
+
})
|
|
17
|
+
.orderBy('billingCustomerBraintree.createdAt', 'ASC')
|
|
18
|
+
.limit(1);
|
|
19
|
+
const result = await queryBuilder.getOne();
|
|
20
|
+
return result;
|
|
21
|
+
}, 'BillingRepository::getUserByBraintreeCustomerId');
|
|
22
|
+
};
|