Device Drivers

A Device Driver is a special type of plugin that defines how Iotellect Server interacts with certain types of hardware devices. The driver is specified during the creation of a Device account.

Iotellect directly supports many communication and control protocols. Device drivers bundled with Iotellect Server allow you to connect various devices produced by thousands of manufacturers.

However, in some cases, it may be necessary to connect a new device that uses a custom protocol for which Iotellect does not have an out-of-the-box solution. In such cases, it is possible to implement a new device driver in programmatic or low code mode. Another option is to use a "device-side" protocol converter called Iotellect Agent.

Iotellect Device Drivers are written in the Java programming language and are thus platform-independent. Since device drivers are implemented in the form of server plugins, installing a new driver is as easy as copying a single file and restarting the server.

Iotellect regularly creates new Iotellect Server device drivers for different types of hardware devices and protocols. Please, check the Iotellect website for the most recent list of available device drivers.

Standard Device Drivers

The below table lists standard device drivers provided by Iotellect and derived products:

Protocol

Driver

Description

Iotellect Protocol

Iotellect Agent

Communicating with implemented Iotellect Agents using any language/platform (Iotellect BASIC, C/C++, .NET, Java).

Asterisk

Asterisk

Monitoring and management of Asterisk computer-integrated telephony by sending CLI commands and response processing.

BACnet

BACnet

Support for BACnet IP and BACnet MS/TP. Reading/writing device properties. Accessing device services and receiving notifications.

CoAP

CoAP

Web transfer protocol for use with constrained nodes and constrained networks in the Internet of Things.

CORBA

CORBA

Performing CORBA calls via IP network by specifying input parameters and processing any output.

CWMP

CWMP

Managing and monitoring customer-premises equipment (CPE) according to TR-069 specifications.

DHCP

Network Host / DHCP

DHCP server operability monitoring.

DLMS/COSEM

DLMS/COSEM

Acquiring spot meter reading values and their history.

DNP3

DNP3

Full support for DNP3 application layer: read/write, select and operate, direct operating, event handling, etc.

DNS

Network Host / DNS

DNS zone contents validation. DNS server operability monitoring.

Ethernet/IP

Ethernet/IP

Support for open industrial Ethernet, CIP protocol.

FTP

Network Host / FTP

Remote file attributes monitoring. FTP server operability monitoring.

GPS/GLONASS Data

Satellite Vehicle Tracker or Flexible Driver

Receiving arbitrary reports from any satellite trackers and other M2M devices via TCP or UDP. Business-rule-based command parsing. Out-of-the-box support for different tracker models.

HTTP/HTTPS

HTTP/HTTPS

Exposing web page contents for the system core. Web server operability monitoring.

ICMP

Network Host / Ping

Availability monitoring (ping) and route tracing (traceroute).

IEC 60870-5-104

IEC-104

Support for IEC 60870-5-104 protocol, both slave and master modes.

IEC 60870-5-104

IEC-104 Server

Support for IEC 60870-5-104 protocol in server mode.

IMAP

Network Host / IMAP

IMAP server operability monitoring.

IPMI

IPMI

Monitoring and control of IPMI-enabled servers and network devices.

JMS

WebSphere MQ

IBM WebSphere MQ monitoring.

JMX

Java Management Extensions

Reading/writing MBean attributes. Executing MBean operations. Receiving MBean notifications.

LDAP

Network Host / LDAP

Exposing search request results to system core for further processing. Operability monitoring for Active Directory or any LDAP server.

LON/LonTalk

OPC

LON device network and LNS servers can be interfaced through an OPC server and OPC device driver. Available LON-to-OPC bridges include IPLONGATE, Matrikon OPC Server for Echelon LNS, Matrikon OPC Server for Echelon LonManager, ConneXSoft CXS iLink DA Server for Echelon Smart Server, Gesytec Easylon OPC Server, Newron System NLOPC MIP, and more.

LON/LonTalk

Web Services

Echelon SmartServer and the hardware behind it can be interfaced through the SOAP (Web Service) API and SOAP device driver.

Meter-Bus

M-Bus

Acquiring spot meter reading values and their history.

Modbus

Modbus

Support for Modbus/RTU, Modbus/ASCII, Modbus/TCP, and Modbus/UDP. Registering read/write operations.

GSM/GPRS Modem Control

Modem or Flexible Driver

Sending/receiving SMS messages, modem control, and data retrieval via AT command execution.

MQTT

MQTT

ISO standard publish-subscribe-based messaging protocol for use on top of TCP/IP protocol.

NMEA 0183

NMEA or Flexible Driver

Exposing any NMEA sentence fields for system core. Device location tracking.

ODBC

Database

Via standard JDBC-ODBC bridge, see SQL device driver.

OPC DA

OLE for Process Control

Support for OPC DA 2.0 via DCOM. Works under Windows and Linux.

OPC DA/HDA/AE

Iotellect Agent Driver + Iotellect OPC Agent

Support for OPC DA, AE, and HDA. Iotellect OPC Agent is standalone software installed on Windows and working with Iotellect servers running on Windows or Linux.

OPC UA

OPC Unified Architecture

Full support of OPC UA stack.

POP3

Network Host / POP3

POP3 server operability monitoring.

Radius

Network Host / Radius

Radius server operability monitoring.

S7 Protocol

Siemens S7

Managing PLCs of the Siemens S7 family.

SIP

SIP

Placing test VoIP calls and retrieving call metrics.

SMB/CIFS

SMB/CIFS

Accessing and monitoring files and folders shared via Microsoft Windows Network (SBM/CIFS) technology.

SMI-S

SMI-S

Control of disk storage supporting SMI-S protocol. Monitoring object properties, executing queries and object methods, processing events.

SMPP

SMPP

Sending SMS messages through an SMPP gateway.

SMTP

Network Host / SMTP

SMTP server operability monitoring.

SNMP

SNMP

Support for SNMP v1, v2c, and v3. Read/write operations, receiving and sending traps. MIB directory and editor.

SOAP

Web Services

Performing arbitrary Web Service calls via SOAP protocol by specifying input data and processing any output.

SQL

Database

Support for any JDBC/ODBC-compliant database server. Dynamic SELECT / UPDATE / INSERT / DELETE query execution. Exposing query results for system core. Database status monitoring.

SSH

Network Host / SSH

Executing shell scripts and applications on remote machines. SSH server operability monitoring.

Telnet

Network Host / SSH

Executing shell scripts and applications on remote machines. Telnet server operability monitoring.

VMware SOAP API

VMware

Retrieving hypervisor/VM status and performance counters.

WMI

WMI

Monitoring WMI object properties, executing WQL queries and object methods, processing WMI events.

XMPP

XMPP

Implementation of Sensor Data and Control extensions of the protocol.

Application/Script

Executing custom applications/scripts on demand or upon schedule. Retrieving and processing their output.

Avatar

Localizing any remote device driver by creating local "Avatars" to simplify solution development and improve network performance.

File

Local file monitoring, checksum verification, exposing file contents for system core.


Flexible

Acting as a self-service driver construction kit for solution engineers to support proprietary protocols without any Java coding.

Folder

Local folder monitoring, exposing folder contents for system core.

Graph Database

Storage of topologies in various graph databases supported by Apache TinkerPop, including Neo4j. Access to graph computing operations provided by Gremlin language.

Message Stream or Flexible Driver

Monitoring incoming data via Serial/TCP/UDP connections.

Virtual Device

The device simulator, provides variables of different types, wave generators, test operations and events.

Web Transaction

Advanced web application monitoring. Allows analyzing availability, health, and performance by modeling end-user activity scenarios of any complexity.

Driver Reference

The subsections of the current section are devoted to different device drivers that are bundled with Iotellect core and diverse vertical market solutions.

Description of every driver includes the following:

Section

Notes

Driver Information

Driver details, such as driver plugin ID, etc.

Global Settings

Global configuration of driver plugin.

User-level Settings

User-level configuration of driver plugin.

Device Account Properties

Device-level configuration of driver plugin. This includes connection settings, manually configured definitions of device resources, etc.

Device Assets

Description of the method used by the driver to define device assets.

Device Settings

Description of the method used by the driver to create variables corresponding to the hardware device's settings.

Device Operations

Description of the method used by the driver to create functions/actions corresponding to the hardware device's operations.

Device Events

Description of the method used by the driver to create event definitions corresponding to the types of notifications provided by the hardware device. This section also illustrates how and when the event instances are received from the hardware and converted into Iotellect events.

Connection Handling

Details on how and when the driver switches the device between Online and Offline status.

Synchronization Details

Any information on the driver-specific peculiarities of the Device synchronization process.

Setting Levels

Since a device driver is a plugin, it has the configuration options that most plugins have. For every driver up to three levels of settings are available:

  • Global Settings These affect the default behavior of drivers. Global settings may be edited only by users with sufficient permissions.

  • User-level Settings. These affect the behavior of a driver only if it is assigned to a Device that belongs to a certain user account. When the driver is communicating with a certain device, it uses the user-level settings stored in the Device owner's account.

  • Device-level Settings (Device Properties). These settings define how the device driver connects to the device, communicates with it, and processes device data.

Many drivers do not use all three setting levels.

Administering Device Drivers

Two context types are used to administer Device Drivers: first is the general Drivers/Plugins Configuration context, which serves as a container. The other is the Driver/Plugin Configuration context, which holds the configuration for a single driver.

These appear in two places:

  • Under the Root context, where they contain global settings

  • Under the User context, where they contain user-level settings

If a given driver doesn't contain settings on one of these levels, the corresponding Device Driver Configuration context will not be created (i.e, won't exist in the System Tree).

Device-level settings for a driver may be accessed using the Edit Device Properties action of a Device context.

Was this page helpful?