Commit bc3008ad7b0005db25ef0adeaf1b9f7fd3872b55

Authored by Volodymyr Babak
2 parents 20a67194 e6056ec8

Merge remote-tracking branch 'upstream/master' into develop/3.3-edge

Showing 100 changed files with 257 additions and 126 deletions

Too many changes to show.

To preserve performance only 100 of 3282 files are displayed.

1 <!-- 1 <!--
2 2
3 - Copyright © 2016-2020 The Thingsboard Authors 3 + Copyright © 2016-2021 The Thingsboard Authors
4 4
5 Licensed under the Apache License, Version 2.0 (the "License"); 5 Licensed under the Apache License, Version 2.0 (the "License");
6 you may not use this file except in compliance with the License. 6 you may not use this file except in compliance with the License.
1 <?xml version="1.0" encoding="UTF-8" ?> 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 Licensed under the Apache License, Version 2.0 (the "License"); 6 Licensed under the Apache License, Version 2.0 (the "License");
7 you may not use this file except in compliance with the License. 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 # Licensed under the Apache License, Version 2.0 (the "License"); 4 # Licensed under the Apache License, Version 2.0 (the "License");
5 # you may not use this file except in compliance with the License. 5 # you may not use this file except in compliance with the License.
@@ -18,7 +18,7 @@ @@ -18,7 +18,7 @@
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}", 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 "settingsSchema": "{}", 19 "settingsSchema": "{}",
20 "dataKeySettingsSchema": "{}\n", 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,7 +66,7 @@
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}", 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 "settingsSchema": "{}", 67 "settingsSchema": "{}",
68 "dataKeySettingsSchema": "{}\n", 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,7 +370,7 @@
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}", 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 "settingsSchema": "{}", 371 "settingsSchema": "{}",
372 "dataKeySettingsSchema": "{}\n", 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 -- Licensed under the Apache License, Version 2.0 (the "License"); 4 -- Licensed under the Apache License, Version 2.0 (the "License");
5 -- you may not use this file except in compliance with the License. 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 -- Licensed under the Apache License, Version 2.0 (the "License"); 4 -- Licensed under the Apache License, Version 2.0 (the "License");
5 -- you may not use this file except in compliance with the License. 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 -- Licensed under the Apache License, Version 2.0 (the "License"); 4 -- Licensed under the Apache License, Version 2.0 (the "License");
5 -- you may not use this file except in compliance with the License. 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 -- Licensed under the Apache License, Version 2.0 (the "License"); 4 -- Licensed under the Apache License, Version 2.0 (the "License");
5 -- you may not use this file except in compliance with the License. 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 -- Licensed under the Apache License, Version 2.0 (the "License"); 4 -- Licensed under the Apache License, Version 2.0 (the "License");
5 -- you may not use this file except in compliance with the License. 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 -- Licensed under the Apache License, Version 2.0 (the "License"); 4 -- Licensed under the Apache License, Version 2.0 (the "License");
5 -- you may not use this file except in compliance with the License. 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 -- Licensed under the Apache License, Version 2.0 (the "License"); 4 -- Licensed under the Apache License, Version 2.0 (the "License");
5 -- you may not use this file except in compliance with the License. 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 -- Licensed under the Apache License, Version 2.0 (the "License"); 4 -- Licensed under the Apache License, Version 2.0 (the "License");
5 -- you may not use this file except in compliance with the License. 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 -- Licensed under the Apache License, Version 2.0 (the "License"); 4 -- Licensed under the Apache License, Version 2.0 (the "License");
5 -- you may not use this file except in compliance with the License. 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 -- Licensed under the Apache License, Version 2.0 (the "License"); 4 -- Licensed under the Apache License, Version 2.0 (the "License");
5 -- you may not use this file except in compliance with the License. 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 -- Licensed under the Apache License, Version 2.0 (the "License"); 4 -- Licensed under the Apache License, Version 2.0 (the "License");
5 -- you may not use this file except in compliance with the License. 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 -- Licensed under the Apache License, Version 2.0 (the "License"); 4 -- Licensed under the Apache License, Version 2.0 (the "License");
5 -- you may not use this file except in compliance with the License. 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 -- Licensed under the Apache License, Version 2.0 (the "License"); 4 -- Licensed under the Apache License, Version 2.0 (the "License");
5 -- you may not use this file except in compliance with the License. 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 -- Licensed under the Apache License, Version 2.0 (the "License"); 4 -- Licensed under the Apache License, Version 2.0 (the "License");
5 -- you may not use this file except in compliance with the License. 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 -- Licensed under the Apache License, Version 2.0 (the "License"); 4 -- Licensed under the Apache License, Version 2.0 (the "License");
5 -- you may not use this file except in compliance with the License. 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 -- Licensed under the Apache License, Version 2.0 (the "License"); 4 -- Licensed under the Apache License, Version 2.0 (the "License");
5 -- you may not use this file except in compliance with the License. 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 -- Licensed under the Apache License, Version 2.0 (the "License"); 4 -- Licensed under the Apache License, Version 2.0 (the "License");
5 -- you may not use this file except in compliance with the License. 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 -- Licensed under the Apache License, Version 2.0 (the "License"); 4 -- Licensed under the Apache License, Version 2.0 (the "License");
5 -- you may not use this file except in compliance with the License. 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 -- Licensed under the Apache License, Version 2.0 (the "License"); 4 -- Licensed under the Apache License, Version 2.0 (the "License");
5 -- you may not use this file except in compliance with the License. 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 -- Licensed under the Apache License, Version 2.0 (the "License"); 4 -- Licensed under the Apache License, Version 2.0 (the "License");
5 -- you may not use this file except in compliance with the License. 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 -- Licensed under the Apache License, Version 2.0 (the "License"); 4 -- Licensed under the Apache License, Version 2.0 (the "License");
5 -- you may not use this file except in compliance with the License. 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 -- Licensed under the Apache License, Version 2.0 (the "License"); 4 -- Licensed under the Apache License, Version 2.0 (the "License");
5 -- you may not use this file except in compliance with the License. 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 -- Licensed under the Apache License, Version 2.0 (the "License"); 4 -- Licensed under the Apache License, Version 2.0 (the "License");
5 -- you may not use this file except in compliance with the License. 5 -- you may not use this file except in compliance with the License.
application/src/main/data/upgrade/3.2.1/schema_update.sql renamed from application/src/main/data/upgrade/3.2.0/schema_update.sql
1 -- 1 --
2 --- Copyright © 2016-2020 The Thingsboard Authors 2 +-- Copyright © 2016-2021 The Thingsboard Authors
3 -- 3 --
4 -- Licensed under the Apache License, Version 2.0 (the "License"); 4 -- Licensed under the Apache License, Version 2.0 (the "License");
5 -- you may not use this file except in compliance with the License. 5 -- you may not use this file except in compliance with the License.
application/src/main/data/upgrade/3.2.1/schema_update_ttl.sql renamed from application/src/main/data/upgrade/3.2.0/schema_update_ttl.sql
1 -- 1 --
2 --- Copyright © 2016-2020 The Thingsboard Authors 2 +-- Copyright © 2016-2021 The Thingsboard Authors
3 -- 3 --
4 -- Licensed under the Apache License, Version 2.0 (the "License"); 4 -- Licensed under the Apache License, Version 2.0 (the "License");
5 -- you may not use this file except in compliance with the License. 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 * Licensed under the Apache License, Version 2.0 (the "License"); 4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License. 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 * Licensed under the Apache License, Version 2.0 (the "License"); 4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License. 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 * Licensed under the Apache License, Version 2.0 (the "License"); 4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License. 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 * Licensed under the Apache License, Version 2.0 (the "License"); 4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License. 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 * Licensed under the Apache License, Version 2.0 (the "License"); 4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License. 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 * Licensed under the Apache License, Version 2.0 (the "License"); 4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License. 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 * Licensed under the Apache License, Version 2.0 (the "License"); 4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License. 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 * Licensed under the Apache License, Version 2.0 (the "License"); 4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License. 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 * Licensed under the Apache License, Version 2.0 (the "License"); 4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License. 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 * Licensed under the Apache License, Version 2.0 (the "License"); 4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License. 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 * Licensed under the Apache License, Version 2.0 (the "License"); 4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License. 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 * Licensed under the Apache License, Version 2.0 (the "License"); 4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License. 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 * Licensed under the Apache License, Version 2.0 (the "License"); 4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License. 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 * Licensed under the Apache License, Version 2.0 (the "License"); 4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License. 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 * Licensed under the Apache License, Version 2.0 (the "License"); 4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License. 5 * you may not use this file except in compliance with the License.
@@ -246,8 +246,18 @@ class DefaultTbContext implements TbContext { @@ -246,8 +246,18 @@ class DefaultTbContext implements TbContext {
246 if (nodeCtx.getSelf().isDebugMode()) { 246 if (nodeCtx.getSelf().isDebugMode()) {
247 mainCtx.persistDebugOutput(nodeCtx.getTenantId(), nodeCtx.getSelf().getId(), msg, TbRelationTypes.FAILURE, th); 247 mainCtx.persistDebugOutput(nodeCtx.getTenantId(), nodeCtx.getSelf().getId(), msg, TbRelationTypes.FAILURE, th);
248 } 248 }
  249 + String failureMessage;
  250 + if (th != null) {
  251 + if (!StringUtils.isEmpty(th.getMessage())) {
  252 + failureMessage = th.getMessage();
  253 + } else {
  254 + failureMessage = th.getClass().getSimpleName();
  255 + }
  256 + } else {
  257 + failureMessage = null;
  258 + }
249 nodeCtx.getChainActor().tell(new RuleNodeToRuleChainTellNextMsg(nodeCtx.getSelf().getId(), Collections.singleton(TbRelationTypes.FAILURE), 259 nodeCtx.getChainActor().tell(new RuleNodeToRuleChainTellNextMsg(nodeCtx.getSelf().getId(), Collections.singleton(TbRelationTypes.FAILURE),
250 - msg, th != null ? th.getMessage() : null)); 260 + msg, failureMessage));
251 } 261 }
252 262
253 public void updateSelf(RuleNode self) { 263 public void updateSelf(RuleNode self) {
1 /** 1 /**
2 - * Copyright © 2016-2020 The Thingsboard Authors 2 + * Copyright © 2016-2021 The Thingsboard Authors
3 * 3 *
4 * Licensed under the Apache License, Version 2.0 (the "License"); 4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License. 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 * Licensed under the Apache License, Version 2.0 (the "License"); 4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License. 5 * you may not use this file except in compliance with the License.
@@ -57,6 +57,7 @@ import java.util.HashMap; @@ -57,6 +57,7 @@ import java.util.HashMap;
57 import java.util.List; 57 import java.util.List;
58 import java.util.Map; 58 import java.util.Map;
59 import java.util.Set; 59 import java.util.Set;
  60 +import java.util.UUID;
60 import java.util.stream.Collectors; 61 import java.util.stream.Collectors;
61 62
62 /** 63 /**
@@ -289,10 +290,10 @@ public class RuleChainActorMessageProcessor extends ComponentMsgProcessor<RuleCh @@ -289,10 +290,10 @@ public class RuleChainActorMessageProcessor extends ComponentMsgProcessor<RuleCh
289 private void putToQueue(TopicPartitionInfo tpi, TbMsg msg, TbQueueCallback callbackWrapper, EntityId target) { 290 private void putToQueue(TopicPartitionInfo tpi, TbMsg msg, TbQueueCallback callbackWrapper, EntityId target) {
290 switch (target.getEntityType()) { 291 switch (target.getEntityType()) {
291 case RULE_NODE: 292 case RULE_NODE:
292 - putToQueue(tpi, msg.copyWithRuleNodeId(entityId, new RuleNodeId(target.getId())), callbackWrapper); 293 + putToQueue(tpi, msg.copyWithRuleNodeId(entityId, new RuleNodeId(target.getId()), UUID.randomUUID()), callbackWrapper);
293 break; 294 break;
294 case RULE_CHAIN: 295 case RULE_CHAIN:
295 - putToQueue(tpi, msg.copyWithRuleChainId(new RuleChainId(target.getId())), callbackWrapper); 296 + putToQueue(tpi, msg.copyWithRuleChainId(new RuleChainId(target.getId()), UUID.randomUUID()), callbackWrapper);
296 break; 297 break;
297 } 298 }
298 } 299 }
1 /** 1 /**
2 - * Copyright © 2016-2020 The Thingsboard Authors 2 + * Copyright © 2016-2021 The Thingsboard Authors
3 * 3 *
4 * Licensed under the Apache License, Version 2.0 (the "License"); 4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License. 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 * Licensed under the Apache License, Version 2.0 (the "License"); 4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License. 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 * Licensed under the Apache License, Version 2.0 (the "License"); 4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License. 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 * Licensed under the Apache License, Version 2.0 (the "License"); 4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License. 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 * Licensed under the Apache License, Version 2.0 (the "License"); 4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License. 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 * Licensed under the Apache License, Version 2.0 (the "License"); 4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License. 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 * Licensed under the Apache License, Version 2.0 (the "License"); 4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License. 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 * Licensed under the Apache License, Version 2.0 (the "License"); 4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License. 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 * Licensed under the Apache License, Version 2.0 (the "License"); 4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License. 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 * Licensed under the Apache License, Version 2.0 (the "License"); 4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License. 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 * Licensed under the Apache License, Version 2.0 (the "License"); 4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License. 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 * Licensed under the Apache License, Version 2.0 (the "License"); 4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License. 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 * Licensed under the Apache License, Version 2.0 (the "License"); 4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License. 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 * Licensed under the Apache License, Version 2.0 (the "License"); 4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License. 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 * Licensed under the Apache License, Version 2.0 (the "License"); 4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License. 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 * Licensed under the Apache License, Version 2.0 (the "License"); 4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License. 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 * Licensed under the Apache License, Version 2.0 (the "License"); 4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License. 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 * Licensed under the Apache License, Version 2.0 (the "License"); 4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License. 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 * Licensed under the Apache License, Version 2.0 (the "License"); 4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License. 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 * Licensed under the Apache License, Version 2.0 (the "License"); 4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License. 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 * Licensed under the Apache License, Version 2.0 (the "License"); 4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License. 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 * Licensed under the Apache License, Version 2.0 (the "License"); 4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License. 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 * Licensed under the Apache License, Version 2.0 (the "License"); 4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License. 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 * Licensed under the Apache License, Version 2.0 (the "License"); 4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License. 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 * Licensed under the Apache License, Version 2.0 (the "License"); 4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License. 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 * Licensed under the Apache License, Version 2.0 (the "License"); 4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License. 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 * Licensed under the Apache License, Version 2.0 (the "License"); 4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License. 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 * Licensed under the Apache License, Version 2.0 (the "License"); 4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License. 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 * Licensed under the Apache License, Version 2.0 (the "License"); 4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License. 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 * Licensed under the Apache License, Version 2.0 (the "License"); 4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License. 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 * Licensed under the Apache License, Version 2.0 (the "License"); 4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License. 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 * Licensed under the Apache License, Version 2.0 (the "License"); 4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License. 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 * Licensed under the Apache License, Version 2.0 (the "License"); 4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License. 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 * Licensed under the Apache License, Version 2.0 (the "License"); 4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License. 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 * Licensed under the Apache License, Version 2.0 (the "License"); 4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License. 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 * Licensed under the Apache License, Version 2.0 (the "License"); 4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License. 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 * Licensed under the Apache License, Version 2.0 (the "License"); 4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License. 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 * Licensed under the Apache License, Version 2.0 (the "License"); 4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License. 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 * Licensed under the Apache License, Version 2.0 (the "License"); 4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License. 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 * Licensed under the Apache License, Version 2.0 (the "License"); 4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License. 5 * you may not use this file except in compliance with the License.
@@ -74,6 +74,8 @@ import org.thingsboard.server.common.data.id.WidgetTypeId; @@ -74,6 +74,8 @@ import org.thingsboard.server.common.data.id.WidgetTypeId;
74 import org.thingsboard.server.common.data.id.WidgetsBundleId; 74 import org.thingsboard.server.common.data.id.WidgetsBundleId;
75 import org.thingsboard.server.common.data.kv.AttributeKvEntry; 75 import org.thingsboard.server.common.data.kv.AttributeKvEntry;
76 import org.thingsboard.server.common.data.kv.DataType; 76 import org.thingsboard.server.common.data.kv.DataType;
  77 +import org.thingsboard.server.common.data.kv.KvEntry;
  78 +import org.thingsboard.server.common.data.kv.TsKvEntry;
77 import org.thingsboard.server.common.data.page.PageLink; 79 import org.thingsboard.server.common.data.page.PageLink;
78 import org.thingsboard.server.common.data.page.SortOrder; 80 import org.thingsboard.server.common.data.page.SortOrder;
79 import org.thingsboard.server.common.data.page.TimePageLink; 81 import org.thingsboard.server.common.data.page.TimePageLink;
@@ -135,9 +137,11 @@ import org.thingsboard.server.service.telemetry.TelemetrySubscriptionService; @@ -135,9 +137,11 @@ import org.thingsboard.server.service.telemetry.TelemetrySubscriptionService;
135 import javax.mail.MessagingException; 137 import javax.mail.MessagingException;
136 import javax.servlet.http.HttpServletResponse; 138 import javax.servlet.http.HttpServletResponse;
137 import java.util.List; 139 import java.util.List;
  140 +import java.util.Map;
138 import java.util.Optional; 141 import java.util.Optional;
139 import java.util.Set; 142 import java.util.Set;
140 import java.util.UUID; 143 import java.util.UUID;
  144 +import java.util.stream.Collectors;
141 145
142 import static org.thingsboard.server.dao.service.Validator.validateId; 146 import static org.thingsboard.server.dao.service.Validator.validateId;
143 147
@@ -783,6 +787,12 @@ public abstract class BaseController { @@ -783,6 +787,12 @@ public abstract class BaseController {
783 case PROVISION_FAILURE: 787 case PROVISION_FAILURE:
784 msgType = DataConstants.PROVISION_FAILURE; 788 msgType = DataConstants.PROVISION_FAILURE;
785 break; 789 break;
  790 + case TIMESERIES_UPDATED:
  791 + msgType = DataConstants.TIMESERIES_UPDATED;
  792 + break;
  793 + case TIMESERIES_DELETED:
  794 + msgType = DataConstants.TIMESERIES_DELETED;
  795 + break;
786 case ASSIGNED_TO_EDGE: 796 case ASSIGNED_TO_EDGE:
787 msgType = DataConstants.ENTITY_ASSIGNED_TO_EDGE; 797 msgType = DataConstants.ENTITY_ASSIGNED_TO_EDGE;
788 break; 798 break;
@@ -843,17 +853,7 @@ public abstract class BaseController { @@ -843,17 +853,7 @@ public abstract class BaseController {
843 metaData.putValue("scope", scope); 853 metaData.putValue("scope", scope);
844 if (attributes != null) { 854 if (attributes != null) {
845 for (AttributeKvEntry attr : attributes) { 855 for (AttributeKvEntry attr : attributes) {
846 - if (attr.getDataType() == DataType.BOOLEAN) {  
847 - entityNode.put(attr.getKey(), attr.getBooleanValue().get());  
848 - } else if (attr.getDataType() == DataType.DOUBLE) {  
849 - entityNode.put(attr.getKey(), attr.getDoubleValue().get());  
850 - } else if (attr.getDataType() == DataType.LONG) {  
851 - entityNode.put(attr.getKey(), attr.getLongValue().get());  
852 - } else if (attr.getDataType() == DataType.JSON) {  
853 - entityNode.set(attr.getKey(), json.readTree(attr.getJsonValue().get()));  
854 - } else {  
855 - entityNode.put(attr.getKey(), attr.getValueAsString());  
856 - } 856 + addKvEntry(entityNode, attr);
857 } 857 }
858 } 858 }
859 } else if (actionType == ActionType.ATTRIBUTES_DELETED) { 859 } else if (actionType == ActionType.ATTRIBUTES_DELETED) {
@@ -864,6 +864,17 @@ public abstract class BaseController { @@ -864,6 +864,17 @@ public abstract class BaseController {
864 if (keys != null) { 864 if (keys != null) {
865 keys.forEach(attrsArrayNode::add); 865 keys.forEach(attrsArrayNode::add);
866 } 866 }
  867 + } else if (actionType == ActionType.TIMESERIES_UPDATED) {
  868 + List<TsKvEntry> timeseries = extractParameter(List.class, 0, additionalInfo);
  869 + addTimeseries(entityNode, timeseries);
  870 + } else if (actionType == ActionType.TIMESERIES_DELETED) {
  871 + List<String> keys = extractParameter(List.class, 0, additionalInfo);
  872 + if (keys != null) {
  873 + ArrayNode timeseriesArrayNode = entityNode.putArray("timeseries");
  874 + keys.forEach(timeseriesArrayNode::add);
  875 + }
  876 + entityNode.put("startTs", extractParameter(Long.class, 1, additionalInfo));
  877 + entityNode.put("endTs", extractParameter(Long.class, 2, additionalInfo));
867 } 878 }
868 } 879 }
869 TbMsg tbMsg = TbMsg.newMsg(msgType, entityId, metaData, TbMsgDataType.JSON, json.writeValueAsString(entityNode)); 880 TbMsg tbMsg = TbMsg.newMsg(msgType, entityId, metaData, TbMsgDataType.JSON, json.writeValueAsString(entityNode));
@@ -880,6 +891,22 @@ public abstract class BaseController { @@ -880,6 +891,22 @@ public abstract class BaseController {
880 } 891 }
881 } 892 }
882 893
  894 + private void addKvEntry(ObjectNode entityNode, KvEntry kvEntry) throws Exception {
  895 + if (kvEntry.getDataType() == DataType.BOOLEAN) {
  896 + kvEntry.getBooleanValue().ifPresent(value -> entityNode.put(kvEntry.getKey(), value));
  897 + } else if (kvEntry.getDataType() == DataType.DOUBLE) {
  898 + kvEntry.getDoubleValue().ifPresent(value -> entityNode.put(kvEntry.getKey(), value));
  899 + } else if (kvEntry.getDataType() == DataType.LONG) {
  900 + kvEntry.getLongValue().ifPresent(value -> entityNode.put(kvEntry.getKey(), value));
  901 + } else if (kvEntry.getDataType() == DataType.JSON) {
  902 + if (kvEntry.getJsonValue().isPresent()) {
  903 + entityNode.set(kvEntry.getKey(), json.readTree(kvEntry.getJsonValue().get()));
  904 + }
  905 + } else {
  906 + entityNode.put(kvEntry.getKey(), kvEntry.getValueAsString());
  907 + }
  908 + }
  909 +
883 private <T> T extractParameter(Class<T> clazz, int index, Object... additionalInfo) { 910 private <T> T extractParameter(Class<T> clazz, int index, Object... additionalInfo) {
884 T result = null; 911 T result = null;
885 if (additionalInfo != null && additionalInfo.length > index) { 912 if (additionalInfo != null && additionalInfo.length > index) {
@@ -1001,4 +1028,20 @@ public abstract class BaseController { @@ -1001,4 +1028,20 @@ public abstract class BaseController {
1001 TransportProtos.ToCoreMsg.newBuilder().setEdgeNotificationMsg(msg).build(), null); 1028 TransportProtos.ToCoreMsg.newBuilder().setEdgeNotificationMsg(msg).build(), null);
1002 } 1029 }
1003 1030
  1031 + private void addTimeseries(ObjectNode entityNode, List<TsKvEntry> timeseries) throws Exception {
  1032 + if (timeseries != null && !timeseries.isEmpty()) {
  1033 + ArrayNode result = entityNode.putArray("timeseries");
  1034 + Map<Long, List<TsKvEntry>> groupedTelemetry = timeseries.stream()
  1035 + .collect(Collectors.groupingBy(TsKvEntry::getTs));
  1036 + for (Map.Entry<Long, List<TsKvEntry>> entry : groupedTelemetry.entrySet()) {
  1037 + ObjectNode element = json.createObjectNode();
  1038 + element.put("ts", entry.getKey());
  1039 + ObjectNode values = element.putObject("values");
  1040 + for (TsKvEntry tsKvEntry : entry.getValue()) {
  1041 + addKvEntry(values, tsKvEntry);
  1042 + }
  1043 + result.add(element);
  1044 + }
  1045 + }
  1046 + }
1004 } 1047 }
1 /** 1 /**
2 - * Copyright © 2016-2020 The Thingsboard Authors 2 + * Copyright © 2016-2021 The Thingsboard Authors
3 * 3 *
4 * Licensed under the Apache License, Version 2.0 (the "License"); 4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License. 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 * Licensed under the Apache License, Version 2.0 (the "License"); 4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License. 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 * Licensed under the Apache License, Version 2.0 (the "License"); 4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License. 5 * you may not use this file except in compliance with the License.
@@ -228,7 +228,7 @@ public class DashboardController extends BaseController { @@ -228,7 +228,7 @@ public class DashboardController extends BaseController {
228 @RequestMapping(value = "/dashboard/{dashboardId}/customers", method = RequestMethod.POST) 228 @RequestMapping(value = "/dashboard/{dashboardId}/customers", method = RequestMethod.POST)
229 @ResponseBody 229 @ResponseBody
230 public Dashboard updateDashboardCustomers(@PathVariable(DASHBOARD_ID) String strDashboardId, 230 public Dashboard updateDashboardCustomers(@PathVariable(DASHBOARD_ID) String strDashboardId,
231 - @RequestBody String[] strCustomerIds) throws ThingsboardException { 231 + @RequestBody(required = false) String[] strCustomerIds) throws ThingsboardException {
232 checkParameter(DASHBOARD_ID, strDashboardId); 232 checkParameter(DASHBOARD_ID, strDashboardId);
233 try { 233 try {
234 DashboardId dashboardId = new DashboardId(toUUID(strDashboardId)); 234 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 * Licensed under the Apache License, Version 2.0 (the "License"); 4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License. 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 * Licensed under the Apache License, Version 2.0 (the "License"); 4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License. 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 * Licensed under the Apache License, Version 2.0 (the "License"); 4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License. 5 * you may not use this file except in compliance with the License.
@@ -16,6 +16,8 @@ @@ -16,6 +16,8 @@
16 package org.thingsboard.server.controller; 16 package org.thingsboard.server.controller;
17 17
18 import lombok.extern.slf4j.Slf4j; 18 import lombok.extern.slf4j.Slf4j;
  19 +import org.apache.commons.lang3.StringUtils;
  20 +import org.springframework.beans.factory.annotation.Autowired;
19 import org.springframework.http.HttpStatus; 21 import org.springframework.http.HttpStatus;
20 import org.springframework.security.access.prepost.PreAuthorize; 22 import org.springframework.security.access.prepost.PreAuthorize;
21 import org.springframework.web.bind.annotation.PathVariable; 23 import org.springframework.web.bind.annotation.PathVariable;
@@ -36,21 +38,30 @@ import org.thingsboard.server.common.data.id.DeviceProfileId; @@ -36,21 +38,30 @@ import org.thingsboard.server.common.data.id.DeviceProfileId;
36 import org.thingsboard.server.common.data.page.PageData; 38 import org.thingsboard.server.common.data.page.PageData;
37 import org.thingsboard.server.common.data.page.PageLink; 39 import org.thingsboard.server.common.data.page.PageLink;
38 import org.thingsboard.server.common.data.plugin.ComponentLifecycleEvent; 40 import org.thingsboard.server.common.data.plugin.ComponentLifecycleEvent;
  41 +import org.thingsboard.server.dao.timeseries.TimeseriesService;
39 import org.thingsboard.server.queue.util.TbCoreComponent; 42 import org.thingsboard.server.queue.util.TbCoreComponent;
40 import org.thingsboard.server.service.security.permission.Operation; 43 import org.thingsboard.server.service.security.permission.Operation;
41 import org.thingsboard.server.service.security.permission.Resource; 44 import org.thingsboard.server.service.security.permission.Resource;
42 45
  46 +import java.util.List;
  47 +import java.util.UUID;
  48 +
43 @RestController 49 @RestController
44 @TbCoreComponent 50 @TbCoreComponent
45 @RequestMapping("/api") 51 @RequestMapping("/api")
46 @Slf4j 52 @Slf4j
47 public class DeviceProfileController extends BaseController { 53 public class DeviceProfileController extends BaseController {
48 54
  55 + private static final String DEVICE_PROFILE_ID = "deviceProfileId";
  56 +
  57 + @Autowired
  58 + private TimeseriesService timeseriesService;
  59 +
49 @PreAuthorize("hasAnyAuthority('TENANT_ADMIN')") 60 @PreAuthorize("hasAnyAuthority('TENANT_ADMIN')")
50 @RequestMapping(value = "/deviceProfile/{deviceProfileId}", method = RequestMethod.GET) 61 @RequestMapping(value = "/deviceProfile/{deviceProfileId}", method = RequestMethod.GET)
51 @ResponseBody 62 @ResponseBody
52 - public DeviceProfile getDeviceProfileById(@PathVariable("deviceProfileId") String strDeviceProfileId) throws ThingsboardException {  
53 - checkParameter("deviceProfileId", strDeviceProfileId); 63 + public DeviceProfile getDeviceProfileById(@PathVariable(DEVICE_PROFILE_ID) String strDeviceProfileId) throws ThingsboardException {
  64 + checkParameter(DEVICE_PROFILE_ID, strDeviceProfileId);
54 try { 65 try {
55 DeviceProfileId deviceProfileId = new DeviceProfileId(toUUID(strDeviceProfileId)); 66 DeviceProfileId deviceProfileId = new DeviceProfileId(toUUID(strDeviceProfileId));
56 return checkDeviceProfileId(deviceProfileId, Operation.READ); 67 return checkDeviceProfileId(deviceProfileId, Operation.READ);
@@ -62,8 +73,8 @@ public class DeviceProfileController extends BaseController { @@ -62,8 +73,8 @@ public class DeviceProfileController extends BaseController {
62 @PreAuthorize("hasAnyAuthority('TENANT_ADMIN', 'CUSTOMER_USER')") 73 @PreAuthorize("hasAnyAuthority('TENANT_ADMIN', 'CUSTOMER_USER')")
63 @RequestMapping(value = "/deviceProfileInfo/{deviceProfileId}", method = RequestMethod.GET) 74 @RequestMapping(value = "/deviceProfileInfo/{deviceProfileId}", method = RequestMethod.GET)
64 @ResponseBody 75 @ResponseBody
65 - public DeviceProfileInfo getDeviceProfileInfoById(@PathVariable("deviceProfileId") String strDeviceProfileId) throws ThingsboardException {  
66 - checkParameter("deviceProfileId", strDeviceProfileId); 76 + public DeviceProfileInfo getDeviceProfileInfoById(@PathVariable(DEVICE_PROFILE_ID) String strDeviceProfileId) throws ThingsboardException {
  77 + checkParameter(DEVICE_PROFILE_ID, strDeviceProfileId);
67 try { 78 try {
68 DeviceProfileId deviceProfileId = new DeviceProfileId(toUUID(strDeviceProfileId)); 79 DeviceProfileId deviceProfileId = new DeviceProfileId(toUUID(strDeviceProfileId));
69 return checkNotNull(deviceProfileService.findDeviceProfileInfoById(getTenantId(), deviceProfileId)); 80 return checkNotNull(deviceProfileService.findDeviceProfileInfoById(getTenantId(), deviceProfileId));
@@ -83,6 +94,46 @@ public class DeviceProfileController extends BaseController { @@ -83,6 +94,46 @@ public class DeviceProfileController extends BaseController {
83 } 94 }
84 } 95 }
85 96
  97 + @PreAuthorize("hasAnyAuthority('TENANT_ADMIN')")
  98 + @RequestMapping(value = "/deviceProfile/devices/keys/timeseries", method = RequestMethod.GET)
  99 + @ResponseBody
  100 + public List<String> getTimeseriesKeys(
  101 + @RequestParam(name = DEVICE_PROFILE_ID, required = false) String deviceProfileIdStr) throws ThingsboardException {
  102 + DeviceProfileId deviceProfileId;
  103 + if (StringUtils.isNotEmpty(deviceProfileIdStr)) {
  104 + deviceProfileId = new DeviceProfileId(UUID.fromString(deviceProfileIdStr));
  105 + checkDeviceProfileId(deviceProfileId, Operation.READ);
  106 + } else {
  107 + deviceProfileId = null;
  108 + }
  109 +
  110 + try {
  111 + return timeseriesService.findAllKeysByDeviceProfileId(getTenantId(), deviceProfileId);
  112 + } catch (Exception e) {
  113 + throw handleException(e);
  114 + }
  115 + }
  116 +
  117 + @PreAuthorize("hasAnyAuthority('TENANT_ADMIN')")
  118 + @RequestMapping(value = "/deviceProfile/devices/keys/attributes", method = RequestMethod.GET)
  119 + @ResponseBody
  120 + public List<String> getAttributesKeys(
  121 + @RequestParam(name = DEVICE_PROFILE_ID, required = false) String deviceProfileIdStr) throws ThingsboardException {
  122 + DeviceProfileId deviceProfileId;
  123 + if (StringUtils.isNotEmpty(deviceProfileIdStr)) {
  124 + deviceProfileId = new DeviceProfileId(UUID.fromString(deviceProfileIdStr));
  125 + checkDeviceProfileId(deviceProfileId, Operation.READ);
  126 + } else {
  127 + deviceProfileId = null;
  128 + }
  129 +
  130 + try {
  131 + return attributesService.findAllKeysByDeviceProfileId(getTenantId(), deviceProfileId);
  132 + } catch (Exception e) {
  133 + throw handleException(e);
  134 + }
  135 + }
  136 +
86 @PreAuthorize("hasAuthority('TENANT_ADMIN')") 137 @PreAuthorize("hasAuthority('TENANT_ADMIN')")
87 @RequestMapping(value = "/deviceProfile", method = RequestMethod.POST) 138 @RequestMapping(value = "/deviceProfile", method = RequestMethod.POST)
88 @ResponseBody 139 @ResponseBody
@@ -101,7 +152,7 @@ public class DeviceProfileController extends BaseController { @@ -101,7 +152,7 @@ public class DeviceProfileController extends BaseController {
101 152
102 logEntityAction(savedDeviceProfile.getId(), savedDeviceProfile, 153 logEntityAction(savedDeviceProfile.getId(), savedDeviceProfile,
103 null, 154 null,
104 - savedDeviceProfile.getId() == null ? ActionType.ADDED : ActionType.UPDATED, null); 155 + created ? ActionType.ADDED : ActionType.UPDATED, null);
105 156
106 sendNotificationMsgToEdgeService(getTenantId(), savedDeviceProfile.getId(), EntityType.DEVICE_PROFILE, 157 sendNotificationMsgToEdgeService(getTenantId(), savedDeviceProfile.getId(), EntityType.DEVICE_PROFILE,
107 deviceProfile.getId() == null ? EdgeEventActionType.ADDED : EdgeEventActionType.UPDATED); 158 deviceProfile.getId() == null ? EdgeEventActionType.ADDED : EdgeEventActionType.UPDATED);
@@ -117,8 +168,8 @@ public class DeviceProfileController extends BaseController { @@ -117,8 +168,8 @@ public class DeviceProfileController extends BaseController {
117 @PreAuthorize("hasAuthority('TENANT_ADMIN')") 168 @PreAuthorize("hasAuthority('TENANT_ADMIN')")
118 @RequestMapping(value = "/deviceProfile/{deviceProfileId}", method = RequestMethod.DELETE) 169 @RequestMapping(value = "/deviceProfile/{deviceProfileId}", method = RequestMethod.DELETE)
119 @ResponseStatus(value = HttpStatus.OK) 170 @ResponseStatus(value = HttpStatus.OK)
120 - public void deleteDeviceProfile(@PathVariable("deviceProfileId") String strDeviceProfileId) throws ThingsboardException {  
121 - checkParameter("deviceProfileId", strDeviceProfileId); 171 + public void deleteDeviceProfile(@PathVariable(DEVICE_PROFILE_ID) String strDeviceProfileId) throws ThingsboardException {
  172 + checkParameter(DEVICE_PROFILE_ID, strDeviceProfileId);
122 try { 173 try {
123 DeviceProfileId deviceProfileId = new DeviceProfileId(toUUID(strDeviceProfileId)); 174 DeviceProfileId deviceProfileId = new DeviceProfileId(toUUID(strDeviceProfileId));
124 DeviceProfile deviceProfile = checkDeviceProfileId(deviceProfileId, Operation.DELETE); 175 DeviceProfile deviceProfile = checkDeviceProfileId(deviceProfileId, Operation.DELETE);
@@ -144,8 +195,8 @@ public class DeviceProfileController extends BaseController { @@ -144,8 +195,8 @@ public class DeviceProfileController extends BaseController {
144 @PreAuthorize("hasAnyAuthority('TENANT_ADMIN')") 195 @PreAuthorize("hasAnyAuthority('TENANT_ADMIN')")
145 @RequestMapping(value = "/deviceProfile/{deviceProfileId}/default", method = RequestMethod.POST) 196 @RequestMapping(value = "/deviceProfile/{deviceProfileId}/default", method = RequestMethod.POST)
146 @ResponseBody 197 @ResponseBody
147 - public DeviceProfile setDefaultDeviceProfile(@PathVariable("deviceProfileId") String strDeviceProfileId) throws ThingsboardException {  
148 - checkParameter("deviceProfileId", strDeviceProfileId); 198 + public DeviceProfile setDefaultDeviceProfile(@PathVariable(DEVICE_PROFILE_ID) String strDeviceProfileId) throws ThingsboardException {
  199 + checkParameter(DEVICE_PROFILE_ID, strDeviceProfileId);
149 try { 200 try {
150 DeviceProfileId deviceProfileId = new DeviceProfileId(toUUID(strDeviceProfileId)); 201 DeviceProfileId deviceProfileId = new DeviceProfileId(toUUID(strDeviceProfileId));
151 DeviceProfile deviceProfile = checkDeviceProfileId(deviceProfileId, Operation.WRITE); 202 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 * Licensed under the Apache License, Version 2.0 (the "License"); 4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License. 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 * Licensed under the Apache License, Version 2.0 (the "License"); 4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License. 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 * Licensed under the Apache License, Version 2.0 (the "License"); 4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License. 5 * you may not use this file except in compliance with the License.
@@ -16,18 +16,23 @@ @@ -16,18 +16,23 @@
16 package org.thingsboard.server.controller; 16 package org.thingsboard.server.controller;
17 17
18 import org.springframework.beans.factory.annotation.Autowired; 18 import org.springframework.beans.factory.annotation.Autowired;
  19 +import org.springframework.http.ResponseEntity;
19 import org.springframework.security.access.prepost.PreAuthorize; 20 import org.springframework.security.access.prepost.PreAuthorize;
20 import org.springframework.web.bind.annotation.RequestBody; 21 import org.springframework.web.bind.annotation.RequestBody;
21 import org.springframework.web.bind.annotation.RequestMapping; 22 import org.springframework.web.bind.annotation.RequestMapping;
22 import org.springframework.web.bind.annotation.RequestMethod; 23 import org.springframework.web.bind.annotation.RequestMethod;
  24 +import org.springframework.web.bind.annotation.RequestParam;
23 import org.springframework.web.bind.annotation.ResponseBody; 25 import org.springframework.web.bind.annotation.ResponseBody;
24 import org.springframework.web.bind.annotation.RestController; 26 import org.springframework.web.bind.annotation.RestController;
  27 +import org.springframework.web.context.request.async.DeferredResult;
25 import org.thingsboard.server.common.data.exception.ThingsboardException; 28 import org.thingsboard.server.common.data.exception.ThingsboardException;
  29 +import org.thingsboard.server.common.data.id.TenantId;
26 import org.thingsboard.server.common.data.page.PageData; 30 import org.thingsboard.server.common.data.page.PageData;
27 import org.thingsboard.server.common.data.query.AlarmData; 31 import org.thingsboard.server.common.data.query.AlarmData;
28 import org.thingsboard.server.common.data.query.AlarmDataQuery; 32 import org.thingsboard.server.common.data.query.AlarmDataQuery;
29 import org.thingsboard.server.common.data.query.EntityCountQuery; 33 import org.thingsboard.server.common.data.query.EntityCountQuery;
30 import org.thingsboard.server.common.data.query.EntityData; 34 import org.thingsboard.server.common.data.query.EntityData;
  35 +import org.thingsboard.server.common.data.query.EntityDataPageLink;
31 import org.thingsboard.server.common.data.query.EntityDataQuery; 36 import org.thingsboard.server.common.data.query.EntityDataQuery;
32 import org.thingsboard.server.queue.util.TbCoreComponent; 37 import org.thingsboard.server.queue.util.TbCoreComponent;
33 import org.thingsboard.server.service.query.EntityQueryService; 38 import org.thingsboard.server.service.query.EntityQueryService;
@@ -40,6 +45,7 @@ public class EntityQueryController extends BaseController { @@ -40,6 +45,7 @@ public class EntityQueryController extends BaseController {
40 @Autowired 45 @Autowired
41 private EntityQueryService entityQueryService; 46 private EntityQueryService entityQueryService;
42 47
  48 + private static final int MAX_PAGE_SIZE = 100;
43 49
44 @PreAuthorize("hasAnyAuthority('TENANT_ADMIN', 'CUSTOMER_USER')") 50 @PreAuthorize("hasAnyAuthority('TENANT_ADMIN', 'CUSTOMER_USER')")
45 @RequestMapping(value = "/entitiesQuery/count", method = RequestMethod.POST) 51 @RequestMapping(value = "/entitiesQuery/count", method = RequestMethod.POST)
@@ -76,4 +82,24 @@ public class EntityQueryController extends BaseController { @@ -76,4 +82,24 @@ public class EntityQueryController extends BaseController {
76 throw handleException(e); 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 * Licensed under the Apache License, Version 2.0 (the "License"); 4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License. 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 * Licensed under the Apache License, Version 2.0 (the "License"); 4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License. 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 * Licensed under the Apache License, Version 2.0 (the "License"); 4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License. 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 * Licensed under the Apache License, Version 2.0 (the "License"); 4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License. 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 * Licensed under the Apache License, Version 2.0 (the "License"); 4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License. 5 * you may not use this file except in compliance with the License.