iotagent-node-lib 2.17.0 → 2.20.0
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/.github/workflows/ci.yml +17 -2
- package/.nyc_output/76bc24ff-5fac-4b5a-997d-de2799342eb0.json +1 -0
- package/.nyc_output/processinfo/76bc24ff-5fac-4b5a-997d-de2799342eb0.json +1 -0
- package/.nyc_output/processinfo/index.json +1 -1
- package/CHANGES_NEXT_RELEASE +1 -0
- package/README.md +3 -54
- package/doc/advanced-topics.md +121 -85
- package/doc/api.md +52 -52
- package/doc/development.md +13 -6
- package/doc/expressionLanguage.md +514 -312
- package/doc/installationguide.md +66 -64
- package/doc/usermanual.md +48 -16
- package/docker/Mosquitto/Dockerfile +1 -0
- package/docker/Mosquitto/README.md +1 -0
- package/docker/Mosquitto/startMosquitto.sh +9 -4
- package/lib/commonConfig.js +1 -14
- package/lib/errors.js +0 -16
- package/lib/fiware-iotagent-lib.js +4 -2
- package/lib/jexlTranformsMap.js +13 -2
- package/lib/model/Device.js +4 -1
- package/lib/model/Group.js +19 -1
- package/lib/plugins/attributeAlias.js +6 -13
- package/lib/plugins/bidirectionalData.js +1 -21
- package/lib/plugins/expressionParser.js +7 -6
- package/lib/plugins/expressionPlugin.js +11 -25
- package/lib/plugins/jexlParser.js +8 -4
- package/lib/plugins/multiEntity.js +54 -145
- package/lib/plugins/pluginUtils.js +12 -48
- package/lib/plugins/timestampProcessPlugin.js +1 -46
- package/lib/request-shim.js +111 -0
- package/lib/services/common/domain.js +6 -2
- package/lib/services/common/genericMiddleware.js +6 -2
- package/lib/services/common/iotManagerService.js +1 -1
- package/lib/services/common/securityServiceKeystone.js +1 -1
- package/lib/services/common/securityServiceOAuth2.js +3 -2
- package/lib/services/devices/deviceRegistryMongoDB.js +2 -0
- package/lib/services/devices/deviceService.js +2 -5
- package/lib/services/devices/devices-NGSI-LD.js +1 -1
- package/lib/services/devices/devices-NGSI-v2.js +4 -8
- package/lib/services/devices/registrationUtils.js +1 -134
- package/lib/services/ngsi/entities-NGSI-LD.js +205 -124
- package/lib/services/ngsi/entities-NGSI-v2.js +109 -15
- package/lib/services/ngsi/ngsiService.js +4 -6
- package/lib/services/ngsi/ngsiUtils.js +0 -36
- package/lib/services/ngsi/subscriptionService.js +1 -4
- package/lib/services/northBound/contextServer-NGSI-LD.js +7 -2
- package/lib/services/northBound/contextServer-NGSI-v2.js +24 -12
- package/lib/services/northBound/contextServer.js +1 -4
- package/lib/services/northBound/contextServerUtils.js +0 -81
- package/lib/services/northBound/deviceProvisioningServer.js +31 -7
- package/lib/services/northBound/northboundServer.js +2 -0
- package/lib/services/northBound/restUtils.js +1 -38
- package/lib/templates/updateDevice.json +4 -0
- package/lib/templates/updateDeviceLax.json +4 -0
- package/package.json +10 -16
- package/test/tools/utils.js +2 -0
- package/test/unit/examples/groupProvisioningRequests/multipleGroupsCreation.json +1 -1
- package/test/unit/expressions/jexlExpression-test.js +44 -5
- package/test/unit/general/contextBrokerKeystoneSecurityAccess-test.js +19 -66
- package/test/unit/general/deviceService-test.js +11 -27
- package/test/unit/general/loglevel-api_test.js +6 -11
- package/test/unit/general/startup-test.js +2 -1
- package/test/unit/memoryRegistry/deviceRegistryMemory_test.js +8 -16
- package/test/unit/mongodb/mongodb-group-registry-test.js +1 -1
- package/test/unit/mongodb/mongodb-registry-test.js +38 -114
- package/test/unit/ngsi-ld/examples/contextRequests/createMinimumProvisionedDevice.json +0 -7
- package/test/unit/ngsi-ld/examples/contextRequests/createProvisionedDevice.json +0 -7
- package/test/unit/ngsi-ld/examples/contextRequests/createProvisionedDeviceMultientity.json +0 -7
- package/test/unit/ngsi-ld/examples/contextRequests/createProvisionedDeviceWithGroupAndStatic.json +0 -14
- package/test/unit/ngsi-ld/examples/contextRequests/createProvisionedDeviceWithGroupAndStatic2.json +0 -14
- package/test/unit/ngsi-ld/examples/contextRequests/createProvisionedDeviceWithGroupAndStatic3.json +1 -15
- package/test/unit/ngsi-ld/examples/contextRequests/createTimeInstantMinimumDevice.json +0 -7
- package/test/unit/ngsi-ld/examples/contextRequests/updateContextAliasPlugin6.json +0 -7
- package/test/unit/ngsi-ld/examples/contextRequests/updateContextAutocast5.json +0 -7
- package/test/unit/ngsi-ld/examples/contextRequests/updateContextExpressionPlugin12a.json +7 -0
- package/test/unit/ngsi-ld/examples/contextRequests/updateContextExpressionPlugin13.json +13 -13
- package/test/unit/ngsi-ld/examples/contextRequests/updateContextExpressionPlugin16.json +0 -7
- package/test/unit/ngsi-ld/examples/contextRequests/updateContextExpressionPlugin17.json +0 -7
- package/test/unit/ngsi-ld/examples/contextRequests/updateContextExpressionPlugin1a.json +18 -0
- package/test/unit/ngsi-ld/examples/contextRequests/updateContextExpressionPlugin29.json +18 -0
- package/test/unit/ngsi-ld/examples/contextRequests/updateContextExpressionPlugin31.json +15 -0
- package/test/unit/ngsi-ld/examples/contextRequests/updateContextExpressionPlugin32.json +17 -0
- package/test/unit/ngsi-ld/examples/contextRequests/updateContextExpressionPlugin33.json +18 -0
- package/test/unit/ngsi-ld/examples/contextRequests/updateContextExpressionPlugin34.json +17 -0
- package/test/unit/ngsi-ld/examples/contextRequests/updateContextExpressionPlugin4a.json +36 -0
- package/test/unit/ngsi-ld/examples/contextRequests/updateContextExpressionPlugin5.json +0 -7
- package/test/unit/ngsi-ld/examples/contextRequests/updateContextExpressionPlugin7.json +16 -16
- package/test/unit/ngsi-ld/examples/contextRequests/updateContextExpressionPlugin8a.json +18 -0
- package/test/unit/ngsi-ld/examples/contextRequests/updateContextGeoproperties3.json +0 -7
- package/test/unit/ngsi-ld/examples/contextRequests/updateContextMultientityPlugin15.json +25 -0
- package/test/unit/ngsi-ld/examples/contextRequests/updateContextMultientityTimestampPlugin1.json +6 -6
- package/test/unit/ngsi-ld/examples/contextRequests/updateContextMultientityTimestampPlugin2.json +3 -3
- package/test/unit/ngsi-ld/examples/contextRequests/updateProvisionActiveAttributes1.json +0 -7
- package/test/unit/ngsi-ld/examples/contextRequests/updateProvisionCommands1.json +0 -7
- package/test/unit/ngsi-ld/examples/contextRequests/updateProvisionDeviceStatic.json +0 -7
- package/test/unit/ngsi-ld/examples/contextRequests/updateProvisionMinimumDevice.json +0 -7
- package/test/unit/ngsi-ld/expressions/jexlBasedTransformations-test.js +1018 -0
- package/test/unit/ngsi-ld/general/contextBrokerOAuthSecurityAccess-test.js +2 -2
- package/test/unit/ngsi-ld/general/deviceService-test.js +1 -1
- package/test/unit/ngsi-ld/general/https-support-test.js +2 -1
- package/test/unit/ngsi-ld/general/iotam-autoregistration-test.js +2 -1
- package/test/unit/ngsi-ld/general/startup-test.js +1 -0
- package/test/unit/ngsi-ld/lazyAndCommands/active-devices-attribute-update-test.js +3 -1
- package/test/unit/ngsi-ld/lazyAndCommands/command-test.js +2 -1
- package/test/unit/ngsi-ld/lazyAndCommands/lazy-devices-test.js +2 -6
- package/test/unit/ngsi-ld/lazyAndCommands/polling-commands-test.js +2 -1
- package/test/unit/ngsi-ld/ngsiService/active-devices-test.js +1 -0
- package/test/unit/ngsi-ld/ngsiService/autocast-test.js +1 -0
- package/test/unit/ngsi-ld/ngsiService/geoproperties-test.js +1 -0
- package/test/unit/ngsi-ld/ngsiService/subscriptions-test.js +4 -3
- package/test/unit/ngsi-ld/plugins/alias-plugin_test.js +1 -0
- package/test/unit/ngsi-ld/plugins/bidirectional-plugin_test.js +3 -2
- package/test/unit/ngsi-ld/plugins/multientity-plugin_test.js +61 -0
- package/test/unit/ngsi-ld/provisioning/device-provisioning-api_test.js +2 -1
- package/test/unit/ngsi-ld/provisioning/device-registration_test.js +3 -2
- package/test/unit/ngsi-ld/provisioning/device-update-registration_test.js +1 -0
- package/test/unit/ngsi-ld/provisioning/listProvisionedDevices-test.js +42 -54
- package/test/unit/ngsi-ld/provisioning/provisionDeviceMultientity-test.js +2 -1
- package/test/unit/ngsi-ld/provisioning/removeProvisionedDevice-test.js +4 -4
- package/test/unit/ngsi-ld/provisioning/singleConfigurationMode-test.js +3 -5
- package/test/unit/ngsi-ld/provisioning/updateProvisionedDevices-test.js +12 -18
- package/test/unit/ngsi-mixed/provisioning/ngsi-versioning-test.js +3 -1
- package/test/unit/ngsiv2/examples/contextAvailabilityRequests/registerIoTAgent3.json +19 -0
- package/test/unit/ngsiv2/examples/contextAvailabilityRequests/registerIoTAgent5.json +19 -0
- package/test/unit/ngsiv2/examples/contextRequests/updateContextExpressionPlugin17.json +1 -1
- package/test/unit/ngsiv2/examples/contextRequests/updateContextExpressionPlugin29.json +22 -0
- package/test/unit/ngsiv2/examples/contextRequests/updateContextExpressionPlugin30.json +6 -0
- package/test/unit/ngsiv2/examples/contextRequests/updateContextExpressionPlugin31.json +18 -0
- package/test/unit/ngsiv2/examples/contextRequests/updateContextExpressionPlugin32.json +16 -0
- package/test/unit/ngsiv2/examples/contextRequests/updateContextExpressionPlugin33.json +22 -0
- package/test/unit/ngsiv2/examples/contextRequests/updateContextExpressionPlugin34.json +12 -0
- package/test/unit/ngsiv2/examples/contextRequests/updateContextMiddleware1.json +10 -0
- package/test/unit/ngsiv2/examples/contextRequests/updateContextMiddleware2.json +10 -0
- package/test/unit/ngsiv2/examples/contextRequests/updateContextMultientityPlugin11.json +13 -0
- package/test/unit/ngsiv2/examples/contextRequests/updateContextMultientityPlugin12.json +33 -0
- package/test/unit/ngsiv2/examples/contextRequests/updateContextMultientityPlugin13.json +33 -0
- package/test/unit/ngsiv2/examples/contextRequests/updateContextMultientityPlugin14.json +33 -0
- package/test/unit/ngsiv2/examples/contextRequests/updateContextMultientityPlugin15.json +25 -0
- package/test/unit/ngsiv2/examples/contextRequests/updateContextMultientityPlugin16.json +25 -0
- package/test/unit/ngsiv2/examples/contextRequests/updateContextMultientityTimestampPlugin1.json +6 -6
- package/test/unit/ngsiv2/examples/contextRequests/updateContextMultientityTimestampPlugin2.json +3 -3
- package/test/unit/{examples → ngsiv2/examples}/contextRequests/updateProvisionDevice.json +0 -0
- package/test/unit/ngsiv2/expressions/expressionBasedTransformations-test.js +37 -4
- package/test/unit/ngsiv2/expressions/jexlBasedTransformations-test.js +598 -0
- package/test/unit/ngsiv2/general/contextBrokerOAuthSecurityAccess-test.js +3 -2
- package/test/unit/ngsiv2/general/deviceService-test.js +9 -8
- package/test/unit/ngsiv2/general/https-support-test.js +2 -1
- package/test/unit/ngsiv2/general/iotam-autoregistration-test.js +2 -1
- package/test/unit/ngsiv2/general/startup-test.js +1 -0
- package/test/unit/ngsiv2/lazyAndCommands/active-devices-attribute-update-test.js +3 -1
- package/test/unit/ngsiv2/lazyAndCommands/command-test.js +2 -1
- package/test/unit/ngsiv2/lazyAndCommands/lazy-devices-test.js +287 -15
- package/test/unit/ngsiv2/lazyAndCommands/polling-commands-test.js +3 -1
- package/test/unit/ngsiv2/ngsiService/active-devices-test.js +88 -0
- package/test/unit/{ngsiService → ngsiv2/ngsiService}/queryDeviceInformationInCb-test.js +20 -49
- package/test/unit/ngsiv2/ngsiService/subscriptions-test.js +4 -3
- package/test/unit/ngsiv2/plugins/bidirectional-plugin_test.js +3 -2
- package/test/unit/ngsiv2/plugins/multientity-plugin_test.js +526 -0
- package/test/unit/{plugins → ngsiv2/plugins}/translation-inPlugins_test.js +21 -21
- package/test/unit/{provisioning → ngsiv2/provisioning}/device-group-api-test.js +19 -50
- package/test/unit/{provisioning/device-group-utils_test.js → ngsiv2/provisioning/device-group-utils-test.js} +5 -4
- package/test/unit/ngsiv2/provisioning/device-provisioning-api_test.js +2 -1
- package/test/unit/ngsiv2/provisioning/device-registration_test.js +3 -2
- package/test/unit/ngsiv2/provisioning/device-update-registration_test.js +4 -3
- package/test/unit/ngsiv2/provisioning/listProvisionedDevices-test.js +42 -53
- package/test/unit/ngsiv2/provisioning/provisionDeviceMultientity-test.js +2 -1
- package/test/unit/ngsiv2/provisioning/removeProvisionedDevice-test.js +4 -4
- package/test/unit/ngsiv2/provisioning/singleConfigurationMode-test.js +3 -4
- package/test/unit/ngsiv2/provisioning/updateProvisionedDevices-test.js +14 -20
- package/test/unit/plugins/capture-configuration-inPlugins_test.js +3 -1
- package/test/unit/plugins/capture-provision-inPlugins_test.js +8 -18
- package/.eslintcache +0 -1
- package/.nyc_output/dca24ca1-851e-490c-9d34-8d13b3330297.json +0 -1
- package/.nyc_output/processinfo/dca24ca1-851e-490c-9d34-8d13b3330297.json +0 -1
- package/bin/agentConsole.js +0 -257
- package/bin/iotAgentTester.js +0 -44
- package/lib/command/commandLine.js +0 -918
- package/lib/command/migration.js +0 -176
- package/lib/services/devices/devices-NGSI-v1.js +0 -310
- package/lib/services/ngsi/entities-NGSI-v1.js +0 -299
- package/lib/services/ngsi/subscription-NGSI-v1.js +0 -234
- package/lib/services/northBound/contextServer-NGSI-v1.js +0 -526
- package/lib/templates/notificationTemplateNgsi1.json +0 -75
- package/lib/templates/updateContextNgsi1.json +0 -50
- package/test/unit/examples/contextAvailabilityRequests/registerIoTAgent1.json +0 -21
- package/test/unit/examples/contextAvailabilityRequests/registerIoTAgent2.json +0 -21
- package/test/unit/examples/contextAvailabilityRequests/registerIoTAgent3.json +0 -25
- package/test/unit/examples/contextAvailabilityRequests/registerIoTAgent4.json +0 -22
- package/test/unit/examples/contextAvailabilityRequests/registerIoTAgentAttributeUpdates.json +0 -16
- package/test/unit/examples/contextAvailabilityRequests/registerIoTAgentCommands.json +0 -21
- package/test/unit/examples/contextAvailabilityRequests/registerNewDevice1.json +0 -21
- package/test/unit/examples/contextAvailabilityRequests/registerNewDevice2.json +0 -21
- package/test/unit/examples/contextAvailabilityRequests/registerProvisionedDevice.json +0 -25
- package/test/unit/examples/contextAvailabilityRequests/registerProvisionedDevice2.json +0 -21
- package/test/unit/examples/contextAvailabilityRequests/registerProvisionedDeviceWithGroup.json +0 -33
- package/test/unit/examples/contextAvailabilityRequests/registerProvisionedDeviceWithGroup2.json +0 -33
- package/test/unit/examples/contextAvailabilityRequests/unregisterDevice1.json +0 -22
- package/test/unit/examples/contextAvailabilityRequests/unregisterDevice3.json +0 -26
- package/test/unit/examples/contextAvailabilityRequests/unregisterProvisionedDevice.json +0 -26
- package/test/unit/examples/contextAvailabilityRequests/updateCommands1.json +0 -22
- package/test/unit/examples/contextAvailabilityRequests/updateIoTAgent1.json +0 -22
- package/test/unit/examples/contextAvailabilityRequests/updateIoTAgent2.json +0 -26
- package/test/unit/examples/contextAvailabilityRequests/updateIoTAgent3.json +0 -26
- package/test/unit/examples/contextAvailabilityResponses/registerIoTAgent1Failed.json +0 -8
- package/test/unit/examples/contextAvailabilityResponses/registerIoTAgent1Success.json +0 -4
- package/test/unit/examples/contextAvailabilityResponses/registerNewDevice1Success.json +0 -4
- package/test/unit/examples/contextAvailabilityResponses/registerNewDevice2Success.json +0 -4
- package/test/unit/examples/contextAvailabilityResponses/registerProvisionedDeviceSuccess.json +0 -4
- package/test/unit/examples/contextAvailabilityResponses/unregisterDevice1Failed.json +0 -8
- package/test/unit/examples/contextAvailabilityResponses/unregisterDevice1Success.json +0 -4
- package/test/unit/examples/contextAvailabilityResponses/updateCommands1Success.json +0 -4
- package/test/unit/examples/contextAvailabilityResponses/updateIoTAgent1Success.json +0 -6
- package/test/unit/examples/contextProviderResponses/queryInformationResponse.json +0 -22
- package/test/unit/examples/contextProviderResponses/queryInformationResponseEmptyAttributes.json +0 -22
- package/test/unit/examples/contextProviderResponses/queryInformationStaticAttributesResponse.json +0 -27
- package/test/unit/examples/contextProviderResponses/updateInformationResponse.json +0 -22
- package/test/unit/examples/contextProviderResponses/updateInformationResponse2.json +0 -22
- package/test/unit/examples/contextRequests/contextSubscriptionRequest.json +0 -20
- package/test/unit/examples/contextRequests/contextSubscriptionRequest2.json +0 -20
- package/test/unit/examples/contextRequests/createBidirectionalDevice.json +0 -17
- package/test/unit/examples/contextRequests/createDatetimeProvisionedDevice.json +0 -17
- package/test/unit/examples/contextRequests/createGeopointProvisionedDevice.json +0 -17
- package/test/unit/examples/contextRequests/createMinimumProvisionedDevice.json +0 -17
- package/test/unit/examples/contextRequests/createProvisionedDevice.json +0 -32
- package/test/unit/examples/contextRequests/createProvisionedDeviceMultientity.json +0 -32
- package/test/unit/examples/contextRequests/createProvisionedDeviceWithGroup.json +0 -47
- package/test/unit/examples/contextRequests/createProvisionedDeviceWithGroupAndStatic.json +0 -52
- package/test/unit/examples/contextRequests/createProvisionedDeviceWithGroupAndStatic2.json +0 -52
- package/test/unit/examples/contextRequests/createTimeinstantDevice.json +0 -17
- package/test/unit/examples/contextRequests/queryContext1.json +0 -13
- package/test/unit/examples/contextRequests/queryContext2.json +0 -13
- package/test/unit/examples/contextRequests/queryContextAliasPlugin1.json +0 -10
- package/test/unit/examples/contextRequests/queryContextCompressTimestamp1.json +0 -13
- package/test/unit/examples/contextRequests/updateActiveAttributes.json +0 -32
- package/test/unit/examples/contextRequests/updateContext1.json +0 -22
- package/test/unit/examples/contextRequests/updateContext2.json +0 -22
- package/test/unit/examples/contextRequests/updateContext3.json +0 -17
- package/test/unit/examples/contextRequests/updateContext3WithStatic.json +0 -22
- package/test/unit/examples/contextRequests/updateContext4.json +0 -22
- package/test/unit/examples/contextRequests/updateContext5.json +0 -19
- package/test/unit/examples/contextRequests/updateContextAliasPlugin.json +0 -22
- package/test/unit/examples/contextRequests/updateContextAliasPlugin2.json +0 -17
- package/test/unit/examples/contextRequests/updateContextAppendMode.json +0 -22
- package/test/unit/examples/contextRequests/updateContextCommandError.json +0 -22
- package/test/unit/examples/contextRequests/updateContextCommandExpired.json +0 -22
- package/test/unit/examples/contextRequests/updateContextCommandFinish.json +0 -22
- package/test/unit/examples/contextRequests/updateContextCommandStatus.json +0 -17
- package/test/unit/examples/contextRequests/updateContextCompressTimestamp1.json +0 -22
- package/test/unit/examples/contextRequests/updateContextCompressTimestamp2.json +0 -29
- package/test/unit/examples/contextRequests/updateContextExpressionPlugin1.json +0 -17
- package/test/unit/examples/contextRequests/updateContextExpressionPlugin10.json +0 -17
- package/test/unit/examples/contextRequests/updateContextExpressionPlugin2.json +0 -27
- package/test/unit/examples/contextRequests/updateContextExpressionPlugin3.json +0 -17
- package/test/unit/examples/contextRequests/updateContextExpressionPlugin4.json +0 -17
- package/test/unit/examples/contextRequests/updateContextExpressionPlugin5.json +0 -27
- package/test/unit/examples/contextRequests/updateContextExpressionPlugin6.json +0 -17
- package/test/unit/examples/contextRequests/updateContextExpressionPlugin7.json +0 -27
- package/test/unit/examples/contextRequests/updateContextExpressionPlugin8.json +0 -22
- package/test/unit/examples/contextRequests/updateContextExpressionPlugin9.json +0 -27
- package/test/unit/examples/contextRequests/updateContextMiddleware1.json +0 -22
- package/test/unit/examples/contextRequests/updateContextMultiEntityPlugin3.json +0 -35
- package/test/unit/examples/contextRequests/updateContextMultientityPlugin1.json +0 -30
- package/test/unit/examples/contextRequests/updateContextMultientityPlugin2.json +0 -30
- package/test/unit/examples/contextRequests/updateContextProcessTimestamp1.json +0 -29
- package/test/unit/examples/contextRequests/updateContextStaticAttributes.json +0 -22
- package/test/unit/examples/contextRequests/updateContextTimestamp.json +0 -41
- package/test/unit/examples/contextRequests/updateContextTimestampOverride.json +0 -22
- package/test/unit/examples/contextRequests/updateContextTimestampOverrideWithoutMilis.json +0 -22
- package/test/unit/examples/contextRequests/updateContextTimestampTimezone.json +0 -41
- package/test/unit/examples/contextRequests/updateProvisionActiveAttributes1.json +0 -17
- package/test/unit/examples/contextRequests/updateProvisionCommands1.json +0 -27
- package/test/unit/examples/contextRequests/updateProvisionDeviceStatic.json +0 -38
- package/test/unit/examples/contextRequests/updateProvisionMinimumDevice.json +0 -17
- package/test/unit/examples/contextResponses/contextSubscriptionRequest2Success.json +0 -7
- package/test/unit/examples/contextResponses/contextSubscriptionRequestSuccess.json +0 -7
- package/test/unit/examples/contextResponses/createBidirectionalDeviceSuccess.json +0 -22
- package/test/unit/examples/contextResponses/createDatetimeProvisionedDeviceSuccess.json +0 -22
- package/test/unit/examples/contextResponses/createGeopointProvisionedDeviceSuccess.json +0 -22
- package/test/unit/examples/contextResponses/createProvisionedDeviceSuccess.json +0 -22
- package/test/unit/examples/contextResponses/createTimeinstantSuccess.json +0 -22
- package/test/unit/examples/contextResponses/queryContext1Success.json +0 -27
- package/test/unit/examples/contextResponses/queryContext2Error.json +0 -7
- package/test/unit/examples/contextResponses/queryContext2UnknownError.json +0 -6
- package/test/unit/examples/contextResponses/queryContext3Error.json +0 -34
- package/test/unit/examples/contextResponses/queryContextAliasPlugin1Success.json +0 -27
- package/test/unit/examples/contextResponses/queryContextCompressTimestamp1Success.json +0 -27
- package/test/unit/examples/contextResponses/updateActiveAttributesSuccess.json +0 -42
- package/test/unit/examples/contextResponses/updateContext1Failed.json +0 -7
- package/test/unit/examples/contextResponses/updateContext1Success.json +0 -27
- package/test/unit/examples/contextResponses/updateContext2Failed.json +0 -35
- package/test/unit/examples/contextResponses/updateContextAliasPlugin2Success.json +0 -27
- package/test/unit/examples/contextResponses/updateContextAliasPluginSuccess.json +0 -27
- package/test/unit/examples/contextResponses/updateContextCommandFinishSuccess.json +0 -27
- package/test/unit/examples/contextResponses/updateContextCommandStatusSuccess.json +0 -22
- package/test/unit/examples/contextResponses/updateContextCompressTimestamp1Success.json +0 -27
- package/test/unit/examples/contextResponses/updateContextCompressTimestamp2Success.json +0 -34
- package/test/unit/examples/contextResponses/updateContextEvents1Success.json +0 -27
- package/test/unit/examples/contextResponses/updateContextExpressionPlugin1Success.json +0 -22
- package/test/unit/examples/contextResponses/updateContextExpressionPlugin2Success.json +0 -22
- package/test/unit/examples/contextResponses/updateContextExpressionPlugin3Success.json +0 -22
- package/test/unit/examples/contextResponses/updateContextExpressionPlugin5Success.json +0 -32
- package/test/unit/examples/contextResponses/updateContextMultientityPlugin1Success.json +0 -40
- package/test/unit/examples/contextResponses/updateContextMultientityPlugin2Success.json +0 -40
- package/test/unit/examples/contextResponses/updateContextMultientityPlugin3Success.json +0 -40
- package/test/unit/examples/contextResponses/updateContextProcessTimestamp1Success.json +0 -27
- package/test/unit/examples/contextResponses/updateProvisionActiveAttributes1Success.json +0 -22
- package/test/unit/examples/contextResponses/updateProvisionCommands1Success.json +0 -32
- package/test/unit/examples/contextResponses/updateProvisionMinimumDeviceSuccess.json +0 -22
- package/test/unit/examples/subscriptionRequests/bidirectionalNotification.json +0 -24
- package/test/unit/examples/subscriptionRequests/bidirectionalSubscriptionRemove.json +0 -3
- package/test/unit/examples/subscriptionRequests/bidirectionalSubscriptionRequest.json +0 -22
- package/test/unit/examples/subscriptionRequests/errorNotification.json +0 -24
- package/test/unit/examples/subscriptionRequests/simpleNotification.json +0 -24
- package/test/unit/examples/subscriptionRequests/simpleSubscriptionRemove.json +0 -3
- package/test/unit/examples/subscriptionRequests/simpleSubscriptionRequest.json +0 -19
- package/test/unit/examples/subscriptionRequests/simpleSubscriptionRequest1.json +0 -19
- package/test/unit/examples/subscriptionResponses/bidirectionalSubscriptionSuccess.json +0 -6
- package/test/unit/examples/subscriptionResponses/simpleSubscriptionSuccess.json +0 -6
- package/test/unit/expressions/expressionBasedTransformations-test.js +0 -328
- package/test/unit/expressions/expressionCombinedTransformations-test.js +0 -306
- package/test/unit/expressions/jexlBasedTransformations-test.js +0 -334
- package/test/unit/general/contextBrokerOAuthSecurityAccess-test.js +0 -902
- package/test/unit/general/https-support-test.js +0 -286
- package/test/unit/general/iotam-autoregistration-test.js +0 -368
- package/test/unit/general/migration-test.js +0 -256
- package/test/unit/lazyAndCommands/active-devices-attribute-update-test.js +0 -168
- package/test/unit/lazyAndCommands/command-test.js +0 -341
- package/test/unit/lazyAndCommands/lazy-devices-test.js +0 -878
- package/test/unit/lazyAndCommands/polling-commands-test.js +0 -421
- package/test/unit/ngsi-ld/examples/contextRequests/updateContextExpressionPlugin20.json +0 -25
- package/test/unit/ngsiService/active-devices-test.js +0 -692
- package/test/unit/ngsiService/staticAttributes-test.js +0 -148
- package/test/unit/ngsiService/subscriptions-test.js +0 -345
- package/test/unit/plugins/alias-plugin_test.js +0 -158
- package/test/unit/plugins/bidirectional-plugin_test.js +0 -564
- package/test/unit/plugins/compress-timestamp-plugin_test.js +0 -257
- package/test/unit/plugins/event-plugin_test.js +0 -119
- package/test/unit/plugins/multientity-plugin_test.js +0 -248
- package/test/unit/plugins/timestamp-processing-plugin_test.js +0 -119
- package/test/unit/provisioning/device-provisioning-api_test.js +0 -748
- package/test/unit/provisioning/device-registration_test.js +0 -432
- package/test/unit/provisioning/device-update-registration_test.js +0 -326
- package/test/unit/provisioning/listProvisionedDevices-test.js +0 -488
- package/test/unit/provisioning/provisionDeviceMultientity-test.js +0 -123
- package/test/unit/provisioning/removeProvisionedDevice-test.js +0 -244
- package/test/unit/provisioning/singleConfigurationMode-test.js +0 -346
- package/test/unit/provisioning/updateProvisionedDevices-test.js +0 -436
|
@@ -71,7 +71,7 @@ function traceRequest(req, res, next) {
|
|
|
71
71
|
|
|
72
72
|
/* eslint-disable-next-line no-unused-vars */
|
|
73
73
|
function changeLogLevel(req, res, next) {
|
|
74
|
-
const levels = ['INFO', 'ERROR', 'FATAL', 'DEBUG', 'WARNING'];
|
|
74
|
+
const levels = ['INFO', 'ERROR', 'FATAL', 'DEBUG', 'WARN', 'WARNING'];
|
|
75
75
|
|
|
76
76
|
if (!req.query.level) {
|
|
77
77
|
res.status(400).json({
|
|
@@ -82,7 +82,11 @@ function changeLogLevel(req, res, next) {
|
|
|
82
82
|
error: 'invalid log level'
|
|
83
83
|
});
|
|
84
84
|
} else {
|
|
85
|
-
|
|
85
|
+
let newLevel = req.query.level.toUpperCase();
|
|
86
|
+
if (newLevel === 'WARNING') {
|
|
87
|
+
newLevel = 'WARN';
|
|
88
|
+
}
|
|
89
|
+
logger.setLevel(newLevel);
|
|
86
90
|
res.status(200).send('');
|
|
87
91
|
}
|
|
88
92
|
}
|
|
@@ -23,7 +23,7 @@
|
|
|
23
23
|
* Modified by: Federico M. Facca - Martel Innovate
|
|
24
24
|
*/
|
|
25
25
|
|
|
26
|
-
const request = require('request');
|
|
26
|
+
const request = require('../../request-shim');
|
|
27
27
|
const async = require('async');
|
|
28
28
|
const errors = require('../../errors');
|
|
29
29
|
const constants = require('../../constants');
|
|
@@ -21,7 +21,7 @@
|
|
|
21
21
|
* please contact with::daniel.moranjimenez@telefonica.com
|
|
22
22
|
*/
|
|
23
23
|
|
|
24
|
-
const request = require('request');
|
|
24
|
+
const request = require('../../request-shim');
|
|
25
25
|
const errors = require('../../errors');
|
|
26
26
|
const config = require('../../commonConfig');
|
|
27
27
|
const intoTrans = require('../common/domain').intoTrans;
|
|
@@ -26,7 +26,7 @@
|
|
|
26
26
|
|
|
27
27
|
/* eslint-disable consistent-return */
|
|
28
28
|
|
|
29
|
-
const request = require('request');
|
|
29
|
+
const request = require('../../request-shim');
|
|
30
30
|
const queryString = require('query-string');
|
|
31
31
|
const errors = require('../../errors');
|
|
32
32
|
const config = require('../../commonConfig');
|
|
@@ -64,7 +64,8 @@ function auth(trust, callback) {
|
|
|
64
64
|
'Content-Length': formData.length,
|
|
65
65
|
'Content-Type': 'application/x-www-form-urlencoded'
|
|
66
66
|
},
|
|
67
|
-
body: formData
|
|
67
|
+
body: formData,
|
|
68
|
+
responseType: 'text'
|
|
68
69
|
};
|
|
69
70
|
|
|
70
71
|
logger.debug(context, 'Authentication on the OAuth2 provider [%s]', url);
|
|
@@ -286,8 +286,10 @@ function update(device, callback) {
|
|
|
286
286
|
data.active = device.active;
|
|
287
287
|
data.internalId = device.internalId;
|
|
288
288
|
data.staticAttributes = device.staticAttributes;
|
|
289
|
+
data.internalAttributes = device.internalAttributes;
|
|
289
290
|
data.commands = device.commands;
|
|
290
291
|
data.endpoint = device.endpoint;
|
|
292
|
+
data.polling = device.polling;
|
|
291
293
|
data.name = device.name;
|
|
292
294
|
data.type = device.type;
|
|
293
295
|
data.apikey = device.apikey;
|
|
@@ -54,14 +54,11 @@ function init() {
|
|
|
54
54
|
case 'ld':
|
|
55
55
|
deviceHandler = require('./devices-NGSI-LD');
|
|
56
56
|
break;
|
|
57
|
-
case 'v2':
|
|
58
|
-
deviceHandler = require('./devices-NGSI-v2');
|
|
59
|
-
break;
|
|
60
57
|
case 'mixed':
|
|
61
58
|
deviceHandler = require('./devices-NGSI-mixed');
|
|
62
59
|
break;
|
|
63
60
|
default:
|
|
64
|
-
deviceHandler = require('./devices-NGSI-
|
|
61
|
+
deviceHandler = require('./devices-NGSI-v2');
|
|
65
62
|
}
|
|
66
63
|
}
|
|
67
64
|
|
|
@@ -277,7 +274,7 @@ function registerDevice(deviceObj, callback) {
|
|
|
277
274
|
}
|
|
278
275
|
|
|
279
276
|
if (!deviceData.name) {
|
|
280
|
-
|
|
277
|
+
let conjunction;
|
|
281
278
|
if (configuration && configuration.defaultEntityNameConjunction !== undefined) {
|
|
282
279
|
conjunction = configuration.defaultEntityNameConjunction;
|
|
283
280
|
} else {
|
|
@@ -27,7 +27,7 @@
|
|
|
27
27
|
|
|
28
28
|
/* eslint-disable consistent-return */
|
|
29
29
|
|
|
30
|
-
const request = require('request');
|
|
30
|
+
const request = require('../../request-shim');
|
|
31
31
|
const async = require('async');
|
|
32
32
|
const apply = async.apply;
|
|
33
33
|
const uuid = require('uuid');
|
|
@@ -94,7 +94,7 @@ function createInitialEntityHandlerNgsi2(deviceData, newDevice, callback) {
|
|
|
94
94
|
body
|
|
95
95
|
);
|
|
96
96
|
|
|
97
|
-
const errorObj = new errors.EntityGenericError(deviceData.id, deviceData.type, body);
|
|
97
|
+
const errorObj = new errors.EntityGenericError(deviceData.id, deviceData.type, body, response.statusCode);
|
|
98
98
|
|
|
99
99
|
callback(errorObj);
|
|
100
100
|
}
|
|
@@ -112,11 +112,7 @@ function createInitialEntityHandlerNgsi2(deviceData, newDevice, callback) {
|
|
|
112
112
|
function updateEntityHandlerNgsi2(deviceData, updatedDevice, callback) {
|
|
113
113
|
return function handleEntityResponse(error, response, body) {
|
|
114
114
|
if (error) {
|
|
115
|
-
logger.error(
|
|
116
|
-
context,
|
|
117
|
-
'ORION-001: Connection error creating inital entity in the Context Broker: %s',
|
|
118
|
-
error
|
|
119
|
-
);
|
|
115
|
+
logger.error(context, 'ORION-001: Connection error updating entity in the Context Broker: %s', error);
|
|
120
116
|
|
|
121
117
|
alarms.raise(constants.ORION_ALARM, error);
|
|
122
118
|
|
|
@@ -133,7 +129,7 @@ function updateEntityHandlerNgsi2(deviceData, updatedDevice, callback) {
|
|
|
133
129
|
body
|
|
134
130
|
);
|
|
135
131
|
|
|
136
|
-
const errorObj = new errors.EntityGenericError(deviceData.id, deviceData.type, body);
|
|
132
|
+
const errorObj = new errors.EntityGenericError(deviceData.id, deviceData.type, body, response.statusCode);
|
|
137
133
|
|
|
138
134
|
callback(errorObj);
|
|
139
135
|
}
|
|
@@ -31,7 +31,6 @@ const logger = require('logops');
|
|
|
31
31
|
const _ = require('underscore');
|
|
32
32
|
const intoTrans = require('../common/domain').intoTrans;
|
|
33
33
|
const config = require('../../commonConfig');
|
|
34
|
-
const ngsiUtils = require('./../ngsi/ngsiUtils');
|
|
35
34
|
const context = {
|
|
36
35
|
op: 'IoTAgentNGSI.Registration'
|
|
37
36
|
};
|
|
@@ -40,45 +39,6 @@ const utils = require('../northBound/restUtils');
|
|
|
40
39
|
|
|
41
40
|
const NGSI_LD_URN = 'urn:ngsi-ld:';
|
|
42
41
|
|
|
43
|
-
/**
|
|
44
|
-
* Generates a handler for the registration requests that checks all the possible errors derived from the registration.
|
|
45
|
-
* The parameter information is needed in order to fulfill error information.
|
|
46
|
-
*
|
|
47
|
-
* @param {Boolen} unregister Indicates whether this registration is an unregistration or register.
|
|
48
|
-
* @param {Object} deviceData Object containing all the deviceData needed to send the registration.
|
|
49
|
-
* @return {Function} The generated handler.
|
|
50
|
-
*/
|
|
51
|
-
function createRegistrationHandler(unregister, deviceData, callback) {
|
|
52
|
-
return function handleRegistrationResponse(error, response, body) {
|
|
53
|
-
if (error) {
|
|
54
|
-
logger.error(context, 'ORION-002: Connection error sending registrations to the Context Broker: %s', error);
|
|
55
|
-
callback(error);
|
|
56
|
-
} else if (response && body && response.statusCode === 200) {
|
|
57
|
-
const errorField = ngsiUtils.getErrorField(body);
|
|
58
|
-
|
|
59
|
-
if (errorField) {
|
|
60
|
-
logger.error(context, 'Registration error connecting to the Context Broker: %j', errorField);
|
|
61
|
-
callback(new errors.BadRequest(JSON.stringify(errorField)));
|
|
62
|
-
} else {
|
|
63
|
-
logger.debug(context, 'Registration success.');
|
|
64
|
-
callback(null, body);
|
|
65
|
-
}
|
|
66
|
-
} else {
|
|
67
|
-
let errorObj;
|
|
68
|
-
|
|
69
|
-
logger.error(context, 'ORION-003: Protocol error connecting to the Context Broker: %j', errorObj);
|
|
70
|
-
|
|
71
|
-
if (unregister) {
|
|
72
|
-
errorObj = new errors.UnregistrationError(deviceData.id, deviceData.type);
|
|
73
|
-
} else {
|
|
74
|
-
errorObj = new errors.RegistrationError(deviceData.id, deviceData.type);
|
|
75
|
-
}
|
|
76
|
-
|
|
77
|
-
callback(errorObj);
|
|
78
|
-
}
|
|
79
|
-
};
|
|
80
|
-
}
|
|
81
|
-
|
|
82
42
|
/**
|
|
83
43
|
* Generates a handler for the registration requests that checks all the possible errors derived from the registration.
|
|
84
44
|
* The parameter information is needed in order to fulfill error information.
|
|
@@ -161,93 +121,6 @@ function createRegistrationHandlerNgsi2(unregister, deviceData, callback) {
|
|
|
161
121
|
};
|
|
162
122
|
}
|
|
163
123
|
|
|
164
|
-
/**
|
|
165
|
-
* Sends a Context Provider registration or unregistration request to the Context Broker using NGSIv1.
|
|
166
|
-
* As registrations cannot be removed, an unregistration consists of an update of the existent registration
|
|
167
|
-
* to make reduce its duration to 1 second.
|
|
168
|
-
*
|
|
169
|
-
* The entity type, entity name and lazy attributes list are needed in order to send the registration:
|
|
170
|
-
*
|
|
171
|
-
* @param {Boolen} unregister Indicates whether this registration is an unregistration or register.
|
|
172
|
-
* @param {Object} deviceData Object containing all the deviceData needed to send the registration.
|
|
173
|
-
*/
|
|
174
|
-
function sendRegistrationsNgsi1(unregister, deviceData, callback) {
|
|
175
|
-
let cbHost = config.getConfig().contextBroker.url;
|
|
176
|
-
if (deviceData.cbHost && deviceData.cbHost.indexOf('://') !== -1) {
|
|
177
|
-
cbHost = deviceData.cbHost;
|
|
178
|
-
} else if (deviceData.cbHost && deviceData.cbHost.indexOf('://') === -1) {
|
|
179
|
-
cbHost = 'http://' + deviceData.cbHost;
|
|
180
|
-
}
|
|
181
|
-
|
|
182
|
-
const options = {
|
|
183
|
-
url: cbHost + '/NGSI9/registerContext',
|
|
184
|
-
method: 'POST',
|
|
185
|
-
json: {
|
|
186
|
-
contextRegistrations: [
|
|
187
|
-
{
|
|
188
|
-
entities: [
|
|
189
|
-
{
|
|
190
|
-
type: deviceData.type,
|
|
191
|
-
isPattern: 'false',
|
|
192
|
-
id: String(deviceData.name)
|
|
193
|
-
}
|
|
194
|
-
],
|
|
195
|
-
attributes: [],
|
|
196
|
-
providingApplication: config.getConfig().providerUrl
|
|
197
|
-
}
|
|
198
|
-
],
|
|
199
|
-
duration: unregister ? 'PT1S' : config.getConfig().deviceRegistrationDuration
|
|
200
|
-
},
|
|
201
|
-
headers: {
|
|
202
|
-
'fiware-service': deviceData.service,
|
|
203
|
-
'fiware-servicepath': deviceData.subservice
|
|
204
|
-
}
|
|
205
|
-
};
|
|
206
|
-
|
|
207
|
-
function formatAttributes(originalVector) {
|
|
208
|
-
const attributeList = [];
|
|
209
|
-
|
|
210
|
-
if (originalVector && originalVector.length) {
|
|
211
|
-
for (let i = 0; i < originalVector.length; i++) {
|
|
212
|
-
attributeList.push({
|
|
213
|
-
name: originalVector[i].name,
|
|
214
|
-
type: originalVector[i].type
|
|
215
|
-
});
|
|
216
|
-
}
|
|
217
|
-
}
|
|
218
|
-
|
|
219
|
-
return attributeList;
|
|
220
|
-
}
|
|
221
|
-
|
|
222
|
-
function mergeWithSameName(old, current) {
|
|
223
|
-
const keys = _.pluck(old, 'name');
|
|
224
|
-
|
|
225
|
-
if (keys.indexOf(current.name) < 0) {
|
|
226
|
-
old.push(current);
|
|
227
|
-
}
|
|
228
|
-
|
|
229
|
-
return old;
|
|
230
|
-
}
|
|
231
|
-
|
|
232
|
-
if (deviceData.registrationId) {
|
|
233
|
-
options.json.registrationId = deviceData.registrationId;
|
|
234
|
-
}
|
|
235
|
-
|
|
236
|
-
options.json.contextRegistrations[0].attributes = options.json.contextRegistrations[0].attributes
|
|
237
|
-
.concat(formatAttributes(deviceData.lazy), formatAttributes(deviceData.commands))
|
|
238
|
-
.reduce(mergeWithSameName, []);
|
|
239
|
-
|
|
240
|
-
if (options.json.contextRegistrations[0].attributes.length === 0) {
|
|
241
|
-
logger.debug(context, 'No Context Provider registrations found for unregister');
|
|
242
|
-
callback(null, deviceData);
|
|
243
|
-
} else {
|
|
244
|
-
logger.debug(context, 'Sending v1 device registrations to Context Broker at [%s]', options.url);
|
|
245
|
-
logger.debug(context, 'Using the following request:\n\n%s\n\n', JSON.stringify(options, null, 4));
|
|
246
|
-
|
|
247
|
-
utils.executeWithSecurity(options, deviceData, createRegistrationHandler(unregister, deviceData, callback));
|
|
248
|
-
}
|
|
249
|
-
}
|
|
250
|
-
|
|
251
124
|
/**
|
|
252
125
|
* Sends a Context Provider unregistration request to the Context Broker using NGSIv2.
|
|
253
126
|
*
|
|
@@ -263,7 +136,6 @@ function sendUnregistrationsNgsi2(deviceData, callback) {
|
|
|
263
136
|
const options = {
|
|
264
137
|
url: cbHost + '/v2/registrations/' + deviceData.registrationId,
|
|
265
138
|
method: 'DELETE',
|
|
266
|
-
json: true,
|
|
267
139
|
headers: {
|
|
268
140
|
'fiware-service': deviceData.service,
|
|
269
141
|
'fiware-servicepath': deviceData.subservice
|
|
@@ -304,7 +176,6 @@ function sendUnregistrationsNgsiLD(deviceData, callback) {
|
|
|
304
176
|
const options = {
|
|
305
177
|
url: cbHost + '/ngsi-ld/v1/csourceRegistrations/' + deviceData.registrationId,
|
|
306
178
|
method: 'DELETE',
|
|
307
|
-
json: true,
|
|
308
179
|
headers: {
|
|
309
180
|
'fiware-service': deviceData.service,
|
|
310
181
|
'fiware-servicepath': deviceData.subservice,
|
|
@@ -469,7 +340,6 @@ function sendRegistrationsNgsiLD(unregister, deviceData, callback) {
|
|
|
469
340
|
logger.debug(context, 'Amending id to a valid URN: %s', id);
|
|
470
341
|
}
|
|
471
342
|
|
|
472
|
-
|
|
473
343
|
const options = {
|
|
474
344
|
url: cbHost + '/ngsi-ld/v1/csourceRegistrations/',
|
|
475
345
|
method: 'POST',
|
|
@@ -514,11 +384,9 @@ function sendRegistrations(unregister, deviceData, callback) {
|
|
|
514
384
|
case 'ld':
|
|
515
385
|
sendRegistrationsNgsiLD(unregister, deviceData, callback);
|
|
516
386
|
break;
|
|
517
|
-
|
|
387
|
+
default:
|
|
518
388
|
sendRegistrationsNgsi2(unregister, deviceData, callback);
|
|
519
389
|
break;
|
|
520
|
-
default:
|
|
521
|
-
sendRegistrationsNgsi1(unregister, deviceData, callback);
|
|
522
390
|
}
|
|
523
391
|
}
|
|
524
392
|
|
|
@@ -540,5 +408,4 @@ function processContextRegistration(deviceData, body, callback) {
|
|
|
540
408
|
}
|
|
541
409
|
|
|
542
410
|
exports.sendRegistrations = intoTrans(context, sendRegistrations);
|
|
543
|
-
exports.createRegistrationHandler = intoTrans(context, createRegistrationHandler);
|
|
544
411
|
exports.processContextRegistration = processContextRegistration;
|