iotagent-node-lib 2.15.1 → 2.19.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 -1
- package/.readthedocs.yml +7 -0
- package/CHANGES_NEXT_RELEASE +0 -1
- package/README.md +1 -0
- package/doc/Contribution.md +60 -1
- package/doc/advanced-topics.md +136 -14
- package/doc/api.md +38 -22
- package/doc/apiary/iotagent.apib +1 -3
- package/doc/architecture.md +2 -2
- package/doc/config-basic-example.js +0 -1
- package/doc/deprecated.md +2 -2
- package/doc/development.md +13 -6
- package/doc/expressionLanguage.md +519 -277
- package/doc/getting-started.md +0 -1
- package/doc/howto.md +13 -17
- package/doc/installationguide.md +67 -69
- package/doc/usermanual.md +48 -16
- package/docker/Mosquitto/Dockerfile +4 -9
- package/docker/Mosquitto/README.md +2 -0
- package/docker/Mosquitto/startMosquitto.sh +18 -1
- package/lib/command/commandLine.js +1 -1
- package/lib/commonConfig.js +5 -14
- package/lib/errors.js +0 -16
- package/lib/fiware-iotagent-lib.js +5 -0
- package/lib/jexlTranformsMap.js +71 -0
- package/lib/model/Command.js +1 -1
- package/lib/model/Device.js +5 -2
- package/lib/model/Group.js +20 -2
- package/lib/model/dbConn.js +7 -1
- package/lib/plugins/attributeAlias.js +6 -13
- package/lib/plugins/bidirectionalData.js +2 -27
- package/lib/plugins/expressionParser.js +41 -17
- package/lib/plugins/expressionPlugin.js +21 -27
- package/lib/plugins/jexlParser.js +71 -67
- package/lib/plugins/multiEntity.js +68 -147
- 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 +2 -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 +29 -22
- package/lib/services/devices/deviceService.js +56 -33
- package/lib/services/devices/devices-NGSI-LD.js +42 -14
- package/lib/services/devices/devices-NGSI-mixed.js +3 -3
- package/lib/services/devices/devices-NGSI-v2.js +48 -24
- package/lib/services/devices/registrationUtils.js +1 -134
- package/lib/services/groups/groupRegistryMemory.js +2 -0
- package/lib/services/groups/groupRegistryMongoDB.js +58 -76
- package/lib/services/groups/groupService.js +1 -1
- package/lib/services/ngsi/entities-NGSI-LD.js +205 -124
- package/lib/services/ngsi/entities-NGSI-v2.js +142 -32
- package/lib/services/ngsi/ngsiService.js +4 -6
- package/lib/services/ngsi/ngsiUtils.js +0 -21
- package/lib/services/ngsi/subscription-NGSI-LD.js +14 -5
- 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 +25 -13
- package/lib/services/northBound/contextServer.js +1 -4
- package/lib/services/northBound/contextServerUtils.js +0 -81
- package/lib/services/northBound/deviceProvisioningServer.js +36 -9
- package/lib/services/northBound/northboundServer.js +2 -0
- package/lib/services/northBound/restUtils.js +2 -39
- package/lib/templates/updateDevice.json +4 -0
- package/lib/templates/updateDeviceLax.json +4 -0
- package/package.json +13 -13
- package/test/tools/utils.js +2 -0
- package/test/unit/examples/deviceProvisioningRequests/provisionAnotherDevice.json +1 -1
- package/test/unit/examples/deviceProvisioningRequests/provisionDeviceMissingParameters.json +1 -1
- package/test/unit/examples/deviceProvisioningRequests/provisionDuplicatedDev.json +1 -1
- package/test/unit/examples/deviceProvisioningRequests/provisionFullDevice.json +1 -1
- package/test/unit/examples/deviceProvisioningRequests/provisionNewDeviceMalformed1.json +1 -1
- package/test/unit/examples/groupProvisioningRequests/multipleGroupsCreation.json +1 -1
- package/test/unit/examples/iotamRequests/registrationEmpty.json +1 -1
- package/test/unit/examples/iotamRequests/registrationWithGroups.json +2 -2
- package/test/unit/examples/iotamRequests/registrationWithGroupsWithoutCB.json +2 -2
- package/test/unit/examples/iotamRequests/registrationWithStaticGroups.json +2 -2
- package/test/unit/expressions/jexlExpression-test.js +119 -0
- package/test/unit/general/config-multi-core-test.js +1 -1
- package/test/unit/general/contextBrokerKeystoneSecurityAccess-test.js +30 -77
- package/test/unit/general/deviceService-test.js +19 -35
- package/test/unit/general/loglevel-api_test.js +8 -13
- package/test/unit/general/migration-test.js +1 -0
- package/test/unit/general/startup-test.js +3 -2
- package/test/unit/general/statistics-persistence_test.js +2 -2
- package/test/unit/general/statistics-service_test.js +2 -2
- package/test/unit/lazyAndCommands/commandRegistry_test.js +18 -18
- package/test/unit/memoryRegistry/deviceRegistryMemory_test.js +16 -24
- package/test/unit/mongodb/mongodb-connectionoptions-test.js +2 -2
- package/test/unit/mongodb/mongodb-group-registry-test.js +11 -11
- package/test/unit/mongodb/mongodb-registry-test.js +55 -131
- package/test/unit/ngsi-ld/examples/contextAvailabilityRequests/registerIoTAgent1.json +1 -1
- package/test/unit/ngsi-ld/examples/contextAvailabilityRequests/registerIoTAgent2.json +1 -1
- package/test/unit/ngsi-ld/examples/contextAvailabilityRequests/registerIoTAgent4.json +1 -1
- package/test/unit/ngsi-ld/examples/contextAvailabilityRequests/registerIoTAgentCommands.json +1 -1
- package/test/unit/ngsi-ld/examples/contextAvailabilityRequests/registerProvisionedDevice.json +1 -1
- package/test/unit/ngsi-ld/examples/contextAvailabilityRequests/registerProvisionedDevice2.json +1 -1
- package/test/unit/ngsi-ld/examples/contextAvailabilityRequests/registerProvisionedDeviceWithGroup.json +1 -1
- package/test/unit/ngsi-ld/examples/contextAvailabilityRequests/registerProvisionedDeviceWithGroup2.json +1 -1
- package/test/unit/ngsi-ld/examples/contextAvailabilityRequests/registerProvisionedDeviceWithGroup3.json +1 -1
- package/test/unit/ngsi-ld/examples/contextAvailabilityRequests/updateCommands1.json +1 -1
- package/test/unit/ngsi-ld/examples/contextAvailabilityRequests/updateIoTAgent1.json +1 -1
- package/test/unit/ngsi-ld/examples/contextAvailabilityRequests/updateIoTAgent2.json +1 -1
- package/test/unit/ngsi-ld/examples/contextAvailabilityRequests/updateIoTAgent3.json +1 -1
- 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/examples/subscriptionRequests/bidirectionalSubscriptionRequest.json +20 -17
- package/test/unit/ngsi-ld/examples/subscriptionRequests/simpleSubscriptionRequest.json +18 -15
- package/test/unit/ngsi-ld/examples/subscriptionRequests/simpleSubscriptionRequest2.json +18 -15
- package/test/unit/ngsi-ld/expressions/expressionBasedTransformations-test.js +21 -21
- package/test/unit/ngsi-ld/expressions/jexlBasedTransformations-test.js +1018 -0
- package/test/unit/ngsi-ld/general/config-jsonld-contexts-test.js +2 -2
- package/test/unit/ngsi-ld/general/contextBrokerOAuthSecurityAccess-test.js +24 -24
- package/test/unit/ngsi-ld/general/deviceService-test.js +7 -7
- package/test/unit/ngsi-ld/general/https-support-test.js +14 -13
- package/test/unit/ngsi-ld/general/iotam-autoregistration-test.js +8 -7
- package/test/unit/ngsi-ld/general/startup-test.js +2 -1
- package/test/unit/ngsi-ld/lazyAndCommands/active-devices-attribute-update-test.js +10 -8
- package/test/unit/ngsi-ld/lazyAndCommands/command-test.js +11 -12
- package/test/unit/ngsi-ld/lazyAndCommands/lazy-devices-test.js +25 -29
- package/test/unit/ngsi-ld/lazyAndCommands/polling-commands-test.js +16 -15
- package/test/unit/ngsi-ld/ngsiService/active-devices-test.js +18 -17
- package/test/unit/ngsi-ld/ngsiService/autocast-test.js +13 -12
- package/test/unit/ngsi-ld/ngsiService/geoproperties-test.js +10 -9
- package/test/unit/ngsi-ld/ngsiService/staticAttributes-test.js +3 -3
- package/test/unit/ngsi-ld/ngsiService/subscriptions-test.js +25 -24
- package/test/unit/ngsi-ld/plugins/alias-plugin_test.js +13 -12
- package/test/unit/ngsi-ld/plugins/bidirectional-plugin_test.js +27 -26
- package/test/unit/ngsi-ld/plugins/compress-timestamp-plugin_test.js +5 -5
- package/test/unit/ngsi-ld/plugins/event-plugin_test.js +3 -3
- package/test/unit/ngsi-ld/plugins/multientity-plugin_test.js +75 -14
- package/test/unit/ngsi-ld/plugins/timestamp-processing-plugin_test.js +3 -3
- package/test/unit/ngsi-ld/provisioning/device-provisioning-api_test.js +54 -53
- package/test/unit/ngsi-ld/provisioning/device-registration_test.js +20 -19
- package/test/unit/ngsi-ld/provisioning/device-update-registration_test.js +23 -22
- package/test/unit/ngsi-ld/provisioning/listProvisionedDevices-test.js +58 -70
- package/test/unit/ngsi-ld/provisioning/provisionDeviceMultientity-test.js +8 -7
- package/test/unit/ngsi-ld/provisioning/removeProvisionedDevice-test.js +19 -19
- package/test/unit/ngsi-ld/provisioning/singleConfigurationMode-test.js +18 -20
- package/test/unit/ngsi-ld/provisioning/updateProvisionedDevices-test.js +43 -49
- package/test/unit/ngsi-mixed/provisioning/ngsi-versioning-test.js +16 -14
- package/test/unit/ngsiv2/examples/contextAvailabilityRequests/registerIoTAgent1.json +1 -1
- package/test/unit/ngsiv2/examples/contextAvailabilityRequests/registerIoTAgent2.json +1 -1
- package/test/unit/ngsiv2/examples/contextAvailabilityRequests/registerIoTAgent3.json +19 -0
- package/test/unit/ngsiv2/examples/contextAvailabilityRequests/registerIoTAgent4.json +1 -1
- package/test/unit/ngsiv2/examples/contextAvailabilityRequests/registerIoTAgent5.json +19 -0
- package/test/unit/ngsiv2/examples/contextAvailabilityRequests/registerIoTAgentCommands.json +1 -1
- package/test/unit/ngsiv2/examples/contextAvailabilityRequests/registerProvisionedDevice.json +1 -1
- package/test/unit/ngsiv2/examples/contextAvailabilityRequests/registerProvisionedDevice2.json +1 -1
- package/test/unit/ngsiv2/examples/contextAvailabilityRequests/registerProvisionedDeviceWithGroup.json +1 -1
- package/test/unit/ngsiv2/examples/contextAvailabilityRequests/registerProvisionedDeviceWithGroup2.json +1 -1
- package/test/unit/ngsiv2/examples/contextAvailabilityRequests/registerProvisionedDeviceWithGroup3.json +1 -1
- package/test/unit/ngsiv2/examples/contextAvailabilityRequests/updateCommands1.json +3 -3
- package/test/unit/ngsiv2/examples/contextAvailabilityRequests/updateIoTAgent1.json +3 -3
- package/test/unit/ngsiv2/examples/contextAvailabilityRequests/updateIoTAgent2.json +1 -1
- package/test/unit/ngsiv2/examples/contextAvailabilityRequests/updateIoTAgent3.json +1 -1
- package/test/unit/ngsiv2/examples/contextRequests/updateContextExpressionPlugin1.json +17 -1
- package/test/unit/ngsiv2/examples/contextRequests/updateContextExpressionPlugin11.json +5 -1
- package/test/unit/ngsiv2/examples/contextRequests/updateContextExpressionPlugin12.json +2 -2
- package/test/unit/ngsiv2/examples/contextRequests/updateContextExpressionPlugin15.json +6 -0
- package/test/unit/ngsiv2/examples/contextRequests/updateContextExpressionPlugin16.json +14 -0
- package/test/unit/ngsiv2/examples/contextRequests/updateContextExpressionPlugin17.json +14 -0
- package/test/unit/ngsiv2/examples/contextRequests/updateContextExpressionPlugin18.json +6 -0
- package/test/unit/ngsiv2/examples/contextRequests/updateContextExpressionPlugin19.json +6 -0
- package/test/unit/ngsiv2/examples/contextRequests/updateContextExpressionPlugin2.json +13 -1
- package/test/unit/ngsiv2/examples/contextRequests/updateContextExpressionPlugin20.json +6 -0
- package/test/unit/ngsiv2/examples/contextRequests/updateContextExpressionPlugin21.json +6 -0
- package/test/unit/ngsiv2/examples/contextRequests/updateContextExpressionPlugin22.json +6 -0
- package/test/unit/ngsiv2/examples/contextRequests/updateContextExpressionPlugin23.json +6 -0
- package/test/unit/ngsiv2/examples/contextRequests/updateContextExpressionPlugin24.json +6 -0
- package/test/unit/ngsiv2/examples/contextRequests/updateContextExpressionPlugin25.json +6 -0
- package/test/unit/ngsiv2/examples/contextRequests/updateContextExpressionPlugin26.json +6 -0
- package/test/unit/ngsiv2/examples/contextRequests/updateContextExpressionPlugin27.json +6 -0
- package/test/unit/ngsiv2/examples/contextRequests/updateContextExpressionPlugin28.json +6 -0
- package/test/unit/ngsiv2/examples/contextRequests/updateContextExpressionPlugin29.json +22 -0
- package/test/unit/ngsiv2/examples/contextRequests/updateContextExpressionPlugin3.json +5 -1
- 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/updateContextExpressionPlugin4.json +12 -0
- package/test/unit/ngsiv2/examples/contextRequests/updateContextExpressionPlugin5.json +5 -1
- package/test/unit/ngsiv2/examples/contextRequests/updateContextExpressionPlugin6.json +5 -1
- package/test/unit/ngsiv2/examples/contextRequests/updateContextExpressionPlugin7.json +5 -1
- package/test/unit/ngsiv2/examples/contextRequests/updateContextExpressionPlugin8.json +17 -1
- package/test/unit/ngsiv2/examples/contextRequests/updateContextExpressionPlugin9.json +5 -1
- 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/updateContextMultientityPlugin1.json +2 -2
- package/test/unit/ngsiv2/examples/contextRequests/updateContextMultientityPlugin10.json +1 -1
- 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/updateContextMultientityPlugin2.json +2 -2
- package/test/unit/ngsiv2/examples/contextRequests/updateContextMultientityPlugin3.json +1 -1
- package/test/unit/ngsiv2/examples/contextRequests/updateContextMultientityPlugin4.json +1 -1
- package/test/unit/ngsiv2/examples/contextRequests/updateContextMultientityPlugin5.json +1 -1
- package/test/unit/ngsiv2/examples/contextRequests/updateContextMultientityPlugin6.json +1 -1
- package/test/unit/ngsiv2/examples/contextRequests/updateContextMultientityPlugin7.json +1 -1
- package/test/unit/ngsiv2/examples/contextRequests/updateContextMultientityPlugin8.json +2 -2
- package/test/unit/ngsiv2/examples/contextRequests/updateContextMultientityPlugin9.json +1 -1
- package/test/unit/ngsiv2/examples/contextRequests/updateContextMultientityTimestampPlugin1.json +8 -8
- package/test/unit/ngsiv2/examples/contextRequests/updateContextMultientityTimestampPlugin2.json +4 -4
- package/test/unit/ngsiv2/examples/contextRequests/updateContextMultientityTimestampPlugin3.json +1 -1
- package/test/unit/ngsiv2/examples/contextRequests/updateContextMultientityTimestampPlugin4.json +2 -2
- package/test/unit/ngsiv2/examples/contextRequests/updateProvisionDevice.json +20 -0
- package/test/unit/ngsiv2/examples/subscriptionRequests/bidirectionalSubscriptionRequest.json +1 -1
- package/test/unit/ngsiv2/examples/subscriptionRequests/simpleSubscriptionRequest.json +1 -1
- package/test/unit/ngsiv2/examples/subscriptionRequests/simpleSubscriptionRequest2.json +1 -1
- package/test/unit/ngsiv2/expressions/expressionBasedTransformations-test.js +93 -60
- package/test/unit/ngsiv2/expressions/expressionCombinedTransformations-test.js +16 -16
- package/test/unit/ngsiv2/expressions/jexlBasedTransformations-test.js +548 -164
- package/test/unit/ngsiv2/general/contextBrokerOAuthSecurityAccess-test.js +34 -33
- package/test/unit/ngsiv2/general/deviceService-test.js +15 -14
- package/test/unit/ngsiv2/general/https-support-test.js +14 -13
- package/test/unit/ngsiv2/general/iotam-autoregistration-test.js +8 -7
- package/test/unit/ngsiv2/general/startup-test.js +2 -1
- package/test/unit/ngsiv2/lazyAndCommands/active-devices-attribute-update-test.js +9 -7
- package/test/unit/ngsiv2/lazyAndCommands/command-test.js +13 -12
- package/test/unit/ngsiv2/lazyAndCommands/lazy-devices-test.js +323 -51
- package/test/unit/ngsiv2/lazyAndCommands/polling-commands-test.js +22 -20
- package/test/unit/ngsiv2/ngsiService/active-devices-test.js +114 -26
- package/test/unit/ngsiv2/ngsiService/autocast-test.js +16 -16
- package/test/unit/ngsiv2/ngsiService/geoproperties-test.js +39 -38
- package/test/unit/{ngsiService → ngsiv2/ngsiService}/queryDeviceInformationInCb-test.js +25 -54
- package/test/unit/ngsiv2/ngsiService/staticAttributes-test.js +5 -5
- package/test/unit/ngsiv2/ngsiService/subscriptions-test.js +25 -24
- package/test/unit/ngsiv2/plugins/alias-plugin_test.js +22 -22
- package/test/unit/ngsiv2/plugins/bidirectional-plugin_test.js +27 -26
- package/test/unit/ngsiv2/plugins/compress-timestamp-plugin_test.js +7 -7
- package/test/unit/ngsiv2/plugins/event-plugin_test.js +4 -4
- package/test/unit/ngsiv2/plugins/multientity-plugin_test.js +549 -24
- package/test/unit/ngsiv2/plugins/timestamp-processing-plugin_test.js +4 -4
- package/test/unit/{plugins → ngsiv2/plugins}/translation-inPlugins_test.js +25 -25
- package/test/unit/{provisioning → ngsiv2/provisioning}/device-group-api-test.js +44 -75
- package/test/unit/{provisioning/device-group-utils_test.js → ngsiv2/provisioning/device-group-utils-test.js} +15 -14
- package/test/unit/ngsiv2/provisioning/device-provisioning-api_test.js +74 -73
- package/test/unit/ngsiv2/provisioning/device-registration_test.js +20 -19
- package/test/unit/ngsiv2/provisioning/device-update-registration_test.js +30 -29
- package/test/unit/ngsiv2/provisioning/listProvisionedDevices-test.js +58 -69
- package/test/unit/ngsiv2/provisioning/provisionDeviceMultientity-test.js +8 -7
- package/test/unit/ngsiv2/provisioning/removeProvisionedDevice-test.js +19 -19
- package/test/unit/ngsiv2/provisioning/singleConfigurationMode-test.js +18 -19
- package/test/unit/ngsiv2/provisioning/updateProvisionedDevices-test.js +49 -52
- package/test/unit/plugins/capture-configuration-inPlugins_test.js +6 -4
- package/test/unit/plugins/capture-provision-inPlugins_test.js +13 -23
- package/.nyc_output/016aca19-69bf-4681-9b41-2835c5131681.json +0 -1
- package/.nyc_output/processinfo/016aca19-69bf-4681-9b41-2835c5131681.json +0 -1
- package/.nyc_output/processinfo/index.json +0 -1
- package/lib/services/devices/devices-NGSI-v1.js +0 -293
- package/lib/services/devices/registrationUtils.js_avega +0 -589
- package/lib/services/ngsi/entities-NGSI-v1.js +0 -300
- 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 -22
- 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 -11
- 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/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/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 -16
- 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/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
|
@@ -34,6 +34,7 @@ const context = {
|
|
|
34
34
|
};
|
|
35
35
|
const apply = async.apply;
|
|
36
36
|
let provisioningHandler;
|
|
37
|
+
let updatingHandler;
|
|
37
38
|
let removeDeviceHandler;
|
|
38
39
|
let updateDeviceTemplate;
|
|
39
40
|
let createDeviceTemplate;
|
|
@@ -53,6 +54,7 @@ const provisioningAPITranslation = {
|
|
|
53
54
|
protocol: 'protocol',
|
|
54
55
|
transport: 'transport',
|
|
55
56
|
endpoint: 'endpoint',
|
|
57
|
+
polling: 'polling',
|
|
56
58
|
attributes: 'active',
|
|
57
59
|
commands: 'commands',
|
|
58
60
|
lazy: 'lazy',
|
|
@@ -181,7 +183,8 @@ function attributeToProvisioningAPIFormat(attribute) {
|
|
|
181
183
|
reverse: attribute.reverse,
|
|
182
184
|
entity_name: attribute.entity_name,
|
|
183
185
|
entity_type: attribute.entity_type,
|
|
184
|
-
mqtt: attribute.mqtt
|
|
186
|
+
mqtt: attribute.mqtt,
|
|
187
|
+
metadata: attribute.metadata
|
|
185
188
|
};
|
|
186
189
|
}
|
|
187
190
|
|
|
@@ -203,6 +206,7 @@ function toProvisioningAPIFormat(device) {
|
|
|
203
206
|
timezone: device.timezone,
|
|
204
207
|
timestamp: device.timestamp,
|
|
205
208
|
endpoint: device.endpoint,
|
|
209
|
+
polling: device.polling,
|
|
206
210
|
transport: device.transport,
|
|
207
211
|
attributes: device.active ? device.active.map(attributeToProvisioningAPIFormat) : undefined,
|
|
208
212
|
lazy: device.lazy ? device.lazy.map(attributeToProvisioningAPIFormat) : undefined,
|
|
@@ -316,7 +320,15 @@ function handleRemoveDevice(req, res, next) {
|
|
|
316
320
|
* This middleware handles updates in the provisioning devices. The only attribute
|
|
317
321
|
*/
|
|
318
322
|
function handleUpdateDevice(req, res, next) {
|
|
319
|
-
|
|
323
|
+
function applyUpdatingHandler(device, callback) {
|
|
324
|
+
if (updatingHandler) {
|
|
325
|
+
updatingHandler(device, callback);
|
|
326
|
+
} else {
|
|
327
|
+
callback(null, device);
|
|
328
|
+
}
|
|
329
|
+
}
|
|
330
|
+
|
|
331
|
+
if (req.body.device_id) {
|
|
320
332
|
next(new errors.BadRequest("Can't change the ID of a preprovisioned device"));
|
|
321
333
|
} else {
|
|
322
334
|
deviceService.getDevice(
|
|
@@ -333,13 +345,23 @@ function handleUpdateDevice(req, res, next) {
|
|
|
333
345
|
for (const i in pairs) {
|
|
334
346
|
newDevice[provisioningAPITranslation[pairs[i][0]]] = pairs[i][1];
|
|
335
347
|
}
|
|
336
|
-
|
|
337
|
-
|
|
338
|
-
|
|
339
|
-
|
|
340
|
-
|
|
341
|
-
|
|
342
|
-
|
|
348
|
+
var isTypeOrNameUpdated = false;
|
|
349
|
+
if (req.body.entity_name || req.body.entity_type) {
|
|
350
|
+
isTypeOrNameUpdated = true;
|
|
351
|
+
}
|
|
352
|
+
async.waterfall([apply(applyUpdatingHandler, newDevice)], function handleUpdating(
|
|
353
|
+
error,
|
|
354
|
+
newDeviceUpdated
|
|
355
|
+
) {
|
|
356
|
+
deviceService.updateRegister(newDeviceUpdated, isTypeOrNameUpdated, function handleDeviceUpdate(
|
|
357
|
+
error
|
|
358
|
+
) {
|
|
359
|
+
if (error) {
|
|
360
|
+
next(error);
|
|
361
|
+
} else {
|
|
362
|
+
res.status(204).json({});
|
|
363
|
+
}
|
|
364
|
+
});
|
|
343
365
|
});
|
|
344
366
|
} else {
|
|
345
367
|
next(new errors.DeviceNotFound(req.params.deviceId));
|
|
@@ -388,6 +410,10 @@ function setProvisioningHandler(newHandler) {
|
|
|
388
410
|
provisioningHandler = newHandler;
|
|
389
411
|
}
|
|
390
412
|
|
|
413
|
+
function setUpdatingHandler(newHandler) {
|
|
414
|
+
updatingHandler = newHandler;
|
|
415
|
+
}
|
|
416
|
+
|
|
391
417
|
function setRemoveDeviceHandler(newHandler) {
|
|
392
418
|
removeDeviceHandler = newHandler;
|
|
393
419
|
}
|
|
@@ -405,6 +431,7 @@ function clear(callback) {
|
|
|
405
431
|
exports.setConfiguration = setConfiguration;
|
|
406
432
|
exports.loadContextRoutes = intoTrans(context, loadContextRoutes);
|
|
407
433
|
exports.setProvisioningHandler = intoTrans(context, setProvisioningHandler);
|
|
434
|
+
exports.setUpdatingHandler = intoTrans(context, setUpdatingHandler);
|
|
408
435
|
exports.setRemoveDeviceHandler = intoTrans(context, setRemoveDeviceHandler);
|
|
409
436
|
exports.addDeviceProvisionMiddleware = addDeviceProvisionMiddleware;
|
|
410
437
|
exports.clear = clear;
|
|
@@ -31,6 +31,7 @@ const domainUtils = require('../common/domain');
|
|
|
31
31
|
const middlewares = require('../common/genericMiddleware');
|
|
32
32
|
const intoTrans = domainUtils.intoTrans;
|
|
33
33
|
const deviceProvisioning = require('./deviceProvisioningServer');
|
|
34
|
+
const deviceUpdating = require('./deviceProvisioningServer');
|
|
34
35
|
const groupProvisioning = require('./deviceGroupAdministrationServer');
|
|
35
36
|
const logger = require('logops');
|
|
36
37
|
const context = {
|
|
@@ -116,6 +117,7 @@ exports.setNotificationHandler = intoTrans(context, contextServer.setNotificatio
|
|
|
116
117
|
exports.setConfigurationHandler = intoTrans(context, groupProvisioning.setConfigurationHandler);
|
|
117
118
|
exports.setRemoveConfigurationHandler = intoTrans(context, groupProvisioning.setRemoveConfigurationHandler);
|
|
118
119
|
exports.setProvisioningHandler = intoTrans(context, deviceProvisioning.setProvisioningHandler);
|
|
120
|
+
exports.setUpdatingHandler = intoTrans(context, deviceUpdating.setUpdatingHandler);
|
|
119
121
|
exports.setRemoveDeviceHandler = intoTrans(context, deviceProvisioning.setRemoveDeviceHandler);
|
|
120
122
|
exports.addDeviceProvisionMiddleware = deviceProvisioning.addDeviceProvisionMiddleware;
|
|
121
123
|
exports.addConfigurationProvisionMiddleware = groupProvisioning.addConfigurationProvisionMiddleware;
|
|
@@ -35,7 +35,7 @@ const context = {
|
|
|
35
35
|
op: 'IoTAgentNGSI.RestUtils'
|
|
36
36
|
};
|
|
37
37
|
const _ = require('underscore');
|
|
38
|
-
const request = require('request');
|
|
38
|
+
const request = require('../../request-shim');
|
|
39
39
|
const async = require('async');
|
|
40
40
|
const apply = async.apply;
|
|
41
41
|
const ngsiService = require('../ngsi/ngsiService');
|
|
@@ -123,25 +123,6 @@ function checkBody(template) {
|
|
|
123
123
|
};
|
|
124
124
|
}
|
|
125
125
|
|
|
126
|
-
/**
|
|
127
|
-
* Checks if the timestamp properties of NGSIv1 entities are valid ISO8601 dates.
|
|
128
|
-
*
|
|
129
|
-
* @param {Object} payload NGSIv1 payload to be analyzed.
|
|
130
|
-
* @return {Boolean} true if timestamp attributes are valid ISO8601. false if not.
|
|
131
|
-
*/
|
|
132
|
-
function IsValidTimestamped(payload) {
|
|
133
|
-
for (const i in payload.contextElements[0].attributes) {
|
|
134
|
-
if (
|
|
135
|
-
payload.contextElements[0].attributes[i].name === constants.TIMESTAMP_ATTRIBUTE &&
|
|
136
|
-
!moment(payload.contextElements[0].attributes[i].value, moment.ISO_8601).isValid()
|
|
137
|
-
) {
|
|
138
|
-
return false;
|
|
139
|
-
}
|
|
140
|
-
}
|
|
141
|
-
|
|
142
|
-
return true;
|
|
143
|
-
}
|
|
144
|
-
|
|
145
126
|
/**
|
|
146
127
|
* Checks if the timestamp properties of NGSIv2 entities are valid ISO8601 dates.
|
|
147
128
|
*
|
|
@@ -173,22 +154,6 @@ function IsValidTimestampedNgsi2(payload) {
|
|
|
173
154
|
return isValidTimestampedNgsi2Entity(payload);
|
|
174
155
|
}
|
|
175
156
|
|
|
176
|
-
/**
|
|
177
|
-
* Checks if timestamp attributes are included in NGSIv1 entities.
|
|
178
|
-
*
|
|
179
|
-
* @param {Object} payload NGSIv1 payload to be analyzed.
|
|
180
|
-
* @return {Boolean} true if timestamp attributes are included. false if not.
|
|
181
|
-
*/
|
|
182
|
-
function isTimestamped(payload) {
|
|
183
|
-
for (const i in payload.contextElements[0].attributes) {
|
|
184
|
-
if (payload.contextElements[0].attributes[i].name === constants.TIMESTAMP_ATTRIBUTE) {
|
|
185
|
-
return true;
|
|
186
|
-
}
|
|
187
|
-
}
|
|
188
|
-
|
|
189
|
-
return false;
|
|
190
|
-
}
|
|
191
|
-
|
|
192
157
|
/**
|
|
193
158
|
* Checks if timestamp attributes are included in NGSIv2 entities.
|
|
194
159
|
*
|
|
@@ -228,7 +193,7 @@ function isTimestampedNgsi2(payload) {
|
|
|
228
193
|
*/
|
|
229
194
|
function executeWithSecurity(requestOptions, deviceData, callback) {
|
|
230
195
|
logger.debug(context, 'executeWithSecurity');
|
|
231
|
-
config.getGroupRegistry().
|
|
196
|
+
config.getGroupRegistry().getTypeSilently(deviceData.type, function (error, deviceGroup) {
|
|
232
197
|
let typeInformation;
|
|
233
198
|
if (error) {
|
|
234
199
|
logger.debug(context, 'error %j in get group device', error);
|
|
@@ -273,7 +238,5 @@ exports.executeWithSecurity = executeWithSecurity;
|
|
|
273
238
|
exports.checkMandatoryQueryParams = intoTrans(context, checkMandatoryQueryParams);
|
|
274
239
|
exports.checkRequestAttributes = intoTrans(context, checkRequestAttributes);
|
|
275
240
|
exports.checkBody = intoTrans(context, checkBody);
|
|
276
|
-
exports.isTimestamped = isTimestamped;
|
|
277
|
-
exports.IsValidTimestamped = IsValidTimestamped;
|
|
278
241
|
exports.isTimestampedNgsi2 = isTimestampedNgsi2;
|
|
279
242
|
exports.IsValidTimestampedNgsi2 = IsValidTimestampedNgsi2;
|
|
@@ -177,6 +177,10 @@
|
|
|
177
177
|
}
|
|
178
178
|
}
|
|
179
179
|
},
|
|
180
|
+
"internal_attributes": {
|
|
181
|
+
"description": "Free form array of internal attributes for particular IOTAgents",
|
|
182
|
+
"type": "any"
|
|
183
|
+
},
|
|
180
184
|
"static_attributes": {
|
|
181
185
|
"description": "Free form array of data to be appended to the target entity",
|
|
182
186
|
"type": "array"
|
|
@@ -149,6 +149,10 @@
|
|
|
149
149
|
}
|
|
150
150
|
}
|
|
151
151
|
},
|
|
152
|
+
"internal_attributes": {
|
|
153
|
+
"description": "Free form array of internal attributes for particular IOTAgents",
|
|
154
|
+
"type": "any"
|
|
155
|
+
},
|
|
152
156
|
"static_attributes": {
|
|
153
157
|
"description": "Free form array of data to be appended to the target entity",
|
|
154
158
|
"type": "array"
|
package/package.json
CHANGED
|
@@ -2,7 +2,7 @@
|
|
|
2
2
|
"name": "iotagent-node-lib",
|
|
3
3
|
"license": "AGPL-3.0-only",
|
|
4
4
|
"description": "IoT Agent library to interface with NGSI Context Broker",
|
|
5
|
-
"version": "2.
|
|
5
|
+
"version": "2.19.0",
|
|
6
6
|
"homepage": "https://github.com/telefonicaid/iotagent-node-lib",
|
|
7
7
|
"keywords": [
|
|
8
8
|
"fiware",
|
|
@@ -27,7 +27,7 @@
|
|
|
27
27
|
},
|
|
28
28
|
"main": "lib/fiware-iotagent-lib",
|
|
29
29
|
"engines": {
|
|
30
|
-
"node": ">=
|
|
30
|
+
"node": ">=12"
|
|
31
31
|
},
|
|
32
32
|
"scripts": {
|
|
33
33
|
"clean": "rm -rf package-lock.json && rm -rf node_modules && rm -rf coverage",
|
|
@@ -36,7 +36,9 @@
|
|
|
36
36
|
"lint:text": "textlint '*.md' 'doc/*.md'",
|
|
37
37
|
"prettier": "prettier --config .prettierrc.json --write '**/**/**/**/*.js' '**/**/**/*.js' '**/**/*.js' '**/*.js' '*.js'",
|
|
38
38
|
"prettier:text": "prettier 'README.md' 'doc/*.md' 'doc/**/*.md' --no-config --tab-width 4 --print-width 120 --write --prose-wrap always",
|
|
39
|
-
"test": "nyc --reporter=text mocha --recursive 'test/**/*.js' --reporter spec --timeout
|
|
39
|
+
"test": "nyc --reporter=text mocha --recursive 'test/**/*.js' --reporter spec --timeout 8000 --ui bdd --exit --color true",
|
|
40
|
+
"test:expression": "nyc --reporter=text mocha --recursive 'test/unit/expressions/*.js' --reporter spec --timeout 5000 --ui bdd --exit --color true",
|
|
41
|
+
"test:multientity": "nyc --reporter=text mocha --recursive 'test/unit/ngsiv2/plugins/multientity-plugin_test.js' --reporter spec --timeout 5000 --ui bdd --exit --color true",
|
|
40
42
|
"test:debug": "mocha --recursive 'test/**/*.js' --reporter spec --inspect-brk --timeout 30000 --ui bdd --exit",
|
|
41
43
|
"test:coverage": "nyc --reporter=lcov mocha -- --recursive 'test/**/*.js' --reporter spec --timeout 5000 --exit",
|
|
42
44
|
"test:coveralls": "npm run test:coverage && cat ./coverage/lcov.info | coveralls && rm -rf ./coverage",
|
|
@@ -48,18 +50,18 @@
|
|
|
48
50
|
"body-parser": "~1.19.0",
|
|
49
51
|
"command-shell-lib": "1.0.0",
|
|
50
52
|
"express": "~4.16.4",
|
|
51
|
-
"
|
|
53
|
+
"got": "~11.8.2",
|
|
54
|
+
"jexl": "2.3.0",
|
|
52
55
|
"jison": "0.4.18",
|
|
53
|
-
"logops": "2.1.
|
|
56
|
+
"logops": "2.1.2",
|
|
54
57
|
"moment": "~2.24.0",
|
|
55
58
|
"moment-timezone": "~0.5.25",
|
|
56
|
-
"mongodb": "3.
|
|
57
|
-
"mongoose": "5.7.
|
|
59
|
+
"mongodb": "3.6.8",
|
|
60
|
+
"mongoose": "5.7.7",
|
|
58
61
|
"mu2": "~0.5.20",
|
|
59
62
|
"query-string": "6.5.0",
|
|
60
|
-
"request": "2.88.0",
|
|
61
63
|
"revalidator": "~0.3.1",
|
|
62
|
-
"underscore": "~1.
|
|
64
|
+
"underscore": "~1.12.1",
|
|
63
65
|
"uuid": "~3.3.2"
|
|
64
66
|
},
|
|
65
67
|
"devDependencies": {
|
|
@@ -92,12 +94,10 @@
|
|
|
92
94
|
},
|
|
93
95
|
"lint-staged": {
|
|
94
96
|
"*.md": [
|
|
95
|
-
"prettier --parser markdown --tab-width 4 --print-width 120 --write --prose-wrap always"
|
|
96
|
-
"git add"
|
|
97
|
+
"prettier --parser markdown --tab-width 4 --print-width 120 --write --prose-wrap always"
|
|
97
98
|
],
|
|
98
99
|
"*.js": [
|
|
99
|
-
"prettier --config .prettierrc.json --write"
|
|
100
|
-
"git add"
|
|
100
|
+
"prettier --config .prettierrc.json --write"
|
|
101
101
|
]
|
|
102
102
|
}
|
|
103
103
|
}
|
package/test/tools/utils.js
CHANGED
|
@@ -22,6 +22,7 @@
|
|
|
22
22
|
*/
|
|
23
23
|
|
|
24
24
|
const fs = require('fs');
|
|
25
|
+
const request = require('../../lib/fiware-iotagent-lib').request;
|
|
25
26
|
|
|
26
27
|
function readExampleFile(name, raw) {
|
|
27
28
|
let text = null;
|
|
@@ -36,3 +37,4 @@ function readExampleFile(name, raw) {
|
|
|
36
37
|
}
|
|
37
38
|
|
|
38
39
|
exports.readExampleFile = readExampleFile;
|
|
40
|
+
exports.request = request;
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"protocol": "GENERIC_PROTOCOL",
|
|
3
3
|
"description": "A generic protocol",
|
|
4
|
-
"iotagent": "http://
|
|
4
|
+
"iotagent": "http://smartgondor.com/iot",
|
|
5
5
|
"resource": "/iot/d",
|
|
6
6
|
"services": [
|
|
7
7
|
{
|
|
@@ -10,7 +10,7 @@
|
|
|
10
10
|
"cbHost":"http://unexistentHost:1026",
|
|
11
11
|
"entity_type": "SensorMachine",
|
|
12
12
|
"resource": "/deviceTest",
|
|
13
|
-
"service": "
|
|
13
|
+
"service": "theservice",
|
|
14
14
|
"service_path": "theSubService",
|
|
15
15
|
"attributes": [
|
|
16
16
|
{
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"protocol": "GENERIC_PROTOCOL",
|
|
3
3
|
"description": "A generic protocol",
|
|
4
|
-
"iotagent": "http://
|
|
4
|
+
"iotagent": "http://smartgondor.com/iot",
|
|
5
5
|
"resource": "/iot/d",
|
|
6
6
|
"services": [
|
|
7
7
|
{
|
|
@@ -9,7 +9,7 @@
|
|
|
9
9
|
"token": "8970A9078A803H3BL98PINEQRW8342HBAMS",
|
|
10
10
|
"entity_type": "SensorMachine",
|
|
11
11
|
"resource": "/deviceTest",
|
|
12
|
-
"service": "
|
|
12
|
+
"service": "theservice",
|
|
13
13
|
"service_path": "theSubService",
|
|
14
14
|
"attributes": [
|
|
15
15
|
{
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"protocol": "GENERIC_PROTOCOL",
|
|
3
3
|
"description": "A generic protocol",
|
|
4
|
-
"iotagent": "http://
|
|
4
|
+
"iotagent": "http://smartgondor.com/iot",
|
|
5
5
|
"resource": "/iot/d",
|
|
6
6
|
"services": [
|
|
7
7
|
{
|
|
@@ -10,7 +10,7 @@
|
|
|
10
10
|
"cbHost":"http://unexistentHost:1026",
|
|
11
11
|
"entity_type": "SensorMachine",
|
|
12
12
|
"resource": "/deviceTest",
|
|
13
|
-
"service": "
|
|
13
|
+
"service": "theservice",
|
|
14
14
|
"service_path": "theSubService",
|
|
15
15
|
"attributes": [
|
|
16
16
|
{
|
|
@@ -23,6 +23,7 @@
|
|
|
23
23
|
|
|
24
24
|
const should = require('should');
|
|
25
25
|
const expressionParser = require('../../../lib/plugins/jexlParser');
|
|
26
|
+
expressionParser.setTransforms({});
|
|
26
27
|
|
|
27
28
|
describe('Jexl expression interpreter', function () {
|
|
28
29
|
const scope = {
|
|
@@ -203,6 +204,16 @@ describe('Jexl expression interpreter', function () {
|
|
|
203
204
|
});
|
|
204
205
|
});
|
|
205
206
|
|
|
207
|
+
describe('When an slice function is used with an string', function () {
|
|
208
|
+
it('should work on the expression value', function (done) {
|
|
209
|
+
expressionParser.parse('"AABBCC"|slice(2,4)', scope, function (error, result) {
|
|
210
|
+
should.not.exist(error);
|
|
211
|
+
result.should.equal('BB');
|
|
212
|
+
done();
|
|
213
|
+
});
|
|
214
|
+
});
|
|
215
|
+
});
|
|
216
|
+
|
|
206
217
|
describe('When an ternary operator is used with an expression', function () {
|
|
207
218
|
it('should work on the expression value', function (done) {
|
|
208
219
|
expressionParser.parse('value == 6? true : false', scope, function (error, result) {
|
|
@@ -243,6 +254,97 @@ describe('Jexl expression interpreter', function () {
|
|
|
243
254
|
});
|
|
244
255
|
});
|
|
245
256
|
|
|
257
|
+
describe('When an transformstion map is provided', function () {
|
|
258
|
+
const niceMap = {
|
|
259
|
+
method1: (val) => val,
|
|
260
|
+
method2: (val) => val
|
|
261
|
+
};
|
|
262
|
+
|
|
263
|
+
const wrongMap = {
|
|
264
|
+
wrongTransformation1: 'not a function',
|
|
265
|
+
wrongTransformation2: 666,
|
|
266
|
+
rightTransformation: (val) => val
|
|
267
|
+
};
|
|
268
|
+
|
|
269
|
+
const noMap = "I'm not what you expect";
|
|
270
|
+
|
|
271
|
+
it('it should detect when it is not a map', function (done) {
|
|
272
|
+
const [error, message, resultMap] = expressionParser.checkTransformationMap(noMap);
|
|
273
|
+
should.exist(error);
|
|
274
|
+
message.should.equal('No trasformations were added to JEXL Parser');
|
|
275
|
+
resultMap.should.eql({});
|
|
276
|
+
done();
|
|
277
|
+
});
|
|
278
|
+
|
|
279
|
+
it('it should be empty {}', function (done) {
|
|
280
|
+
const [error, message, resultMap] = expressionParser.checkTransformationMap({});
|
|
281
|
+
should.not.exist(error);
|
|
282
|
+
message.should.equal('No trasformations were added to JEXL Parser');
|
|
283
|
+
resultMap.should.eql({});
|
|
284
|
+
done();
|
|
285
|
+
});
|
|
286
|
+
|
|
287
|
+
it('it should be empty null', function (done) {
|
|
288
|
+
const [error, message, resultMap] = expressionParser.checkTransformationMap(null);
|
|
289
|
+
should.not.exist(error);
|
|
290
|
+
message.should.equal('No trasformations were added to JEXL Parser');
|
|
291
|
+
resultMap.should.eql({});
|
|
292
|
+
done();
|
|
293
|
+
});
|
|
294
|
+
|
|
295
|
+
it('it should detect wrong transformations (not a funtion)', function (done) {
|
|
296
|
+
const [error, message, resultMap] = expressionParser.checkTransformationMap(wrongMap);
|
|
297
|
+
should.not.exist(error);
|
|
298
|
+
message.should.equal('wrongTransformation1,wrongTransformation2 must be a function');
|
|
299
|
+
should.not.exist(resultMap.wrongTransformation1);
|
|
300
|
+
should.not.exist(resultMap.wrongTransformation2);
|
|
301
|
+
should.exist(resultMap.rightTransformation);
|
|
302
|
+
done();
|
|
303
|
+
});
|
|
304
|
+
|
|
305
|
+
it('it should be correct (map of funtions)', function (done) {
|
|
306
|
+
const [error, message, resultMap] = expressionParser.checkTransformationMap(niceMap);
|
|
307
|
+
should.not.exist(error);
|
|
308
|
+
message.should.equal('Trasformations can be added to JEXL parser');
|
|
309
|
+
resultMap.should.eql(niceMap);
|
|
310
|
+
done();
|
|
311
|
+
});
|
|
312
|
+
});
|
|
313
|
+
|
|
314
|
+
describe('When a JSON parse transformation is applied', function () {
|
|
315
|
+
it('should work on the expression value', function (done) {
|
|
316
|
+
expressionParser.parse('"{\\"name\\":\\"John\\",\\"surname\\":\\"Doe\\"}"|jsonparse', scope, function (
|
|
317
|
+
error,
|
|
318
|
+
result
|
|
319
|
+
) {
|
|
320
|
+
should.not.exist(error);
|
|
321
|
+
result.should.eql(scope.object);
|
|
322
|
+
done();
|
|
323
|
+
});
|
|
324
|
+
});
|
|
325
|
+
});
|
|
326
|
+
|
|
327
|
+
describe('When a JSON stringify transformation is applied', function () {
|
|
328
|
+
it('should work on the expression value', function (done) {
|
|
329
|
+
expressionParser.parse('{name: "John",surname: "Doe"}|jsonstringify', scope, function (error, result) {
|
|
330
|
+
should.not.exist(error);
|
|
331
|
+
result.should.equal(JSON.stringify(scope.object));
|
|
332
|
+
done();
|
|
333
|
+
});
|
|
334
|
+
});
|
|
335
|
+
});
|
|
336
|
+
|
|
337
|
+
describe('When a JSON with an NGSI operator is applied', function () {
|
|
338
|
+
it('should work on the expression value', function (done) {
|
|
339
|
+
const scope = { ina: 34, outa: 4 };
|
|
340
|
+
expressionParser.parse('{$inc:ina-outa}', scope, function (error, result) {
|
|
341
|
+
should.not.exist(error);
|
|
342
|
+
result.should.eql({ $inc: 30 });
|
|
343
|
+
done();
|
|
344
|
+
});
|
|
345
|
+
});
|
|
346
|
+
});
|
|
347
|
+
|
|
246
348
|
describe('When an expression aims at creating an object', function () {
|
|
247
349
|
it('it should work', function (done) {
|
|
248
350
|
expressionParser.parse('{type:"Point",coordinates: [value,other]}', scope, function (error, result) {
|
|
@@ -252,4 +354,21 @@ describe('Jexl expression interpreter', function () {
|
|
|
252
354
|
});
|
|
253
355
|
});
|
|
254
356
|
});
|
|
357
|
+
|
|
358
|
+
describe('When an expression access to non existent property', function () {
|
|
359
|
+
it('it should return null', function (done) {
|
|
360
|
+
expressionParser.parse('object["nothing"]', scope, function (error, result) {
|
|
361
|
+
should.not.exist(error);
|
|
362
|
+
should.equal(result, null);
|
|
363
|
+
done();
|
|
364
|
+
});
|
|
365
|
+
});
|
|
366
|
+
it('it should return null', function (done) {
|
|
367
|
+
expressionParser.parse('object["nothing"]?object["nothing"]:null', scope, function (error, result) {
|
|
368
|
+
should.not.exist(error);
|
|
369
|
+
should.equal(result, null);
|
|
370
|
+
done();
|
|
371
|
+
});
|
|
372
|
+
});
|
|
373
|
+
});
|
|
255
374
|
});
|