diff --git a/_data/docs-home.yml b/_data/docs-home.yml
index e73b407484..28baff7b7b 100644
--- a/_data/docs-home.yml
+++ b/_data/docs-home.yml
@@ -9,6 +9,8 @@ toc:
path: /docs/getting-started-guides/connectivity/
- title: Key concepts
section:
+ - title: Key Concepts and Architecture
+ path: /docs/user-guide/entities-and-relations/
- title: Alarms
path: /docs/user-guide/alarms/
- title: Alarm rules
@@ -19,8 +21,8 @@ toc:
new: true
- title: Notification center
path: /docs/user-guide/notifications/
- - title: Entities and Relations
- path: /docs/user-guide/entities-and-relations/
+ - title: Relations
+ path: /docs/key-concepts/relations/
- title: Device profiles
path: /docs/user-guide/device-profiles/
- title: Asset profiles
diff --git a/_data/host-constant.yml b/_data/host-constant.yml
index 54cc307b31..2e791b6f56 100644
--- a/_data/host-constant.yml
+++ b/_data/host-constant.yml
@@ -3,7 +3,7 @@
hostName: localhost
mqttHostName: localhost
coapHostName: localhost
- httpsUrl: https://localhost
+ httpsUrl: http(s)://localhost
lwm2mHostName: localhost
apiHostName: localhost
- tag: pe
@@ -11,7 +11,7 @@
hostName: localhost
mqttHostName: localhost
coapHostName: localhost
- httpsUrl: https://thingsboard.cloud
+ httpsUrl: http(s)://localhost
lwm2mHostName: lwm2m.thingsboard.cloud
apiHostName: YOUR_SERVER_HOSTNAME
- tag: paas
diff --git a/_data/paas-eu/docs-home.yml b/_data/paas-eu/docs-home.yml
index e1ecced9e9..2d1076a6a4 100644
--- a/_data/paas-eu/docs-home.yml
+++ b/_data/paas-eu/docs-home.yml
@@ -43,6 +43,8 @@ toc:
path: /docs/paas/eu/solution-templates/waste-management/
- title: Key concepts
section:
+ - title: Key Concepts and Architecture
+ path: /docs/paas/eu/user-guide/entities-and-relations/
- title: Alarms
path: /docs/paas/eu/user-guide/alarms/
- title: Alarm rules
@@ -53,8 +55,8 @@ toc:
new: true
- title: Notification center
path: /docs/paas/eu/user-guide/notifications/
- - title: Entities and Relations
- path: /docs/paas/eu/user-guide/entities-and-relations/
+ - title: Relations
+ path: /docs/paas/eu/key-concepts/relations/
- title: Device profiles
path: /docs/paas/eu/user-guide/device-profiles/
- title: Asset profiles
diff --git a/_data/paas/docs-home.yml b/_data/paas/docs-home.yml
index 2f8da86dd2..f5b197e8d2 100644
--- a/_data/paas/docs-home.yml
+++ b/_data/paas/docs-home.yml
@@ -43,18 +43,19 @@ toc:
path: /docs/paas/solution-templates/waste-management/
- title: Key concepts
section:
+ - title: Key Concepts and Architecture
+ path: /docs/paas/user-guide/entities-and-relations/
- title: Alarms
path: /docs/paas/user-guide/alarms/
- title: Alarm rules
path: /docs/paas/user-guide/alarm-rules/
- title: Calculated fields
- new: true
path: /docs/paas/user-guide/calculated-fields/
new: true
- title: Notification center
path: /docs/paas/user-guide/notifications/
- - title: Entities and Relations
- path: /docs/paas/user-guide/entities-and-relations/
+ - title: Relations
+ path: /docs/paas/key-concepts/relations/
- title: Device profiles
path: /docs/paas/user-guide/device-profiles/
- title: Asset profiles
diff --git a/_data/pages_info.yml b/_data/pages_info.yml
index 98ae65239c..b8721f6098 100644
--- a/_data/pages_info.yml
+++ b/_data/pages_info.yml
@@ -771,6 +771,9 @@
"/docs/iot-gateway/what-is-iot-gateway/":
url: "/docs/iot-gateway/what-is-iot-gateway/"
redirect_from: []
+"/docs/key-concepts/relations/":
+ url: "/docs/key-concepts/relations/"
+ redirect_from: []
"/docs/license/search/":
url: "/docs/license/search/"
redirect_from: []
@@ -1842,6 +1845,9 @@
"/docs/paas/eu/":
url: "/docs/paas/eu/"
redirect_from: []
+"/docs/paas/eu/key-concepts/relations/":
+ url: "/docs/paas/eu/key-concepts/relations/"
+ redirect_from: []
"/docs/paas/eu/legacy-subscriptions/":
url: "/docs/paas/eu/legacy-subscriptions/"
redirect_from:
@@ -1898,6 +1904,9 @@
url: "/docs/paas/eu/reference/snmp-api/"
redirect_from:
- "/docs/paas/eu/reference/snmp-api"
+"/docs/paas/eu/samples/abeeway/tracker/":
+ url: "/docs/paas/eu/samples/abeeway/tracker/"
+ redirect_from: []
"/docs/paas/eu/samples/analytics/ai-models/":
url: "/docs/paas/eu/samples/analytics/ai-models/"
redirect_from: []
@@ -2407,6 +2416,9 @@
"/docs/paas/":
url: "/docs/paas/"
redirect_from: []
+"/docs/paas/key-concepts/relations/":
+ url: "/docs/paas/key-concepts/relations/"
+ redirect_from: []
"/docs/paas/legacy-subscriptions/":
url: "/docs/paas/legacy-subscriptions/"
redirect_from:
@@ -2463,6 +2475,9 @@
url: "/docs/paas/reference/snmp-api/"
redirect_from:
- "/docs/paas/reference/snmp-api"
+"/docs/paas/samples/abeeway/tracker/":
+ url: "/docs/paas/samples/abeeway/tracker/"
+ redirect_from: []
"/docs/paas/samples/analytics/ai-models/":
url: "/docs/paas/samples/analytics/ai-models/"
redirect_from: []
@@ -3562,6 +3577,9 @@
"/docs/pe/":
url: "/docs/pe/"
redirect_from: []
+"/docs/pe/key-concepts/relations/":
+ url: "/docs/pe/key-concepts/relations/"
+ redirect_from: []
"/docs/pe/mobile/alarm-dashboard/":
url: "/docs/pe/mobile/alarm-dashboard/"
redirect_from: []
@@ -4002,6 +4020,9 @@
"/docs/pe/releases/roadmap/":
url: "/docs/pe/releases/roadmap/"
redirect_from: []
+"/docs/pe/samples/abeeway/tracker/":
+ url: "/docs/pe/samples/abeeway/tracker/"
+ redirect_from: []
"/docs/pe/samples/analytics/ai-models/":
url: "/docs/pe/samples/analytics/ai-models/"
redirect_from: []
diff --git a/_data/pe/docs-home.yml b/_data/pe/docs-home.yml
index d25100659c..33a1c7b839 100644
--- a/_data/pe/docs-home.yml
+++ b/_data/pe/docs-home.yml
@@ -41,6 +41,8 @@ toc:
path: /docs/pe/solution-templates/waste-management/
- title: Key concepts
section:
+ - title: Key Concepts and Architecture
+ path: /docs/pe/user-guide/entities-and-relations/
- title: Alarms
path: /docs/pe/user-guide/alarms/
- title: Alarm rules
@@ -51,8 +53,8 @@ toc:
new: true
- title: Notification center
path: /docs/pe/user-guide/notifications/
- - title: Entities and Relations
- path: /docs/pe/user-guide/entities-and-relations/
+ - title: Relations
+ path: /docs/pe/key-concepts/relations/
- title: Device profiles
path: /docs/pe/user-guide/device-profiles/
- title: Asset profiles
diff --git a/_includes/docs/key-concepts/relations.md b/_includes/docs/key-concepts/relations.md
new file mode 100644
index 0000000000..a8d1a80c24
--- /dev/null
+++ b/_includes/docs/key-concepts/relations.md
@@ -0,0 +1,149 @@
+* TOC
+{:toc}
+
+**Relations** in ThingsBoard represent **directed connections between two entities**. They allow you to model real-world relationships (like hierarchy, ownership, or control) in your IoT solution.
+
+A relation has the following properties:
+- A relation connects two entities within the same [Tenant](/docs/{{docsPrefix}}user-guide/ui/tenants/){:target="_blank"}.
+- Each relation has a **direction**: _From_ and _To_.
+- Each relation has a **relation type** (string), for example: _Contains_, _Manages_, _Uses_, _Supports_.
+- You can define **custom relation types** depending on your needs.
+
+## Why Use Relations?
+
+Relations help you model logical and physical connections between entities such as:
+- A building (asset) contains multiple devices.
+- A customer manages assigned assets and devices.
+- A gateway device is connected to multiple sensors.
+
+Relations are commonly used for:
+- Representing entity hierarchies (e.g., Customer ⇾ Asset ⇾ Device)
+- Navigating related entities in dashboards
+- Performing relation-based processing in rule chains
+- Filtering, aggregating, and visualizing data across entity groups
+
+## Relation Direction and Types
+
+Direction
+Relations in ThingsBoard are **directional**:
+- **From** – the source entity
+- **To** – the target entity
+
+Direction is important because most API queries and rule engine operations depend on it to determine which entities are considered parent/child.
+The same relation type behaves differently depending on whether you query relations **from** an entity or **to** an entity.
+
+Relation Types
+
+Relation types define the meaning of the relationship. Common examples:
+- **Contains** - Entity A contains Entity B (hierarchy)
+- **Manages** - Entity A manages Entity B
+- **Uses** - Entity A uses or depends on Entity B
+- **Supports** - abstract dependency or support relationship
+
+You can create **your own relation types** if needed.
+
+## Creating and Managing Relations
+
+Relations are created and managed in the ThingsBoard UI from the **Relations** tab on the entity details page.
+
+To create a relation:
+1. Open the entity details page.
+2. Navigate to the **Relations** tab.
+3. Select the relation **direction** (**From** or **To**).
+4. Click the "**+**" button to open the **Add relation** dialog.
+5. In the dialog, specify the **Relation type** (for example, _Contains_).
+6. Define the **relation type** and select the **related entity**.
+7. (Optional) Fill in the **Additional info (JSON)** field if additional metadata is required.
+8. lick **Add** to create the relation.
+
+## How Relations Are Used in ThingsBoard
+
+Relations are widely used across the ThingsBoard platform to build hierarchical models, simplify entity navigation, and implement advanced data processing scenarios.
+
+In Dashboards
+
+Relations enable dashboards to dynamically resolve and display entities without hardcoding identifiers.
+They are commonly used in:
+- [Entity aliases](/docs/user-guide/ui/aliases/){:target="_blank"}
+- Dashboard states
+- Widgets that display related entity data (for example, Alarms table)
+
+[Widgets](/docs/{{docsPrefix}}user-guide/widgets/){:target="_blank"} can display alarms, telemetry and attributes from related entities, filter entities based on relationships, visualize hierarchical structures (_Customer_ ⇾ _Assets_ ⇾ _Devices_)
+
+This enables reusable dashboards that adapt automatically to different customers and deployments.
+
+In Rule Engine
+
+Relations are actively used in the ThingsBoard [Rule Engine](/docs/{{docsPrefix}}user-guide/rule-engine-2-0/overview/){:target="_blank"} to route messages, enrich telemetry, and forward data between related entities.
+
+Common relation-based nodes include: [Check relation presence](/docs/user-guide/rule-engine-2-0/nodes/filter/check-relation-presence){:target="_blank"}, [Related device attributes](/docs/user-guide/rule-engine-2-0/nodes/enrichment/related-device-attributes){:target="_blank"}, [Related entity data](/docs/user-guide/rule-engine-2-0/nodes/enrichment/related-entity-data){:target="_blank"}, [Duplicate to related](/docs/user-guide/rule-engine-2-0/nodes/transformation/duplicate-to-related){:target="_blank"}.
+
+These nodes allow rule chains to validate relations, fetch data from related entities, and propagate messages based on relation direction and type.
+
+In Calculated fields
+
+Relations can also be used in [Calculated fields](/docs/{{docsPrefix}}user-guide/calculated-fields/){:target="_blank"} to dynamically compute values based on related entities.
+
+Typical use cases include:
+- [Propagation](/docs/user-guide/calculated-fields/propagation-calculated-field){:target="_blank"} – transforming or propagating data to related entities
+- [Related entities aggregation](/docs/user-guide/calculated-fields/related-entities-aggregation-calculated-field){:target="_blank"} – aggregating latest data (min, max, avg, sum, count, etc.) from related entities
+- [Geofencing](/docs/user-guide/calculated-fields/geofencing-calculated-field){:target="_blank"} – detecting enter/exit events relative to related geozones and generating notifications
+
+## API and Tools
+
+Relations can also be created, queried, and deleted programmatically using the ThingsBoard [REST API](/docs/{{docsPrefix}}reference/rest-api/){:target="_blank"}.
+
+A relation is represented as a JSON object containing:
+- **from** (entityType + id)
+- **to** (entityType + id)
+- **type** (the relation name)
+- **typeGroup** (optional categorization)
+- optional **additionalInfo** (custom JSON)
+
+**Example:**
+
+```json
+{
+ "from": {
+ "id": "156c853f-89b1-321b-635j-y8febb2784h4",
+ "entityType": "DEVICE"
+ },
+ "to": {
+ "id": "784f394c-42b6-435a-983c-b7beff2784f9",
+ "entityType": "DEVICE"
+ },
+ "type": "Contains",
+ "typeGroup": "COMMON",
+ "version": 0,
+ "additionalInfo": {}
+}
+```
+
+## Example Hierarchy Using Relations
+
+The following example illustrates how the _Contains_ relation can be used to model a hierarchical structure in ThingsBoard.
+
+In this example:
+- **Region A** is defined as an **Asset**.
+- Region A contains two child assets: **Field A** and **Field B**.
+- Each field contains multiple **Devices**, such as moisture sensors and irrigation systems.
+
+This forms the following hierarchy:
+
+{% if docsPrefix == null %}
+
+{% endif %}
+{% if docsPrefix == "pe/" or docsPrefix contains "paas/" %}
+
+{% endif %}
+
+The _Contains_ relation follows the direction:
+**From (Parent) → To (Child)**
+
+In this case:
+- Region A ⇾ Contains ⇾ Field A
+- Region A ⇾ Contains ⇾ Field B
+- Field A ⇾ Contains ⇾ Devices
+- Field B ⇾ Contains ⇾ Devices
+
+This structure demonstrates how relations are used to model real-world physical or logical hierarchies such as geographic regions, production areas, facilities, or equipment groups.
diff --git a/_includes/docs/user-guide/attributes.md b/_includes/docs/user-guide/attributes.md
index 8033a70d5a..a0b110471b 100644
--- a/_includes/docs/user-guide/attributes.md
+++ b/_includes/docs/user-guide/attributes.md
@@ -1,327 +1,278 @@
+{% if docsPrefix == nil or docsPrefix == "pe/" %} {% assign HOST_NAME = "$THINGSBOARD_HOST_NAME" %} {% endif %}
+{% if docsPrefix == "edge/" or docsPrefix == "pe/edge/" %}{% assign HOST_NAME = "$THINGSBOARD_EDGE_HOST_NAME" %} {% endif %}
+{% if docsPrefix == "paas/" %} {% assign HOST_NAME = "thingsboard.cloud" %} {% endif %}
+{% if docsPrefix == "paas/eu/" %} {% assign HOST_NAME = "eu.thingsboard.cloud" %} {% endif %}
+
* TOC
{:toc}
-## Assigning custom attributes to entities and attributes managing
-
-ThingsBoard provides the ability to assign custom attributes to your entities and manage these attributes.
-Those attributes are stored in the database and may be used for data visualization and data processing.
+In ThingsBoard, IoT attributes are key-value pairs that describe the properties, current state, and configuration of connected devices.
+Attribute values can be stored as different data types, such as strings, booleans, double, integer or JSON objects.
+They can represent both static information (for example, firmware version or serial number) and semi-dynamic data (such as device state or temperature), enabling remote monitoring, management, and control of devices within an IoT ecosystem.
-Attributes are treated as key-value pairs. Flexibility and simplicity of the key-value format allow easy and seamless integration with almost any IoT device on the market.
-Key is always a string and is basically an attribute name, while the attribute value can be either string, boolean, double, integer or JSON.
-For example:
+Unlike telemetry, attributes are not intended to represent continuously changing sensor data.
-```json
-{
- "firmwareVersion": "v2.3.1",
- "booleanParameter": true,
- "doubleParameter": 42.0,
- "longParameter": 73,
- "configuration": {
- "someNumber": 42,
- "someArray": [1, 2, 3],
- "someNestedObject": { "key": "value" }
- }
-}
-```
-{: .copy-code}
+ThingsBoard stores only the latest attribute value along with the timestamp of the last update in the SQL database. This enables use of [entity filters](/docs/{{docsPrefix}}user-guide/dashboards/#entity-filters) in the dashboards.
+Changes to the attributes initiated by the user are recorded in the [audit logs](/docs/{{docsPrefix}}user-guide/audit-log/){:target="_blank"}.
-## Attribute names
+> As a platform user, you can define any attribute name. However, we recommend using the [camelCase](https://en.wikipedia.org/wiki/Camel_case){:target="_blank"} naming convention. This makes it easier to write custom JavaScript functions for data processing and visualization.
-As a platform user, you can define any attribute name.
-However, we recommend to use [camelCase](https://en.wikipedia.org/wiki/Camel_case).
-This make it easy to write custom JS functions for data processing and visualization.
+
## Attribute types
-ThingsBoard supports three types of attributes: **server-side**, **shared**, and **client-side**.
-Each type has a specific purpose, access rules, and use cases, which we explain below.
+ThingsBoard supports three attribute scopes:
+- **Server-side attributes**
+- **Shared attributes**
+- **Client-side attributes**
-### Server-side attributes
+Each scope defines who can write the attribute, who can read it, and what it is typically used for.
-This type of attribute is supported by almost any platform entity: Device, Asset, Customer, Tenant, User, etc.
-Server-side attributes are the ones that you may configure via Administration UI or REST API.
-The device firmware can't access the server-side attribute.
+
+
+### Server-side attributes
{:refdef: style="text-align: center;"}

{: refdef}
-Let's assume you would like to build a building monitoring solution and review few examples:
-
-1. The *latitude*, *longitude* and *address* are good examples of server-side attribute you may assign to assets that represent building or other real estate. You may use this attributes on the Map Widget in your dashboard to visualize location of the buildings.
-2. The *floorPlanImage* may contain a URL to the image. You may use this attribute to visualize floor plan on the Image Map Widget.
-3. The *maxTemperatureThreshold* and *temperatureAlarmEnabled* may be used to configure and enable/disable alarms for a certain device or asset.
+
-#### Administration UI
+Server-side attributes are used to store platform-managed metadata and configuration parameters for entities. These attributes are managed only by the ThingsBoard platform and cannot be modified directly by devices.
-{% include images-gallery.html imageCollection="server-side-attrs-ui" showListImageTitles="true" %}
+> They are available for all major entity types, including **Device, Asset, Customer, Tenant, User, etc**.
+When to use
+Use server-side attributes when entity parameters must be controlled centrally by the platform (for example, location data, alarm thresholds, or operational settings).
-{% capture bulk_provisioning %}
-[Bulk provisioning](/docs/{{docsPrefix}}user-guide/bulk-provisioning/) feature allows you to quickly create multiple devices and assets and their attributes from CSV file.
-{% endcapture %}
-{% include templates/info-banner.md content=bulk_provisioning %}
-
-#### REST API
-
-Use [REST API](/docs/{{docsPrefix}}reference/rest-api/) documentation to get the value of the JWT token. You will use it to populate the 'X-Authorization' header and authenticate your REST API call request.
-
-Send POST request with JSON representation of the attribute to the following URL:
-
-```text
-https://$YOUR_THINGSBOARD_HOST/api/plugins/telemetry/$ENTITY_TYPE/$ENTITY_ID/SERVER_SCOPE
-```
-
-The example below creates attribute with the name "newAttributeName" and value "newAttributeValue" for device with ID 'ad17c410-914c-11eb-af0c-d5862211a5f6' and ThingsBoard Cloud server:
-```shell
-curl -v '{{httpsUrl}}/api/plugins/telemetry/DEVICE/ad17c410-914c-11eb-af0c-d5862211a5f6/SERVER_SCOPE' \
--H 'x-authorization: Bearer $YOUR_JWT_TOKEN_HERE' \
--H 'content-type: application/json' \
---data-raw '{"newAttributeName":"newAttributeValue"}'
-```
-{: .copy-code}
-
-Similar, you can fetch all server-side attributes using the following command:
-
-```shell
-curl -v -X GET '{{httpsUrl}}/api/plugins/telemetry/DEVICE/ad17c410-914c-11eb-af0c-d5862211a5f6/values/attributes/SERVER_SCOPE' \
- -H 'x-authorization: Bearer $YOUR_JWT_TOKEN_HERE' \
- -H 'content-type: application/json'
-```
-{: .copy-code}
-
-
-The output will include 'key', 'value' and timestamp of the last update:
+Device interaction
+From the device perspective, server-side attributes are not writable. A device cannot publish or update server-side attributes.
+However, server-side attributes can be used by the platform to control Rule Engine logic, dashboards, calculated fields, and alarm processing.
+**Server-side attributes example**
```json
-[
- {
- "lastUpdateTs": 1617633139380,
- "key": "newAttributeName",
- "value": "newAttributeValue"
- }
-]
+{
+ "latitude": 40.7128,
+ "longitude": -74.0060,
+ "maxTemperatureThreshold": 40,
+ "alarmEnabled": true
+}
```
-{: .copy-code}
-
-As an alternative to curl, you may use [Java](/docs/{{docsPrefix}}reference/rest-client/) or [Python](/docs/{{docsPrefix}}reference/python-rest-client/) REST clients.
-
-### Shared attributes
-Shared attributes are available only for entities of type Device. It is not available for any other entity types, such as Assets or Customers. They are designed to send configuration or operational parameters such as *thresholds* from the server to the device.
+**Explanation**
+This example shows server-side attributes configured by the platform.
+- _latitude_ and _longitude_ specify the entity’s location and are commonly used in map widgets.
+- _maxTemperatureThreshold_ defines a temperature limit that can be used by the Rule Engine to trigger alarms or automation.
+- _alarmEnabled_ controls whether alarm generation is active.
-#### How Devices Interact with Shared Attributes
+These attributes are managed via the ThingsBoard UI or REST API and cannot be modified directly by the device.
-A device cannot publish or change the value of a shared attribute. From the device's perspective, these attributes are read-only. A device's firmware or application can interact with shared attributes in the following ways:
-* Request Current Values: The device can send a request to the server to retrieve the current value(s) of one or more shared attributes.
-* Subscribe to Updates: The device can subscribe to receive notifications whenever a shared attribute's value is changed on the server.
-* Receive Updates via Downlinks: For certain network integrations, shared attribute updates can be pushed to the device as a [downlink message](/docs/user-guide/integrations/#example).
+
-#### Communication Protocol Examples
-
-The method for receiving updates typically depends on the communication protocol used by the device:
-* Real-time Subscriptions (e.g., MQTT): Devices that use bi-directional protocols like [MQTT](/docs/{{docsPrefix}}reference/mqtt-api/#attributes-api) can subscribe to attribute updates and receive notifications in real-time as soon as a value changes.
-* Periodic Polling (e.g., HTTP): Devices that use request-response protocols like [HTTP](/docs/{{docsPrefix}}reference/http-api/#attributes-api) can periodically poll the server to fetch the latest values of their shared attributes.
+### Shared attributes
{:refdef: style="text-align: center;"}

{: refdef}
-The most common use case of shared attributes is to store device settings.
-Let's assume the same building monitoring solution and review few examples:
-
-1. The *targetFirmwareVersion* attribute may be used to store the firmware version for particular Device.
-2. Devices can monitor the *maxTemperatureThreshold* attribute and activate cooling if the temperature exceeds the set limit.
+
-The user may change the attribute via UI. The script or other server-side application may change the attribute value via REST API.
+Shared attributes are used to deliver configuration and operational parameters (for example, thresholds or feature enable/disable flags) from the platform to the device.
-#### Administration UI
+> Shared attributes are available only for [Device](/docs/{{docsPrefix}}user-guide/ui/devices/){:target="_blank"} entities.
-{% include images-gallery.html imageCollection="shared-attrs-ui" showListImageTitles="true" %}
-
-{% include templates/info-banner.md content=bulk_provisioning %}
+When to use
+Use shared attributes when the platform needs to remotely control or configure device behavior.
-#### REST API
+Device interaction
+From the device perspective, shared attributes are **read-only**. A device cannot publish or modify shared attribute values.
+However, the device can:
+- **Send a request to the server** to retrieve the current values of shared server attributes.
+- **Subscribe to updates** and receive notifications when shared attribute values change on the server.
+- **Receive updates via downlink** (for certain network integrations, shared attribute updates can be delivered to the device as [downlink messages](/docs/user-guide/integrations/#example){:target="_blank"}).
-Use [REST API](/docs/{{docsPrefix}}reference/rest-api/) documentation to get the value of the JWT token. You will use it to populate the 'X-Authorization' header and authenticate your REST API call request.
+Protocol behavior
+The method for receiving updates usually depends on the communication protocol used by the device:
+- **Real-time subscriptions** (e.g., [MQTT](/docs/{{docsPrefix}}reference/mqtt-api/#attributes-api){:target="_blank"}): Devices that use bi-directional protocols typically subscribe to attribute updates and receive notifications immediately when a value changes.
+- **Periodic polling** (e.g., [HTTP](/docs/{{docsPrefix}}reference/http-api/#attributes-api){:target="_blank"}): Devices that use request-response protocols usually poll the server periodically to retrieve the latest shared attribute values.
-Send POST request with JSON representation of the attribute to the following URL:
-
-```text
-https://$YOUR_THINGSBOARD_HOST/api/plugins/telemetry/$ENTITY_TYPE/$ENTITY_ID/SHARED_SCOPE
-```
-
-The example below creates attribute with the name "newAttributeName" and value "newAttributeValue" for device with ID 'ad17c410-914c-11eb-af0c-d5862211a5f6' and ThingsBoard Cloud server:
-```shell
-curl -v '{{httpsUrl}}/api/plugins/telemetry/DEVICE/ad17c410-914c-11eb-af0c-d5862211a5f6/SHARED_SCOPE' \
--H 'x-authorization: Bearer $YOUR_JWT_TOKEN_HERE' \
--H 'content-type: application/json' \
---data-raw '{"newAttributeName":"newAttributeValue"}'
-```
-{: .copy-code}
-
-Similar, you can fetch all shared attributes using the following command:
-
-```shell
-curl -v -X GET '{{httpsUrl}}/api/plugins/telemetry/DEVICE/ad17c410-914c-11eb-af0c-d5862211a5f6/values/attributes/SHARED_SCOPE' \
- -H 'x-authorization: Bearer $YOUR_JWT_TOKEN_HERE' \
- -H 'content-type: application/json' \
-```
-{: .copy-code}
-
-The output will include 'key', 'value' and timestamp of the last update:
+**Shared attributes example**
```json
-[
- {
- "lastUpdateTs": 1617633139380,
- "key": "newAttributeName",
- "value": "newAttributeValue"
- }
-]
+{
+"targetFirmwareVersion": "v2.4.0",
+"reportingInterval": 60,
+"maxTemperatureThreshold": 45
+}
```
-{: .copy-code}
-As an alternative to curl, you may use [Java](/docs/{{docsPrefix}}reference/rest-client/) or [Python](/docs/{{docsPrefix}}reference/python-rest-client/) REST clients.
+**Explanation**
+This example represents shared attributes, which are used to deliver configuration parameters from the platform to the device:
+- _targetFirmwareVersion_ defines the firmware version that the device is expected to run. Devices can use this value to decide whether a firmware upgrade is required.
+- _reportingInterval_ defines how frequently the device should publish telemetry data (for example, every 60 seconds).
+- _maxTemperatureThreshold_ defines the temperature limit that the device should use locally for control logic (for example, enabling cooling systems).
-#### API for device firmware or applications:
+Shared attributes are writable from the platform and readable by the device. Devices can request their current values or subscribe to updates.
-- request *shared* attributes from the server: [MQTT API](/docs/{{docsPrefix}}reference/mqtt-api/#request-attribute-values-from-the-server), [CoAP API](/docs/{{docsPrefix}}reference/coap-api/#request-attribute-values-from-the-server), [HTTP API](/docs/{{docsPrefix}}reference/http-api/#request-attribute-values-from-the-server), [LwM2M API](/docs/{{docsPrefix}}reference/lwm2m-api/#attributes-api);
-- subscribe to *shared* attribute updates from the server: [MQTT API](/docs/{{docsPrefix}}reference/mqtt-api/#subscribe-to-attribute-updates-from-the-server), [CoAP API](/docs/{{docsPrefix}}reference/coap-api/#subscribe-to-attribute-updates-from-the-server), [HTTP API](/docs/{{docsPrefix}}reference/http-api/#subscribe-to-attribute-updates-from-the-server), [LwM2M API](/docs/{{docsPrefix}}reference/lwm2m-api/#attributes-api);.
+
-{% capture missed_updates %}
-If device went offline, it may miss the important attribute update notification. We recommend to subscribe to attribute updates on application startup and request latest values of the attributes after each connect or reconnect.
+### Client-side attributes
-{% endcapture %}
-{% include templates/info-banner.md content=missed_updates %}
+{:refdef: style="text-align: center;"}
+
+{: refdef}
-### Client-side attributes
+
+
+**Client-side attributes** are used to report semi-static information from the device (client) to ThingsBoard (server).
+The device firmware or application sends attribute values to the platform, where they can be stored and viewed but not modified from the UI or REST API.
This type of attributes is available only for Devices. It is used to report various semi-static data from Device (Client) to ThingsBoard (Server).
It is similar to [shared attributes](/docs/{{docsPrefix}}user-guide/attributes/#shared-attributes), but has one important difference.
The device firmware/application may send the value of the attributes from device to the platform.
-{:refdef: style="text-align: center;"}
-
-{: refdef}
+> Client-side attributes are available only for [Device](/docs/{{docsPrefix}}user-guide/ui/devices/){:target="_blank"} entities.
+When to use
The most common use case of client attributes is to report device state.
-Let's assume the same building monitoring solution and review few examples:
-1. The *currentFirmwareVersion* attribute may be used to report the installed firmware/application version for the device to the platform.
-2. The *currentConfiguration* attribute may be used to report current firmware/application configuration to the platform.
-3. The *currentState* may be used to persist and restore current firmware/application state via network, if device does not have the persistent storage.
+**Client-side attributes example**
-The user and server-side applications may browse the client-side attributes via UI/REST API but they are not able to change them.
-Basically, the value of the client-side attribute is read-only for the UI/REST API.
+```json
+{
+"currentFirmwareVersion": "v2.3.1",
+"currentConfiguration": {
+"mode": "auto",
+"interval": 30
+},
+"deviceState": "ACTIVE"
+}
+```
-#### Fetch client-side attributes via REST API
+**Explanation**
+This example represents client-side attributes, which are reported by the device to ThingsBoard:
+- _currentFirmwareVersion_ reports the firmware version currently installed on the device. This can be used for monitoring and fleet management.
+- _currentConfiguration_ is a JSON object that reports the device’s active configuration. For example:
+- _mode_ defines the operating mode (auto)
+- _interval_ defines an internal interval value used by the firmware
+- _deviceState_ represents the current device status (for example, ACTIVE, IDLE, ERROR, etc.).
-Use [REST API](/docs/{{docsPrefix}}reference/rest-api/) documentation to get the value of the JWT token. You will use it to populate the 'X-Authorization' header and authenticate your REST API call request.
+Client-side attributes are writable only by the device. The platform can read them via UI or REST API but cannot modify them.
-Send GET request to the following URL:
+
-```text
-https://$YOUR_THINGSBOARD_HOST/api/plugins/telemetry/$ENTITY_TYPE/$ENTITY_ID/CLIENT_SCOPE
-```
-{: .copy-code}
+## Create attribute via administration UI
-The example below gets all attributes for device with ID 'ad17c410-914c-11eb-af0c-d5862211a5f6' and ThingsBoard Cloud server:
+You can create or update attributes directly from the ThingsBoard Administration UI.
-```shell
-curl -v -X GET '{{httpsUrl}}/api/plugins/telemetry/DEVICE/ad17c410-914c-11eb-af0c-d5862211a5f6/values/attributes/CLIENT_SCOPE' \
- -H 'x-authorization: Bearer $YOUR_JWT_TOKEN_HERE' \
- -H 'content-type: application/json' \
-```
-{: .copy-code}
+1. Select the required entity (for example, **Entities ⇾ Device** (Asset, Customer, etc.)).
+2. Navigate to the **Attributes** tab.
+3. Select the appropriate **scope**:
+ • Server-side attribute
+ • Shared attribute (Device only)
+ • Client-side attribute (read-only, published by device)
+4. Click **+** (**Add**) attribute.
+5. Enter:
+ • **Key** (attribute name)
+ • Select the appropriate **data type** (String, Boolean, Integer, Double, or JSON)
+ • **Value**
+6. Click **Add**.
-The output will include 'key', 'value' and timestamp of the last update:
+The attribute will be stored immediately and become available for [dashboards](https://thingsboard.io/docs/pe/user-guide/dashboards/){:target="_blank"}, [Rule Engine](/docs/pe/user-guide/rule-engine-2-0/overview/){:target="_blank"} and [Calculated fields](/docs/pe/user-guide/calculated-fields/){:target="_blank"} processing, and [REST API](/docs/reference/rest-api/){:target="_blank"} queries.
-```json
-[
- {
- "lastUpdateTs": 1617633139380,
- "key": "newAttributeName",
- "value": "newAttributeValue"
- }
-]
-```
-{: .copy-code}
+> **Note:** Client-side attributes cannot be created or modified from the UI because they are published by the device.
-As an alternative to curl, you may use [Java](/docs/{{docsPrefix}}reference/rest-client/) or [Python](/docs/{{docsPrefix}}reference/python-rest-client/) REST clients.
+{% capture bulk_provisioning %}
+[Bulk provisioning](/docs/{{docsPrefix}}user-guide/bulk-provisioning/){:target="_blank"} feature allows you to quickly create multiple devices and assets and their attributes from CSV file.
+{% endcapture %}
+{% include templates/info-banner.md content=bulk_provisioning %}
-#### API for device firmware or applications:
+
-- publish *client-side* attributes to the server: [MQTT API](/docs/{{docsPrefix}}reference/mqtt-api/#publish-attribute-update-to-the-server), [CoAP API](/docs/{{docsPrefix}}reference/coap-api/#publish-attribute-update-to-the-server), [HTTP API](/docs/{{docsPrefix}}reference/http-api/#publish-attribute-update-to-the-server);
-- request *client-side* attributes from the server: [MQTT API](/docs/{{docsPrefix}}reference/mqtt-api/#request-attribute-values-from-the-server), [CoAP API](/docs/{{docsPrefix}}reference/coap-api/#request-attribute-values-from-the-server), [HTTP API](/docs/{{docsPrefix}}reference/http-api/#request-attribute-values-from-the-server).
+## REST API
-## Attributes persistence
+The APIs listed below are available through **Swagger UI**.
-ThingsBoard stores latest value of the attribute and last modification time in the SQL database. This enables use of [entity filters](/docs/{{docsPrefix}}user-guide/dashboards/#entity-filters) in the dashboards.
-Changes to the attributes initiated by the user are recorded in the [audit logs](/docs/{{docsPrefix}}user-guide/audit-log/).
-
-## Data Query API
+Before sending requests, obtain a valid JWT token using the [REST API documentation](/docs/{{docsPrefix}}reference/rest-api/){:target="_blank"}.
+Include the token in the **X-Authorization** header of each request to authenticate API calls.
-Telemetry Controller provides the following REST API to fetch entity data:
+**Select attribute type**
-
+{% capture attributetypes %}
+Server-side attributes %,%serverSide%,%templates/attributes/server-side-attributes.md%br%
+Shared attributes(Device only) %,%shared%,%templates/attributes/shared-attributes.md%br%
+Client-side attributes(read-only, published by device) %,%clientSide%,%templates/attributes/client-side-attributes.md{% endcapture %}
+{% include content-toggle.liquid content-toggle-id="attributetypes" toggle-spec=attributetypes %}
{% capture api_note %}
-**NOTE:** The API listed above is available via Swagger UI. Please review the general [REST API](/docs/{{docsPrefix}}reference/rest-api/) documentation for more details.
-The API is backward compatible with TB v1.0+ and this is the main reason why API call URLs contain "plugin".
+**NOTE:** The API is backward compatible with TB v1.0+ and this is the main reason why API call URLs contain "plugin".
{% endcapture %}
{% include templates/info-banner.md content=api_note %}
+
+
## Data visualization
-We assume you have already provisioned device attributes. Now you may use them in your dashboards. We recommend [dashboards overview](/docs/{{docsPrefix}}user-guide/dashboards/) to get started.
-Once you are familiar how to create dashboards and configure data sources,
-you may use [digital](/docs/{{docsPrefix}}user-guide/ui/widget-library/#digital-gauges) and [analog](/docs/{{docsPrefix}}user-guide/ui/widget-library/#analog-gauges) gauges to visualize
-temperature, speed, pressure or other numeric values. You may also use [cards](/docs/{{docsPrefix}}user-guide/ui/widget-library/#cards) to visualize multiple attributes using card or [entities table](/docs/{{docsPrefix}}user-guide/ui/entity-table-widget/).
+Once device attributes are provisioned, they can be used in dashboards for monitoring and interaction.
+
+If you are new to dashboards, refer to the [Dashboards overview](/docs/{{docsPrefix}}user-guide/dashboards/){:target}.
-You may also use [input widgets](/docs/{{docsPrefix}}user-guide/ui/widget-library/#input-widgets) to allow dashboard users to change the values of the attributes on the dashboards.
+Attributes can be visualized using various widgets from the Widget Library:
+- [Digital](/docs/{{docsPrefix}}user-guide/ui/widget-library/#digital-gauges){:target="_blank"} and [Analog](/docs/{{docsPrefix}}user-guide/ui/widget-library/#analog-gauges){:target="_blank"} gauges to display numeric attribute values (for example, temperature, speed, or pressure).
+- [Cards](/docs/{{docsPrefix}}user-guide/ui/widget-library/#cards){:target="_blank"} to present multiple attribute values in a compact format.
+- [Entities table](/docs/{{docsPrefix}}user-guide/ui/entity-table-widget/){:target="_blank"} to display attributes across multiple entities.
+
+In addition to visualization, you can use [Input widgets](/docs/{{docsPrefix}}user-guide/ui/widget-library/#input-widgets){:target="_blank"} to allow dashboard users to modify writable attributes directly from the dashboard (for example, updating shared or server-side attributes).
## Rule engine
-The [Rule Engine](/docs/{{docsPrefix}}user-guide/rule-engine-2-0/re-getting-started/) is responsible for processing all sorts of incoming data and event.
-You may find most popular scenarios of using attributes within rule engine below:
+The [Rule Engine](/docs/{{docsPrefix}}user-guide/rule-engine-2-0/re-getting-started/){:target="_blank"} processes incoming data and events, including attribute updates.
+
+Attributes are commonly used in the following scenarios:
+
+**Generate alarms based on attribute values**
+
+You can configure alarm conditions using:
+- [Alarm rules](/docs/{{docsPrefix}}user-guide/device-profiles/#alarm-rules){:target="_blank"} for standard use cases.
+- [Filter nodes](/docs/user-guide/rule-engine-2-0/nodes/filter/){:target="_blank"} with custom JavaScript for advanced logic.
+
+This allows alarm generation based on logical expressions that reference attribute values.
-**Generate alarms based on the logical expressions against attribute values**
+**Modify incoming client-side attributes before persistence**
-Use [alarm rules](/docs/{{docsPrefix}}user-guide/device-profiles/#alarm-rules) to configure most common alarm conditions via UI
-or use [filter nodes](/docs/user-guide/rule-engine-2-0/nodes/filter/) to configure more specific use cases via custom JS functions.
+To process client-side attributes before they are stored:
+- Use the [message type switch](/docs/user-guide/rule-engine-2-0/nodes/filter/message-type-switch/){:target="_blank"} node to filter messages containing a "Post attributes" request.
+- Use [transformation nodes](/docs/user-guide/rule-engine-2-0/nodes/transformation/){:target="_blank"} to modify the attribute payload.
-**Modify incoming client-side attributes before they are stored in the database**
+This enables validation, normalization, or enrichment before saving data.
-Use [message type switch](/docs/user-guide/rule-engine-2-0/nodes/filter/message-type-switch/) rule node to filter messages that contain "Post attributes" request.
-Then, use [transformation rule nodes](/docs/user-guide/rule-engine-2-0/nodes/transformation/) to modify a particular message.
+**React to server-side attribute updates**
-**React on the change of server-side attribute**
+To trigger actions when a server-side attribute changes:
+- Use the [message type switch](/docs/user-guide/rule-engine-2-0/nodes/filter/message-type-switch/){:target="_blank"} node to filter "Attributes Updated" events.
+- Use [action](/docs/user-guide/rule-engine-2-0/nodes/action/){:target="_blank"} or [external](/docs/user-guide/rule-engine-2-0/nodes/external/){:target="_blank"} nodes to execute the required logic.
-Use [message type switch](/docs/user-guide/rule-engine-2-0/nodes/filter/message-type-switch/) rule node to filter messages that contain "Attributes Updated" notification.
-Then, use [action](/docs/user-guide/rule-engine-2-0/nodes/action/) or [external](/docs/user-guide/rule-engine-2-0/nodes/external/) to react on the incoming event.
+This allows dynamic reconfiguration and automation when platform-managed settings are updated.
-**Fetch attribute values to analyze incoming telemetry from device**
+**Enrich telemetry with attribute values**
-Use [enrichment](/docs/user-guide/rule-engine-2-0/nodes/enrichment/) rule nodes to enrich incoming telemetry message with attributes of the device, related asset, customer or tenant.
-This is extremely powerful technique that allows to modify processing logic and parameters based on settings stored in the attributes.
+Use [enrichment](/docs/user-guide/rule-engine-2-0/nodes/enrichment/){:target="_blank"} nodes to add attribute values to incoming telemetry messages.
+
+This technique allows you to:
+- Apply dynamic thresholds
+- Adjust processing logic
+- Personalize behavior per device, asset, customer, or tenant
+
+Enrichment based on attributes is a powerful method for building scalable and configurable IoT solutions.
{% unless docsPrefix contains "paas/" %}
## Performance enhancement
-You can achieve higher performance with Attributes Cache enabled (see cache.attributes.enabled property of the [Configuration properties](/docs/user-guide/install/{{docsPrefix}}config/#thingsboard-core-settings))
+You can achieve higher performance with Attributes Cache enabled (see cache.attributes.enabled property of the [Configuration properties](/docs/user-guide/install/{{docsPrefix}}config/#thingsboard-core-settings){:target="_blank"})
Having attributes cache enabled ThingsBoard will load the specific attribute from the database only once, all subsequent requests to the attribute will be loaded from the faster cache connection.
-**NOTE:** If you are using Redis or Valkey cache, make sure that you change maxmemory-policy to allkeys-random to prevent the service from filling up all available memory.
+> **NOTE:** If you are using Redis or Valkey cache, make sure that you change maxmemory-policy to allkeys-random to prevent the service from filling up all available memory.
{% endunless %}
-
-## Old video Tutorial
-
-
diff --git a/_includes/docs/user-guide/entities-and-relations.md b/_includes/docs/user-guide/entities-and-relations.md
index 420b78f540..cb2cc29655 100644
--- a/_includes/docs/user-guide/entities-and-relations.md
+++ b/_includes/docs/user-guide/entities-and-relations.md
@@ -2,96 +2,181 @@
* TOC
{:toc}
-## Entities Overview
+ThingsBoard is built around a flexible and scalable architecture that enables you to design, manage, and operate complex IoT solutions. The platform organizes devices, assets, users, and business structures into a unified hierarchy, while providing powerful tools for data ingestion, processing, visualization, analytics, integration, and access control.
-ThingsBoard provides the user interface and REST APIs to provision and manage multiple entity types and their relations in your IoT application.
-Supported entities are:
+This page provides a structured overview of the core ThingsBoard concepts grouped by logical architecture layers. Each concept includes a short definition and a link to detailed documentation.
- - **[Tenants](/docs/{{docsPrefix}}user-guide/ui/tenants/)** - you can treat the tenant as a separate business-entity: it's an individual or an organization who owns or produce devices and assets;
- Tenant may have multiple tenant administrator users and millions of customers, devices and assets;
- - **[Customers](/docs/{{docsPrefix}}user-guide/ui/customers/)** - the customer is also a separate business-entity: individual or organization who purchase or uses tenant devices and/or assets;
- Customer may have multiple users and millions of devices and/or assets;
- - **[Users](/docs/{{docsPrefix}}user-guide/ui/users/)** - users are able to browse dashboards and manage entities;
- - **[Devices](/docs/{{docsPrefix}}user-guide/ui/devices/)** - basic IoT entities that may produce telemetry data and handle RPC commands. For example, sensors, actuators, switches;
- - **[Assets](/docs/{{docsPrefix}}user-guide/ui/assets/)** - abstract IoT entities that may be related to other devices and assets. For example factory, field, vehicle;
- - **[Entity Views](/docs/{{docsPrefix}}user-guide/entity-views/)** - useful if you like to share only part of device or asset data to the customers;
- - **[Alarms](/docs/{{docsPrefix}}user-guide/alarms/)** - events that identify issues with your assets, devices, or other entities;
- - **[Dashboards](/docs/{{docsPrefix}}user-guide/dashboards/)** - visualization of your IoT data and ability to control particular devices through the user interface;
- - **Rule Node** - processing units for incoming messages, entity lifecycle events, etc;
- - **Rule Chain** - defines the flow of the processing in the [Rule Engine](/docs/{{docsPrefix}}user-guide/rule-engine-2-0/re-getting-started/). May contain many rule nodes and links to other rule chains;
+## Organization & Access
-Each entity supports:
+### Ownership Layer
- - **[Attributes](/docs/{{docsPrefix}}user-guide/attributes/)** - static and semi-static key-value pairs associated with entities. For example serial number, model, firmware version;
- - **[Time-series data](/docs/{{docsPrefix}}user-guide/telemetry/)** - time-series data points available for storage, querying and visualization. For example temperature, humidity, battery level;
- - **[Relations](#relations)** - directed connections to other entities. For example contains, manages, owns, produces.
+Defines organizational boundaries and multi-tenancy.
-Some entities support profiles:
+- Tenants
+ A [Tenant](/docs/{{docsPrefix}}user-guide/ui/tenants/){:target="_blank"} is the top-level organizational entity that represents a company or business unit in ThingsBoard.
+ Tenants own and manage all platform resources (devices, assets, dashboards, rule chains, users, and customers) and define the main security boundary between organizations.
+- Customers
+ A [Customer](/docs/{{docsPrefix}}user-guide/ui/customers/){:target="_blank"} is a logical sub-organization within a tenant that typically represents an end user group, client, or a department consuming IoT resources managed by the Tenant. Customers are primarily used to logically separate devices, assets, dashboards, and alarms, enabling secure data sharing and delegated access management.
+ Customers support scalable multi-customer deployments by allowing tenants to assign resources to specific customer accounts and manage customer users independently.
- - **[Tenant Profiles](/docs/{{docsPrefix}}user-guide/tenant-profiles/)** - contains common settings for multiple tenants: entity, API and rate limits, etc. Each Tenant has the one and only profile at a single point in time.
- - **[Device Profiles](/docs/{{docsPrefix}}user-guide/device-profiles/)** - contains common settings for multiple devices: processing and transport configuration, etc. Each Device has the one and only profile at a single point in time.
- - **[Asset Profiles](/docs/{{docsPrefix}}user-guide/asset-profiles/)** - contains common settings for multiple assets: processing configuration, etc. Each Asset has the one and only profile at a single point in time.
+### Identity and Access Layer
-{% if docsPrefix == "pe/" %}
-**[Entity Groups](/docs/pe/user-guide/groups/)**:
+Controls authentication and authorization.
-ThingsBoard Professional Edition allows you to configure Entity Groups for Customers, Users, Devices, Assets, Entity Views and Dashboards.
-Each entity may belong to multiple groups simultaneously. Entity Group always have an owner - particular Tenant or Customer.
-All entities in the group must have the same entity type (i.e. You can't put device and asset into one group).
-Entity Groups are useful for dashboards and data processing, but the primary reason of their existence is to support advanced Role-Based Access Control ([RBAC](/docs/pe/user-guide/rbac/)) for IoT.
+- Users
+ A [User](/docs/{{docsPrefix}}user-guide/ui/users/){:target="_blank"} is an authenticated account with role-based access to ThingsBoard.
+ Users can belong to a Tenant or a Customer and can manage entities, dashboards, telemetry, and device operations based on assigned permissions.
+{% unless docsPrefix == nil %}- Role-Based Access Control (RBAC)
+ [Role-Based Access Control (RBAC)](/docs/pe/user-guide/rbac/){:target="_blank"} is a security mechanism that regulates user access to entities and platform operations based on assigned roles and permissions. It allows administrators to define what actions users can perform and which resources they can access.
+ RBAC is used to enforce secure multi-tenant deployments, isolate customer data, and implement fine-grained access control across devices, assets, dashboards, and other platform components.{% endunless %}
+- Tenant Profiles
+ A [Tenant Profile](/docs/{{docsPrefix}}user-guide/tenant-profiles/){:target="_blank"} defines common policies and limits applied to tenants, such as entity quotas, API limits, and rate limits.
+ Tenant Profiles are used to enforce resource usage rules and manage platform scalability. Each tenant is assigned to exactly one tenant profile at a time.
-**[Integrations](/docs/user-guide/integrations/)** and **[Data Converters](/docs/user-guide/integrations/#data-converters)**:
+## Things (Core IoT Model)
-ThingsBoard Platform integrations feature was designed for two primary use cases / deployment options:
+### IoT Domain Model Layer
- - Connect existing NB IoT, LoRaWAN, SigFox and other devices with specific payload formats directly to ThingsBoard platform.
- - Stream data from devices connected to existing IoT Platforms to enable real-time interactive dashboards and efficient data processing.
+Represents physical and logical IoT infrastructure.
-Data Converters is a part of the Platform Integrations feature. Their purpose is to transform raw payload from device to the format that ThingsBoard uses and vise-versa.
+- Devices
+ A [Device](/docs/{{docsPrefix}}user-guide/ui/devices/){:target="_blank"} represents a physical or virtual IoT device connected to ThingsBoard. Devices publish telemetry and attributes, receive RPC commands, and typically represent sensors, actuators, gateways, controllers, or software agents.
+- Assets
+ An [Assets](/docs/{{docsPrefix}}user-guide/ui/assets/){:target="_blank"} is an abstract entity used to model real-world objects and organize devices into hierarchical structures. Assets commonly represent infrastructure such as buildings, production lines, vehicles, warehouses, farms, or geographic areas.
+- Entity Views
+ An [Entity Views](/docs/{{docsPrefix}}user-guide/entity-views/){:target="_blank"} is a virtual representation of a device or asset that exposes only a selected subset of telemetry and attributes. Entity Views are used to securely share limited data with customers and behave as independent entities in dashboards and rule engine processing.
+- Gateway
+ A [Gateway](/docs/iot-gateway/){:target="_blank"} is a specialized device that acts as an intermediary between multiple downstream devices and ThingsBoard. It aggregates telemetry and attributes from connected devices, forwards data to the platform over a single connection, and routes RPC commands back to subordinate devices.
+ Gateways are commonly used to integrate non-IP or constrained devices (e.g., Modbus, BLE, Zigbee, LoRa), perform protocol translation, and reduce the number of direct platform connections. In ThingsBoard, a Gateway is registered as a Device operating in gateway mode and can manage multiple subordinate devices.
-{% endif %}
+### Policy Management Layer
-This guide provides an overview of the features listed above, some useful links to get more details, and real-life examples of their usage.
+Provides centralized configuration control.
-## Relations
+- Device Profiles
+ A [Device Profile](/docs/{{docsPrefix}}user-guide/device-profiles/){:target="_blank"} defines common configuration and behavior shared across multiple devices, including transport settings and default processing logic.
+ Device Profiles simplify fleet management by applying consistent connectivity and rule engine configuration. Each device is assigned to exactly one device profile at a time.
+- Asset Profiles
+ An [Asset Profile](/docs/{{docsPrefix}}user-guide/asset-profiles/){:target="_blank"} defines common processing configuration and behavior for assets.
+ Asset Profiles help standardize asset management and rule engine processing across large deployments. Each asset is assigned to exactly one asset profile at a time.
-Entity relation defines connection between two ThingsBoard entities that belong to the same [Tenant](/docs/{{docsPrefix}}user-guide/ui/tenants/).
-The relation has an arbitrary type: Contains, Manages, Supports, etc. The relation is also directional.
-You may treat ThingsBoard relations as a [Has-a](https://en.wikipedia.org/wiki/Has-a) relationship from object-oriented programming.
+## Data Model
-Relations help to model physical world objects in ThingsBoard. The easiest way to understand them is using the example.
-Let’s assume we want to build an application that collects data from soil moisture and temperature sensors, visualize this data on the dashboard, detect issues, raise alarms and control the irrigation.
-Let’s also assume we want to support multiple fields with hundreds of sensors. Fields may be also grouped into the Geo regions.
+Defines how entity data is stored and structured.
-The following diagram explains how those entities are configured and stored in ThingsBoard:
+- Attributes
+ [Attributes](/docs/{{docsPrefix}}user-guide/attributes/){:target="_blank"} are static or semi-static key-value pairs associated with an entity.
+ They are commonly used to store metadata, configuration parameters, and entity state information such as model, firmware version, location, or operational status.
+- Time-series Data
+ [Time-series data](/docs/{{docsPrefix}}user-guide/telemetry/){:target="_blank"} (telemetry) represents timestamped measurements published by devices and stored in ThingsBoard.
+ It is used for real-time monitoring, historical data analysis, querying, aggregation, and visualization in dashboards.
+- Relations
+ [Relations](/docs/key-concepts/relations/){:target="_blank"} are directed links between ThingsBoard entities used to model hierarchical and logical structures.
+ They enable building entity relationships such as containment, ownership, or location (e.g., Contains, Manages, Located In) and are commonly used in dashboards and rule engine processing.
-
+## Connectivity & Control
+### Connectivity Layer
-See ["add and delete assets"](/docs/pe/user-guide/ui/assets/#add-and-delete-assets) and ["manage asset relations"](/docs/pe/user-guide/ui/assets/#manage-asset-relations)
-to learn how to configure this entities via Administration UI. You may also use [REST API](/docs/reference/rest-client/) to create entities and relations programmatically.
+Defines how devices connect and authenticate.
-## Next steps
+- Device credentials
+ Device credentials are authentication parameters used by devices to connect securely to ThingsBoard. They typically include access tokens, X.509 certificates, or MQTT/HTTP credentials depending on the selected transport protocol.
+- Transport protocols
+ ThingsBoard supports multiple transport protocols for device connectivity, such as MQTT, HTTP, CoAP, and LwM2M. Transport protocols define how devices publish telemetry and attributes, and how they receive commands from the platform.
-**Assign attributes to the assets and devices**
+Connects ThingsBoard with external systems.
-ThingsBoard provides the ability to assign attributes to entities and manage them.
-You are welcome to learn how to do it here:
-Working with device attributes
+- Integrations
+ An [Integrations](/docs/{{docsPrefix}}user-guide/integrations/){:target="_blank"} provides connectivity between ThingsBoard and external IoT networks, devices, and third-party platforms, enabling data collection from external sources and delivery to ThingsBoard for real-time visualization and processing. Integrations are mainly used to connect NB-IoT, LoRaWAN, SigFox, and other devices with specific payload formats directly to ThingsBoard, or to stream data from existing IoT platforms to support interactive dashboards and efficient data processing.
+- Data Converters
+ [Data Converters](/docs/{{docsPrefix}}user-guide/integrations/#data-converters){:target="_blank"} are used within integrations to transform raw incoming and outgoing payloads into the ThingsBoard message format and vice versa, ensuring compatibility with various protocols and device-specific data structures.
+### Device Control Layer
-**Upload telemetry data from devices**
+Defines device command and management mechanisms.
-ThingsBoard provides the ability to work with telemetry data for devices and other entities.
-You are welcome to learn how to do it here:
-Working with telemetry data
+- Remote Procedure Call (RPC)
+ [Remote Procedure Call (RPC)](/docs/{{docsPrefix}}user-guide/rpc/){:target="_blank"} is a communication mechanism that allows ThingsBoard to send commands to devices and receive responses.
+ RPC is commonly used for device control operations such as switching relays, updating configuration, or triggering actions remotely.
+- OTA Updates
+ [OTA updates](/docs/{{docsPrefix}}user-guide/ota-updates/){:target="_blank"} enable remote firmware and software distribution to devices.
+ They are used for centralized device lifecycle management and fleet maintenance.
-**Creating Rules for Alarms**
+## Processing & Automation
-ThingsBoard provides the ability to raise alarms using rule engine for devices and other entities.
-You are welcome to learn how to do it here:
-Working with alarms
+### Operational Monitoring Layer
-**Design your dashboard**
+Tracks system state and abnormal conditions.
-Please [import](/docs/{{docsPrefix}}user-guide/ui/dashboards/#dashboard-import) the following [**dashboard**](/docs/{{docsPrefix}}user-guide/resources/region_fields_dashboard.json) that demonstrates Map, Alarm, Entity Table and Charts widgets.
+- Alarms
+ An [Alarms](/docs/{{docsPrefix}}user-guide/alarms/){:target="_blank"} is an event entity that represents abnormal behavior or an issue detected for another entity (device, asset, etc.).
+ Alarms can be generated by rule chains, acknowledged and cleared manually, and monitored through dashboards and notifications.
+- Notifications
+ [Notifications](/docs/{{docsPrefix}}user-guide/notifications/){:target="_blank"} provide automated delivery of important events to users and external systems.
+ They are typically triggered by by alarms, device activity, entity action, system failure, and more, and can be delivered via email, SMS, webhooks, or other supported channels.
+
+### Data Processing and Enrichment Layer
+
+Handles message routing and workflow automation.
+
+- Alarm Rules
+ [Alarm rules](/docs/{{docsPrefix}}user-guide/alarm-rules/){:target="_blank"} define conditions for generating alarms based on telemetry or attribute data.
+ They are typically implemented in rule chains to enable automated issue detection.
+- Rule Nodes
+ A [Rule Node](/docs/{{docsPrefix}}user-guide/rule-engine-2-0/nodes/){:target="_blank"} is a processing component of the ThingsBoard Rule Engine that performs a specific action or transformation on incoming messages.
+ Rule Nodes can filter, enrich, route data, manage alarms, trigger notifications, execute RPC, and integrate with external systems.
+- Rule Chains
+ A [Rule Chain](/docs/{{docsPrefix}}user-guide/rule-engine-2-0/overview/#rule-chain){:target="_blank"} is a configurable workflow in the ThingsBoard [Rule Engine](/docs/{{docsPrefix}}user-guide/rule-engine-2-0/re-getting-started/){:target="_blank"} that defines how messages are routed and processed.
+ Rule Chains consist of connected rule nodes and handle telemetry, attributes, alarms, lifecycle events, and RPC-related processing.
+
+Extends raw telemetry with derived insights.
+
+- Calculated fields
+ [Calculated fields](/docs/{{docsPrefix}}user-guide/calculated-fields/){:target="_blank"} are virtual data points derived from existing telemetry or attributes using configurable expressions. They allow real-time data transformation and enrichment without modifying device firmware.
+ Calculated fields are commonly used to compute KPIs, normalize measurements, or generate aggregated metrics directly within the platform.
+
+## Visualization & Analytics
+
+### Visualization Layer
+
+Provides real-time monitoring and control interfaces.
+
+- Dashboards
+ A [Dashboards](/docs/{{docsPrefix}}user-guide/dashboards/){:target="_blank"} is an interactive interface for real-time monitoring and control of IoT entities. Dashboards provide widgets for telemetry visualization, alarm monitoring, entity management, and device control via RPC or attribute updates.
+- Widgets
+ [Widgets](/docs/{{docsPrefix}}user-guide/widgets/){:target="_blank"} are dashboard building blocks used to visualize telemetry, display entity data, manage alarms, and control devices. Widgets support multiple visualization types such as charts, tables, maps, and custom UI components.
+
+### Business Intelligence and Advanced Analytics Layer
+
+Transforms operational data into structured outputs.
+
+- Reporting
+ [Reporting](/docs/{{docsPrefix}}user-guide/reporting/reporting-key-concepts/){:target="_blank"} provides structured data export and scheduled report generation based on telemetry, alarms, and entity data. It enables automated delivery of operational insights in formats suitable for business users. Reporting is typically used for periodic summaries, compliance documentation, and sharing analytics results with stakeholders.
+
+Advanced data analytics and visualization.
+
+- Trendz Analytics [Add On]
+ [Trendz Analytics](/docs/trendz/){:target="_blank"} is an advanced analytics solution integrated with ThingsBoard that provides powerful tools for historical data exploration and interactive visualization. It is commonly used to build analytics dashboards, detect trends, and generate insights based on telemetry and entity data.
+
+
+## Edge Computing Layer [Add On]
+
+Extends ThingsBoard processing to remote sites.
+
+- ThingsBoard Edge
+ [ThingsBoard Edge](/docs/edge/){:target="_blank"} is an edge computing solution that enables running data processing, automation, and dashboards closer to devices.
+ It supports local operation, reduces latency, and ensures continued functionality during intermittent cloud connectivity by synchronizing data and configuration with the ThingsBoard platform.
+
+
+## Next Steps
+
+After reviewing ThingsBoard key concepts, you can continue with the following guides:
+
+- [Getting Started with ThingsBoard](/docs/getting-started-guides/helloworld/){:target="_blank"} - Quick step-by-step tutorials that introduce core ThingsBoard features and typical IoT workflows. Designed to be completed in 15–30 minutes.
+- [Connect your device](/docs/user-guide/integrations/){:target="_blank"} - Learn how to connect devices to ThingsBoard using supported protocols, gateways, and integrations based on your connectivity technology.
+- [Creating dashboards](/docs/{{docsPrefix}}user-guide/dashboards/) - Learn how to build interactive dashboards for real-time monitoring, visualization, and device control using widgets and entity aliases.
+- [Data processing & actions](/docs/guides/#AnchorIDDataProcessing){:target="_blank"} - Learn how to process incoming messages, enrich telemetry, route data, trigger actions, and integrate with external systems.
+- [Working with alarms](/docs/{{docsPrefix}}user-guide/alarms/) - Learn how to configure alarm generation, monitor active alarms, acknowledge and clear them, and build alarm-based monitoring workflows.
+- [Working with device attributes](/docs/{{docsPrefix}}user-guide/attributes/) - Learn how to store and manage entity metadata and configuration using attributes, including client-side, shared, and server-side attribute scopes.
+- [Working with telemetry](/docs/{{docsPrefix}}user-guide/telemetry/) - Learn how to publish, query, and visualize time-series telemetry data, including aggregation, historical analysis, and real-time monitoring.
diff --git a/_includes/templates/attributes/client-side-attributes.md b/_includes/templates/attributes/client-side-attributes.md
new file mode 100644
index 0000000000..5320b1a6c6
--- /dev/null
+++ b/_includes/templates/attributes/client-side-attributes.md
@@ -0,0 +1,52 @@
+
+### Fetch client-side attributes
+
+To retrieve client-side attributes, send a **GET** request to:
+
+```shell
+https://{{HOST_NAME}}/api/plugins/telemetry/$ENTITY_TYPE/$ENTITY_ID/values/attributes/CLIENT_SCOPE
+```
+{: .copy-code}
+
+Replace {% unless docsPrefix contains "paas/" %}
+ • {{HOST_NAME}} with your ThingsBoard{% if docsPrefix == "edge/" or docsPrefix == "pe/edge/" %} Edge{% endif %} hostname or IP address.{% endunless %}
+ • $ENTITY_TYPE with your entity type.
+ • $ENTITY_ID with your entity ID.
+
+**Example**: fetch all client-side attributes for a device with ID _**ad17c410-914c-11eb-af0c-d5862211a5f6**_:
+
+```shell
+curl -v -X GET '{{httpsUrl}}/api/plugins/telemetry/DEVICE/ad17c410-914c-11eb-af0c-d5862211a5f6/values/attributes/CLIENT_SCOPE' \
+-H 'X-Authorization: Bearer $YOUR_JWT_TOKEN_HERE' \
+-H 'Content-Type: application/json'
+```
+{: .copy-code}
+
+Replace $YOUR_JWT_TOKEN_HERE with your JWT token value.
+
+**Response example**
+The response contains the attribute key, value, and the timestamp of the last update:
+
+```json
+[
+ {
+ "lastUpdateTs": 1617633139380,
+ "key": "newAttributeName",
+ "value": "newAttributeValue"
+ }
+]
+```
+
+### Device API
+
+Devices can interact with client-side attributes using the following APIs:
+- Publish client-side attributes:
+ - [MQTT API](/docs/{{docsPrefix}}reference/mqtt-api/#publish-attribute-update-to-the-server){:target="_blank"}
+ - [CoAP API](/docs/{{docsPrefix}}reference/coap-api/#publish-attribute-update-to-the-server){:target="_blank"}
+ - [HTTP API](/docs/{{docsPrefix}}reference/http-api/#publish-attribute-update-to-the-server){:target="_blank"}
+- Request client-side attributes:
+ - [MQTT API](/docs/{{docsPrefix}}reference/mqtt-api/#request-attribute-values-from-the-server){:target="_blank"}
+ - [CoAP API](/docs/{{docsPrefix}}reference/coap-api/#request-attribute-values-from-the-server){:target="_blank"}
+ - [HTTP API](/docs/{{docsPrefix}}reference/http-api/#request-attribute-values-from-the-server){:target="_blank"}
+
+Client-side attributes are published by the device and can be read from the platform, but cannot be modified via UI or REST API.
\ No newline at end of file
diff --git a/_includes/templates/attributes/server-side-attributes.md b/_includes/templates/attributes/server-side-attributes.md
new file mode 100644
index 0000000000..8f382f3aaa
--- /dev/null
+++ b/_includes/templates/attributes/server-side-attributes.md
@@ -0,0 +1,52 @@
+
+### Create or update server-side attribute
+
+Send a **POST** request with a JSON payload to:
+
+```shell
+https://{{HOST_NAME}}/api/plugins/telemetry/$ENTITY_TYPE/$ENTITY_ID/SERVER_SCOPE
+```
+{: .copy-code}
+
+Replace {% unless docsPrefix contains "paas/" %}
+ • {{HOST_NAME}} with your ThingsBoard{% if docsPrefix == "edge/" or docsPrefix == "pe/edge/" %} Edge{% endif %} hostname or IP address.{% endunless %}
+ • $ENTITY_TYPE with your entity type.
+ • $ENTITY_ID with your entity ID.
+
+**Example**: create a server-side attribute with the name _**newAttributeName**_ and value _**newAttributeValue**_ for device with ID _**ad17c410-914c-11eb-af0c-d5862211a5f6**_:
+
+```shell
+curl -v '{{httpsUrl}}/api/plugins/telemetry/DEVICE/ad17c410-914c-11eb-af0c-d5862211a5f6/SERVER_SCOPE' \
+-H 'x-authorization: Bearer $YOUR_JWT_TOKEN_HERE' \
+-H 'content-type: application/json' \
+--data-raw '{"newAttributeName":"newAttributeValue"}'
+```
+{: .copy-code}
+
+Replace $YOUR_JWT_TOKEN_HERE with your JWT token value.
+
+### Fetch server-side attributes
+
+To retrieve all server-side attributes for an entity, send a **GET** request:
+
+```shell
+curl -v -X GET '{{httpsUrl}}/api/plugins/telemetry/DEVICE/ad17c410-914c-11eb-af0c-d5862211a5f6/values/attributes/SERVER_SCOPE' \
+ -H 'x-authorization: Bearer $YOUR_JWT_TOKEN_HERE' \
+ -H 'content-type: application/json'
+```
+{: .copy-code}
+
+**Response example**
+The response contains the attribute key, value, and the timestamp of the last update:
+
+```json
+[
+ {
+ "lastUpdateTs": 1617633139380,
+ "key": "newAttributeName",
+ "value": "newAttributeValue"
+ }
+]
+```
+
+As an alternative to curl, you may use the official [Java](/docs/{{docsPrefix}}reference/rest-client/){:target="_blank"} or [Python](/docs/{{docsPrefix}}reference/python-rest-client/){:target="_blank"} REST clients.
diff --git a/_includes/templates/attributes/shared-attributes.md b/_includes/templates/attributes/shared-attributes.md
new file mode 100644
index 0000000000..c96069df78
--- /dev/null
+++ b/_includes/templates/attributes/shared-attributes.md
@@ -0,0 +1,73 @@
+
+### Create or update shared attribute
+
+To create or update a shared attribute, send a **POST** request with a JSON payload to:
+
+```shell
+https://{{HOST_NAME}}/api/plugins/telemetry/$ENTITY_TYPE/$ENTITY_ID/SHARED_SCOPE
+```
+{: .copy-code}
+
+Replace {% unless docsPrefix contains "paas/" %}
+ • {{HOST_NAME}} with your ThingsBoard{% if docsPrefix == "edge/" or docsPrefix == "pe/edge/" %} Edge{% endif %} hostname or IP address.{% endunless %}
+ • $ENTITY_TYPE with your entity type.
+ • $ENTITY_ID with your entity ID.
+
+**Example**: create a shared attribute with the name _**newAttributeName**_ and value _**newAttributeValue**_ for device with ID _**ad17c410-914c-11eb-af0c-d5862211a5f6**_:
+
+```shell
+curl -v '{{httpsUrl}}/api/plugins/telemetry/DEVICE/ad17c410-914c-11eb-af0c-d5862211a5f6/SHARED_SCOPE' \
+-H 'X-Authorization: Bearer $YOUR_JWT_TOKEN_HERE' \
+-H 'Content-Type: application/json' \
+--data-raw '{"newAttributeName":"newAttributeValue"}'
+```
+{: .copy-code}
+
+Replace $YOUR_JWT_TOKEN_HERE with your JWT token value.
+
+### Fetch shared attributes
+
+To retrieve all shared attributes for a device, send a GET request:
+
+```shell
+curl -v -X GET '{{httpsUrl}}/api/plugins/telemetry/DEVICE/ad17c410-914c-11eb-af0c-d5862211a5f6/values/attributes/SHARED_SCOPE' \
+-H 'X-Authorization: Bearer $YOUR_JWT_TOKEN_HERE' \
+-H 'Content-Type: application/json'
+```
+{: .copy-code}
+
+**Response example**
+The response contains the attribute key, value, and the timestamp of the last update:
+
+```json
+[
+ {
+ "lastUpdateTs": 1617633139380,
+ "key": "newAttributeName",
+ "value": "newAttributeValue"
+ }
+]
+```
+
+As an alternative to curl, you may use the official [Java](/docs/{{docsPrefix}}reference/rest-client/){:target="_blank"} or [Python](/docs/{{docsPrefix}}reference/python-rest-client/){:target="_blank"} REST clients.
+
+### Device API
+
+Devices can interact with shared attributes using the following APIs:
+- Request shared attribute values:
+ - [MQTT API](/docs/{{docsPrefix}}reference/mqtt-api/#request-attribute-values-from-the-server){:target="_blank"}
+ - [CoAP API](/docs/{{docsPrefix}}reference/coap-api/#request-attribute-values-from-the-server){:target="_blank"}
+ - [HTTP API](/docs/{{docsPrefix}}reference/http-api/#request-attribute-values-from-the-server){:target="_blank"}
+ - [LwM2M API](/docs/{{docsPrefix}}reference/lwm2m-api/#attributes-api){:target="_blank"}
+
+- Subscribe to shared attribute updates:
+ - [MQTT API](/docs/{{docsPrefix}}reference/mqtt-api/#subscribe-to-attribute-updates-from-the-server){:target="_blank"}
+ - [CoAP API](/docs/{{docsPrefix}}reference/coap-api/#subscribe-to-attribute-updates-from-the-server){:target="_blank"}
+ - [HTTP API](/docs/{{docsPrefix}}reference/http-api/#subscribe-to-attribute-updates-from-the-server){:target="_blank"}
+ - [LwM2M API](/docs/{{docsPrefix}}reference/lwm2m-api/#attributes-api){:target="_blank"}
+
+{% capture missed_updates %}
+If a device goes offline, it may miss attribute update notifications.
+We recommend subscribing to attribute updates on application startup and requesting the latest attribute values after each connection or reconnection.
+{% endcapture %}
+{% include templates/info-banner.md content=missed_updates %}
diff --git a/docs/key-concepts/relations.md b/docs/key-concepts/relations.md
new file mode 100644
index 0000000000..dce01720e9
--- /dev/null
+++ b/docs/key-concepts/relations.md
@@ -0,0 +1,8 @@
+---
+layout: docwithnav
+title: Relations in ThingsBoard
+description: What are Relations in ThingsBoard
+---
+
+{% include get-hosts-name.html %}
+{% include docs/key-concepts/relations.md %}
diff --git a/docs/paas/eu/key-concepts/relations.md b/docs/paas/eu/key-concepts/relations.md
new file mode 100644
index 0000000000..9f41894f16
--- /dev/null
+++ b/docs/paas/eu/key-concepts/relations.md
@@ -0,0 +1,9 @@
+---
+layout: docwithnav-paas-eu
+title: Relations in ThingsBoard
+description: What are Relations in ThingsBoard
+---
+
+{% assign docsPrefix = "paas/eu/" %}
+{% include get-hosts-name.html docsTag="paas-eu" %}
+{% include docs/key-concepts/relations.md %}
diff --git a/docs/paas/eu/user-guide/attributes.md b/docs/paas/eu/user-guide/attributes.md
index 265539cc4f..221b85dc6a 100644
--- a/docs/paas/eu/user-guide/attributes.md
+++ b/docs/paas/eu/user-guide/attributes.md
@@ -4,27 +4,6 @@ assignees:
- ashvayka
title: Working with IoT device attributes
description: IoT device management using ThingsBoard attributes feature
-server-side-attrs-ui:
- 0:
- image: /images/user-guide/attributes/add-server-side-pe-src.png
- title: 'Go to Entities → Devices and open the device you want to edit by clicking its row. In the device details, open the "Attributes" tab, select the "Server attributes" scope, and click the "+" icon to add a new attribute.'
- 1:
- image: /images/user-guide/attributes/add-server-side-pe2-src.png
- title: 'In the dialog, enter the attribute key, select the value type (for example, String), and provide a value.'
- 2:
- image: /images/user-guide/attributes/add-server-side-pe3-src.png
- title: 'After saving, the new attribute appears in the list with its key, value, and last update time. Sort using "Last update time" to quickly locate the newly created attribute.'
-
-shared-attrs-ui:
- 0:
- image: /images/user-guide/attributes/add-shared-pe-src.png
- title: 'Go to Entities → Devices and open the device you want to edit by clicking its row. In the device details, open the "Attributes" tab, select the "Shared attributes" scope, and click the "+" icon to add a new attribute.'
- 1:
- image: /images/user-guide/attributes/add-shared-pe2-src.png
- title: 'In the dialog, enter the attribute key, select the value type (for example, Double), and provide a value.'
- 2:
- image: /images/user-guide/attributes/add-shared-pe3-src.png
- title: 'After saving, the new attribute appears in the list with its key, value, and last update time.'
---
diff --git a/docs/paas/eu/user-guide/entities-and-relations.md b/docs/paas/eu/user-guide/entities-and-relations.md
index 589a0db351..95bc7cbe51 100644
--- a/docs/paas/eu/user-guide/entities-and-relations.md
+++ b/docs/paas/eu/user-guide/entities-and-relations.md
@@ -2,8 +2,8 @@
layout: docwithnav-paas-eu
assignees:
- ashvayka
-title: Entities and relations
-description: IoT asset management using ThingsBoard entities and relations feature
+title: Key Concepts and Architecture
+description: IoT asset management using ThingsBoard entities and components
---
diff --git a/docs/paas/key-concepts/relations.md b/docs/paas/key-concepts/relations.md
new file mode 100644
index 0000000000..bddf2ca31a
--- /dev/null
+++ b/docs/paas/key-concepts/relations.md
@@ -0,0 +1,9 @@
+---
+layout: docwithnav-paas
+title: Relations in ThingsBoard
+description: What are Relations in ThingsBoard
+---
+
+{% assign docsPrefix = "paas/" %}
+{% include get-hosts-name.html docsPrefix=docsPrefix %}
+{% include docs/key-concepts/relations.md %}
diff --git a/docs/paas/user-guide/attributes.md b/docs/paas/user-guide/attributes.md
index 14c91ae3e1..49be015622 100644
--- a/docs/paas/user-guide/attributes.md
+++ b/docs/paas/user-guide/attributes.md
@@ -4,27 +4,6 @@ assignees:
- ashvayka
title: Working with IoT device attributes
description: IoT device management using ThingsBoard attributes feature
-server-side-attrs-ui:
- 0:
- image: /images/user-guide/attributes/add-server-side-pe-src.png
- title: 'Go to Entities → Devices and open the device you want to edit by clicking its row. In the device details, open the "Attributes" tab, select the "Server attributes" scope, and click the "+" icon to add a new attribute.'
- 1:
- image: /images/user-guide/attributes/add-server-side-pe2-src.png
- title: 'In the dialog, enter the attribute key, select the value type (for example, String), and provide a value.'
- 2:
- image: /images/user-guide/attributes/add-server-side-pe3-src.png
- title: 'After saving, the new attribute appears in the list with its key, value, and last update time. Sort using "Last update time" to quickly locate the newly created attribute.'
-
-shared-attrs-ui:
- 0:
- image: /images/user-guide/attributes/add-shared-pe-src.png
- title: 'Go to Entities → Devices and open the device you want to edit by clicking its row. In the device details, open the "Attributes" tab, select the "Shared attributes" scope, and click the "+" icon to add a new attribute.'
- 1:
- image: /images/user-guide/attributes/add-shared-pe2-src.png
- title: 'In the dialog, enter the attribute key, select the value type (for example, Double), and provide a value.'
- 2:
- image: /images/user-guide/attributes/add-shared-pe3-src.png
- title: 'After saving, the new attribute appears in the list with its key, value, and last update time.'
---
diff --git a/docs/paas/user-guide/entities-and-relations.md b/docs/paas/user-guide/entities-and-relations.md
index b42ee790ca..645754af4d 100644
--- a/docs/paas/user-guide/entities-and-relations.md
+++ b/docs/paas/user-guide/entities-and-relations.md
@@ -2,8 +2,8 @@
layout: docwithnav-paas
assignees:
- ashvayka
-title: Entities and relations
-description: IoT asset management using ThingsBoard entities and relations feature
+title: Key Concepts and Architecture
+description: IoT asset management using ThingsBoard entities and components
---
diff --git a/docs/pe/key-concepts/relations.md b/docs/pe/key-concepts/relations.md
new file mode 100644
index 0000000000..8df2d24555
--- /dev/null
+++ b/docs/pe/key-concepts/relations.md
@@ -0,0 +1,9 @@
+---
+layout: docwithnav-pe
+title: Relations in ThingsBoard
+description: What are Relations in ThingsBoard
+---
+
+{% assign docsPrefix = "pe/" %}
+{% include get-hosts-name.html docsPrefix=docsPrefix %}
+{% include docs/key-concepts/relations.md %}
diff --git a/docs/pe/user-guide/attributes.md b/docs/pe/user-guide/attributes.md
index 495f09737c..7b265419ae 100644
--- a/docs/pe/user-guide/attributes.md
+++ b/docs/pe/user-guide/attributes.md
@@ -4,27 +4,6 @@ assignees:
- ashvayka
title: Working with IoT device attributes
description: IoT device management using ThingsBoard attributes feature
-server-side-attrs-ui:
- 0:
- image: /images/user-guide/attributes/add-server-side-pe-src.png
- title: 'Go to Entities → Devices and open the device you want to edit by clicking its row. In the device details, open the "Attributes" tab, select the "Server attributes" scope, and click the "+" icon to add a new attribute.'
- 1:
- image: /images/user-guide/attributes/add-server-side-pe2-src.png
- title: 'In the dialog, enter the attribute key, select the value type (for example, String), and provide a value.'
- 2:
- image: /images/user-guide/attributes/add-server-side-pe3-src.png
- title: 'After saving, the new attribute appears in the list with its key, value, and last update time. Sort using "Last update time" to quickly locate the newly created attribute.'
-
-shared-attrs-ui:
- 0:
- image: /images/user-guide/attributes/add-shared-pe-src.png
- title: 'Go to Entities → Devices and open the device you want to edit by clicking its row. In the device details, open the "Attributes" tab, select the "Shared attributes" scope, and click the "+" icon to add a new attribute.'
- 1:
- image: /images/user-guide/attributes/add-shared-pe2-src.png
- title: 'In the dialog, enter the attribute key, select the value type (for example, Double), and provide a value.'
- 2:
- image: /images/user-guide/attributes/add-shared-pe3-src.png
- title: 'After saving, the new attribute appears in the list with its key, value, and last update time.'
---
diff --git a/docs/pe/user-guide/entities-and-relations.md b/docs/pe/user-guide/entities-and-relations.md
index 3099779703..76a87f914c 100644
--- a/docs/pe/user-guide/entities-and-relations.md
+++ b/docs/pe/user-guide/entities-and-relations.md
@@ -2,8 +2,8 @@
layout: docwithnav-pe
assignees:
- ashvayka
-title: Entities and relations
-description: IoT asset management using ThingsBoard entities and relations feature
+title: Key Concepts and Architecture
+description: IoT asset management using ThingsBoard entities and components
---
diff --git a/docs/pe/user-guide/resources/region_fields_dashboard.json b/docs/pe/user-guide/resources/region_fields_dashboard.json
deleted file mode 100644
index a1a5ffe1e8..0000000000
--- a/docs/pe/user-guide/resources/region_fields_dashboard.json
+++ /dev/null
@@ -1,820 +0,0 @@
-{
- "title": "Region",
- "configuration": {
- "widgets": {
- "864ae6da-a436-9482-360b-148df93f7cc1": {
- "isSystemType": true,
- "bundleAlias": "maps_v2",
- "typeAlias": "image_map",
- "type": "latest",
- "title": "New widget",
- "sizeX": 13,
- "sizeY": 6,
- "config": {
- "datasources": [
- {
- "type": "entity",
- "dataKeys": [
- {
- "name": "xPos",
- "type": "attribute",
- "label": "xPos",
- "color": "#2196f3",
- "settings": {},
- "_hash": 0.9516904367739742
- },
- {
- "name": "yPos",
- "type": "attribute",
- "label": "yPos",
- "color": "#4caf50",
- "settings": {},
- "_hash": 0.943977233636577
- }
- ],
- "entityAliasId": "24cec249-9954-d166-ed17-f74af5d7a94f"
- }
- ],
- "timewindow": {
- "realtime": {
- "timewindowMs": 60000
- }
- },
- "showTitle": true,
- "backgroundColor": "#fff",
- "color": "rgba(255, 254, 254, 0.87)",
- "padding": "8px",
- "settings": {
- "showLabel": true,
- "label": "${entityName}",
- "tooltipPattern": "${entityName} X Pos: ${xPos:2}Y Pos: ${yPos:2}Field details ",
- "markerImageSize": 34,
- "useColorFunction": true,
- "markerImages": [
- "",
- "",
- "",
- ""
- ],
- "useMarkerImageFunction": true,
- "colorFunction": "var type = dsData[dsIndex]['type'];\nif (type == 'colorpin') {\n\tvar temperature = dsData[dsIndex]['temperature'];\n\tif (typeof temperature !== undefined) {\n\t var percent = (temperature + 60)/120 * 100;\n\t return tinycolor.mix('blue', 'red', amount = percent).toHexString();\n\t}\n\treturn 'blue';\n}\n",
- "markerImageFunction": "var type = dsData[dsIndex]['type'];\nif (type == 'thermomether') {\n\tvar res = {\n\t url: images[0],\n\t size: 40\n\t}\n\tvar temperature = dsData[dsIndex]['temperature'];\n\tif (typeof temperature !== undefined) {\n\t var percent = (temperature + 60)/120;\n\t var index = Math.floor(4 * percent);\n\t res.url = images[index];\n\t}\n\treturn res;\n}",
- "color": "#fe7569",
- "mapImageUrl": "",
- "xPosKeyName": "xPos",
- "yPosKeyName": "yPos",
- "posFunction": "return {x: origXPos, y: origYPos};",
- "markerOffsetX": 0.5,
- "markerOffsetY": 1
- },
- "title": "Fields Map",
- "dropShadow": true,
- "enableFullscreen": true,
- "titleStyle": {
- "fontSize": "16px",
- "fontWeight": 400,
- "color": "rgba(1, 1, 1, 0.87)"
- },
- "useDashboardTimewindow": true,
- "showLegend": false,
- "widgetStyle": {},
- "actions": {
- "markerClick": [
- {
- "id": "7dd0b13e-a079-f10b-18c3-ce2faeedca13",
- "name": "Select Field",
- "icon": "more_horiz",
- "type": "updateDashboardState",
- "targetDashboardStateId": null,
- "setEntityId": true,
- "stateEntityParamName": "selected_field"
- }
- ],
- "tooltipAction": [
- {
- "id": "a88b913d-5f5e-18d3-967f-35c70d49e830",
- "name": "Open Field Details",
- "icon": "more_horiz",
- "type": "openDashboardState",
- "targetDashboardStateId": "field",
- "setEntityId": true
- }
- ]
- }
- },
- "id": "864ae6da-a436-9482-360b-148df93f7cc1"
- },
- "2faca02d-30d4-6069-6aef-18b44506e72d": {
- "isSystemType": true,
- "bundleAlias": "cards",
- "typeAlias": "entities_table",
- "type": "latest",
- "title": "New widget",
- "sizeX": 11,
- "sizeY": 6,
- "config": {
- "timewindow": {
- "realtime": {
- "interval": 1000,
- "timewindowMs": 86400000
- },
- "aggregation": {
- "type": "NONE",
- "limit": 200
- }
- },
- "showTitle": true,
- "backgroundColor": "rgb(255, 255, 255)",
- "color": "rgba(0, 0, 0, 0.87)",
- "padding": "4px",
- "settings": {
- "enableSearch": true,
- "displayPagination": true,
- "defaultPageSize": 10,
- "defaultSortOrder": "entityName",
- "displayEntityName": true,
- "displayEntityType": false,
- "entitiesTitle": "Fields",
- "entityNameColumnTitle": "Field"
- },
- "title": "Fields",
- "dropShadow": true,
- "enableFullscreen": true,
- "titleStyle": {
- "fontSize": "18px",
- "fontWeight": 400,
- "padding": "5px 10px 5px 10px"
- },
- "useDashboardTimewindow": false,
- "showLegend": false,
- "datasources": [
- {
- "type": "entity",
- "dataKeys": [
- {
- "name": "waterSpent",
- "type": "attribute",
- "label": "Water spent",
- "color": "#2196f3",
- "settings": {
- "columnWidth": "0px",
- "useCellStyleFunction": false,
- "useCellContentFunction": true,
- "cellContentFunction": "return value + ' gal';"
- },
- "_hash": 0.31847158456654756
- }
- ],
- "entityAliasId": "24cec249-9954-d166-ed17-f74af5d7a94f"
- }
- ],
- "widgetStyle": {},
- "actions": {
- "actionCellButton": [
- {
- "id": "e81a6784-c8cc-1c6a-1e93-aeef3bb901a0",
- "name": "Open Field Details",
- "icon": "play_arrow",
- "type": "openDashboardState",
- "targetDashboardStateId": "field",
- "setEntityId": true
- }
- ],
- "rowClick": [
- {
- "id": "a6cce823-d1ca-4fce-002e-d8083ec342eb",
- "name": "Select Field",
- "icon": "more_horiz",
- "type": "updateDashboardState",
- "targetDashboardStateId": null,
- "setEntityId": true,
- "stateEntityParamName": "selected_field"
- }
- ]
- }
- },
- "id": "2faca02d-30d4-6069-6aef-18b44506e72d"
- },
- "d489fb00-82a2-d0d2-9cb3-c417bdaabe66": {
- "isSystemType": true,
- "bundleAlias": "alarm_widgets",
- "typeAlias": "alarms_table",
- "type": "alarm",
- "title": "New widget",
- "sizeX": 24,
- "sizeY": 6,
- "config": {
- "timewindow": {
- "realtime": {
- "interval": 1000,
- "timewindowMs": 86400000
- },
- "aggregation": {
- "type": "NONE",
- "limit": 200
- }
- },
- "showTitle": true,
- "backgroundColor": "rgb(255, 255, 255)",
- "color": "rgba(0, 0, 0, 0.87)",
- "padding": "4px",
- "settings": {
- "enableSelection": true,
- "enableSearch": true,
- "displayDetails": true,
- "allowAcknowledgment": true,
- "allowClear": true,
- "displayPagination": true,
- "defaultPageSize": 10,
- "defaultSortOrder": "-createdTime",
- "alarmsTitle": "Alarms: ${entityName}"
- },
- "title": "New Alarms table",
- "dropShadow": true,
- "enableFullscreen": true,
- "titleStyle": {
- "fontSize": "18px",
- "fontWeight": 400,
- "padding": "5px 10px 5px 10px"
- },
- "useDashboardTimewindow": false,
- "showLegend": false,
- "alarmSource": {
- "type": "entity",
- "dataKeys": [
- {
- "name": "createdTime",
- "type": "alarm",
- "label": "Created time",
- "color": "#2196f3",
- "settings": {},
- "_hash": 0.6244551770744973
- },
- {
- "name": "originator",
- "type": "alarm",
- "label": "Originator",
- "color": "#4caf50",
- "settings": {},
- "_hash": 0.7471580233279045
- },
- {
- "name": "type",
- "type": "alarm",
- "label": "Type",
- "color": "#f44336",
- "settings": {},
- "_hash": 0.9328521123794775
- },
- {
- "name": "severity",
- "type": "alarm",
- "label": "Severity",
- "color": "#ffc107",
- "settings": {},
- "_hash": 0.6981735799340436
- },
- {
- "name": "status",
- "type": "alarm",
- "label": "Status",
- "color": "#607d8b",
- "settings": {},
- "_hash": 0.49709924785966786
- }
- ],
- "entityAliasId": "360b0e25-1659-75d6-1cb8-70afaef2a7ea",
- "name": "alarms"
- },
- "alarmSearchStatus": "ANY",
- "alarmsPollingInterval": 5,
- "datasources": [],
- "widgetStyle": {},
- "actions": {}
- },
- "id": "d489fb00-82a2-d0d2-9cb3-c417bdaabe66"
- },
- "1fca566e-5e28-7002-d73d-a43b04ed12df": {
- "isSystemType": true,
- "bundleAlias": "maps_v2",
- "typeAlias": "image_map",
- "type": "latest",
- "title": "New widget",
- "sizeX": 12,
- "sizeY": 6,
- "config": {
- "datasources": [
- {
- "type": "entity",
- "dataKeys": [
- {
- "name": "xPos",
- "type": "attribute",
- "label": "xPos",
- "color": "#2196f3",
- "settings": {},
- "_hash": 0.0575757175634275
- },
- {
- "name": "yPos",
- "type": "attribute",
- "label": "yPos",
- "color": "#4caf50",
- "settings": {},
- "_hash": 0.9964038554348893
- }
- ],
- "entityAliasId": "806e675c-1ae7-e8f2-740e-6ffdbc94a806"
- }
- ],
- "timewindow": {
- "realtime": {
- "timewindowMs": 60000
- }
- },
- "showTitle": true,
- "backgroundColor": "#fff",
- "color": "rgba(255, 254, 254, 0.87)",
- "padding": "8px",
- "settings": {
- "showLabel": true,
- "label": "${entityName}",
- "tooltipPattern": "${entityName} X Pos: ${xPos:2}Y Pos: ${yPos:2} ",
- "markerImageSize": 34,
- "useColorFunction": true,
- "markerImages": [
- "",
- "",
- "",
- ""
- ],
- "useMarkerImageFunction": true,
- "colorFunction": "var type = dsData[dsIndex]['type'];\nif (type == 'colorpin') {\n\tvar temperature = dsData[dsIndex]['temperature'];\n\tif (typeof temperature !== undefined) {\n\t var percent = (temperature + 60)/120 * 100;\n\t return tinycolor.mix('blue', 'red', amount = percent).toHexString();\n\t}\n\treturn 'blue';\n}\n",
- "markerImageFunction": "var type = dsData[dsIndex]['type'];\nif (type == 'thermomether') {\n\tvar res = {\n\t url: images[0],\n\t size: 40\n\t}\n\tvar temperature = dsData[dsIndex]['temperature'];\n\tif (typeof temperature !== undefined) {\n\t var percent = (temperature + 60)/120;\n\t var index = Math.floor(4 * percent);\n\t res.url = images[index];\n\t}\n\treturn res;\n}",
- "color": "#fe7569",
- "mapImageUrl": "",
- "xPosKeyName": "xPos",
- "yPosKeyName": "yPos",
- "posFunction": "return {x: origXPos, y: origYPos};",
- "markerOffsetX": 0.5,
- "markerOffsetY": 1
- },
- "title": "Field Sensors Map",
- "dropShadow": true,
- "enableFullscreen": true,
- "titleStyle": {
- "fontSize": "16px",
- "fontWeight": 400,
- "color": "rgba(1, 1, 1, 0.87)"
- },
- "useDashboardTimewindow": true,
- "showLegend": false,
- "widgetStyle": {},
- "actions": {
- "markerClick": [
- {
- "id": "83f2d975-ef79-67ae-d542-74559ed425f2",
- "name": "Select Sensor",
- "icon": "more_horiz",
- "type": "updateDashboardState",
- "targetDashboardStateId": null,
- "setEntityId": true,
- "stateEntityParamName": "selected_sensor"
- }
- ]
- }
- },
- "id": "1fca566e-5e28-7002-d73d-a43b04ed12df"
- },
- "d26e4cd6-cdf1-3219-dd02-f29397720970": {
- "isSystemType": true,
- "bundleAlias": "cards",
- "typeAlias": "entities_table",
- "type": "latest",
- "title": "New widget",
- "sizeX": 12,
- "sizeY": 6,
- "config": {
- "timewindow": {
- "realtime": {
- "interval": 1000,
- "timewindowMs": 86400000
- },
- "aggregation": {
- "type": "NONE",
- "limit": 200
- }
- },
- "showTitle": true,
- "backgroundColor": "rgb(255, 255, 255)",
- "color": "rgba(0, 0, 0, 0.87)",
- "padding": "4px",
- "settings": {
- "enableSearch": true,
- "displayPagination": true,
- "defaultPageSize": 10,
- "defaultSortOrder": "entityName",
- "displayEntityName": true,
- "displayEntityType": false,
- "entitiesTitle": "Moisture Sensors",
- "entityNameColumnTitle": "Sensor"
- },
- "title": "Moisture sensors",
- "dropShadow": true,
- "enableFullscreen": true,
- "titleStyle": {
- "fontSize": "18px",
- "fontWeight": 400,
- "padding": "5px 10px 5px 10px"
- },
- "useDashboardTimewindow": false,
- "showLegend": false,
- "datasources": [
- {
- "type": "entity",
- "dataKeys": [
- {
- "name": "moisture",
- "type": "timeseries",
- "label": "Moisture",
- "color": "#2196f3",
- "settings": {
- "columnWidth": "0px",
- "useCellStyleFunction": false,
- "useCellContentFunction": false
- },
- "_hash": 0.47716227517316945
- }
- ],
- "entityAliasId": "806e675c-1ae7-e8f2-740e-6ffdbc94a806"
- }
- ],
- "widgetStyle": {},
- "actions": {
- "rowClick": [
- {
- "id": "f10c3647-241e-f422-36c4-47103beb5d19",
- "name": "Select Sensor",
- "icon": "more_horiz",
- "type": "updateDashboardState",
- "targetDashboardStateId": null,
- "setEntityId": true,
- "stateEntityParamName": "selected_sensor"
- }
- ]
- }
- },
- "id": "d26e4cd6-cdf1-3219-dd02-f29397720970"
- },
- "ca3f8272-fefd-e314-b114-83c2029f481b": {
- "isSystemType": true,
- "bundleAlias": "alarm_widgets",
- "typeAlias": "alarms_table",
- "type": "alarm",
- "title": "New widget",
- "sizeX": 12,
- "sizeY": 6,
- "config": {
- "timewindow": {
- "realtime": {
- "interval": 1000,
- "timewindowMs": 86400000
- },
- "aggregation": {
- "type": "NONE",
- "limit": 200
- }
- },
- "showTitle": true,
- "backgroundColor": "rgb(255, 255, 255)",
- "color": "rgba(0, 0, 0, 0.87)",
- "padding": "4px",
- "settings": {
- "enableSelection": true,
- "enableSearch": true,
- "displayDetails": true,
- "allowAcknowledgment": true,
- "allowClear": true,
- "displayPagination": true,
- "defaultPageSize": 10,
- "defaultSortOrder": "-createdTime",
- "alarmsTitle": "Alarms: ${entityName}"
- },
- "title": "New Alarms table",
- "dropShadow": true,
- "enableFullscreen": true,
- "titleStyle": {
- "fontSize": "18px",
- "fontWeight": 400,
- "padding": "5px 10px 5px 10px"
- },
- "useDashboardTimewindow": false,
- "showLegend": false,
- "alarmSource": {
- "type": "entity",
- "dataKeys": [
- {
- "name": "createdTime",
- "type": "alarm",
- "label": "Created time",
- "color": "#2196f3",
- "settings": {},
- "_hash": 0.6244551770744973
- },
- {
- "name": "originator",
- "type": "alarm",
- "label": "Originator",
- "color": "#4caf50",
- "settings": {},
- "_hash": 0.7471580233279045
- },
- {
- "name": "type",
- "type": "alarm",
- "label": "Type",
- "color": "#f44336",
- "settings": {},
- "_hash": 0.9328521123794775
- },
- {
- "name": "severity",
- "type": "alarm",
- "label": "Severity",
- "color": "#ffc107",
- "settings": {},
- "_hash": 0.6981735799340436
- },
- {
- "name": "status",
- "type": "alarm",
- "label": "Status",
- "color": "#607d8b",
- "settings": {},
- "_hash": 0.49709924785966786
- }
- ],
- "entityAliasId": "f7aa34e4-d5cf-4b20-e71f-522d8feeb661",
- "name": "alarms"
- },
- "alarmSearchStatus": "ANY",
- "alarmsPollingInterval": 5,
- "datasources": [],
- "widgetStyle": {},
- "actions": {}
- },
- "id": "ca3f8272-fefd-e314-b114-83c2029f481b"
- },
- "3f0eb154-cb83-a31d-65dc-333bf9a51ea1": {
- "isSystemType": true,
- "bundleAlias": "charts",
- "typeAlias": "basic_timeseries",
- "type": "timeseries",
- "title": "New widget",
- "sizeX": 12,
- "sizeY": 6,
- "config": {
- "datasources": [
- {
- "type": "entity",
- "dataKeys": [
- {
- "name": "moisture",
- "type": "timeseries",
- "label": "${entityName}: moisture",
- "color": "#2196f3",
- "settings": {
- "showLines": true,
- "fillLines": false,
- "showPoints": false,
- "showSeparateAxis": false,
- "axisTickDecimals": 0,
- "axisPosition": "left"
- },
- "_hash": 0.3426935845498511
- }
- ],
- "entityAliasId": "806e675c-1ae7-e8f2-740e-6ffdbc94a806"
- }
- ],
- "timewindow": {
- "realtime": {
- "timewindowMs": 60000
- }
- },
- "showTitle": true,
- "backgroundColor": "#fff",
- "color": "rgba(0, 0, 0, 0.87)",
- "padding": "8px",
- "settings": {
- "shadowSize": 4,
- "fontColor": "#545454",
- "fontSize": 10,
- "xaxis": {
- "showLabels": true,
- "color": "#545454"
- },
- "yaxis": {
- "showLabels": true,
- "color": "#545454"
- },
- "grid": {
- "color": "#545454",
- "tickColor": "#DDDDDD",
- "verticalLines": true,
- "horizontalLines": true,
- "outlineWidth": 1
- },
- "stack": false,
- "tooltipIndividual": false
- },
- "title": "Soil moisture history",
- "dropShadow": true,
- "enableFullscreen": true,
- "titleStyle": {
- "fontSize": "16px",
- "fontWeight": 400
- },
- "mobileHeight": null,
- "widgetStyle": {},
- "useDashboardTimewindow": true,
- "showLegend": true,
- "actions": {}
- },
- "id": "3f0eb154-cb83-a31d-65dc-333bf9a51ea1"
- }
- },
- "states": {
- "default": {
- "name": "Region",
- "root": true,
- "layouts": {
- "main": {
- "widgets": {
- "864ae6da-a436-9482-360b-148df93f7cc1": {
- "sizeX": 13,
- "sizeY": 6,
- "row": 0,
- "col": 0
- },
- "2faca02d-30d4-6069-6aef-18b44506e72d": {
- "sizeX": 11,
- "sizeY": 6,
- "row": 0,
- "col": 13
- },
- "d489fb00-82a2-d0d2-9cb3-c417bdaabe66": {
- "sizeX": 24,
- "sizeY": 6,
- "row": 6,
- "col": 0
- }
- },
- "gridSettings": {
- "backgroundColor": "#eeeeee",
- "color": "rgba(0,0,0,0.870588)",
- "columns": 24,
- "margins": [
- 10,
- 10
- ],
- "backgroundSizeMode": "100%"
- }
- }
- }
- },
- "field": {
- "name": "${entityName}",
- "root": false,
- "layouts": {
- "main": {
- "widgets": {
- "1fca566e-5e28-7002-d73d-a43b04ed12df": {
- "sizeX": 12,
- "sizeY": 6,
- "row": 0,
- "col": 0
- },
- "d26e4cd6-cdf1-3219-dd02-f29397720970": {
- "sizeX": 12,
- "sizeY": 6,
- "row": 0,
- "col": 12
- },
- "ca3f8272-fefd-e314-b114-83c2029f481b": {
- "sizeX": 12,
- "sizeY": 6,
- "row": 6,
- "col": 0
- },
- "3f0eb154-cb83-a31d-65dc-333bf9a51ea1": {
- "sizeX": 12,
- "sizeY": 6,
- "mobileHeight": null,
- "row": 6,
- "col": 12
- }
- },
- "gridSettings": {
- "backgroundColor": "#eeeeee",
- "color": "rgba(0,0,0,0.870588)",
- "columns": 24,
- "margins": [
- 10,
- 10
- ],
- "backgroundSizeMode": "100%"
- }
- }
- }
- }
- },
- "entityAliases": {
- "24cec249-9954-d166-ed17-f74af5d7a94f": {
- "id": "24cec249-9954-d166-ed17-f74af5d7a94f",
- "alias": "Fields",
- "filter": {
- "type": "assetSearchQuery",
- "resolveMultiple": true,
- "rootStateEntity": false,
- "stateEntityParamName": null,
- "defaultStateEntity": null,
- "rootEntity": {
- "entityType": "ASSET",
- "id": "adc7a2c0-8419-11e7-b56d-c7f326cba909"
- },
- "direction": "FROM",
- "maxLevel": 1,
- "relationType": "Contains",
- "assetTypes": [
- "field"
- ]
- }
- },
- "360b0e25-1659-75d6-1cb8-70afaef2a7ea": {
- "id": "360b0e25-1659-75d6-1cb8-70afaef2a7ea",
- "alias": "Selected field",
- "filter": {
- "type": "stateEntity",
- "resolveMultiple": false,
- "stateEntityParamName": "selected_field",
- "defaultStateEntity": {
- "entityType": "ASSET",
- "id": "adc7a2c0-8419-11e7-b56d-c7f326cba909"
- }
- }
- },
- "806e675c-1ae7-e8f2-740e-6ffdbc94a806": {
- "id": "806e675c-1ae7-e8f2-740e-6ffdbc94a806",
- "alias": "Field sensors",
- "filter": {
- "type": "deviceSearchQuery",
- "resolveMultiple": true,
- "rootStateEntity": true,
- "stateEntityParamName": null,
- "defaultStateEntity": null,
- "rootEntity": null,
- "direction": "FROM",
- "maxLevel": 1,
- "relationType": "Contains",
- "deviceTypes": [
- "moisture-temperature"
- ]
- }
- },
- "f7aa34e4-d5cf-4b20-e71f-522d8feeb661": {
- "id": "f7aa34e4-d5cf-4b20-e71f-522d8feeb661",
- "alias": "Selected sensor",
- "filter": {
- "type": "stateEntity",
- "resolveMultiple": false,
- "stateEntityParamName": "selected_sensor",
- "defaultStateEntity": {
- "entityType": "ASSET",
- "id": "adc7a2c0-8419-11e7-b56d-c7f326cba909"
- }
- }
- }
- },
- "timewindow": {
- "realtime": {
- "interval": 300000,
- "timewindowMs": 3600000
- },
- "aggregation": {
- "type": "AVG",
- "limit": 200
- }
- },
- "settings": {
- "stateControllerId": "entity",
- "showTitle": false,
- "showDashboardsSelect": true,
- "showEntitiesSelect": true,
- "showDashboardTimewindow": true,
- "showDashboardExport": true,
- "toolbarAlwaysOpen": true
- }
- },
- "name": "Region"
-}
diff --git a/docs/user-guide/attributes.md b/docs/user-guide/attributes.md
index 3a5ca049b2..1ab91c1cd0 100644
--- a/docs/user-guide/attributes.md
+++ b/docs/user-guide/attributes.md
@@ -4,27 +4,6 @@ assignees:
- ashvayka
title: Working with IoT device attributes
description: IoT device management using ThingsBoard attributes feature
-server-side-attrs-ui:
- 0:
- image: /images/user-guide/attributes/add-server-side-ce-src.png
- title: 'Go to Entities → Devices and open the device you want to edit by clicking its row. In the device details, open the "Attributes" tab, select the "Server attributes" scope, and click the "+" icon to add a new attribute.'
- 1:
- image: /images/user-guide/attributes/add-server-side-ce2-src.png
- title: 'In the dialog, enter the attribute key, select the value type (for example, String), and provide a value.'
- 2:
- image: /images/user-guide/attributes/add-server-side-ce3-src.png
- title: 'After saving, the new attribute appears in the list with its key, value, and last update time. Sort using "Last update time" to quickly locate the newly created attribute.'
-
-shared-attrs-ui:
- 0:
- image: /images/user-guide/attributes/add-shared-ce-src.png
- title: 'Go to Entities → Devices and open the device you want to edit by clicking its row. In the device details, open the "Attributes" tab, select the "Shared attributes" scope, and click the "+" icon to add a new attribute.'
- 1:
- image: /images/user-guide/attributes/add-shared-ce2-src.png
- title: 'In the dialog, enter the attribute key, select the value type (for example, Double), and provide a value.'
- 2:
- image: /images/user-guide/attributes/add-shared-ce3-src.png
- title: 'After saving, the new attribute appears in the list with its key, value, and last update time.'
---
diff --git a/docs/user-guide/entities-and-relations.md b/docs/user-guide/entities-and-relations.md
index 5537116ad4..5e391c84a0 100644
--- a/docs/user-guide/entities-and-relations.md
+++ b/docs/user-guide/entities-and-relations.md
@@ -2,8 +2,8 @@
layout: docwithnav
assignees:
- ashvayka
-title: Entities and relations
-description: IoT asset management using ThingsBoard entities and relations feature
+title: Key Concepts and Architecture
+description: IoT asset management using ThingsBoard entities and components
---
diff --git a/docs/user-guide/resources/region_fields_dashboard.json b/docs/user-guide/resources/region_fields_dashboard.json
deleted file mode 100644
index a1a5ffe1e8..0000000000
--- a/docs/user-guide/resources/region_fields_dashboard.json
+++ /dev/null
@@ -1,820 +0,0 @@
-{
- "title": "Region",
- "configuration": {
- "widgets": {
- "864ae6da-a436-9482-360b-148df93f7cc1": {
- "isSystemType": true,
- "bundleAlias": "maps_v2",
- "typeAlias": "image_map",
- "type": "latest",
- "title": "New widget",
- "sizeX": 13,
- "sizeY": 6,
- "config": {
- "datasources": [
- {
- "type": "entity",
- "dataKeys": [
- {
- "name": "xPos",
- "type": "attribute",
- "label": "xPos",
- "color": "#2196f3",
- "settings": {},
- "_hash": 0.9516904367739742
- },
- {
- "name": "yPos",
- "type": "attribute",
- "label": "yPos",
- "color": "#4caf50",
- "settings": {},
- "_hash": 0.943977233636577
- }
- ],
- "entityAliasId": "24cec249-9954-d166-ed17-f74af5d7a94f"
- }
- ],
- "timewindow": {
- "realtime": {
- "timewindowMs": 60000
- }
- },
- "showTitle": true,
- "backgroundColor": "#fff",
- "color": "rgba(255, 254, 254, 0.87)",
- "padding": "8px",
- "settings": {
- "showLabel": true,
- "label": "${entityName}",
- "tooltipPattern": "${entityName} X Pos: ${xPos:2}Y Pos: ${yPos:2}Field details ",
- "markerImageSize": 34,
- "useColorFunction": true,
- "markerImages": [
- "",
- "",
- "",
- ""
- ],
- "useMarkerImageFunction": true,
- "colorFunction": "var type = dsData[dsIndex]['type'];\nif (type == 'colorpin') {\n\tvar temperature = dsData[dsIndex]['temperature'];\n\tif (typeof temperature !== undefined) {\n\t var percent = (temperature + 60)/120 * 100;\n\t return tinycolor.mix('blue', 'red', amount = percent).toHexString();\n\t}\n\treturn 'blue';\n}\n",
- "markerImageFunction": "var type = dsData[dsIndex]['type'];\nif (type == 'thermomether') {\n\tvar res = {\n\t url: images[0],\n\t size: 40\n\t}\n\tvar temperature = dsData[dsIndex]['temperature'];\n\tif (typeof temperature !== undefined) {\n\t var percent = (temperature + 60)/120;\n\t var index = Math.floor(4 * percent);\n\t res.url = images[index];\n\t}\n\treturn res;\n}",
- "color": "#fe7569",
- "mapImageUrl": "",
- "xPosKeyName": "xPos",
- "yPosKeyName": "yPos",
- "posFunction": "return {x: origXPos, y: origYPos};",
- "markerOffsetX": 0.5,
- "markerOffsetY": 1
- },
- "title": "Fields Map",
- "dropShadow": true,
- "enableFullscreen": true,
- "titleStyle": {
- "fontSize": "16px",
- "fontWeight": 400,
- "color": "rgba(1, 1, 1, 0.87)"
- },
- "useDashboardTimewindow": true,
- "showLegend": false,
- "widgetStyle": {},
- "actions": {
- "markerClick": [
- {
- "id": "7dd0b13e-a079-f10b-18c3-ce2faeedca13",
- "name": "Select Field",
- "icon": "more_horiz",
- "type": "updateDashboardState",
- "targetDashboardStateId": null,
- "setEntityId": true,
- "stateEntityParamName": "selected_field"
- }
- ],
- "tooltipAction": [
- {
- "id": "a88b913d-5f5e-18d3-967f-35c70d49e830",
- "name": "Open Field Details",
- "icon": "more_horiz",
- "type": "openDashboardState",
- "targetDashboardStateId": "field",
- "setEntityId": true
- }
- ]
- }
- },
- "id": "864ae6da-a436-9482-360b-148df93f7cc1"
- },
- "2faca02d-30d4-6069-6aef-18b44506e72d": {
- "isSystemType": true,
- "bundleAlias": "cards",
- "typeAlias": "entities_table",
- "type": "latest",
- "title": "New widget",
- "sizeX": 11,
- "sizeY": 6,
- "config": {
- "timewindow": {
- "realtime": {
- "interval": 1000,
- "timewindowMs": 86400000
- },
- "aggregation": {
- "type": "NONE",
- "limit": 200
- }
- },
- "showTitle": true,
- "backgroundColor": "rgb(255, 255, 255)",
- "color": "rgba(0, 0, 0, 0.87)",
- "padding": "4px",
- "settings": {
- "enableSearch": true,
- "displayPagination": true,
- "defaultPageSize": 10,
- "defaultSortOrder": "entityName",
- "displayEntityName": true,
- "displayEntityType": false,
- "entitiesTitle": "Fields",
- "entityNameColumnTitle": "Field"
- },
- "title": "Fields",
- "dropShadow": true,
- "enableFullscreen": true,
- "titleStyle": {
- "fontSize": "18px",
- "fontWeight": 400,
- "padding": "5px 10px 5px 10px"
- },
- "useDashboardTimewindow": false,
- "showLegend": false,
- "datasources": [
- {
- "type": "entity",
- "dataKeys": [
- {
- "name": "waterSpent",
- "type": "attribute",
- "label": "Water spent",
- "color": "#2196f3",
- "settings": {
- "columnWidth": "0px",
- "useCellStyleFunction": false,
- "useCellContentFunction": true,
- "cellContentFunction": "return value + ' gal';"
- },
- "_hash": 0.31847158456654756
- }
- ],
- "entityAliasId": "24cec249-9954-d166-ed17-f74af5d7a94f"
- }
- ],
- "widgetStyle": {},
- "actions": {
- "actionCellButton": [
- {
- "id": "e81a6784-c8cc-1c6a-1e93-aeef3bb901a0",
- "name": "Open Field Details",
- "icon": "play_arrow",
- "type": "openDashboardState",
- "targetDashboardStateId": "field",
- "setEntityId": true
- }
- ],
- "rowClick": [
- {
- "id": "a6cce823-d1ca-4fce-002e-d8083ec342eb",
- "name": "Select Field",
- "icon": "more_horiz",
- "type": "updateDashboardState",
- "targetDashboardStateId": null,
- "setEntityId": true,
- "stateEntityParamName": "selected_field"
- }
- ]
- }
- },
- "id": "2faca02d-30d4-6069-6aef-18b44506e72d"
- },
- "d489fb00-82a2-d0d2-9cb3-c417bdaabe66": {
- "isSystemType": true,
- "bundleAlias": "alarm_widgets",
- "typeAlias": "alarms_table",
- "type": "alarm",
- "title": "New widget",
- "sizeX": 24,
- "sizeY": 6,
- "config": {
- "timewindow": {
- "realtime": {
- "interval": 1000,
- "timewindowMs": 86400000
- },
- "aggregation": {
- "type": "NONE",
- "limit": 200
- }
- },
- "showTitle": true,
- "backgroundColor": "rgb(255, 255, 255)",
- "color": "rgba(0, 0, 0, 0.87)",
- "padding": "4px",
- "settings": {
- "enableSelection": true,
- "enableSearch": true,
- "displayDetails": true,
- "allowAcknowledgment": true,
- "allowClear": true,
- "displayPagination": true,
- "defaultPageSize": 10,
- "defaultSortOrder": "-createdTime",
- "alarmsTitle": "Alarms: ${entityName}"
- },
- "title": "New Alarms table",
- "dropShadow": true,
- "enableFullscreen": true,
- "titleStyle": {
- "fontSize": "18px",
- "fontWeight": 400,
- "padding": "5px 10px 5px 10px"
- },
- "useDashboardTimewindow": false,
- "showLegend": false,
- "alarmSource": {
- "type": "entity",
- "dataKeys": [
- {
- "name": "createdTime",
- "type": "alarm",
- "label": "Created time",
- "color": "#2196f3",
- "settings": {},
- "_hash": 0.6244551770744973
- },
- {
- "name": "originator",
- "type": "alarm",
- "label": "Originator",
- "color": "#4caf50",
- "settings": {},
- "_hash": 0.7471580233279045
- },
- {
- "name": "type",
- "type": "alarm",
- "label": "Type",
- "color": "#f44336",
- "settings": {},
- "_hash": 0.9328521123794775
- },
- {
- "name": "severity",
- "type": "alarm",
- "label": "Severity",
- "color": "#ffc107",
- "settings": {},
- "_hash": 0.6981735799340436
- },
- {
- "name": "status",
- "type": "alarm",
- "label": "Status",
- "color": "#607d8b",
- "settings": {},
- "_hash": 0.49709924785966786
- }
- ],
- "entityAliasId": "360b0e25-1659-75d6-1cb8-70afaef2a7ea",
- "name": "alarms"
- },
- "alarmSearchStatus": "ANY",
- "alarmsPollingInterval": 5,
- "datasources": [],
- "widgetStyle": {},
- "actions": {}
- },
- "id": "d489fb00-82a2-d0d2-9cb3-c417bdaabe66"
- },
- "1fca566e-5e28-7002-d73d-a43b04ed12df": {
- "isSystemType": true,
- "bundleAlias": "maps_v2",
- "typeAlias": "image_map",
- "type": "latest",
- "title": "New widget",
- "sizeX": 12,
- "sizeY": 6,
- "config": {
- "datasources": [
- {
- "type": "entity",
- "dataKeys": [
- {
- "name": "xPos",
- "type": "attribute",
- "label": "xPos",
- "color": "#2196f3",
- "settings": {},
- "_hash": 0.0575757175634275
- },
- {
- "name": "yPos",
- "type": "attribute",
- "label": "yPos",
- "color": "#4caf50",
- "settings": {},
- "_hash": 0.9964038554348893
- }
- ],
- "entityAliasId": "806e675c-1ae7-e8f2-740e-6ffdbc94a806"
- }
- ],
- "timewindow": {
- "realtime": {
- "timewindowMs": 60000
- }
- },
- "showTitle": true,
- "backgroundColor": "#fff",
- "color": "rgba(255, 254, 254, 0.87)",
- "padding": "8px",
- "settings": {
- "showLabel": true,
- "label": "${entityName}",
- "tooltipPattern": "${entityName} X Pos: ${xPos:2}Y Pos: ${yPos:2} ",
- "markerImageSize": 34,
- "useColorFunction": true,
- "markerImages": [
- "",
- "",
- "",
- ""
- ],
- "useMarkerImageFunction": true,
- "colorFunction": "var type = dsData[dsIndex]['type'];\nif (type == 'colorpin') {\n\tvar temperature = dsData[dsIndex]['temperature'];\n\tif (typeof temperature !== undefined) {\n\t var percent = (temperature + 60)/120 * 100;\n\t return tinycolor.mix('blue', 'red', amount = percent).toHexString();\n\t}\n\treturn 'blue';\n}\n",
- "markerImageFunction": "var type = dsData[dsIndex]['type'];\nif (type == 'thermomether') {\n\tvar res = {\n\t url: images[0],\n\t size: 40\n\t}\n\tvar temperature = dsData[dsIndex]['temperature'];\n\tif (typeof temperature !== undefined) {\n\t var percent = (temperature + 60)/120;\n\t var index = Math.floor(4 * percent);\n\t res.url = images[index];\n\t}\n\treturn res;\n}",
- "color": "#fe7569",
- "mapImageUrl": "",
- "xPosKeyName": "xPos",
- "yPosKeyName": "yPos",
- "posFunction": "return {x: origXPos, y: origYPos};",
- "markerOffsetX": 0.5,
- "markerOffsetY": 1
- },
- "title": "Field Sensors Map",
- "dropShadow": true,
- "enableFullscreen": true,
- "titleStyle": {
- "fontSize": "16px",
- "fontWeight": 400,
- "color": "rgba(1, 1, 1, 0.87)"
- },
- "useDashboardTimewindow": true,
- "showLegend": false,
- "widgetStyle": {},
- "actions": {
- "markerClick": [
- {
- "id": "83f2d975-ef79-67ae-d542-74559ed425f2",
- "name": "Select Sensor",
- "icon": "more_horiz",
- "type": "updateDashboardState",
- "targetDashboardStateId": null,
- "setEntityId": true,
- "stateEntityParamName": "selected_sensor"
- }
- ]
- }
- },
- "id": "1fca566e-5e28-7002-d73d-a43b04ed12df"
- },
- "d26e4cd6-cdf1-3219-dd02-f29397720970": {
- "isSystemType": true,
- "bundleAlias": "cards",
- "typeAlias": "entities_table",
- "type": "latest",
- "title": "New widget",
- "sizeX": 12,
- "sizeY": 6,
- "config": {
- "timewindow": {
- "realtime": {
- "interval": 1000,
- "timewindowMs": 86400000
- },
- "aggregation": {
- "type": "NONE",
- "limit": 200
- }
- },
- "showTitle": true,
- "backgroundColor": "rgb(255, 255, 255)",
- "color": "rgba(0, 0, 0, 0.87)",
- "padding": "4px",
- "settings": {
- "enableSearch": true,
- "displayPagination": true,
- "defaultPageSize": 10,
- "defaultSortOrder": "entityName",
- "displayEntityName": true,
- "displayEntityType": false,
- "entitiesTitle": "Moisture Sensors",
- "entityNameColumnTitle": "Sensor"
- },
- "title": "Moisture sensors",
- "dropShadow": true,
- "enableFullscreen": true,
- "titleStyle": {
- "fontSize": "18px",
- "fontWeight": 400,
- "padding": "5px 10px 5px 10px"
- },
- "useDashboardTimewindow": false,
- "showLegend": false,
- "datasources": [
- {
- "type": "entity",
- "dataKeys": [
- {
- "name": "moisture",
- "type": "timeseries",
- "label": "Moisture",
- "color": "#2196f3",
- "settings": {
- "columnWidth": "0px",
- "useCellStyleFunction": false,
- "useCellContentFunction": false
- },
- "_hash": 0.47716227517316945
- }
- ],
- "entityAliasId": "806e675c-1ae7-e8f2-740e-6ffdbc94a806"
- }
- ],
- "widgetStyle": {},
- "actions": {
- "rowClick": [
- {
- "id": "f10c3647-241e-f422-36c4-47103beb5d19",
- "name": "Select Sensor",
- "icon": "more_horiz",
- "type": "updateDashboardState",
- "targetDashboardStateId": null,
- "setEntityId": true,
- "stateEntityParamName": "selected_sensor"
- }
- ]
- }
- },
- "id": "d26e4cd6-cdf1-3219-dd02-f29397720970"
- },
- "ca3f8272-fefd-e314-b114-83c2029f481b": {
- "isSystemType": true,
- "bundleAlias": "alarm_widgets",
- "typeAlias": "alarms_table",
- "type": "alarm",
- "title": "New widget",
- "sizeX": 12,
- "sizeY": 6,
- "config": {
- "timewindow": {
- "realtime": {
- "interval": 1000,
- "timewindowMs": 86400000
- },
- "aggregation": {
- "type": "NONE",
- "limit": 200
- }
- },
- "showTitle": true,
- "backgroundColor": "rgb(255, 255, 255)",
- "color": "rgba(0, 0, 0, 0.87)",
- "padding": "4px",
- "settings": {
- "enableSelection": true,
- "enableSearch": true,
- "displayDetails": true,
- "allowAcknowledgment": true,
- "allowClear": true,
- "displayPagination": true,
- "defaultPageSize": 10,
- "defaultSortOrder": "-createdTime",
- "alarmsTitle": "Alarms: ${entityName}"
- },
- "title": "New Alarms table",
- "dropShadow": true,
- "enableFullscreen": true,
- "titleStyle": {
- "fontSize": "18px",
- "fontWeight": 400,
- "padding": "5px 10px 5px 10px"
- },
- "useDashboardTimewindow": false,
- "showLegend": false,
- "alarmSource": {
- "type": "entity",
- "dataKeys": [
- {
- "name": "createdTime",
- "type": "alarm",
- "label": "Created time",
- "color": "#2196f3",
- "settings": {},
- "_hash": 0.6244551770744973
- },
- {
- "name": "originator",
- "type": "alarm",
- "label": "Originator",
- "color": "#4caf50",
- "settings": {},
- "_hash": 0.7471580233279045
- },
- {
- "name": "type",
- "type": "alarm",
- "label": "Type",
- "color": "#f44336",
- "settings": {},
- "_hash": 0.9328521123794775
- },
- {
- "name": "severity",
- "type": "alarm",
- "label": "Severity",
- "color": "#ffc107",
- "settings": {},
- "_hash": 0.6981735799340436
- },
- {
- "name": "status",
- "type": "alarm",
- "label": "Status",
- "color": "#607d8b",
- "settings": {},
- "_hash": 0.49709924785966786
- }
- ],
- "entityAliasId": "f7aa34e4-d5cf-4b20-e71f-522d8feeb661",
- "name": "alarms"
- },
- "alarmSearchStatus": "ANY",
- "alarmsPollingInterval": 5,
- "datasources": [],
- "widgetStyle": {},
- "actions": {}
- },
- "id": "ca3f8272-fefd-e314-b114-83c2029f481b"
- },
- "3f0eb154-cb83-a31d-65dc-333bf9a51ea1": {
- "isSystemType": true,
- "bundleAlias": "charts",
- "typeAlias": "basic_timeseries",
- "type": "timeseries",
- "title": "New widget",
- "sizeX": 12,
- "sizeY": 6,
- "config": {
- "datasources": [
- {
- "type": "entity",
- "dataKeys": [
- {
- "name": "moisture",
- "type": "timeseries",
- "label": "${entityName}: moisture",
- "color": "#2196f3",
- "settings": {
- "showLines": true,
- "fillLines": false,
- "showPoints": false,
- "showSeparateAxis": false,
- "axisTickDecimals": 0,
- "axisPosition": "left"
- },
- "_hash": 0.3426935845498511
- }
- ],
- "entityAliasId": "806e675c-1ae7-e8f2-740e-6ffdbc94a806"
- }
- ],
- "timewindow": {
- "realtime": {
- "timewindowMs": 60000
- }
- },
- "showTitle": true,
- "backgroundColor": "#fff",
- "color": "rgba(0, 0, 0, 0.87)",
- "padding": "8px",
- "settings": {
- "shadowSize": 4,
- "fontColor": "#545454",
- "fontSize": 10,
- "xaxis": {
- "showLabels": true,
- "color": "#545454"
- },
- "yaxis": {
- "showLabels": true,
- "color": "#545454"
- },
- "grid": {
- "color": "#545454",
- "tickColor": "#DDDDDD",
- "verticalLines": true,
- "horizontalLines": true,
- "outlineWidth": 1
- },
- "stack": false,
- "tooltipIndividual": false
- },
- "title": "Soil moisture history",
- "dropShadow": true,
- "enableFullscreen": true,
- "titleStyle": {
- "fontSize": "16px",
- "fontWeight": 400
- },
- "mobileHeight": null,
- "widgetStyle": {},
- "useDashboardTimewindow": true,
- "showLegend": true,
- "actions": {}
- },
- "id": "3f0eb154-cb83-a31d-65dc-333bf9a51ea1"
- }
- },
- "states": {
- "default": {
- "name": "Region",
- "root": true,
- "layouts": {
- "main": {
- "widgets": {
- "864ae6da-a436-9482-360b-148df93f7cc1": {
- "sizeX": 13,
- "sizeY": 6,
- "row": 0,
- "col": 0
- },
- "2faca02d-30d4-6069-6aef-18b44506e72d": {
- "sizeX": 11,
- "sizeY": 6,
- "row": 0,
- "col": 13
- },
- "d489fb00-82a2-d0d2-9cb3-c417bdaabe66": {
- "sizeX": 24,
- "sizeY": 6,
- "row": 6,
- "col": 0
- }
- },
- "gridSettings": {
- "backgroundColor": "#eeeeee",
- "color": "rgba(0,0,0,0.870588)",
- "columns": 24,
- "margins": [
- 10,
- 10
- ],
- "backgroundSizeMode": "100%"
- }
- }
- }
- },
- "field": {
- "name": "${entityName}",
- "root": false,
- "layouts": {
- "main": {
- "widgets": {
- "1fca566e-5e28-7002-d73d-a43b04ed12df": {
- "sizeX": 12,
- "sizeY": 6,
- "row": 0,
- "col": 0
- },
- "d26e4cd6-cdf1-3219-dd02-f29397720970": {
- "sizeX": 12,
- "sizeY": 6,
- "row": 0,
- "col": 12
- },
- "ca3f8272-fefd-e314-b114-83c2029f481b": {
- "sizeX": 12,
- "sizeY": 6,
- "row": 6,
- "col": 0
- },
- "3f0eb154-cb83-a31d-65dc-333bf9a51ea1": {
- "sizeX": 12,
- "sizeY": 6,
- "mobileHeight": null,
- "row": 6,
- "col": 12
- }
- },
- "gridSettings": {
- "backgroundColor": "#eeeeee",
- "color": "rgba(0,0,0,0.870588)",
- "columns": 24,
- "margins": [
- 10,
- 10
- ],
- "backgroundSizeMode": "100%"
- }
- }
- }
- }
- },
- "entityAliases": {
- "24cec249-9954-d166-ed17-f74af5d7a94f": {
- "id": "24cec249-9954-d166-ed17-f74af5d7a94f",
- "alias": "Fields",
- "filter": {
- "type": "assetSearchQuery",
- "resolveMultiple": true,
- "rootStateEntity": false,
- "stateEntityParamName": null,
- "defaultStateEntity": null,
- "rootEntity": {
- "entityType": "ASSET",
- "id": "adc7a2c0-8419-11e7-b56d-c7f326cba909"
- },
- "direction": "FROM",
- "maxLevel": 1,
- "relationType": "Contains",
- "assetTypes": [
- "field"
- ]
- }
- },
- "360b0e25-1659-75d6-1cb8-70afaef2a7ea": {
- "id": "360b0e25-1659-75d6-1cb8-70afaef2a7ea",
- "alias": "Selected field",
- "filter": {
- "type": "stateEntity",
- "resolveMultiple": false,
- "stateEntityParamName": "selected_field",
- "defaultStateEntity": {
- "entityType": "ASSET",
- "id": "adc7a2c0-8419-11e7-b56d-c7f326cba909"
- }
- }
- },
- "806e675c-1ae7-e8f2-740e-6ffdbc94a806": {
- "id": "806e675c-1ae7-e8f2-740e-6ffdbc94a806",
- "alias": "Field sensors",
- "filter": {
- "type": "deviceSearchQuery",
- "resolveMultiple": true,
- "rootStateEntity": true,
- "stateEntityParamName": null,
- "defaultStateEntity": null,
- "rootEntity": null,
- "direction": "FROM",
- "maxLevel": 1,
- "relationType": "Contains",
- "deviceTypes": [
- "moisture-temperature"
- ]
- }
- },
- "f7aa34e4-d5cf-4b20-e71f-522d8feeb661": {
- "id": "f7aa34e4-d5cf-4b20-e71f-522d8feeb661",
- "alias": "Selected sensor",
- "filter": {
- "type": "stateEntity",
- "resolveMultiple": false,
- "stateEntityParamName": "selected_sensor",
- "defaultStateEntity": {
- "entityType": "ASSET",
- "id": "adc7a2c0-8419-11e7-b56d-c7f326cba909"
- }
- }
- }
- },
- "timewindow": {
- "realtime": {
- "interval": 300000,
- "timewindowMs": 3600000
- },
- "aggregation": {
- "type": "AVG",
- "limit": 200
- }
- },
- "settings": {
- "stateControllerId": "entity",
- "showTitle": false,
- "showDashboardsSelect": true,
- "showEntitiesSelect": true,
- "showDashboardTimewindow": true,
- "showDashboardExport": true,
- "toolbarAlwaysOpen": true
- }
- },
- "name": "Region"
-}
diff --git a/images/key-concepts/relations-ce.svg b/images/key-concepts/relations-ce.svg
new file mode 100644
index 0000000000..d4ab0f066f
--- /dev/null
+++ b/images/key-concepts/relations-ce.svg
@@ -0,0 +1,132 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
diff --git a/images/key-concepts/relations-pe.svg b/images/key-concepts/relations-pe.svg
new file mode 100644
index 0000000000..e854b24aae
--- /dev/null
+++ b/images/key-concepts/relations-pe.svg
@@ -0,0 +1,132 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
diff --git a/images/user-guide/attributes/add-server-side-ce-src-preview.png b/images/user-guide/attributes/add-server-side-ce-src-preview.png
deleted file mode 100644
index 09221b4ce7..0000000000
Binary files a/images/user-guide/attributes/add-server-side-ce-src-preview.png and /dev/null differ
diff --git a/images/user-guide/attributes/add-server-side-ce-src.png b/images/user-guide/attributes/add-server-side-ce-src.png
deleted file mode 100644
index beeecf77f0..0000000000
Binary files a/images/user-guide/attributes/add-server-side-ce-src.png and /dev/null differ
diff --git a/images/user-guide/attributes/add-server-side-ce2-src-preview.png b/images/user-guide/attributes/add-server-side-ce2-src-preview.png
deleted file mode 100644
index 6aa08c2ef0..0000000000
Binary files a/images/user-guide/attributes/add-server-side-ce2-src-preview.png and /dev/null differ
diff --git a/images/user-guide/attributes/add-server-side-ce2-src.png b/images/user-guide/attributes/add-server-side-ce2-src.png
deleted file mode 100644
index 8185d50057..0000000000
Binary files a/images/user-guide/attributes/add-server-side-ce2-src.png and /dev/null differ
diff --git a/images/user-guide/attributes/add-server-side-ce3-src-preview.png b/images/user-guide/attributes/add-server-side-ce3-src-preview.png
deleted file mode 100644
index 7eadff4c25..0000000000
Binary files a/images/user-guide/attributes/add-server-side-ce3-src-preview.png and /dev/null differ
diff --git a/images/user-guide/attributes/add-server-side-ce3-src.png b/images/user-guide/attributes/add-server-side-ce3-src.png
deleted file mode 100644
index 4626cdccb4..0000000000
Binary files a/images/user-guide/attributes/add-server-side-ce3-src.png and /dev/null differ
diff --git a/images/user-guide/attributes/add-server-side-pe-src-preview.png b/images/user-guide/attributes/add-server-side-pe-src-preview.png
deleted file mode 100644
index ccb8cf86be..0000000000
Binary files a/images/user-guide/attributes/add-server-side-pe-src-preview.png and /dev/null differ
diff --git a/images/user-guide/attributes/add-server-side-pe-src.png b/images/user-guide/attributes/add-server-side-pe-src.png
deleted file mode 100644
index 9b53c3bfc2..0000000000
Binary files a/images/user-guide/attributes/add-server-side-pe-src.png and /dev/null differ
diff --git a/images/user-guide/attributes/add-server-side-pe2-src-preview.png b/images/user-guide/attributes/add-server-side-pe2-src-preview.png
deleted file mode 100644
index 5a3e50f475..0000000000
Binary files a/images/user-guide/attributes/add-server-side-pe2-src-preview.png and /dev/null differ
diff --git a/images/user-guide/attributes/add-server-side-pe2-src.png b/images/user-guide/attributes/add-server-side-pe2-src.png
deleted file mode 100644
index 6be0cb3df7..0000000000
Binary files a/images/user-guide/attributes/add-server-side-pe2-src.png and /dev/null differ
diff --git a/images/user-guide/attributes/add-server-side-pe3-src-preview.png b/images/user-guide/attributes/add-server-side-pe3-src-preview.png
deleted file mode 100644
index 3774f617f2..0000000000
Binary files a/images/user-guide/attributes/add-server-side-pe3-src-preview.png and /dev/null differ
diff --git a/images/user-guide/attributes/add-server-side-pe3-src.png b/images/user-guide/attributes/add-server-side-pe3-src.png
deleted file mode 100644
index 619bd99264..0000000000
Binary files a/images/user-guide/attributes/add-server-side-pe3-src.png and /dev/null differ
diff --git a/images/user-guide/attributes/add-shared-ce-src-preview.png b/images/user-guide/attributes/add-shared-ce-src-preview.png
deleted file mode 100644
index 9efcb8a345..0000000000
Binary files a/images/user-guide/attributes/add-shared-ce-src-preview.png and /dev/null differ
diff --git a/images/user-guide/attributes/add-shared-ce-src.png b/images/user-guide/attributes/add-shared-ce-src.png
deleted file mode 100644
index e088e4f1d3..0000000000
Binary files a/images/user-guide/attributes/add-shared-ce-src.png and /dev/null differ
diff --git a/images/user-guide/attributes/add-shared-ce2-src-preview.png b/images/user-guide/attributes/add-shared-ce2-src-preview.png
deleted file mode 100644
index 026dccfb99..0000000000
Binary files a/images/user-guide/attributes/add-shared-ce2-src-preview.png and /dev/null differ
diff --git a/images/user-guide/attributes/add-shared-ce2-src.png b/images/user-guide/attributes/add-shared-ce2-src.png
deleted file mode 100644
index 6e32cfbc66..0000000000
Binary files a/images/user-guide/attributes/add-shared-ce2-src.png and /dev/null differ
diff --git a/images/user-guide/attributes/add-shared-ce3-src-preview.png b/images/user-guide/attributes/add-shared-ce3-src-preview.png
deleted file mode 100644
index 40d3d62c37..0000000000
Binary files a/images/user-guide/attributes/add-shared-ce3-src-preview.png and /dev/null differ
diff --git a/images/user-guide/attributes/add-shared-ce3-src.png b/images/user-guide/attributes/add-shared-ce3-src.png
deleted file mode 100644
index 2558559771..0000000000
Binary files a/images/user-guide/attributes/add-shared-ce3-src.png and /dev/null differ
diff --git a/images/user-guide/attributes/add-shared-pe-src-preview.png b/images/user-guide/attributes/add-shared-pe-src-preview.png
deleted file mode 100644
index 7b7c9d410d..0000000000
Binary files a/images/user-guide/attributes/add-shared-pe-src-preview.png and /dev/null differ
diff --git a/images/user-guide/attributes/add-shared-pe-src.png b/images/user-guide/attributes/add-shared-pe-src.png
deleted file mode 100644
index 35d433d24f..0000000000
Binary files a/images/user-guide/attributes/add-shared-pe-src.png and /dev/null differ
diff --git a/images/user-guide/attributes/add-shared-pe2-src-preview.png b/images/user-guide/attributes/add-shared-pe2-src-preview.png
deleted file mode 100644
index 2b2dcdb71c..0000000000
Binary files a/images/user-guide/attributes/add-shared-pe2-src-preview.png and /dev/null differ
diff --git a/images/user-guide/attributes/add-shared-pe2-src.png b/images/user-guide/attributes/add-shared-pe2-src.png
deleted file mode 100644
index ca5c2aa03a..0000000000
Binary files a/images/user-guide/attributes/add-shared-pe2-src.png and /dev/null differ
diff --git a/images/user-guide/attributes/add-shared-pe3-src-preview.png b/images/user-guide/attributes/add-shared-pe3-src-preview.png
deleted file mode 100644
index 2fb78480a9..0000000000
Binary files a/images/user-guide/attributes/add-shared-pe3-src-preview.png and /dev/null differ
diff --git a/images/user-guide/attributes/add-shared-pe3-src.png b/images/user-guide/attributes/add-shared-pe3-src.png
deleted file mode 100644
index a67ad66c7b..0000000000
Binary files a/images/user-guide/attributes/add-shared-pe3-src.png and /dev/null differ