Datapoint Objects
Datapoint objects combine value and meta data such as direction, type, and description. The data type is typically not changeable, although advanced applications and processors can support changes to the data type at runtime, subject to certain conditions.
An IAP Datapoint object has these properties:
Field Name | Type | Description | ||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|
active | Boolean | Active flag is used with overrides. A write-only property. For more information, see Working with Datapoint Values and Working with Unions. | ||||||||||
cat | string | Either “in” (input to the block) or “out” (output from the block) to indicate the datapoint's direction. An input datapoint is one that delivers a value into an application that processes the value. For example, an edge device that controls a physical light dimmer has an input datapoint through which it receives the desired dimming level. The application then drives the physical dimmer output circuitry accordingly. Most properties are implemented using input datapoints, and are used to provide input to the application's algorithm, such as calibration data or alarm threshold values. Some properties can also provide outputs from the application, such as those that report an application's version number. Properties should be seen as directionless in the general case. | ||||||||||
default | object | (Optional) Default value. If default is undefined, default is assumed to be all zeroes. Value must match type. For more information, see Working with Datapoint Values and Working with Unions. | ||||||||||
desc | string | (Optional) A description of the datapoint. | ||||||||||
name | string | (Optional) A human readable name for the datapoint. The name is absent or null if it is not supplied. The name property specifies the datapoint instance name. If the name property is not supplied, the datapoint XIF name specifies the datapoint instance name. Example block object:
| ||||||||||
monitor | String or object | monitor can be null (undefined), “0”, “none”, “slow”, “normal” or “fast”, or a Monitoring Preference Object for detailed control.
Changes to datapoint and properties initiated through IAP always yield an updated value in the feedback channel. A datapoint can also be monitored for unsolicited change, that is, for a change that is not initiated through IAP. Monitoring looks for changes that occur due to external events, such as peer-to-peer connections, or due to events occurring on the edge device, such as new physical sensor samples or alerts. Simple monitoring always updates the feedback channel object, has no throttle, threshold or change filtering, and uses the default event category “data”. Monitoring Preference ObjectWhen the monitoring engine detects a new value for a datapoint, it examines the new value and the most recently reported value for the datapoint under the rules detailed in the monitoring preference object. This evaluation may cause a report of the new value in the event channel using an Event object (see Events). Newly captured values also trigger an update of the feedback channel object that contains the corresponding datapoint, if the value changed. This can cause frequent updates of large feedback channel objects. The monitoring preferences can suppress this feedback update with the inFeedback property, described in Monitoring Preference Object. Reporting a Captured ValueWhen a captured value qualifies for reporting, the report is made through an Event object in the IAP/MQ event channel, using the sub-channel selected with the monitoring preference object’s cat property (the Event object properties are described in Events). The default for the category is “data”, and therefore the corresponding Event object is published to Three properties in the Event object are of particular interest in terms of reporting a captured value:
The topic and message properties combine to complete the path to the property that corresponds to the data reported. | ||||||||||
prio | Number | (Optional) Priority used with assignments to value. prio can be set to integer levels 1 to 17. See the value field for a description of the priority values. The prio property defaults to priority 8. prio is a write-only property. When prio is assigned at the same time as value, processing the value assignment occurs under the new prio value. For more information, see Working with Datapoint Values and Working with Unions. | ||||||||||
property | Boolean | (Optional) Set to True for property datapoints. Defaults to False if undefined. | ||||||||||
read-only | Boolean | (Optional) A read-only datapoint or property is one that may not be changed through IAP. However, an output read-only datapoint or property can change its value. Read-only input datapoints are supported but not in use except for datapoints implementing properties. Output datapoints that are implemented on remote edge devices are always considered read-only. But output datapoints that are local to an IAP application that defines them, can be written by that application, thereby providing output data to the network. Defaults to False if undefined. | ||||||||||
status | List of strings | (Optional) Datapoint status. The status property may be omitted if not supported. Otherwise, it is a list of strings, each string representing a known status. The list must not contain duplicates and cannot be assigned from a tool. Non-standard status values can be conveyed with a prefix from the edge protocol identifier and a period. For example, an “xyz” protocol processor might include an “xyz.out-of-range” status. The standard datapoint status values:
| ||||||||||
type | string | See Data Type Definitions for information on data types. Example: "SNVT_alarm2" | ||||||||||
value | Any valid JSON that matches the type. Or the string "invalid" for an invalid value. | The current value. Matches type. Datapoints support assignment of prioritized values with the value, prio, and default properties as follows:
For more information, see Working with Datapoint Values and Working with Unions. | ||||||||||
values | Object | Active priority array, read only. For more information, see Working with Datapoint Values and Working with Unions. | ||||||||||
values := { | ||||||||||||
presets Presets is available with SmartServer 2.8 and higher. | Object | (Optional) Presets map. Datapoint presets allows you to specify preset values for a datapoint. A preset is an optional string that represents a specific native value for a datapoint. The string can be up to 256 characters with allowed spaces and special characters. For example, you might define a preset named ON for an nvoLampSW datapoint (which is defined as an SNVT_switch) as 100.0. You might also define a preset named ON for an nvoHeatSetpoint datapoint (which is of type SNVT_temp_f) to be 22.0. The presets value has the same structure as the datapoint. If the value does not map to any of the presets, then no preset value is reported. For example, the nvoHeatSetpoint datapoint in the above paragraph only has 2 presets defined. The preset named ON to be 22.0 and OFF to be 80.0. The datapoint value is set to 100.0. In this case there is no corresponding preset that can be mapped to the datapoint value. The scope for the datapoint presets is per datapoint. This means that each datapoint can have different presets even though they have the same datapoints type. For example, datapoint #1 and datapoint #2 use SNVT_temp_f, where:
For more information, see Datapoint Presets. Example:
| ||||||||||
localization Localization is available with SmartServer 2.8 and higher. | Object | (Optional) The datapoint localization property contains the localization rules (value) to be used by this datapoint. It contains of the transformation maps for this datapoint. There is only one localization transformation rule specified in a value property for the datapoint. The value property may contain a transformation rule for each field, but only one rule per field. The localization value rules have the same structure as the datapoint. The scope for the datapoint localization transformation is per datapoint. This means that each datapoint can have different localization transformations even though they have the same datapoints type. localization can be null or empty. If it is not defined, there is no localization for this datapoint. For more information, see Datapoint Localization. Example:
|