udmi

UDMI / Docs / Specs / Discovery

Discovery

Discovery consists of two related processes for describing the ‘as built’ state of a system: scanning and enumeration. For devices, the overall discovery sequence describes the exact sequence of device messages employed in each case. Each process can be executed independently, or together (known as scan enumeration):

Backend services will receive a streaming set of discovery enumeration messages that follow the appropriate discovery event schema.

Sequence Diagram

The overall discovery sequence involves multiple components that work together to provide the overall flow:

(The * prefixing a *term means that this id/property is being sourced/created at that step.)

sequenceDiagram
  %%{wrap}%%
  participant Devices
  participant Spotter
  participant Agent as Agent<br/>(w/ Mapping)
  participant Pipeline
  Note over Devices, Agent: Discovery Start
  activate Agent
  Agent->>Spotter: DISCOVERY CONFIG<br/>()
  loop
    Devices-->Spotter: fieldbus
    Spotter->>Agent: DISCOVERY EVENT<br/>(*scan_id)<br/><properties: *uniqs>
  end
  Note over Agent: Provisioning<br/>& Mapping
  Agent ->> Pipeline: (config device)
  deactivate Agent
  Devices->>Pipeline: POINTSET EVENT<br/>(device_id, device_num_id, points)<br/><pointset>

Scanning

Scanning is the process of scanning a network and identifying the various entities thereof. Often (but not always), this comes along with a correlation of various address families (e.g. IPv4 address associated with a particular MAC):

Scanning results can only describe a subset of the complete picture (e.g. only the ETHMAC and IPv4 address), and it is up to the back-end systems to properly link/infer complete relationships. Some systems may only care about singular entries (e.g. just discovering what IoT devices are there, but not caring about any association).

Discovery is a process that can be explicitly requested through UDMI for on-prem devices that support the capability (e.g. an IoT Gateway), or it can be done automatically by a device itself (e.g. on a predefined interval). Depending on device capabilities and system configuration, the scanning process may also trigger discovered device enumeration.

Enumeration

Enumeration is the process for listing all the parameters available from a device (rather than just the ones in its designated reporting set). This information can either come directly from a device (self enumeration) or as the result of a discovery scan (scan enumeration). Both report the same kind of content, but the mechanism (and message source) are different: one comes from the device itself, the other by proxy.

Within an enumeration message, there’s a number of different kinds of information that can be reported: