Commit d5c3f4c9973cdc4eaf90c6599a9b42f51c9a1ef8

Authored by Vladyslav_Prykhodko
2 parents b9d39041 61723da3

Merge master in develop/3.3

Showing 100 changed files with 257 additions and 126 deletions

Too many changes to show.

To preserve performance only 100 of 2885 files are displayed.

1 1 <!--
2 2
3   - Copyright © 2016-2020 The Thingsboard Authors
  3 + Copyright © 2016-2021 The Thingsboard Authors
4 4
5 5 Licensed under the Apache License, Version 2.0 (the "License");
6 6 you may not use this file except in compliance with the License.
... ...
1 1 <?xml version="1.0" encoding="UTF-8" ?>
2 2 <!--
3 3
4   - Copyright © 2016-2020 The Thingsboard Authors
  4 + Copyright © 2016-2021 The Thingsboard Authors
5 5
6 6 Licensed under the Apache License, Version 2.0 (the "License");
7 7 you may not use this file except in compliance with the License.
... ...
1 1 #
2   -# Copyright © 2016-2020 The Thingsboard Authors
  2 +# Copyright © 2016-2021 The Thingsboard Authors
3 3 #
4 4 # Licensed under the Apache License, Version 2.0 (the "License");
5 5 # you may not use this file except in compliance with the License.
... ...
... ... @@ -18,7 +18,7 @@
18 18 "controllerScript": "self.onInit = function() {\n self.ctx.map = new TbMapWidgetV2('openstreet-map', false, self.ctx, null, true);\n}\n\nself.onDataUpdated = function() {\n self.ctx.map.update();\n}\n\nself.onResize = function() {\n self.ctx.map.resize();\n}\n\nself.getSettingsSchema = function() {\n return TbMapWidgetV2.settingsSchema('openstreet-map');\n}\n\nself.getDataKeySettingsSchema = function() {\n return TbMapWidgetV2.dataKeySettingsSchema('openstreet-map');\n}\n\nself.actionSources = function() {\n return TbMapWidgetV2.actionSources();\n}\n\nself.onDestroy = function() {\n}\n\nself.typeParameters = function() {\n return {\n hasDataPageLink: true\n };\n}",
19 19 "settingsSchema": "{}",
20 20 "dataKeySettingsSchema": "{}\n",
21   - "defaultConfig": "{\"datasources\":[{\"type\":\"function\",\"name\":\"First point\",\"dataKeys\":[{\"name\":\"f(x)\",\"type\":\"function\",\"label\":\"latitude\",\"color\":\"#2196f3\",\"settings\":{},\"_hash\":0.05427416942713381,\"funcBody\":\"var value = prevValue || 15.833293;\\nif (time % 5000 < 500) {\\n value += Math.random() * 0.05 - 0.025;\\n}\\nreturn value;\"},{\"name\":\"f(x)\",\"type\":\"function\",\"label\":\"longitude\",\"color\":\"#4caf50\",\"settings\":{},\"_hash\":0.680594833308841,\"funcBody\":\"var value = prevValue || -90.454350;\\nif (time % 5000 < 500) {\\n value += Math.random() * 0.05 - 0.025;\\n}\\nreturn value;\"}]},{\"type\":\"function\",\"name\":\"Second point\",\"dataKeys\":[{\"name\":\"f(x)\",\"type\":\"function\",\"label\":\"latitude\",\"color\":\"#607d8b\",\"settings\":{},\"_hash\":0.7867521952070078,\"funcBody\":\"var value = prevValue || 14.450463;\\nif (time % 4000 < 500) {\\n value += Math.random() * 0.05 - 0.025;\\n}\\nreturn value;\"},{\"name\":\"f(x)\",\"type\":\"function\",\"label\":\"longitude\",\"color\":\"#9c27b0\",\"settings\":{},\"_hash\":0.7040053227577256,\"funcBody\":\"var value = prevValue || -84.845334;\\nif (time % 4000 < 500) {\\n value += Math.random() * 0.05 - 0.025;\\n}\\nreturn value;\"}]}],\"timewindow\":{\"realtime\":{\"timewindowMs\":60000}},\"showTitle\":true,\"backgroundColor\":\"#fff\",\"color\":\"rgba(0, 0, 0, 0.87)\",\"padding\":\"8px\",\"settings\":{\"fitMapBounds\":true,\"latKeyName\":\"latitude\",\"lngKeyName\":\"longitude\",\"showLabel\":true,\"label\":\"${entityName}\",\"tooltipPattern\":\"<b>${entityName}</b><br/><br/><b>Latitude:</b> ${latitude:7}<br/><b>Longitude:</b> ${longitude:7}<br/><br/><link-act name='delete'>Delete</link-act>\",\"markerImageSize\":34,\"useColorFunction\":false,\"markerImages\":[],\"useMarkerImageFunction\":false,\"color\":\"#fe7569\",\"mapProvider\":\"OpenStreetMap.Mapnik\",\"showTooltip\":true,\"autocloseTooltip\":true,\"defaultCenterPosition\":\"0,0\",\"customProviderTileUrl\":\"https://{s}.tile.openstreetmap.org/{z}/{x}/{y}.png\",\"showTooltipAction\":\"click\",\"polygonKeyName\":\"coordinates\",\"polygonOpacity\":0.5,\"polygonStrokeOpacity\":1,\"polygonStrokeWeight\":1,\"zoomOnClick\":true,\"showCoverageOnHover\":true,\"animate\":true,\"maxClusterRadius\":80,\"removeOutsideVisibleBounds\":true,\"defaultZoomLevel\":5,\"provider\":\"openstreet-map\",\"draggableMarker\":true,\"editablePolygon\":true,\"mapPageSize\":16384,\"showPolygon\":false,\"polygonTooltipPattern\":\"<b>${entityName}</b><br/><br/><b>TimeStamp:</b> ${coordinates|ts:7}<br/><br/><link-act name='delete'>Delete</link-act>\"},\"title\":\"Markers Placement - OpenStreetMap\",\"dropShadow\":true,\"enableFullscreen\":true,\"titleStyle\":{\"fontSize\":\"16px\",\"fontWeight\":400},\"useDashboardTimewindow\":true,\"showLegend\":false,\"widgetStyle\":{},\"actions\":{\"tooltipAction\":[{\"name\":\"delete\",\"icon\":\"more_horiz\",\"type\":\"custom\",\"customFunction\":\"var entityDatasource = widgetContext.map.map.datasources.filter(\\n function(entity) {\\n return entity.entityId === entityId.id;\\n });\\n\\nwidgetContext.map.setMarkerLocation(entityDatasource[0], null, null).subscribe();\",\"id\":\"54c293c4-9ca6-e34f-dc6a-0271944c1c66\"},{\"name\":\"delete_polygon\",\"icon\":\"more_horiz\",\"type\":\"custom\",\"customFunction\":\"var entityDatasource = widgetContext.map.map.datasources.filter(\\n function(entity) {\\n return entity.entityId === entityId.id\\n });\\n\\nwidgetContext.map.savePolygonLocation(entityDatasource[0], null).subscribe();\",\"id\":\"6beb7bed-dfd8-388d-b60c-82988ab52f06\"}]},\"showTitleIcon\":false,\"titleIcon\":\"more_horiz\",\"iconColor\":\"rgba(0, 0, 0, 0.87)\",\"iconSize\":\"24px\",\"titleTooltip\":\"\",\"displayTimewindow\":true}"
  21 + "defaultConfig": "{\"datasources\":[{\"type\":\"function\",\"name\":\"First point\",\"dataKeys\":[{\"name\":\"f(x)\",\"type\":\"function\",\"label\":\"latitude\",\"color\":\"#2196f3\",\"settings\":{},\"_hash\":0.05427416942713381,\"funcBody\":\"var value = prevValue || 15.833293;\\nif (time % 5000 < 500) {\\n value += Math.random() * 0.05 - 0.025;\\n}\\nreturn value;\"},{\"name\":\"f(x)\",\"type\":\"function\",\"label\":\"longitude\",\"color\":\"#4caf50\",\"settings\":{},\"_hash\":0.680594833308841,\"funcBody\":\"var value = prevValue || -90.454350;\\nif (time % 5000 < 500) {\\n value += Math.random() * 0.05 - 0.025;\\n}\\nreturn value;\"}]},{\"type\":\"function\",\"name\":\"Second point\",\"dataKeys\":[{\"name\":\"f(x)\",\"type\":\"function\",\"label\":\"latitude\",\"color\":\"#607d8b\",\"settings\":{},\"_hash\":0.7867521952070078,\"funcBody\":\"var value = prevValue || 14.450463;\\nif (time % 4000 < 500) {\\n value += Math.random() * 0.05 - 0.025;\\n}\\nreturn value;\"},{\"name\":\"f(x)\",\"type\":\"function\",\"label\":\"longitude\",\"color\":\"#9c27b0\",\"settings\":{},\"_hash\":0.7040053227577256,\"funcBody\":\"var value = prevValue || -84.845334;\\nif (time % 4000 < 500) {\\n value += Math.random() * 0.05 - 0.025;\\n}\\nreturn value;\"}]}],\"timewindow\":{\"realtime\":{\"timewindowMs\":60000}},\"showTitle\":true,\"backgroundColor\":\"#fff\",\"color\":\"rgba(0, 0, 0, 0.87)\",\"padding\":\"8px\",\"settings\":{\"fitMapBounds\":true,\"latKeyName\":\"latitude\",\"lngKeyName\":\"longitude\",\"showLabel\":true,\"label\":\"${entityName}\",\"tooltipPattern\":\"<b>${entityName}</b><br/><br/><b>Latitude:</b> ${latitude:7}<br/><b>Longitude:</b> ${longitude:7}<br/><br/><link-act name='delete'>Delete</link-act>\",\"markerImageSize\":34,\"useColorFunction\":false,\"markerImages\":[],\"useMarkerImageFunction\":false,\"color\":\"#fe7569\",\"mapProvider\":\"OpenStreetMap.Mapnik\",\"showTooltip\":true,\"autocloseTooltip\":true,\"defaultCenterPosition\":\"0,0\",\"customProviderTileUrl\":\"https://{s}.tile.openstreetmap.org/{z}/{x}/{y}.png\",\"showTooltipAction\":\"click\",\"polygonKeyName\":\"coordinates\",\"polygonOpacity\":0.5,\"polygonStrokeOpacity\":1,\"polygonStrokeWeight\":1,\"zoomOnClick\":true,\"showCoverageOnHover\":true,\"animate\":true,\"maxClusterRadius\":80,\"removeOutsideVisibleBounds\":true,\"defaultZoomLevel\":5,\"provider\":\"openstreet-map\",\"draggableMarker\":true,\"editablePolygon\":true,\"mapPageSize\":16384,\"showPolygon\":false,\"polygonTooltipPattern\":\"<b>${entityName}</b><br/><br/><b>TimeStamp:</b> ${coordinates|ts:7}<br/><br/><link-act name='delete'>Delete</link-act>\"},\"title\":\"Markers Placement - OpenStreetMap\",\"dropShadow\":true,\"enableFullscreen\":true,\"titleStyle\":{\"fontSize\":\"16px\",\"fontWeight\":400},\"useDashboardTimewindow\":true,\"showLegend\":false,\"widgetStyle\":{},\"actions\":{\"tooltipAction\":[{\"name\":\"delete\",\"icon\":\"more_horiz\",\"type\":\"custom\",\"customFunction\":\"var entityDatasource = widgetContext.map.map.datasources.filter(\\n function(entity) {\\n return entity.entityId === entityId.id;\\n });\\n\\nwidgetContext.map.setMarkerLocation(entityDatasource[0], null, null).subscribe(() => widgetContext.updateAliases());\",\"id\":\"54c293c4-9ca6-e34f-dc6a-0271944c1c66\"},{\"name\":\"delete_polygon\",\"icon\":\"more_horiz\",\"type\":\"custom\",\"customFunction\":\"var entityDatasource = widgetContext.map.map.datasources.filter(\\n function(entity) {\\n return entity.entityId === entityId.id\\n });\\n\\nwidgetContext.map.savePolygonLocation(entityDatasource[0], null).subscribe(() => widgetContext.updateAliases());\",\"id\":\"6beb7bed-dfd8-388d-b60c-82988ab52f06\"}]},\"showTitleIcon\":false,\"titleIcon\":\"more_horiz\",\"iconColor\":\"rgba(0, 0, 0, 0.87)\",\"iconSize\":\"24px\",\"titleTooltip\":\"\",\"displayTimewindow\":true}"
22 22 }
23 23 },
24 24 {
... ... @@ -66,7 +66,7 @@
66 66 "controllerScript": "self.onInit = function() {\n self.ctx.map = new TbMapWidgetV2('image-map', false, self.ctx, null, true);\n}\n\nself.onDataUpdated = function() {\n self.ctx.map.update();\n}\n\nself.onResize = function() {\n self.ctx.map.resize();\n}\n\nself.getSettingsSchema = function() {\n return TbMapWidgetV2.settingsSchema('image-map');\n}\n\nself.getDataKeySettingsSchema = function() {\n return TbMapWidgetV2.dataKeySettingsSchema('image-map');\n}\n\nself.actionSources = function() {\n return TbMapWidgetV2.actionSources();\n}\n\nself.onDestroy = function() {\n}\n\nself.typeParameters = function() {\n return {\n hasDataPageLink: true\n };\n}",
67 67 "settingsSchema": "{}",
68 68 "dataKeySettingsSchema": "{}\n",
69   - "defaultConfig": "{\"datasources\":[{\"type\":\"function\",\"name\":\"First point\",\"dataKeys\":[{\"name\":\"f(x)\",\"type\":\"function\",\"label\":\"xPos\",\"color\":\"#2196f3\",\"settings\":{},\"_hash\":0.05427416942713381,\"funcBody\":\"var value = prevValue || 0.2;\\nif (time % 5000 < 500) {\\n value += Math.random() * 0.05 - 0.025;\\n}\\nreturn value;\"},{\"name\":\"f(x)\",\"type\":\"function\",\"label\":\"yPos\",\"color\":\"#4caf50\",\"settings\":{},\"_hash\":0.680594833308841,\"funcBody\":\"var value = prevValue || 0.3;\\nif (time % 5000 < 500) {\\n value += Math.random() * 0.05 - 0.025;\\n}\\nreturn value;\"}]},{\"type\":\"function\",\"name\":\"Second point\",\"dataKeys\":[{\"name\":\"f(x)\",\"type\":\"function\",\"label\":\"xPos\",\"color\":\"#f44336\",\"settings\":{},\"_hash\":0.05012157428742059,\"funcBody\":\"var value = prevValue || 0.6;\\nif (time % 4000 < 500) {\\n value += Math.random() * 0.05 - 0.025;\\n}\\nreturn value;\"},{\"name\":\"f(x)\",\"type\":\"function\",\"label\":\"yPos\",\"color\":\"#ffc107\",\"settings\":{},\"_hash\":0.6742359401617628,\"funcBody\":\"var value = prevValue || 0.7;\\nif (time % 4000 < 500) {\\n value += Math.random() * 0.05 - 0.025;\\n}\\nreturn value;\"}]}],\"timewindow\":{\"realtime\":{\"timewindowMs\":60000}},\"showTitle\":true,\"backgroundColor\":\"#fff\",\"color\":\"rgba(0, 0, 0, 0.87)\",\"padding\":\"8px\",\"settings\":{\"showLabel\":true,\"label\":\"${entityName}\",\"tooltipPattern\":\"<b>${entityName}</b><br/><br/><b>X Pos:</b> ${xPos:2}<br/><b>Y Pos:</b> ${yPos:2}<br/><br/><link-act name='delete'>Delete</link-act>\",\"markerImageSize\":34,\"useColorFunction\":false,\"markerImages\":[],\"useMarkerImageFunction\":false,\"color\":\"#fe7569\",\"mapImageUrl\":\"\",\"xPosKeyName\":\"xPos\",\"yPosKeyName\":\"yPos\",\"posFunction\":\"return {x: origXPos, y: origYPos};\",\"markerOffsetX\":0.5,\"markerOffsetY\":1,\"showTooltip\":true,\"autocloseTooltip\":true,\"showTooltipAction\":\"click\",\"defaultCenterPosition\":\"0,0\",\"provider\":\"image-map\",\"fitMapBounds\":true,\"latKeyName\":\"latitude\",\"lngKeyName\":\"longitude\",\"polygonKeyName\":\"coordinates\",\"polygonOpacity\":0.5,\"polygonStrokeOpacity\":1,\"polygonStrokeWeight\":1,\"mapProvider\":\"HERE.normalDay\",\"draggableMarker\":true,\"editablePolygon\":true,\"mapPageSize\":16384,\"showPolygon\":false,\"polygonTooltipPattern\":\"<b>${entityName}</b><br/><br/><b>TimeStamp:</b> ${coordinates|ts:7}<br/><br/><link-act name='delete_polygon'>Delete</link-act>\"},\"title\":\"Markers Placement - Image Map\",\"dropShadow\":true,\"enableFullscreen\":true,\"titleStyle\":{\"fontSize\":\"16px\",\"fontWeight\":400},\"useDashboardTimewindow\":true,\"showLegend\":false,\"widgetStyle\":{},\"actions\":{\"tooltipAction\":[{\"name\":\"delete\",\"icon\":\"more_horiz\",\"type\":\"custom\",\"customFunction\":\"var entityDatasource = widgetContext.map.map.datasources.filter(\\n function(entity) {\\n return entity.entityId === entityId.id;\\n });\\n\\nwidgetContext.map.setMarkerLocation(entityDatasource[0], null, null).subscribe();\",\"id\":\"c39f512a-21c6-6b06-3aa1-715262c6553d\"},{\"name\":\"delete_polygon\",\"icon\":\"more_horiz\",\"type\":\"custom\",\"customFunction\":\"var entityDatasource = widgetContext.map.map.datasources.filter(\\n function(entity) {\\n return entity.entityId === entityId.id\\n });\\n\\nwidgetContext.map.savePolygonLocation(entityDatasource[0], null).subscribe();\",\"id\":\"94bf5ffd-b526-c6c3-ae3b-ab42191217d9\"}]},\"showTitleIcon\":false,\"titleIcon\":\"more_horiz\",\"iconColor\":\"rgba(0, 0, 0, 0.87)\",\"iconSize\":\"24px\",\"titleTooltip\":\"\",\"displayTimewindow\":true}"
  69 + "defaultConfig": "{\"datasources\":[{\"type\":\"function\",\"name\":\"First point\",\"dataKeys\":[{\"name\":\"f(x)\",\"type\":\"function\",\"label\":\"xPos\",\"color\":\"#2196f3\",\"settings\":{},\"_hash\":0.05427416942713381,\"funcBody\":\"var value = prevValue || 0.2;\\nif (time % 5000 < 500) {\\n value += Math.random() * 0.05 - 0.025;\\n}\\nreturn value;\"},{\"name\":\"f(x)\",\"type\":\"function\",\"label\":\"yPos\",\"color\":\"#4caf50\",\"settings\":{},\"_hash\":0.680594833308841,\"funcBody\":\"var value = prevValue || 0.3;\\nif (time % 5000 < 500) {\\n value += Math.random() * 0.05 - 0.025;\\n}\\nreturn value;\"}]},{\"type\":\"function\",\"name\":\"Second point\",\"dataKeys\":[{\"name\":\"f(x)\",\"type\":\"function\",\"label\":\"xPos\",\"color\":\"#f44336\",\"settings\":{},\"_hash\":0.05012157428742059,\"funcBody\":\"var value = prevValue || 0.6;\\nif (time % 4000 < 500) {\\n value += Math.random() * 0.05 - 0.025;\\n}\\nreturn value;\"},{\"name\":\"f(x)\",\"type\":\"function\",\"label\":\"yPos\",\"color\":\"#ffc107\",\"settings\":{},\"_hash\":0.6742359401617628,\"funcBody\":\"var value = prevValue || 0.7;\\nif (time % 4000 < 500) {\\n value += Math.random() * 0.05 - 0.025;\\n}\\nreturn value;\"}]}],\"timewindow\":{\"realtime\":{\"timewindowMs\":60000}},\"showTitle\":true,\"backgroundColor\":\"#fff\",\"color\":\"rgba(0, 0, 0, 0.87)\",\"padding\":\"8px\",\"settings\":{\"showLabel\":true,\"label\":\"${entityName}\",\"tooltipPattern\":\"<b>${entityName}</b><br/><br/><b>X Pos:</b> ${xPos:2}<br/><b>Y Pos:</b> ${yPos:2}<br/><br/><link-act name='delete'>Delete</link-act>\",\"markerImageSize\":34,\"useColorFunction\":false,\"markerImages\":[],\"useMarkerImageFunction\":false,\"color\":\"#fe7569\",\"mapImageUrl\":\"\",\"xPosKeyName\":\"xPos\",\"yPosKeyName\":\"yPos\",\"posFunction\":\"return {x: origXPos, y: origYPos};\",\"markerOffsetX\":0.5,\"markerOffsetY\":1,\"showTooltip\":true,\"autocloseTooltip\":true,\"showTooltipAction\":\"click\",\"defaultCenterPosition\":\"0,0\",\"provider\":\"image-map\",\"fitMapBounds\":true,\"latKeyName\":\"latitude\",\"lngKeyName\":\"longitude\",\"polygonKeyName\":\"coordinates\",\"polygonOpacity\":0.5,\"polygonStrokeOpacity\":1,\"polygonStrokeWeight\":1,\"mapProvider\":\"HERE.normalDay\",\"draggableMarker\":true,\"editablePolygon\":true,\"mapPageSize\":16384,\"showPolygon\":false,\"polygonTooltipPattern\":\"<b>${entityName}</b><br/><br/><b>TimeStamp:</b> ${coordinates|ts:7}<br/><br/><link-act name='delete_polygon'>Delete</link-act>\"},\"title\":\"Markers Placement - Image Map\",\"dropShadow\":true,\"enableFullscreen\":true,\"titleStyle\":{\"fontSize\":\"16px\",\"fontWeight\":400},\"useDashboardTimewindow\":true,\"showLegend\":false,\"widgetStyle\":{},\"actions\":{\"tooltipAction\":[{\"name\":\"delete\",\"icon\":\"more_horiz\",\"type\":\"custom\",\"customFunction\":\"var entityDatasource = widgetContext.map.map.datasources.filter(\\n function(entity) {\\n return entity.entityId === entityId.id;\\n });\\n\\nwidgetContext.map.setMarkerLocation(entityDatasource[0], null, null).subscribe(() => widgetContext.updateAliases());\",\"id\":\"c39f512a-21c6-6b06-3aa1-715262c6553d\"},{\"name\":\"delete_polygon\",\"icon\":\"more_horiz\",\"type\":\"custom\",\"customFunction\":\"var entityDatasource = widgetContext.map.map.datasources.filter(\\n function(entity) {\\n return entity.entityId === entityId.id\\n });\\n\\nwidgetContext.map.savePolygonLocation(entityDatasource[0], null).subscribe(() => widgetContext.updateAliases());\",\"id\":\"94bf5ffd-b526-c6c3-ae3b-ab42191217d9\"}]},\"showTitleIcon\":false,\"titleIcon\":\"more_horiz\",\"iconColor\":\"rgba(0, 0, 0, 0.87)\",\"iconSize\":\"24px\",\"titleTooltip\":\"\",\"displayTimewindow\":true}"
70 70 }
71 71 },
72 72 {
... ... @@ -370,7 +370,7 @@
370 370 "controllerScript": "self.onInit = function() {\n self.ctx.map = new TbMapWidgetV2('google-map', false, self.ctx, null, true);\n}\n\nself.onDataUpdated = function() {\n self.ctx.map.update();\n}\n\nself.onResize = function() {\n self.ctx.map.resize();\n}\n\nself.getSettingsSchema = function() {\n return TbMapWidgetV2.settingsSchema('google-map');\n}\n\nself.getDataKeySettingsSchema = function() {\n return TbMapWidgetV2.dataKeySettingsSchema('google-map');\n}\n\nself.actionSources = function() {\n return TbMapWidgetV2.actionSources();\n}\n\nself.onDestroy = function() {\n}\n\nself.typeParameters = function() {\n return {\n hasDataPageLink: true\n };\n}",
371 371 "settingsSchema": "{}",
372 372 "dataKeySettingsSchema": "{}\n",
373   - "defaultConfig": "{\"datasources\":[{\"type\":\"function\",\"name\":\"First point\",\"dataKeys\":[{\"name\":\"f(x)\",\"type\":\"function\",\"label\":\"latitude\",\"color\":\"#2196f3\",\"settings\":{},\"_hash\":0.05427416942713381,\"funcBody\":\"var value = prevValue || 15.833293;\\nif (time % 5000 < 500) {\\n value += Math.random() * 0.05 - 0.025;\\n}\\nreturn value;\"},{\"name\":\"f(x)\",\"type\":\"function\",\"label\":\"longitude\",\"color\":\"#4caf50\",\"settings\":{},\"_hash\":0.680594833308841,\"funcBody\":\"var value = prevValue || -90.454350;\\nif (time % 5000 < 500) {\\n value += Math.random() * 0.05 - 0.025;\\n}\\nreturn value;\"}]},{\"type\":\"function\",\"name\":\"Second point\",\"dataKeys\":[{\"name\":\"f(x)\",\"type\":\"function\",\"label\":\"latitude\",\"color\":\"#f44336\",\"settings\":{},\"_hash\":0.05012157428742059,\"funcBody\":\"var value = prevValue || 14.450463;\\nif (time % 4000 < 500) {\\n value += Math.random() * 0.05 - 0.025;\\n}\\nreturn value;\"},{\"name\":\"f(x)\",\"type\":\"function\",\"label\":\"longitude\",\"color\":\"#ffc107\",\"settings\":{},\"_hash\":0.6742359401617628,\"funcBody\":\"var value = prevValue || -84.845334;\\nif (time % 4000 < 500) {\\n value += Math.random() * 0.05 - 0.025;\\n}\\nreturn value;\"}]}],\"timewindow\":{\"realtime\":{\"timewindowMs\":60000}},\"showTitle\":true,\"backgroundColor\":\"#fff\",\"color\":\"rgba(0, 0, 0, 0.87)\",\"padding\":\"8px\",\"settings\":{\"fitMapBounds\":true,\"latKeyName\":\"latitude\",\"lngKeyName\":\"longitude\",\"showLabel\":true,\"label\":\"${entityName}\",\"tooltipPattern\":\"<b>${entityName}</b><br/><br/><b>Latitude:</b> ${latitude:7}<br/><b>Longitude:</b> ${longitude:7}<br/><br/><link-act name='delete'>Delete</link-act>\",\"markerImageSize\":34,\"gmDefaultMapType\":\"roadmap\",\"gmApiKey\":\"AIzaSyDoEx2kaGz3PxwbI9T7ccTSg5xjdw8Nw8Q\",\"useColorFunction\":false,\"markerImages\":[],\"useMarkerImageFunction\":false,\"colorFunction\":\"\\n\",\"color\":\"#fe7569\",\"showTooltip\":true,\"autocloseTooltip\":true,\"defaultCenterPosition\":\"0,0\",\"showTooltipAction\":\"click\",\"polygonKeyName\":\"coordinates\",\"polygonOpacity\":0.5,\"polygonStrokeOpacity\":1,\"polygonStrokeWeight\":1,\"zoomOnClick\":true,\"defaultZoomLevel\":5,\"provider\":\"google-map\",\"showCoverageOnHover\":true,\"animate\":true,\"maxClusterRadius\":80,\"removeOutsideVisibleBounds\":true,\"mapProvider\":\"HERE.normalDay\",\"draggableMarker\":true,\"editablePolygon\":true,\"mapPageSize\":16384,\"showPolygon\":false,\"polygonTooltipPattern\":\"<b>${entityName}</b><br/><br/><b>TimeStamp:</b> ${coordinates|ts:7}<br/><br/><link-act name='delete_polygon'>Delete</link-act>\",\"showPolygonTooltip\":false},\"title\":\"Markers Placement - Google Maps\",\"dropShadow\":true,\"enableFullscreen\":true,\"titleStyle\":{\"fontSize\":\"16px\",\"fontWeight\":400},\"useDashboardTimewindow\":true,\"showLegend\":false,\"widgetStyle\":{},\"actions\":{\"tooltipAction\":[{\"name\":\"delete\",\"icon\":\"more_horiz\",\"type\":\"custom\",\"customFunction\":\"var entityDatasource = widgetContext.map.map.datasources.filter(\\n function(entity) {\\n return entity.entityId === entityId.id;\\n });\\n\\nwidgetContext.map.setMarkerLocation(entityDatasource[0], null, null).subscribe();\",\"id\":\"8d3c0156-0a14-7a6f-0ddd-0ec16b9ffc91\"},{\"name\":\"delete_polygon\",\"icon\":\"more_horiz\",\"type\":\"custom\",\"customFunction\":\"var entityDatasource = widgetContext.map.map.datasources.filter(\\n function(entity) {\\n return entity.entityId === entityId.id\\n });\\n\\nwidgetContext.map.savePolygonLocation(entityDatasource[0], null).subscribe();\",\"id\":\"46bf69cd-8906-234c-a879-e2e4c92f5b67\"}]},\"showTitleIcon\":false,\"titleIcon\":\"more_horiz\",\"iconColor\":\"rgba(0, 0, 0, 0.87)\",\"iconSize\":\"24px\",\"titleTooltip\":\"\",\"displayTimewindow\":true}"
  373 + "defaultConfig": "{\"datasources\":[{\"type\":\"function\",\"name\":\"First point\",\"dataKeys\":[{\"name\":\"f(x)\",\"type\":\"function\",\"label\":\"latitude\",\"color\":\"#2196f3\",\"settings\":{},\"_hash\":0.05427416942713381,\"funcBody\":\"var value = prevValue || 15.833293;\\nif (time % 5000 < 500) {\\n value += Math.random() * 0.05 - 0.025;\\n}\\nreturn value;\"},{\"name\":\"f(x)\",\"type\":\"function\",\"label\":\"longitude\",\"color\":\"#4caf50\",\"settings\":{},\"_hash\":0.680594833308841,\"funcBody\":\"var value = prevValue || -90.454350;\\nif (time % 5000 < 500) {\\n value += Math.random() * 0.05 - 0.025;\\n}\\nreturn value;\"}]},{\"type\":\"function\",\"name\":\"Second point\",\"dataKeys\":[{\"name\":\"f(x)\",\"type\":\"function\",\"label\":\"latitude\",\"color\":\"#f44336\",\"settings\":{},\"_hash\":0.05012157428742059,\"funcBody\":\"var value = prevValue || 14.450463;\\nif (time % 4000 < 500) {\\n value += Math.random() * 0.05 - 0.025;\\n}\\nreturn value;\"},{\"name\":\"f(x)\",\"type\":\"function\",\"label\":\"longitude\",\"color\":\"#ffc107\",\"settings\":{},\"_hash\":0.6742359401617628,\"funcBody\":\"var value = prevValue || -84.845334;\\nif (time % 4000 < 500) {\\n value += Math.random() * 0.05 - 0.025;\\n}\\nreturn value;\"}]}],\"timewindow\":{\"realtime\":{\"timewindowMs\":60000}},\"showTitle\":true,\"backgroundColor\":\"#fff\",\"color\":\"rgba(0, 0, 0, 0.87)\",\"padding\":\"8px\",\"settings\":{\"fitMapBounds\":true,\"latKeyName\":\"latitude\",\"lngKeyName\":\"longitude\",\"showLabel\":true,\"label\":\"${entityName}\",\"tooltipPattern\":\"<b>${entityName}</b><br/><br/><b>Latitude:</b> ${latitude:7}<br/><b>Longitude:</b> ${longitude:7}<br/><br/><link-act name='delete'>Delete</link-act>\",\"markerImageSize\":34,\"gmDefaultMapType\":\"roadmap\",\"gmApiKey\":\"AIzaSyDoEx2kaGz3PxwbI9T7ccTSg5xjdw8Nw8Q\",\"useColorFunction\":false,\"markerImages\":[],\"useMarkerImageFunction\":false,\"colorFunction\":\"\\n\",\"color\":\"#fe7569\",\"showTooltip\":true,\"autocloseTooltip\":true,\"defaultCenterPosition\":\"0,0\",\"showTooltipAction\":\"click\",\"polygonKeyName\":\"coordinates\",\"polygonOpacity\":0.5,\"polygonStrokeOpacity\":1,\"polygonStrokeWeight\":1,\"zoomOnClick\":true,\"defaultZoomLevel\":5,\"provider\":\"google-map\",\"showCoverageOnHover\":true,\"animate\":true,\"maxClusterRadius\":80,\"removeOutsideVisibleBounds\":true,\"mapProvider\":\"HERE.normalDay\",\"draggableMarker\":true,\"editablePolygon\":true,\"mapPageSize\":16384,\"showPolygon\":false,\"polygonTooltipPattern\":\"<b>${entityName}</b><br/><br/><b>TimeStamp:</b> ${coordinates|ts:7}<br/><br/><link-act name='delete_polygon'>Delete</link-act>\",\"showPolygonTooltip\":false},\"title\":\"Markers Placement - Google Maps\",\"dropShadow\":true,\"enableFullscreen\":true,\"titleStyle\":{\"fontSize\":\"16px\",\"fontWeight\":400},\"useDashboardTimewindow\":true,\"showLegend\":false,\"widgetStyle\":{},\"actions\":{\"tooltipAction\":[{\"name\":\"delete\",\"icon\":\"more_horiz\",\"type\":\"custom\",\"customFunction\":\"var entityDatasource = widgetContext.map.map.datasources.filter(\\n function(entity) {\\n return entity.entityId === entityId.id;\\n });\\n\\nwidgetContext.map.setMarkerLocation(entityDatasource[0], null, null).subscribe(() => widgetContext.updateAliases());\",\"id\":\"8d3c0156-0a14-7a6f-0ddd-0ec16b9ffc91\"},{\"name\":\"delete_polygon\",\"icon\":\"more_horiz\",\"type\":\"custom\",\"customFunction\":\"var entityDatasource = widgetContext.map.map.datasources.filter(\\n function(entity) {\\n return entity.entityId === entityId.id\\n });\\n\\nwidgetContext.map.savePolygonLocation(entityDatasource[0], null).subscribe(() => widgetContext.updateAliases());\",\"id\":\"46bf69cd-8906-234c-a879-e2e4c92f5b67\"}]},\"showTitleIcon\":false,\"titleIcon\":\"more_horiz\",\"iconColor\":\"rgba(0, 0, 0, 0.87)\",\"iconSize\":\"24px\",\"titleTooltip\":\"\",\"displayTimewindow\":true}"
374 374 }
375 375 },
376 376 {
... ...
1 1 --
2   --- Copyright © 2016-2020 The Thingsboard Authors
  2 +-- Copyright © 2016-2021 The Thingsboard Authors
3 3 --
4 4 -- Licensed under the Apache License, Version 2.0 (the "License");
5 5 -- you may not use this file except in compliance with the License.
... ...
1 1 --
2   --- Copyright © 2016-2020 The Thingsboard Authors
  2 +-- Copyright © 2016-2021 The Thingsboard Authors
3 3 --
4 4 -- Licensed under the Apache License, Version 2.0 (the "License");
5 5 -- you may not use this file except in compliance with the License.
... ...
1 1 --
2   --- Copyright © 2016-2020 The Thingsboard Authors
  2 +-- Copyright © 2016-2021 The Thingsboard Authors
3 3 --
4 4 -- Licensed under the Apache License, Version 2.0 (the "License");
5 5 -- you may not use this file except in compliance with the License.
... ...
1 1 --
2   --- Copyright © 2016-2020 The Thingsboard Authors
  2 +-- Copyright © 2016-2021 The Thingsboard Authors
3 3 --
4 4 -- Licensed under the Apache License, Version 2.0 (the "License");
5 5 -- you may not use this file except in compliance with the License.
... ...
1 1 --
2   --- Copyright © 2016-2020 The Thingsboard Authors
  2 +-- Copyright © 2016-2021 The Thingsboard Authors
3 3 --
4 4 -- Licensed under the Apache License, Version 2.0 (the "License");
5 5 -- you may not use this file except in compliance with the License.
... ...
1 1 --
2   --- Copyright © 2016-2020 The Thingsboard Authors
  2 +-- Copyright © 2016-2021 The Thingsboard Authors
3 3 --
4 4 -- Licensed under the Apache License, Version 2.0 (the "License");
5 5 -- you may not use this file except in compliance with the License.
... ...
1 1 --
2   --- Copyright © 2016-2020 The Thingsboard Authors
  2 +-- Copyright © 2016-2021 The Thingsboard Authors
3 3 --
4 4 -- Licensed under the Apache License, Version 2.0 (the "License");
5 5 -- you may not use this file except in compliance with the License.
... ...
1 1 --
2   --- Copyright © 2016-2020 The Thingsboard Authors
  2 +-- Copyright © 2016-2021 The Thingsboard Authors
3 3 --
4 4 -- Licensed under the Apache License, Version 2.0 (the "License");
5 5 -- you may not use this file except in compliance with the License.
... ...
1 1 --
2   --- Copyright © 2016-2020 The Thingsboard Authors
  2 +-- Copyright © 2016-2021 The Thingsboard Authors
3 3 --
4 4 -- Licensed under the Apache License, Version 2.0 (the "License");
5 5 -- you may not use this file except in compliance with the License.
... ...
1 1 --
2   --- Copyright © 2016-2020 The Thingsboard Authors
  2 +-- Copyright © 2016-2021 The Thingsboard Authors
3 3 --
4 4 -- Licensed under the Apache License, Version 2.0 (the "License");
5 5 -- you may not use this file except in compliance with the License.
... ...
1 1 --
2   --- Copyright © 2016-2020 The Thingsboard Authors
  2 +-- Copyright © 2016-2021 The Thingsboard Authors
3 3 --
4 4 -- Licensed under the Apache License, Version 2.0 (the "License");
5 5 -- you may not use this file except in compliance with the License.
... ...
1 1 --
2   --- Copyright © 2016-2020 The Thingsboard Authors
  2 +-- Copyright © 2016-2021 The Thingsboard Authors
3 3 --
4 4 -- Licensed under the Apache License, Version 2.0 (the "License");
5 5 -- you may not use this file except in compliance with the License.
... ...
1 1 --
2   --- Copyright © 2016-2020 The Thingsboard Authors
  2 +-- Copyright © 2016-2021 The Thingsboard Authors
3 3 --
4 4 -- Licensed under the Apache License, Version 2.0 (the "License");
5 5 -- you may not use this file except in compliance with the License.
... ...
1 1 --
2   --- Copyright © 2016-2020 The Thingsboard Authors
  2 +-- Copyright © 2016-2021 The Thingsboard Authors
3 3 --
4 4 -- Licensed under the Apache License, Version 2.0 (the "License");
5 5 -- you may not use this file except in compliance with the License.
... ...
1 1 --
2   --- Copyright © 2016-2020 The Thingsboard Authors
  2 +-- Copyright © 2016-2021 The Thingsboard Authors
3 3 --
4 4 -- Licensed under the Apache License, Version 2.0 (the "License");
5 5 -- you may not use this file except in compliance with the License.
... ...
1 1 --
2   --- Copyright © 2016-2020 The Thingsboard Authors
  2 +-- Copyright © 2016-2021 The Thingsboard Authors
3 3 --
4 4 -- Licensed under the Apache License, Version 2.0 (the "License");
5 5 -- you may not use this file except in compliance with the License.
... ...
1 1 --
2   --- Copyright © 2016-2020 The Thingsboard Authors
  2 +-- Copyright © 2016-2021 The Thingsboard Authors
3 3 --
4 4 -- Licensed under the Apache License, Version 2.0 (the "License");
5 5 -- you may not use this file except in compliance with the License.
... ...
1 1 --
2   --- Copyright © 2016-2020 The Thingsboard Authors
  2 +-- Copyright © 2016-2021 The Thingsboard Authors
3 3 --
4 4 -- Licensed under the Apache License, Version 2.0 (the "License");
5 5 -- you may not use this file except in compliance with the License.
... ...
1 1 --
2   --- Copyright © 2016-2020 The Thingsboard Authors
  2 +-- Copyright © 2016-2021 The Thingsboard Authors
3 3 --
4 4 -- Licensed under the Apache License, Version 2.0 (the "License");
5 5 -- you may not use this file except in compliance with the License.
... ...
1 1 --
2   --- Copyright © 2016-2020 The Thingsboard Authors
  2 +-- Copyright © 2016-2021 The Thingsboard Authors
3 3 --
4 4 -- Licensed under the Apache License, Version 2.0 (the "License");
5 5 -- you may not use this file except in compliance with the License.
... ...
1 1 --
2   --- Copyright © 2016-2020 The Thingsboard Authors
  2 +-- Copyright © 2016-2021 The Thingsboard Authors
3 3 --
4 4 -- Licensed under the Apache License, Version 2.0 (the "License");
5 5 -- you may not use this file except in compliance with the License.
... ...
1 1 --
2   --- Copyright © 2016-2020 The Thingsboard Authors
  2 +-- Copyright © 2016-2021 The Thingsboard Authors
3 3 --
4 4 -- Licensed under the Apache License, Version 2.0 (the "License");
5 5 -- you may not use this file except in compliance with the License.
... ...
1 1 --
2   --- Copyright © 2016-2020 The Thingsboard Authors
  2 +-- Copyright © 2016-2021 The Thingsboard Authors
3 3 --
4 4 -- Licensed under the Apache License, Version 2.0 (the "License");
5 5 -- you may not use this file except in compliance with the License.
... ...
1 1 /**
2   - * Copyright © 2016-2020 The Thingsboard Authors
  2 + * Copyright © 2016-2021 The Thingsboard Authors
3 3 *
4 4 * Licensed under the Apache License, Version 2.0 (the "License");
5 5 * you may not use this file except in compliance with the License.
... ...
1 1 /**
2   - * Copyright © 2016-2020 The Thingsboard Authors
  2 + * Copyright © 2016-2021 The Thingsboard Authors
3 3 *
4 4 * Licensed under the Apache License, Version 2.0 (the "License");
5 5 * you may not use this file except in compliance with the License.
... ...
1 1 /**
2   - * Copyright © 2016-2020 The Thingsboard Authors
  2 + * Copyright © 2016-2021 The Thingsboard Authors
3 3 *
4 4 * Licensed under the Apache License, Version 2.0 (the "License");
5 5 * you may not use this file except in compliance with the License.
... ...
1 1 /**
2   - * Copyright © 2016-2020 The Thingsboard Authors
  2 + * Copyright © 2016-2021 The Thingsboard Authors
3 3 *
4 4 * Licensed under the Apache License, Version 2.0 (the "License");
5 5 * you may not use this file except in compliance with the License.
... ...
1 1 /**
2   - * Copyright © 2016-2020 The Thingsboard Authors
  2 + * Copyright © 2016-2021 The Thingsboard Authors
3 3 *
4 4 * Licensed under the Apache License, Version 2.0 (the "License");
5 5 * you may not use this file except in compliance with the License.
... ...
1 1 /**
2   - * Copyright © 2016-2020 The Thingsboard Authors
  2 + * Copyright © 2016-2021 The Thingsboard Authors
3 3 *
4 4 * Licensed under the Apache License, Version 2.0 (the "License");
5 5 * you may not use this file except in compliance with the License.
... ...
1 1 /**
2   - * Copyright © 2016-2020 The Thingsboard Authors
  2 + * Copyright © 2016-2021 The Thingsboard Authors
3 3 *
4 4 * Licensed under the Apache License, Version 2.0 (the "License");
5 5 * you may not use this file except in compliance with the License.
... ...
1 1 /**
2   - * Copyright © 2016-2020 The Thingsboard Authors
  2 + * Copyright © 2016-2021 The Thingsboard Authors
3 3 *
4 4 * Licensed under the Apache License, Version 2.0 (the "License");
5 5 * you may not use this file except in compliance with the License.
... ...
1 1 /**
2   - * Copyright © 2016-2020 The Thingsboard Authors
  2 + * Copyright © 2016-2021 The Thingsboard Authors
3 3 *
4 4 * Licensed under the Apache License, Version 2.0 (the "License");
5 5 * you may not use this file except in compliance with the License.
... ...
1 1 /**
2   - * Copyright © 2016-2020 The Thingsboard Authors
  2 + * Copyright © 2016-2021 The Thingsboard Authors
3 3 *
4 4 * Licensed under the Apache License, Version 2.0 (the "License");
5 5 * you may not use this file except in compliance with the License.
... ...
1 1 /**
2   - * Copyright © 2016-2020 The Thingsboard Authors
  2 + * Copyright © 2016-2021 The Thingsboard Authors
3 3 *
4 4 * Licensed under the Apache License, Version 2.0 (the "License");
5 5 * you may not use this file except in compliance with the License.
... ...
1 1 /**
2   - * Copyright © 2016-2020 The Thingsboard Authors
  2 + * Copyright © 2016-2021 The Thingsboard Authors
3 3 *
4 4 * Licensed under the Apache License, Version 2.0 (the "License");
5 5 * you may not use this file except in compliance with the License.
... ...
1 1 /**
2   - * Copyright © 2016-2020 The Thingsboard Authors
  2 + * Copyright © 2016-2021 The Thingsboard Authors
3 3 *
4 4 * Licensed under the Apache License, Version 2.0 (the "License");
5 5 * you may not use this file except in compliance with the License.
... ...
1 1 /**
2   - * Copyright © 2016-2020 The Thingsboard Authors
  2 + * Copyright © 2016-2021 The Thingsboard Authors
3 3 *
4 4 * Licensed under the Apache License, Version 2.0 (the "License");
5 5 * you may not use this file except in compliance with the License.
... ...
1 1 /**
2   - * Copyright © 2016-2020 The Thingsboard Authors
  2 + * Copyright © 2016-2021 The Thingsboard Authors
3 3 *
4 4 * Licensed under the Apache License, Version 2.0 (the "License");
5 5 * you may not use this file except in compliance with the License.
... ... @@ -244,8 +244,18 @@ class DefaultTbContext implements TbContext {
244 244 if (nodeCtx.getSelf().isDebugMode()) {
245 245 mainCtx.persistDebugOutput(nodeCtx.getTenantId(), nodeCtx.getSelf().getId(), msg, TbRelationTypes.FAILURE, th);
246 246 }
  247 + String failureMessage;
  248 + if (th != null) {
  249 + if (!StringUtils.isEmpty(th.getMessage())) {
  250 + failureMessage = th.getMessage();
  251 + } else {
  252 + failureMessage = th.getClass().getSimpleName();
  253 + }
  254 + } else {
  255 + failureMessage = null;
  256 + }
247 257 nodeCtx.getChainActor().tell(new RuleNodeToRuleChainTellNextMsg(nodeCtx.getSelf().getId(), Collections.singleton(TbRelationTypes.FAILURE),
248   - msg, th != null ? th.getMessage() : null));
  258 + msg, failureMessage));
249 259 }
250 260
251 261 public void updateSelf(RuleNode self) {
... ...
1 1 /**
2   - * Copyright © 2016-2020 The Thingsboard Authors
  2 + * Copyright © 2016-2021 The Thingsboard Authors
3 3 *
4 4 * Licensed under the Apache License, Version 2.0 (the "License");
5 5 * you may not use this file except in compliance with the License.
... ...
1 1 /**
2   - * Copyright © 2016-2020 The Thingsboard Authors
  2 + * Copyright © 2016-2021 The Thingsboard Authors
3 3 *
4 4 * Licensed under the Apache License, Version 2.0 (the "License");
5 5 * you may not use this file except in compliance with the License.
... ... @@ -56,6 +56,7 @@ import java.util.HashMap;
56 56 import java.util.List;
57 57 import java.util.Map;
58 58 import java.util.Set;
  59 +import java.util.UUID;
59 60 import java.util.stream.Collectors;
60 61
61 62 /**
... ... @@ -288,10 +289,10 @@ public class RuleChainActorMessageProcessor extends ComponentMsgProcessor<RuleCh
288 289 private void putToQueue(TopicPartitionInfo tpi, TbMsg msg, TbQueueCallback callbackWrapper, EntityId target) {
289 290 switch (target.getEntityType()) {
290 291 case RULE_NODE:
291   - putToQueue(tpi, msg.copyWithRuleNodeId(entityId, new RuleNodeId(target.getId())), callbackWrapper);
  292 + putToQueue(tpi, msg.copyWithRuleNodeId(entityId, new RuleNodeId(target.getId()), UUID.randomUUID()), callbackWrapper);
292 293 break;
293 294 case RULE_CHAIN:
294   - putToQueue(tpi, msg.copyWithRuleChainId(new RuleChainId(target.getId())), callbackWrapper);
  295 + putToQueue(tpi, msg.copyWithRuleChainId(new RuleChainId(target.getId()), UUID.randomUUID()), callbackWrapper);
295 296 break;
296 297 }
297 298 }
... ...
1 1 /**
2   - * Copyright © 2016-2020 The Thingsboard Authors
  2 + * Copyright © 2016-2021 The Thingsboard Authors
3 3 *
4 4 * Licensed under the Apache License, Version 2.0 (the "License");
5 5 * you may not use this file except in compliance with the License.
... ...
1 1 /**
2   - * Copyright © 2016-2020 The Thingsboard Authors
  2 + * Copyright © 2016-2021 The Thingsboard Authors
3 3 *
4 4 * Licensed under the Apache License, Version 2.0 (the "License");
5 5 * you may not use this file except in compliance with the License.
... ...
1 1 /**
2   - * Copyright © 2016-2020 The Thingsboard Authors
  2 + * Copyright © 2016-2021 The Thingsboard Authors
3 3 *
4 4 * Licensed under the Apache License, Version 2.0 (the "License");
5 5 * you may not use this file except in compliance with the License.
... ...
1 1 /**
2   - * Copyright © 2016-2020 The Thingsboard Authors
  2 + * Copyright © 2016-2021 The Thingsboard Authors
3 3 *
4 4 * Licensed under the Apache License, Version 2.0 (the "License");
5 5 * you may not use this file except in compliance with the License.
... ...
1 1 /**
2   - * Copyright © 2016-2020 The Thingsboard Authors
  2 + * Copyright © 2016-2021 The Thingsboard Authors
3 3 *
4 4 * Licensed under the Apache License, Version 2.0 (the "License");
5 5 * you may not use this file except in compliance with the License.
... ...
1 1 /**
2   - * Copyright © 2016-2020 The Thingsboard Authors
  2 + * Copyright © 2016-2021 The Thingsboard Authors
3 3 *
4 4 * Licensed under the Apache License, Version 2.0 (the "License");
5 5 * you may not use this file except in compliance with the License.
... ...
1 1 /**
2   - * Copyright © 2016-2020 The Thingsboard Authors
  2 + * Copyright © 2016-2021 The Thingsboard Authors
3 3 *
4 4 * Licensed under the Apache License, Version 2.0 (the "License");
5 5 * you may not use this file except in compliance with the License.
... ...
1 1 /**
2   - * Copyright © 2016-2020 The Thingsboard Authors
  2 + * Copyright © 2016-2021 The Thingsboard Authors
3 3 *
4 4 * Licensed under the Apache License, Version 2.0 (the "License");
5 5 * you may not use this file except in compliance with the License.
... ...
1 1 /**
2   - * Copyright © 2016-2020 The Thingsboard Authors
  2 + * Copyright © 2016-2021 The Thingsboard Authors
3 3 *
4 4 * Licensed under the Apache License, Version 2.0 (the "License");
5 5 * you may not use this file except in compliance with the License.
... ...
1 1 /**
2   - * Copyright © 2016-2020 The Thingsboard Authors
  2 + * Copyright © 2016-2021 The Thingsboard Authors
3 3 *
4 4 * Licensed under the Apache License, Version 2.0 (the "License");
5 5 * you may not use this file except in compliance with the License.
... ...
1 1 /**
2   - * Copyright © 2016-2020 The Thingsboard Authors
  2 + * Copyright © 2016-2021 The Thingsboard Authors
3 3 *
4 4 * Licensed under the Apache License, Version 2.0 (the "License");
5 5 * you may not use this file except in compliance with the License.
... ...
1 1 /**
2   - * Copyright © 2016-2020 The Thingsboard Authors
  2 + * Copyright © 2016-2021 The Thingsboard Authors
3 3 *
4 4 * Licensed under the Apache License, Version 2.0 (the "License");
5 5 * you may not use this file except in compliance with the License.
... ...
1 1 /**
2   - * Copyright © 2016-2020 The Thingsboard Authors
  2 + * Copyright © 2016-2021 The Thingsboard Authors
3 3 *
4 4 * Licensed under the Apache License, Version 2.0 (the "License");
5 5 * you may not use this file except in compliance with the License.
... ...
1 1 /**
2   - * Copyright © 2016-2020 The Thingsboard Authors
  2 + * Copyright © 2016-2021 The Thingsboard Authors
3 3 *
4 4 * Licensed under the Apache License, Version 2.0 (the "License");
5 5 * you may not use this file except in compliance with the License.
... ...
1 1 /**
2   - * Copyright © 2016-2020 The Thingsboard Authors
  2 + * Copyright © 2016-2021 The Thingsboard Authors
3 3 *
4 4 * Licensed under the Apache License, Version 2.0 (the "License");
5 5 * you may not use this file except in compliance with the License.
... ...
1 1 /**
2   - * Copyright © 2016-2020 The Thingsboard Authors
  2 + * Copyright © 2016-2021 The Thingsboard Authors
3 3 *
4 4 * Licensed under the Apache License, Version 2.0 (the "License");
5 5 * you may not use this file except in compliance with the License.
... ...
1 1 /**
2   - * Copyright © 2016-2020 The Thingsboard Authors
  2 + * Copyright © 2016-2021 The Thingsboard Authors
3 3 *
4 4 * Licensed under the Apache License, Version 2.0 (the "License");
5 5 * you may not use this file except in compliance with the License.
... ...
1 1 /**
2   - * Copyright © 2016-2020 The Thingsboard Authors
  2 + * Copyright © 2016-2021 The Thingsboard Authors
3 3 *
4 4 * Licensed under the Apache License, Version 2.0 (the "License");
5 5 * you may not use this file except in compliance with the License.
... ...
1 1 /**
2   - * Copyright © 2016-2020 The Thingsboard Authors
  2 + * Copyright © 2016-2021 The Thingsboard Authors
3 3 *
4 4 * Licensed under the Apache License, Version 2.0 (the "License");
5 5 * you may not use this file except in compliance with the License.
... ...
1 1 /**
2   - * Copyright © 2016-2020 The Thingsboard Authors
  2 + * Copyright © 2016-2021 The Thingsboard Authors
3 3 *
4 4 * Licensed under the Apache License, Version 2.0 (the "License");
5 5 * you may not use this file except in compliance with the License.
... ...
1 1 /**
2   - * Copyright © 2016-2020 The Thingsboard Authors
  2 + * Copyright © 2016-2021 The Thingsboard Authors
3 3 *
4 4 * Licensed under the Apache License, Version 2.0 (the "License");
5 5 * you may not use this file except in compliance with the License.
... ...
1 1 /**
2   - * Copyright © 2016-2020 The Thingsboard Authors
  2 + * Copyright © 2016-2021 The Thingsboard Authors
3 3 *
4 4 * Licensed under the Apache License, Version 2.0 (the "License");
5 5 * you may not use this file except in compliance with the License.
... ...
1 1 /**
2   - * Copyright © 2016-2020 The Thingsboard Authors
  2 + * Copyright © 2016-2021 The Thingsboard Authors
3 3 *
4 4 * Licensed under the Apache License, Version 2.0 (the "License");
5 5 * you may not use this file except in compliance with the License.
... ...
1 1 /**
2   - * Copyright © 2016-2020 The Thingsboard Authors
  2 + * Copyright © 2016-2021 The Thingsboard Authors
3 3 *
4 4 * Licensed under the Apache License, Version 2.0 (the "License");
5 5 * you may not use this file except in compliance with the License.
... ...
1 1 /**
2   - * Copyright © 2016-2020 The Thingsboard Authors
  2 + * Copyright © 2016-2021 The Thingsboard Authors
3 3 *
4 4 * Licensed under the Apache License, Version 2.0 (the "License");
5 5 * you may not use this file except in compliance with the License.
... ...
1 1 /**
2   - * Copyright © 2016-2020 The Thingsboard Authors
  2 + * Copyright © 2016-2021 The Thingsboard Authors
3 3 *
4 4 * Licensed under the Apache License, Version 2.0 (the "License");
5 5 * you may not use this file except in compliance with the License.
... ...
1 1 /**
2   - * Copyright © 2016-2020 The Thingsboard Authors
  2 + * Copyright © 2016-2021 The Thingsboard Authors
3 3 *
4 4 * Licensed under the Apache License, Version 2.0 (the "License");
5 5 * you may not use this file except in compliance with the License.
... ...
1 1 /**
2   - * Copyright © 2016-2020 The Thingsboard Authors
  2 + * Copyright © 2016-2021 The Thingsboard Authors
3 3 *
4 4 * Licensed under the Apache License, Version 2.0 (the "License");
5 5 * you may not use this file except in compliance with the License.
... ...
1 1 /**
2   - * Copyright © 2016-2020 The Thingsboard Authors
  2 + * Copyright © 2016-2021 The Thingsboard Authors
3 3 *
4 4 * Licensed under the Apache License, Version 2.0 (the "License");
5 5 * you may not use this file except in compliance with the License.
... ...
1 1 /**
2   - * Copyright © 2016-2020 The Thingsboard Authors
  2 + * Copyright © 2016-2021 The Thingsboard Authors
3 3 *
4 4 * Licensed under the Apache License, Version 2.0 (the "License");
5 5 * you may not use this file except in compliance with the License.
... ...
1 1 /**
2   - * Copyright © 2016-2020 The Thingsboard Authors
  2 + * Copyright © 2016-2021 The Thingsboard Authors
3 3 *
4 4 * Licensed under the Apache License, Version 2.0 (the "License");
5 5 * you may not use this file except in compliance with the License.
... ...
1 1 /**
2   - * Copyright © 2016-2020 The Thingsboard Authors
  2 + * Copyright © 2016-2021 The Thingsboard Authors
3 3 *
4 4 * Licensed under the Apache License, Version 2.0 (the "License");
5 5 * you may not use this file except in compliance with the License.
... ...
1 1 /**
2   - * Copyright © 2016-2020 The Thingsboard Authors
  2 + * Copyright © 2016-2021 The Thingsboard Authors
3 3 *
4 4 * Licensed under the Apache License, Version 2.0 (the "License");
5 5 * you may not use this file except in compliance with the License.
... ...
1 1 /**
2   - * Copyright © 2016-2020 The Thingsboard Authors
  2 + * Copyright © 2016-2021 The Thingsboard Authors
3 3 *
4 4 * Licensed under the Apache License, Version 2.0 (the "License");
5 5 * you may not use this file except in compliance with the License.
... ...
1 1 /**
2   - * Copyright © 2016-2020 The Thingsboard Authors
  2 + * Copyright © 2016-2021 The Thingsboard Authors
3 3 *
4 4 * Licensed under the Apache License, Version 2.0 (the "License");
5 5 * you may not use this file except in compliance with the License.
... ...
1 1 /**
2   - * Copyright © 2016-2020 The Thingsboard Authors
  2 + * Copyright © 2016-2021 The Thingsboard Authors
3 3 *
4 4 * Licensed under the Apache License, Version 2.0 (the "License");
5 5 * you may not use this file except in compliance with the License.
... ...
1 1 /**
2   - * Copyright © 2016-2020 The Thingsboard Authors
  2 + * Copyright © 2016-2021 The Thingsboard Authors
3 3 *
4 4 * Licensed under the Apache License, Version 2.0 (the "License");
5 5 * you may not use this file except in compliance with the License.
... ...
1 1 /**
2   - * Copyright © 2016-2020 The Thingsboard Authors
  2 + * Copyright © 2016-2021 The Thingsboard Authors
3 3 *
4 4 * Licensed under the Apache License, Version 2.0 (the "License");
5 5 * you may not use this file except in compliance with the License.
... ...
1 1 /**
2   - * Copyright © 2016-2020 The Thingsboard Authors
  2 + * Copyright © 2016-2021 The Thingsboard Authors
3 3 *
4 4 * Licensed under the Apache License, Version 2.0 (the "License");
5 5 * you may not use this file except in compliance with the License.
... ...
1 1 /**
2   - * Copyright © 2016-2020 The Thingsboard Authors
  2 + * Copyright © 2016-2021 The Thingsboard Authors
3 3 *
4 4 * Licensed under the Apache License, Version 2.0 (the "License");
5 5 * you may not use this file except in compliance with the License.
... ... @@ -53,6 +53,8 @@ import org.thingsboard.server.common.data.id.WidgetTypeId;
53 53 import org.thingsboard.server.common.data.id.WidgetsBundleId;
54 54 import org.thingsboard.server.common.data.kv.AttributeKvEntry;
55 55 import org.thingsboard.server.common.data.kv.DataType;
  56 +import org.thingsboard.server.common.data.kv.KvEntry;
  57 +import org.thingsboard.server.common.data.kv.TsKvEntry;
56 58 import org.thingsboard.server.common.data.page.PageLink;
57 59 import org.thingsboard.server.common.data.page.SortOrder;
58 60 import org.thingsboard.server.common.data.page.TimePageLink;
... ... @@ -107,9 +109,11 @@ import org.thingsboard.server.service.telemetry.TelemetrySubscriptionService;
107 109 import javax.mail.MessagingException;
108 110 import javax.servlet.http.HttpServletResponse;
109 111 import java.util.List;
  112 +import java.util.Map;
110 113 import java.util.Optional;
111 114 import java.util.Set;
112 115 import java.util.UUID;
  116 +import java.util.stream.Collectors;
113 117
114 118 import static org.thingsboard.server.dao.service.Validator.validateId;
115 119
... ... @@ -713,6 +717,12 @@ public abstract class BaseController {
713 717 case PROVISION_FAILURE:
714 718 msgType = DataConstants.PROVISION_FAILURE;
715 719 break;
  720 + case TIMESERIES_UPDATED:
  721 + msgType = DataConstants.TIMESERIES_UPDATED;
  722 + break;
  723 + case TIMESERIES_DELETED:
  724 + msgType = DataConstants.TIMESERIES_DELETED;
  725 + break;
716 726 }
717 727 if (!StringUtils.isEmpty(msgType)) {
718 728 try {
... ... @@ -757,17 +767,7 @@ public abstract class BaseController {
757 767 metaData.putValue("scope", scope);
758 768 if (attributes != null) {
759 769 for (AttributeKvEntry attr : attributes) {
760   - if (attr.getDataType() == DataType.BOOLEAN) {
761   - entityNode.put(attr.getKey(), attr.getBooleanValue().get());
762   - } else if (attr.getDataType() == DataType.DOUBLE) {
763   - entityNode.put(attr.getKey(), attr.getDoubleValue().get());
764   - } else if (attr.getDataType() == DataType.LONG) {
765   - entityNode.put(attr.getKey(), attr.getLongValue().get());
766   - } else if (attr.getDataType() == DataType.JSON) {
767   - entityNode.set(attr.getKey(), json.readTree(attr.getJsonValue().get()));
768   - } else {
769   - entityNode.put(attr.getKey(), attr.getValueAsString());
770   - }
  770 + addKvEntry(entityNode, attr);
771 771 }
772 772 }
773 773 } else if (actionType == ActionType.ATTRIBUTES_DELETED) {
... ... @@ -778,6 +778,17 @@ public abstract class BaseController {
778 778 if (keys != null) {
779 779 keys.forEach(attrsArrayNode::add);
780 780 }
  781 + } else if (actionType == ActionType.TIMESERIES_UPDATED) {
  782 + List<TsKvEntry> timeseries = extractParameter(List.class, 0, additionalInfo);
  783 + addTimeseries(entityNode, timeseries);
  784 + } else if (actionType == ActionType.TIMESERIES_DELETED) {
  785 + List<String> keys = extractParameter(List.class, 0, additionalInfo);
  786 + if (keys != null) {
  787 + ArrayNode timeseriesArrayNode = entityNode.putArray("timeseries");
  788 + keys.forEach(timeseriesArrayNode::add);
  789 + }
  790 + entityNode.put("startTs", extractParameter(Long.class, 1, additionalInfo));
  791 + entityNode.put("endTs", extractParameter(Long.class, 2, additionalInfo));
781 792 }
782 793 }
783 794 TbMsg tbMsg = TbMsg.newMsg(msgType, entityId, metaData, TbMsgDataType.JSON, json.writeValueAsString(entityNode));
... ... @@ -794,6 +805,22 @@ public abstract class BaseController {
794 805 }
795 806 }
796 807
  808 + private void addKvEntry(ObjectNode entityNode, KvEntry kvEntry) throws Exception {
  809 + if (kvEntry.getDataType() == DataType.BOOLEAN) {
  810 + kvEntry.getBooleanValue().ifPresent(value -> entityNode.put(kvEntry.getKey(), value));
  811 + } else if (kvEntry.getDataType() == DataType.DOUBLE) {
  812 + kvEntry.getDoubleValue().ifPresent(value -> entityNode.put(kvEntry.getKey(), value));
  813 + } else if (kvEntry.getDataType() == DataType.LONG) {
  814 + kvEntry.getLongValue().ifPresent(value -> entityNode.put(kvEntry.getKey(), value));
  815 + } else if (kvEntry.getDataType() == DataType.JSON) {
  816 + if (kvEntry.getJsonValue().isPresent()) {
  817 + entityNode.set(kvEntry.getKey(), json.readTree(kvEntry.getJsonValue().get()));
  818 + }
  819 + } else {
  820 + entityNode.put(kvEntry.getKey(), kvEntry.getValueAsString());
  821 + }
  822 + }
  823 +
797 824 private <T> T extractParameter(Class<T> clazz, int index, Object... additionalInfo) {
798 825 T result = null;
799 826 if (additionalInfo != null && additionalInfo.length > index) {
... ... @@ -814,4 +841,20 @@ public abstract class BaseController {
814 841 return null;
815 842 }
816 843
  844 + private void addTimeseries(ObjectNode entityNode, List<TsKvEntry> timeseries) throws Exception {
  845 + if (timeseries != null && !timeseries.isEmpty()) {
  846 + ArrayNode result = entityNode.putArray("timeseries");
  847 + Map<Long, List<TsKvEntry>> groupedTelemetry = timeseries.stream()
  848 + .collect(Collectors.groupingBy(TsKvEntry::getTs));
  849 + for (Map.Entry<Long, List<TsKvEntry>> entry : groupedTelemetry.entrySet()) {
  850 + ObjectNode element = json.createObjectNode();
  851 + element.put("ts", entry.getKey());
  852 + ObjectNode values = element.putObject("values");
  853 + for (TsKvEntry tsKvEntry : entry.getValue()) {
  854 + addKvEntry(values, tsKvEntry);
  855 + }
  856 + result.add(element);
  857 + }
  858 + }
  859 + }
817 860 }
... ...
1 1 /**
2   - * Copyright © 2016-2020 The Thingsboard Authors
  2 + * Copyright © 2016-2021 The Thingsboard Authors
3 3 *
4 4 * Licensed under the Apache License, Version 2.0 (the "License");
5 5 * you may not use this file except in compliance with the License.
... ...
1 1 /**
2   - * Copyright © 2016-2020 The Thingsboard Authors
  2 + * Copyright © 2016-2021 The Thingsboard Authors
3 3 *
4 4 * Licensed under the Apache License, Version 2.0 (the "License");
5 5 * you may not use this file except in compliance with the License.
... ...
1 1 /**
2   - * Copyright © 2016-2020 The Thingsboard Authors
  2 + * Copyright © 2016-2021 The Thingsboard Authors
3 3 *
4 4 * Licensed under the Apache License, Version 2.0 (the "License");
5 5 * you may not use this file except in compliance with the License.
... ... @@ -212,7 +212,7 @@ public class DashboardController extends BaseController {
212 212 @RequestMapping(value = "/dashboard/{dashboardId}/customers", method = RequestMethod.POST)
213 213 @ResponseBody
214 214 public Dashboard updateDashboardCustomers(@PathVariable(DASHBOARD_ID) String strDashboardId,
215   - @RequestBody String[] strCustomerIds) throws ThingsboardException {
  215 + @RequestBody(required = false) String[] strCustomerIds) throws ThingsboardException {
216 216 checkParameter(DASHBOARD_ID, strDashboardId);
217 217 try {
218 218 DashboardId dashboardId = new DashboardId(toUUID(strDashboardId));
... ...
1 1 /**
2   - * Copyright © 2016-2020 The Thingsboard Authors
  2 + * Copyright © 2016-2021 The Thingsboard Authors
3 3 *
4 4 * Licensed under the Apache License, Version 2.0 (the "License");
5 5 * you may not use this file except in compliance with the License.
... ...
1 1 /**
2   - * Copyright © 2016-2020 The Thingsboard Authors
  2 + * Copyright © 2016-2021 The Thingsboard Authors
3 3 *
4 4 * Licensed under the Apache License, Version 2.0 (the "License");
5 5 * you may not use this file except in compliance with the License.
... ... @@ -16,6 +16,8 @@
16 16 package org.thingsboard.server.controller;
17 17
18 18 import lombok.extern.slf4j.Slf4j;
  19 +import org.apache.commons.lang3.StringUtils;
  20 +import org.springframework.beans.factory.annotation.Autowired;
19 21 import org.springframework.http.HttpStatus;
20 22 import org.springframework.security.access.prepost.PreAuthorize;
21 23 import org.springframework.web.bind.annotation.PathVariable;
... ... @@ -35,21 +37,30 @@ import org.thingsboard.server.common.data.id.DeviceProfileId;
35 37 import org.thingsboard.server.common.data.page.PageData;
36 38 import org.thingsboard.server.common.data.page.PageLink;
37 39 import org.thingsboard.server.common.data.plugin.ComponentLifecycleEvent;
  40 +import org.thingsboard.server.dao.timeseries.TimeseriesService;
38 41 import org.thingsboard.server.queue.util.TbCoreComponent;
39 42 import org.thingsboard.server.service.security.permission.Operation;
40 43 import org.thingsboard.server.service.security.permission.Resource;
41 44
  45 +import java.util.List;
  46 +import java.util.UUID;
  47 +
42 48 @RestController
43 49 @TbCoreComponent
44 50 @RequestMapping("/api")
45 51 @Slf4j
46 52 public class DeviceProfileController extends BaseController {
47 53
  54 + private static final String DEVICE_PROFILE_ID = "deviceProfileId";
  55 +
  56 + @Autowired
  57 + private TimeseriesService timeseriesService;
  58 +
48 59 @PreAuthorize("hasAnyAuthority('TENANT_ADMIN')")
49 60 @RequestMapping(value = "/deviceProfile/{deviceProfileId}", method = RequestMethod.GET)
50 61 @ResponseBody
51   - public DeviceProfile getDeviceProfileById(@PathVariable("deviceProfileId") String strDeviceProfileId) throws ThingsboardException {
52   - checkParameter("deviceProfileId", strDeviceProfileId);
  62 + public DeviceProfile getDeviceProfileById(@PathVariable(DEVICE_PROFILE_ID) String strDeviceProfileId) throws ThingsboardException {
  63 + checkParameter(DEVICE_PROFILE_ID, strDeviceProfileId);
53 64 try {
54 65 DeviceProfileId deviceProfileId = new DeviceProfileId(toUUID(strDeviceProfileId));
55 66 return checkDeviceProfileId(deviceProfileId, Operation.READ);
... ... @@ -61,8 +72,8 @@ public class DeviceProfileController extends BaseController {
61 72 @PreAuthorize("hasAnyAuthority('TENANT_ADMIN', 'CUSTOMER_USER')")
62 73 @RequestMapping(value = "/deviceProfileInfo/{deviceProfileId}", method = RequestMethod.GET)
63 74 @ResponseBody
64   - public DeviceProfileInfo getDeviceProfileInfoById(@PathVariable("deviceProfileId") String strDeviceProfileId) throws ThingsboardException {
65   - checkParameter("deviceProfileId", strDeviceProfileId);
  75 + public DeviceProfileInfo getDeviceProfileInfoById(@PathVariable(DEVICE_PROFILE_ID) String strDeviceProfileId) throws ThingsboardException {
  76 + checkParameter(DEVICE_PROFILE_ID, strDeviceProfileId);
66 77 try {
67 78 DeviceProfileId deviceProfileId = new DeviceProfileId(toUUID(strDeviceProfileId));
68 79 return checkNotNull(deviceProfileService.findDeviceProfileInfoById(getTenantId(), deviceProfileId));
... ... @@ -82,6 +93,46 @@ public class DeviceProfileController extends BaseController {
82 93 }
83 94 }
84 95
  96 + @PreAuthorize("hasAnyAuthority('TENANT_ADMIN')")
  97 + @RequestMapping(value = "/deviceProfile/devices/keys/timeseries", method = RequestMethod.GET)
  98 + @ResponseBody
  99 + public List<String> getTimeseriesKeys(
  100 + @RequestParam(name = DEVICE_PROFILE_ID, required = false) String deviceProfileIdStr) throws ThingsboardException {
  101 + DeviceProfileId deviceProfileId;
  102 + if (StringUtils.isNotEmpty(deviceProfileIdStr)) {
  103 + deviceProfileId = new DeviceProfileId(UUID.fromString(deviceProfileIdStr));
  104 + checkDeviceProfileId(deviceProfileId, Operation.READ);
  105 + } else {
  106 + deviceProfileId = null;
  107 + }
  108 +
  109 + try {
  110 + return timeseriesService.findAllKeysByDeviceProfileId(getTenantId(), deviceProfileId);
  111 + } catch (Exception e) {
  112 + throw handleException(e);
  113 + }
  114 + }
  115 +
  116 + @PreAuthorize("hasAnyAuthority('TENANT_ADMIN')")
  117 + @RequestMapping(value = "/deviceProfile/devices/keys/attributes", method = RequestMethod.GET)
  118 + @ResponseBody
  119 + public List<String> getAttributesKeys(
  120 + @RequestParam(name = DEVICE_PROFILE_ID, required = false) String deviceProfileIdStr) throws ThingsboardException {
  121 + DeviceProfileId deviceProfileId;
  122 + if (StringUtils.isNotEmpty(deviceProfileIdStr)) {
  123 + deviceProfileId = new DeviceProfileId(UUID.fromString(deviceProfileIdStr));
  124 + checkDeviceProfileId(deviceProfileId, Operation.READ);
  125 + } else {
  126 + deviceProfileId = null;
  127 + }
  128 +
  129 + try {
  130 + return attributesService.findAllKeysByDeviceProfileId(getTenantId(), deviceProfileId);
  131 + } catch (Exception e) {
  132 + throw handleException(e);
  133 + }
  134 + }
  135 +
85 136 @PreAuthorize("hasAuthority('TENANT_ADMIN')")
86 137 @RequestMapping(value = "/deviceProfile", method = RequestMethod.POST)
87 138 @ResponseBody
... ... @@ -100,7 +151,7 @@ public class DeviceProfileController extends BaseController {
100 151
101 152 logEntityAction(savedDeviceProfile.getId(), savedDeviceProfile,
102 153 null,
103   - savedDeviceProfile.getId() == null ? ActionType.ADDED : ActionType.UPDATED, null);
  154 + created ? ActionType.ADDED : ActionType.UPDATED, null);
104 155
105 156 return savedDeviceProfile;
106 157 } catch (Exception e) {
... ... @@ -113,8 +164,8 @@ public class DeviceProfileController extends BaseController {
113 164 @PreAuthorize("hasAuthority('TENANT_ADMIN')")
114 165 @RequestMapping(value = "/deviceProfile/{deviceProfileId}", method = RequestMethod.DELETE)
115 166 @ResponseStatus(value = HttpStatus.OK)
116   - public void deleteDeviceProfile(@PathVariable("deviceProfileId") String strDeviceProfileId) throws ThingsboardException {
117   - checkParameter("deviceProfileId", strDeviceProfileId);
  167 + public void deleteDeviceProfile(@PathVariable(DEVICE_PROFILE_ID) String strDeviceProfileId) throws ThingsboardException {
  168 + checkParameter(DEVICE_PROFILE_ID, strDeviceProfileId);
118 169 try {
119 170 DeviceProfileId deviceProfileId = new DeviceProfileId(toUUID(strDeviceProfileId));
120 171 DeviceProfile deviceProfile = checkDeviceProfileId(deviceProfileId, Operation.DELETE);
... ... @@ -139,8 +190,8 @@ public class DeviceProfileController extends BaseController {
139 190 @PreAuthorize("hasAnyAuthority('TENANT_ADMIN')")
140 191 @RequestMapping(value = "/deviceProfile/{deviceProfileId}/default", method = RequestMethod.POST)
141 192 @ResponseBody
142   - public DeviceProfile setDefaultDeviceProfile(@PathVariable("deviceProfileId") String strDeviceProfileId) throws ThingsboardException {
143   - checkParameter("deviceProfileId", strDeviceProfileId);
  193 + public DeviceProfile setDefaultDeviceProfile(@PathVariable(DEVICE_PROFILE_ID) String strDeviceProfileId) throws ThingsboardException {
  194 + checkParameter(DEVICE_PROFILE_ID, strDeviceProfileId);
144 195 try {
145 196 DeviceProfileId deviceProfileId = new DeviceProfileId(toUUID(strDeviceProfileId));
146 197 DeviceProfile deviceProfile = checkDeviceProfileId(deviceProfileId, Operation.WRITE);
... ...
1 1 /**
2   - * Copyright © 2016-2020 The Thingsboard Authors
  2 + * Copyright © 2016-2021 The Thingsboard Authors
3 3 *
4 4 * Licensed under the Apache License, Version 2.0 (the "License");
5 5 * you may not use this file except in compliance with the License.
... ... @@ -16,18 +16,23 @@
16 16 package org.thingsboard.server.controller;
17 17
18 18 import org.springframework.beans.factory.annotation.Autowired;
  19 +import org.springframework.http.ResponseEntity;
19 20 import org.springframework.security.access.prepost.PreAuthorize;
20 21 import org.springframework.web.bind.annotation.RequestBody;
21 22 import org.springframework.web.bind.annotation.RequestMapping;
22 23 import org.springframework.web.bind.annotation.RequestMethod;
  24 +import org.springframework.web.bind.annotation.RequestParam;
23 25 import org.springframework.web.bind.annotation.ResponseBody;
24 26 import org.springframework.web.bind.annotation.RestController;
  27 +import org.springframework.web.context.request.async.DeferredResult;
25 28 import org.thingsboard.server.common.data.exception.ThingsboardException;
  29 +import org.thingsboard.server.common.data.id.TenantId;
26 30 import org.thingsboard.server.common.data.page.PageData;
27 31 import org.thingsboard.server.common.data.query.AlarmData;
28 32 import org.thingsboard.server.common.data.query.AlarmDataQuery;
29 33 import org.thingsboard.server.common.data.query.EntityCountQuery;
30 34 import org.thingsboard.server.common.data.query.EntityData;
  35 +import org.thingsboard.server.common.data.query.EntityDataPageLink;
31 36 import org.thingsboard.server.common.data.query.EntityDataQuery;
32 37 import org.thingsboard.server.queue.util.TbCoreComponent;
33 38 import org.thingsboard.server.service.query.EntityQueryService;
... ... @@ -40,6 +45,7 @@ public class EntityQueryController extends BaseController {
40 45 @Autowired
41 46 private EntityQueryService entityQueryService;
42 47
  48 + private static final int MAX_PAGE_SIZE = 100;
43 49
44 50 @PreAuthorize("hasAnyAuthority('TENANT_ADMIN', 'CUSTOMER_USER')")
45 51 @RequestMapping(value = "/entitiesQuery/count", method = RequestMethod.POST)
... ... @@ -76,4 +82,24 @@ public class EntityQueryController extends BaseController {
76 82 throw handleException(e);
77 83 }
78 84 }
  85 +
  86 + @PreAuthorize("hasAnyAuthority('TENANT_ADMIN', 'CUSTOMER_USER')")
  87 + @RequestMapping(value = "/entitiesQuery/find/keys", method = RequestMethod.POST)
  88 + @ResponseBody
  89 + public DeferredResult<ResponseEntity> findEntityTimeseriesAndAttributesKeysByQuery(@RequestBody EntityDataQuery query,
  90 + @RequestParam("timeseries") boolean isTimeseries,
  91 + @RequestParam("attributes") boolean isAttributes) throws ThingsboardException {
  92 + TenantId tenantId = getTenantId();
  93 + checkNotNull(query);
  94 + try {
  95 + EntityDataPageLink pageLink = query.getPageLink();
  96 + if (pageLink.getPageSize() > MAX_PAGE_SIZE) {
  97 + pageLink.setPageSize(MAX_PAGE_SIZE);
  98 + }
  99 + return entityQueryService.getKeysByQuery(getCurrentUser(), tenantId, query, isTimeseries, isAttributes);
  100 + } catch (Exception e) {
  101 + throw handleException(e);
  102 + }
  103 + }
  104 +
79 105 }
... ...
1 1 /**
2   - * Copyright © 2016-2020 The Thingsboard Authors
  2 + * Copyright © 2016-2021 The Thingsboard Authors
3 3 *
4 4 * Licensed under the Apache License, Version 2.0 (the "License");
5 5 * you may not use this file except in compliance with the License.
... ...
1 1 /**
2   - * Copyright © 2016-2020 The Thingsboard Authors
  2 + * Copyright © 2016-2021 The Thingsboard Authors
3 3 *
4 4 * Licensed under the Apache License, Version 2.0 (the "License");
5 5 * you may not use this file except in compliance with the License.
... ...
1 1 /**
2   - * Copyright © 2016-2020 The Thingsboard Authors
  2 + * Copyright © 2016-2021 The Thingsboard Authors
3 3 *
4 4 * Licensed under the Apache License, Version 2.0 (the "License");
5 5 * you may not use this file except in compliance with the License.
... ...
1 1 /**
2   - * Copyright © 2016-2020 The Thingsboard Authors
  2 + * Copyright © 2016-2021 The Thingsboard Authors
3 3 *
4 4 * Licensed under the Apache License, Version 2.0 (the "License");
5 5 * you may not use this file except in compliance with the License.
... ...
1 1 /**
2   - * Copyright © 2016-2020 The Thingsboard Authors
  2 + * Copyright © 2016-2021 The Thingsboard Authors
3 3 *
4 4 * Licensed under the Apache License, Version 2.0 (the "License");
5 5 * you may not use this file except in compliance with the License.
... ...
1 1 /**
2   - * Copyright © 2016-2020 The Thingsboard Authors
  2 + * Copyright © 2016-2021 The Thingsboard Authors
3 3 *
4 4 * Licensed under the Apache License, Version 2.0 (the "License");
5 5 * you may not use this file except in compliance with the License.
... ...
1 1 /**
2   - * Copyright © 2016-2020 The Thingsboard Authors
  2 + * Copyright © 2016-2021 The Thingsboard Authors
3 3 *
4 4 * Licensed under the Apache License, Version 2.0 (the "License");
5 5 * you may not use this file except in compliance with the License.
... ...
1 1 /**
2   - * Copyright © 2016-2020 The Thingsboard Authors
  2 + * Copyright © 2016-2021 The Thingsboard Authors
3 3 *
4 4 * Licensed under the Apache License, Version 2.0 (the "License");
5 5 * you may not use this file except in compliance with the License.
... ...
1 1 /**
2   - * Copyright © 2016-2020 The Thingsboard Authors
  2 + * Copyright © 2016-2021 The Thingsboard Authors
3 3 *
4 4 * Licensed under the Apache License, Version 2.0 (the "License");
5 5 * you may not use this file except in compliance with the License.
... ...
1 1 /**
2   - * Copyright © 2016-2020 The Thingsboard Authors
  2 + * Copyright © 2016-2021 The Thingsboard Authors
3 3 *
4 4 * Licensed under the Apache License, Version 2.0 (the "License");
5 5 * you may not use this file except in compliance with the License.
... ...