Version History¶
Flir v2¶
v2.6.0¶
Release Date: 2024-10-24
- Flir Core - New Features: - Monitoring of the available space on the disk that holds the SQLite buffer for readings ingested by Flir has been added. Entries will be written to the error log to predict the expiration of the disk space and also logs when the spaces left available fall below 10% and 5%. 
- Failures to send data north via the north service raise an alert. This is now cleared if the flow of data north later resumes. 
- An issue that could cause high CPU utilisation when a north service was unable to send data to the upstream system has been resolved. The user is also made more aware of failed attempts to send data upstream using the alerting feature. An alert will be created and shown in the GUI status bar. 
- It is now possible to create allow and block lists for IP addresses that are allowed access or explicitly denied access to the API port of the instance. 
- The configuration items within the configuration category now have the ability to limit the user roles that are allowed to update the configuration item. 
- Configuration items can now be given a permission property that can be used to control which user roles have access to the configuration item. 
- Performance monitors have been improved. 
- A new section relating to all aspects of monitoring within Flir has been added to the documentation. 
- The tuning documentation has been updated to discuss the use of the configuration cache size tuning parameter and to add a discussion on tuning the log level for the various services. 
 
- Bug Fix: - An issue that caused incorrect payloads to be sent north when choosing the audit log as the data source has been resolved. 
- An issue that incorrectly prevented some authorised users from executing a control endpoint has been resolved. 
- An issue with backup and restore when using Postgres as the storage engine to store the configuration data has been resolved. 
- The manual purge, in the developer features of the user interface, was not working for assets containing ‘ #’, ‘+’ or ‘&’ characters in asset name. 
- An issue with north services that have been misconfigured not cleanly shutting down has been resolved. 
- An issue that could cause a backup file to not download has been resolved. 
- An issue that could allow an unauthorised user to change the password of another user has been resolved. 
- After restart of Flir, the sent count in the Flir GUI dashboard would increase by few readings after every restart of Flir, even if no south plugins were running. This has been fixed. This was an error in the increment of the counter; there were never any additional readings sent. 
- An issue with an incorrect audit entry being created when adding new properties to a configuration item has been resolved. 
- A security issue that could allow one user to see the profile of another has been resolved. 
- Users now need to have administration permissions to see the user names and roles of other users. 
- The handling of errors during pipeline creation has been enhanced to give better reporting of filter plugin exceptions. 
- The notification service has been updated to allow sub-second retriever times for notifications to be specified. 
- The documentation for deleting users via the REST API has been corrected. 
 
 
- GUI - New Features: - The rendering of lists in the configuration options has been improved. 
- The ordering of the tabs in the configuration user interface is no longer alphabetical but controlled by the configuration category itself. 
- The user interface now hides configuration options the user does not have permission to change. 
- The rendering of the developer menu has been brought into line with other sub-menu rendering. 
 
- Bug Fix: - An issue with the user interface incorrectly displaying a timestamp has been resolved. 
- An issue with list type configuration items occasionally not rendering correctly for filters has been resolved. 
- An issue related to improper length validation for certain entries in the configuration items has been resolved. 
- An issue with forcible session disconnection sometimes failing has been resolved. 
- The performance related to management of services and plugins has been improved. 
- An issue that prevents export of persisted data in developer mode has been resolved. 
- An issue that prevented deletion of persisted data for plugins in developer mode has been resolved. 
- An issue with the filter plugin that involved underscores in the name has been resolved. 
 
 
- Plugins - New Features: - flir-filter-anomaly-injection has been added that allows data anomalies to be superimposed on data in a pipeline. This is used to test downstream anomaly detection and is not intended for production use. 
- flir-filter-asset now supports to allow regular expressions to be used in the asset name to match when applying the filter. 
- flir-filter-bounds has been added that checks for data being within certain limits and adds meta data to the reading to indicate the status. 
- flir-filter-delta has been enhanced to give greater control over the action when one or more datapoints in an asset are detected as changing. 
- flir-filter-sam has been added that creates a semantic model based on data from one or more sources into a single asset structure. 
- flir-filter-fft2 has been made that allows for periodic calculation of the FFT. 
- flir-filter-regex has been enhanced to allow the matched strings to be reused in the substituted strings. It also now has an option to control the scope of the regular expression matching. 
- flir-filter-sigmacleanse has been enhanced to allow an option that outliers be labeled rather than removed. The default behaviour still removes the outliers from the pipeline. 
- flir-notify-operation now supports data substitution as with the other control-related notification delivery plugins. 
- flir-north-edna and corresponding flir-filter-ednahint have been created to send data into the AVEVA eDNA historian. 
- flir-north-mqtt-scripted has been enhanced to support macros in the topic to which data is sent. These macros allow the name of the asset and/or the values of any of the datapoints within a reading to be substituted into the topic string. 
- flir-north-OMF plugin’s action code in the HTTP header is typically set to update for OMF Data messages. This setting allows old values to be updated when timestamps match and ensures that new data is compressed correctly by the PI Data Archive. However, if the AVEVA PI Buffer Subsystem is configured, the update action code is converted to an internal PI storage mode, which causes new data to bypass compression and may lead to excessive storage of too many data values. To address this issue, the OMF North plugin now allows you to change the OMF Data action code to create. This option should only be used when the AVEVA PI Buffer Subsystem is configured. 
- flir-south-etherip has some improvements for the Micro8xx PLC. It also supports readings PLC tags that contain an array of boolean values. 
- flir-south-mqtt-scripted has some improvements in frequency with which MQTT broker failure is reported has been reduced to prevent flooding the error log with messages. 
- flir-south-south-rest plugin has been updated to support numeric timestamps. A numeric timestamp is taken as the number of seconds since the Unix epoch, 1st January 1970. 
- flir-south-s2opcua now supports for the OPC UA Data Change Filter. This filter type is defined in the OPC UA Specification, Part 4, Section 7.22.2. The Data Change Filter allows OPC UA clients (such as this plugin) to request that the OPC UA server send data value updates only if the server’s data values have changed significantly. With careful tuning, you can reduce the data traffic from OPC UA server to the client without significant loss of fidelity. This plugin has been upgraded to use Systerel’s S2OPC Toolkit Version 1.5.0. 
- flir-filter-normalise documentation has been updated to interpolate dates to defined time intervals, has been updated. 
- flir-south-s7 documentation has been updated to include a note regarding the use of optimised block access. 
- flir-south-etherip documentation has been updated to include the currently supported types that can be read from the PLC. 
 
- Bug Fix: - An issue that could cause a crash during purge operations has been resolved. 
- flir-north-mqtt-scripted
- It has been updated such that if the topic string cannot be substituted fully, the data will not be sent. 
- It also handled the failure of the MQTT broker. The plugin is now more resilient to broker failure and able to recover correctly when the broker is available again. 
 
 
- flir-notify-north used to implement conditional forwarding of data via north tasks has been updated to support complex pipelines with branches and parallel processing. 
- flir-south-dt9837 that could cause buffer overrun and stop the data ingesting has been resolved. 
- flir-south-etherip
- Problem with the dynamic reconfiguration of the EthernetIP south plugin when changing between reading per tag and reading per asset modes has been resolved. 
- It allows the action to be taken if an error is encountered reading data from the PLC to be configured. 
- It is not correctly recognising network disconnections has been resolved. 
- Documentation has been updated to stress the requirement that the type in the data map matches the type used in the PLC code. 
 
 
- flir-south-modbusc plugin that could cause it to fail if the IP address of the MODBUS device was changed incorrectly and then changed back to the correct address has been resolved. 
- flir-south-mqtt-sparkplug now supports various data types, including string, integer, float and boolean. 
- flir-south-randomwalk has been improved to give a more random result. 
- flir-south-s2opcua would sometimes fail to connect to an OPC UA server with a large number of available endpoints on a distant or noisy network. This has been fixed. 
 
 
v2.5.0¶
Release Date: 2024-06-26
- Flir Core - New Features: - A new parameter has been added to the storage service to configure the number of threads that will be used to interact with the buffered reading data. This limits that impact on heavily loaded systems and also allows for the threads to be pre-created, which slightly reduces the latency. 
- A new tuning option has been added to the core that tunes the size of the cache maintained by the configuration manager. Increasing this cache size can speed up the startup of the system when large numbers of services are used within the system. 
- A new tuning option has been added to the north service to control the frequency of updating the stream position when writing data to the north. More details are available in the tuning section of the documentation. 
- A new tuning option has been added to the north service that allows the number of buffers that are prefetched to be tuned. 
- A small performance enhancement has been made in the south service such that the rate of storing statistics is not dependent on the ingest rate of the service. This will improve the performance of south services with high ingest rates. 
- A performance enhancement has been added to all SQLite storage plugins that results in higher throughput and lower latency in all cases when using SQLite as a storage engine. 
- The storage performance monitors have been updated to include the table name in the monitor name. This allows tracking of which tables are being heavily used within the system. 
- A new security option has been added to allow for a password policy to be set. This policy defines characters that must appear within a user password. 
- Password encryption has been made more secure. 
- Some changes have been done to the way the API handles passwords to make them more secure. 
- The system now tracks failed login attempts and can block accounts that have excessive failed attempts to login. 
- A new security feature has been added to disconnect idle sessions after a configurable time. 
- The build mechanism has been updated to support profiled builds. 
- Support bundles and backups have been updated to require extra privileges to access. 
- The documentation on securing Flir has been updated. 
- The documentation for the SQLite storage plugin has been improved and some duplication removed. 
- The Configuration lifecycle documentation has been updated to include more explanation and examples of the use of the various list type configuration items. 
- Documentation has been added to the ‘Tuning Flir’ section to describe the performance counters in the storage layer and also give some general tips on the subject of using the performance counters to tune the Flir installation. 
 
- Bug Fix: - A typo in the statistics description for “Readings Sent North” has been fixed. 
- An issue that may occasionally cause the storage service to fail during purge when using the default SQLite storage engine for readings data storage has been resolved. 
- A problem with integer overflow in the SQLite storage engine has been resolved. 
- An issue with one of the API entry points that could allow for command injection into the underlying operating system has been resolved. 
 
 
- GUI - New Features: - An option to use the flow editor interface for notifications has been added. 
- An option has been added to the graph display to scroll to the latest readings available. 
- A facility to read a JSON configuration item from a file and insert the contents into a configuration item has been added to the user interface. 
- Support has been added to the GUI for key/value lists in configuration items. 
- The ability to create and manage backups has become a privileged operation. Likewise support bundles can only be created by administrators. 
- The user management screen now shows if a user has been blocked due to excessive failed login attempts. 
- The documentation on viewing data has been updated in line with a number of recent changes to the user interface. 
 
- Bug Fix: - A missing health icon in the north service flow editor has been added. 
- An issue when deleting a disabled notification service could result in an error has been resolved. 
- An issue that could result in two identical audit logs when deleting a filter from a pipeline has been resolved. 
- The north flow editor page was not showing branches in pipelines, this has now been resolved. 
 
 
- Services & Plugins - New Features: - A new filter plugin (flir-filter-enumeration) has been added that allows the mapping between numeric and string values for enumerated types in readings. 
- Support has been added for 16 and 32 bit signed integer values in the flir-south-s7 plugin. 
- The type and abbreviated area definitions in the flir-south-s7 plugin map has now been made case independent. 
- The error reporting in the flir-south-s7 plugin has been improved such that errors in the map are not reported on every poll operation of the plugin. Such errors are now only reported periodically, preventing the error log from becoming overwhelmed by these errors. 
- The reading structure configuration parameter of the flir-south-etherip plugin has been updated to allow a new “Reading per Asset” option. 
- The handling of disconnects from an EthernetIP PLC has been improved in flir-south-etherip plugin. 
- Support has been added for reading string from EthernetIP PLCs in flir-south-etherip plugin. 
- Performance improvements have been made to the flir-south-etherip plugin for EthernetIP PLCs. 
- flir-north-opcua: In the hierarchy map, forward-slash-separated string tokens in the meta-data and the Asset Name are now parsed and used to construct an object hierarchy in the OPC UA Server’s Address Space. Since some South plugins and filters send path information to Flir that is split between a path Datapoint and the Asset Name, path segments found in the Asset Name will be added to the end of the path Datapoint. The plugin supports the entire path being present in the Asset Name. 
- OMF North plugin: The default naming convention of PI tags created is Asset name and Datapoint name separated by a dot (.) delimiter. It is now possible to choose any single character as the delimiter except characters that are not allowed in OMF field names. 
- Exception handling within the spectrogram filter has been improved. 
- Support has been added to automatically detect new storage engines upon restart of Flir. 
 
- Bug Fix: - A memory leak in the flir-filter-scale plugin has been fixed. 
- An issue with reconfiguring the flir-south-s7 plugin that required a restart before some of the changes took affect has been resolved. 
- An issue that prevented the flir-south-s7 plugin from reconnecting correctly after losing connection to the PLC has been resolved. 
- A Python compatibility issue with the Python version of the flir-south-s7-python plugin has been resolved. 
- An issue reconfiguring the flir-south-etherip plugin when connected to a Micro8XX PLC has been resolved, 
- An issue with “Single Reading” structure option on the flir-south-etherip plugin has been resolved. 
- An issue when adding an flir-south-etherip in disabled mode has been resolved. The plugin no longer attempts to connect to the PLC when it is disabled. 
- An issue that caused excessive log entries from the flir-south-etherip plugin during a network failure has been resolved. 
- An issue with flir-south-dt9837 plugin configuration has been resolved. 
- An issue that could cause the failure of the service if configuring a regular expression in the flir-filter-omfhint with an invalid regular expression has been resolved. 
- An issue that could cause a file descriptor leak when using the flir-filter-csv-writer and flir-notify-north notification delivery plugin has been resolved. 
- An issue that could cause some data to be lost in the flir-filter-csv-writer plugin has been resolved. 
- Support has been enhanced in the conditional labelling filter for different data types. 
- An issue with reordering filters in a control pipeline has been resolved. 
- A problem that could cause the control dispatcher to fail when deleting a filter from a control pipeline has been resolved. 
- A problem that could cause the control dispatcher to become unresponsive when adding a filter to an active control pipeline has been resolved. 
- When using the conditional forwarding feature the audit log entry to record the sending of the notification could sometimes be lost, this is now resolved. 
- An issue that meant the notification service could not find the control dispatcher if the control dispatcher was started with a non-default name has now been resolved. 
 
 
v2.4.0¶
Release Date: 2024-04-10
- Flir Core - New Features: - A new feature has been added that allows for internal alerts to be raised. These are used to inform users of any issue internally that may require attention; they are not related to specific data that is flowing through the Flir data pipelines. Examples of alerts that may be raised are that updates to the software are available, a service is repeatedly failing or an exceptional issue has occurred. 
- A new task (update checker) has been added that will run periodically and raise an alert if there are software updates available. 
- The internal service monitor has been updated to use the new alerts mechanism to alert a user if services are failing. 
- A new storage configuration option has been added that allows the server request timeout value to be modified. 
- The ability to tune the cache flushing frequency of the asset tracker has been added to the advanced configuration options of the south and north services. 
- The reporting of south service send latency has been updated to give more detail regarding continue send latency issues. 
- A new tuning parameter has been added to the purge process to control the number of readings purged within single blocks. This can be used to tune the intention between the purge process and the ingestion of new data in highly loaded systems. 
- A new list type has been added to the types supported in the configuration category. This allows for improved configuration interactions. 
- Support has been added in the C++ configuration manager code to allow for the new list, key/value list and object list types in configuration categories. Also some convenience functions have been added for use by plugins that wish to traverse the lists. 
- In the hierarchy map of flir-north-opcua., forward-slash-separated string tokens in the meta-data are now parsed and used to construct an object hierarchy in the OPC UA Server’s Address Space. 
- The scheduler has been enhanced to provide the capability to order the startup of services when Flir is started. 
- A performance improvement, courtesy of a community member, for the JSON escaping code has been added. This improves performance of the PostgreSQL storage plugin and other areas of the system. 
- A new section has been added to the documentation that describes how storage plugins are built. 
- The plugin developers guide has been updated with information and examples of the new list handling facilities added to configuration items within Flir. 
- The tuning section of the documentation has been updated to include details of the service startup ordering enhancement. 
- The plugin developers guide has been updated to add some additional guidance to the developer as to how to decide if features should be added to a plugin or not and also to document common problems that cause problems with plugins. 
- Documentation that describes what firewall settings are needed to install Flir has been added to the Quick Start Guide. 
 
- Bug Fix: - An issue that prevented configuration categories items called messages has been resolved. 
- An issue that could cause data to be repeated in a north service when using a pipeline in the north that adds new readings to the pipeline has been resolved. 
- An issue that could cause the order of filters in a control pipeline API to be modified has been fixed. 
- An issue that could result in series that are already installed being shown in the list of services available to be installed has been resolved. 
- An issue that could cause some north plugins to fail following a restart when using the SQLite in-memory storage plugin has been fixed. 
- An issue that could prevent a plugin being updated in some circumstances has been resolved. 
- An issue requiring a restart before the change in log level for the storage service took effect has been resolved. 
- An issue causing the database to potentially not initialize correctly when switching the readings plugin from SQLite to PostgreSQL has been resolved. 
- An issue in the control pipeline API related to the type of one of the parameters of the pipeline has been resolved. This issue could manifest itself as an inability to edit a control pipeline. 
- The return type of plugin_shutdown was incorrectly documented in the plugin developers guide for north plugins. This has now been resolved. 
 
 
- GUI - New Features: - A new page has been added for managing additional services within an instance. 
- Support for entering simple lists for configuration items has been added. 
- Support has been added for manipulating key/value lists using the new available list configuration type that is available. 
- Navigation buttons have been added to the tabs in the south and north services to facilitate easier navigation between tabs. 
- A preview of the new flow editor for the north side has been added. This may be enabled via the GUI settings page. 
- The GUI now shows the internal alerts via an icon in the navigation bar at the top of the screen. 
 
- Bug Fix: - An issue with creating an operation in a control script with no parameters in the GUI has been resolved. 
- An issue with the Next button not being enabled when changing the name of a service in the service creation wizard has been resolved. 
- An issue that could result in a filter not being added to a control pipeline when the user does not click on the See button has been addressed by adding a check before navigating off the page. 
- An issue that could result in the JSON code editor being incorrectly displayed for non-JSON code has been resolved. 
- An issue with the visibility of the last item on the side menu when scrolling in a small window has been resolved. 
 
 
- Services & Plugins - New Features: - A new filter plugin (flir-filter-inventory) has been added that allows an inventory of data to be created. This is used to build information as to what data has been collected in various states of a machine and is intended to aid data collection for machine learning model generation. 
- A new filter plugin (flir-filter-conditional-labeling) has been added that can apply a label to a reading based on the evaluation of an expression. 
- A new notification delivery plugin (flir-notify-alert) has been added that will create an alert in the user interface. 
- A new notification delivery plugin (flir-notify-schedule) has been added that can toggle the state of a service. 
- Improvements have been made to the buffering strategy of the OMF north plugin to reduce the overhead in creating outgoing OMF messages. 
- The control pipelines mechanism has been enhanced to allow pipelines to change the name of the operation that is performed as well as the parameters. 
- The documentation of the expression filter has been updated to document the restriction on asset and datapoint names. 
 
- Bug Fix: - An issue with the dynamic reconfiguration of filters in control pipelines has been resolved. 
- An issue that could cause the control dispatcher service to fail when changing the destination of a control pipeline has been resolved. 
- An issue with the control dispatcher that prevents operations with no parameters from being correctly passed via control pipelines has been resolved. 
- An issue in the control dispatcher that could cause a crash if a control pipeline completely removed the request has now been resolved. 
- An issue that could cause an error to be logged when installing the control dispatcher has been resolved. The error did not prevent the dispatcher from executing. 
- An issue that could cause some loss of data when using conditional forwarding has been resolved. 
- An issue when using the PostgreSQL storage plugin and data containing double quotes within JSON data has been resolved. 
- An issue that could cause an error in the south plugin written in Python that supports control operations has been resolved. 
- A memory consumption issue in the flir-filter-asset when using the flatten option has been resolved. 
- The flir-filter-asset issue causing deadlock in pipelines with two instances has been resolved. 
- A problem with excessive logs being produced by the flir-filter-specgram plugin if added in disabled mode has been resolved. 
- A file descriptor leak in the flir-filter-specgram plugin has been resolved. 
- An issue that could cause excessive memory usage when using the conditional forwarding feature has been resolved. 
- An issue that limited the number of variables the flir-south-s2opcua plugin could subscribed to has been resolved. 
- An issue that could result in the sent count being incorrectly incremented when using the flir-north-kafka (C based) plugin has been resolved. 
- An issue that could cause excessive messages regarding connection loss and regain to be raised in the OMF north plugin has been resolved. 
- An issue that caused the flir-north-kafka (C based) plugin to fetch data when it was disabled has been resolved. 
- An issue that could cause the notification service to fail when using conditional forwarding has been resolved. 
- In flir-south-s2opcua, If you set the User Authentication Policy to username, you must select a Security Policy other than None to communicate with the OPC UA Server. Allowing username authentication with None would mean that usernames and passwords would be passed from the plugin to the server as clear text which is a serious security risk. This is explained in the OPC UA Specification. In addition, OPC UA defines a Security Policy for a “UserIdentityToken”. When configuring the flir-south-s2opcua plugin, the Security Policy selected in your configuration must match a supported “UserIdentityToken” Security Policy. To help troubleshoot configuration problems, log messages for the endpoint search have been improved. The documentation includes a new section called “Username Authentication”. 
- Support for the DT9837 plugin on the Raspberry Pi Bullseye aarch64 platform has been added. 
- If a datapoint or asset name contains a reserved mathematical symbol then the flir-filter-expression plugin was previously unable to use this as a variable in an expression. A mechanism has been added to allow these names. 
- The Notification service would create Rule and Delivery support objects even if the notification was disabled. When the notification was later enabled, the original objects would remain. This has been fixed. 
- If the OMF North plugin gets an exception when POSTing data to the PI Web API, the plugin would declare the connection to PI broken when it wasn’t. This would result in endless connection loss and reconnection messages. This has been fixed. The plugin will now ping the PI Web API every 60 seconds and will determine that connection has been lost only if this ping fails. The OMFHint LegacyType has been deprecated because a Container cannot be changed after it is created in the PI System. This means there is no way to process the LegacyType hint when readings are processed. If the LegacyType hint appears in any reading, a warning message will be written saying that this hint type has been deprecated. 
- This fix applies when configuring OMF North to create an Asset Framework (AF) structure. The first time an AF Element holding an AF Attribute pointing to a PI Point (i.e. the Container) is created, it will appear in Asset Framework as a normal AF Element. If the path is then changed using an “AFLocation hint”, a reference to the AF Element should appear in the hint’s location. The original AF Element’s location should remain unchanged. This feature was not working correctly but has been fixed. Before this fix, the hint’s path would be created as expected but no reference to the original data location was created. 
- The storage service with the SQLite in-memory plugin does consume large amounts of memory while running at higher data rates. Analysis has determined this is not caused by a memory leak but rather by legitimately storing large amounts of data in memory while operating. The reason for the high load on the storage service appears to be database purging but this is a subject for further study. 
- An issue in the control pipeline documentation that stated that services could only be the source of control pipelines has been fixed to now show that they may be the source or the destination. 
- It is not possible to change the numeric data type of OMF Container (which maps to a PI Point) after it has been created. This means it is not possible to enable or disable an integer OMFHint or change the numeric data type in the Flir GUI after the Container has been created. It is possible to manually correct the problem if it is necessary. OMF North plugin documentation has been updated with the procedure. 
 
 
v2.3.0¶
Release Date: 2023-12-28
- Flir Core - New Features: - A new REST API has been added to the public API to allow performance counters to be fetched and reset. This API is intended for diagnostic purposes only. 
- Improvements have been made to the way load issues on the storage service are logged. 
- Documentation has been added that describes how to extend the API to include custom URLs for executing control functions. This documentation also shows how these are then called using the graphical user interface. 
 
- Bug Fix: - An issue with the PostgreSQL storage plugin when very large numbers of readings are ingested, more than 4294967296, has now been resolved. 
- An issue with services shutting down rather than restarting when they fail to get a valid bearer token has been resolved. 
- A problem with the interruption of “true” and “false” strings in storage layer result sets has been resolved. 
- The user interface for creating write API endpoints incorrectly requires both a constant and a variable when only one is required. This is now resolved. 
- A problem that meant parameters to set point control operations were not correctly sent to south plugins written in Python has been resolved. 
 
 
- GUI - New Features: - The user interface has been upgraded to use Angular version 16. 
- The configuration section of the user interface that allows for instance wide configuration has been improved with a single tree navigation item and improved visual feedback. 
- A link to the documentation has been added to the Control API pages of the user interface. 
 
- Bug Fix: - An issue that could cause some datapoints to display incorrectly in the user interface graph when multiple assets are displayed and those assets have data points with the same name in both assets has been resolved. 
- An issue in the user interface that meant exporting data as a CSV file created incorrect files if any of the data point names containing a comma has been fixed. 
- An issue with the user interface not always correctly showing the information for the dispatcher service has been resolved. 
- A broken link to the documentation in the control pipeline user interface page of the user interface has been fixed. 
 
 
- Services & Plugins - New Features: - A new flir-north-mqtt-sparkplug plugin has been added. 
- The flir-south-benchmark plugin has been enhanced to increase the load that can be placed during testing. 
- The flir-south-s2opcua plugin has been enhanced to allow filtering of nodes using regular expressions on the Browse Name of the nodes. 
- Support has been added for the Query Parameters to include an array of queries for either PI Points (using the PIPoints JSON object) or AF Attributes (using the Attributes and Elements JSON objects). This allows the system administrator to configure multiple PI queries to determine the data to be read from the PI Server. 
- Data value updates retrieved from the PI System are labeled with a code indicating whether the data value is new, updated or inserted into history. Previously, only new data values (that is, newer than the snapshot) were sent as Readings to Flir. This has been changed so that all data values are sent to Flir except values marked as deleted. 
- The OMF north plugin has been updated to improve both the time and space efficiency of the lookup data used to map to PI Server objects. 
- OMF North plugin documentation has been updated to show which version of the OMF specification the plugin will adopt when communicating with different versions of AVEVA products: PI Web API, Edge Data Store (EDS) and AVEVA Data Hub (ADH). 
 
- Bug Fix: - A memory leak in the SQLite in-memory storage plugin has been resolved. 
- A memory leak in the OMF north plugin has been resolved. 
- An issue that could cause data to fail to send using the OMF plugin when the names of data points contain special characters has now been resolved. 
- When the “Send full structure” configuration boolean was false, OMF North would create an AF structure anyways. All AF Elements were at the root of the AF database, with every AF Element having a single AF Attribute mapped to a PI Point. Creation of this AF structure would take a long time for large databases which would lead to PI Web API POST timeouts. This has been fixed. If the configuration boolean is false, OMF North will create PI Points only. In the configuration page, the Send full structure has been renamed to “Create AF Structure”. 
- The OMF North plugin was unable to connect to AVEVA Data Hub (ADH) and OSIsoft Cloud Services (OCS) endpoints. This has been fixed. 
- An issue with using an OMF Hint that defines a specific name to use with a tag has been resolved. The issue would show itself as the data not being sent to PI or ADH in some circumstances. 
- An issue that meant some OPC UA nodes stored in the root of the hierarchy were not correctly ingested in the flir-south-s2opcua plugin has been resolved. 
- A problem with the flir-north-mqtt-scripted plugin that would use the sent count to increase even if data was not sent has been resolved. 
- The SQLite storage plugin had an issue that caused it to create overflow tables multiple times. This was not a problem in itself, but did cause the database to become locked for excessive periods of time, creating contention and delays for data ingestions in progress at the time. 
- A problem that, in rare circumstances, could result in data being added to the incorrect asset in the SQLite plugin has been resolved. 
- An issue with assets containing bracket characters not being stored in the PostgreSQL storage plugin has been resolved. 
- An issue with string type parameters to control operations having extra pairs of quotes added has been resolved. 
- A problem that caused the dispatcher service to log messages regarding incorrect bearer tokens has been resolved. 
- The control dispatcher service was previously advertising itself before it had completed initialisation. This meant that a request could be received when it was partially configured, resulting in a crash of the service. Registration now takes place only once the service is completely ready to accept requests. 
- The control dispatcher was not always using the correct source information when looking for matching pipelines. This has now been resolved. 
- Control pipelines were previously still being executed if the entire pipeline was disabled, this has now been resolved. 
 
 
v2.2.0¶
Release Date: 2023-10-17
- Flir Core - New Features: - New audit logs have been added to reflect the creation, update and deletion of access control lists. 
- New public API Entry Points have been added to allow for the creation and manipulation of control pipelines. 
- A new user role has been added for those users able to update the control features of the platform. 
- A new tuning parameter has been added to the PostgreSQL storage plugin to allow the maximum number of readings inserted into the database in a single insert to be limited. This is useful when high data rates or large bursts of readings are received as it limits the memory consumption of the plugin and reduces the lock contention on the database. 
- The asset tracker component has been optimized in order to improve the ingress and egress performance of Flir. 
- The mechanism used by the south and north services to interact with the audit log has been optimized. This improves the ingress and egress performance of the product at the cost of a small delay before the audit log is updated. 
- A number of optimizations have been made to improve the performance of Python filters within a pipeline. 
- A number of optimizations to the SQLite in-memory storage plugin and the SQLiteLB storage plugin have been added that increase the rate at which readings can be stored with these plugins. 
- A number of changes have been made to improve the performance of sending data north from the system. 
- The support bundle creation process has been updated to include any performance counters available in the system. 
- The ability to monitor performance counters has been added to Flir. The South and North services now offer performance counters that can be captured by the system. These are designed to provide information useful for tuning the respective services. 
- The process used to extract log information from the system logs has been updated to improve performance and reduce the system overhead required to extract log data. 
- The performance of the statistics history task has been improved. It now makes fewer calls to the storage subsystem, improving the overall system performance. 
- The performance of the asset tracker system has been improved, resulting in an improvement in the ingress performance of the system. 
- Changes have been made to the purge process in the SQLiteLB and SQLite in-memory plugins in order to improve performance. 
- The audit log entries have been updated to include more information when schedules are updated. 
- Audit logs have been added to the user API of the public REST interface. 
- The plugin developers guide has been updated to include the mechanism for adding audit trail entries from C++ plugins. 
- Plugins that run within the south and north services and north tasks now have access to the audit logging system. 
- The public API has been updated to include the ability to make control requests. 
- The public API of the system has been updated to allow selection of readings from the storage buffer for given time intervals. 
- The public API that is used to retrieve reading data from the storage layer has been updated to allow data for multiple assets to be retrieved in a single call. 
- The SQLite in-memory storage plugin now has an option that allows the data to be persisted when shutting the system down and reloaded on startup. 
- The SQLite storage plugins have been updated to improve the error reporting around database contention issues. 
- A change has been made to the configuration of the storage plugin such that rather than having to type correct names for storage plugins the user may now select the plugins to use from a drop down list. Note however that the system must still be restarted for the new storage plugin to take effect. 
- The storage service has been updated to allow other services to subscribe the notifications of inserts into the generic tables. 
- A change has been made to prevent the schedules used to start services from being renamed as this could cause the services to fail. 
- The default interval for running the purge process has been reduced, the purge process will now run every 10 minutes. This change only affects new installations, the purge process will run as before on systems that are upgraded. 
- The ingestion of data from asynchronous south services paid no attention to the advanced configuration option “Throttle”. This meant that very fast asynchronous south plugins could build extremely large queues of data within the south service, using system resources and taking a long time to shutdown. This has now been rectified, with asynchronous south services now subject to flow control if the “Throttle” option is set for the service. Unconstrained input is still available if the “Throttle” option is not checked. 
- The south plugin now supports three different modes of polling. Polling at fixed intervals from the time started, polling at fixed times or polling on demand via the control mechanisms. 
- Support has been added to allow filters to ingest pass data onwards during a shutdown of the filter. This allows any buffered data to be flushed to the next filter in the pipeline. 
- A numeric list data type has been added to the reading ingestion code of the system. 
- A Python package, used by the system, found to have a security vulnerability. This has been updated. 
- The format of Python traceback has been improved to use multiple lines within the log. This makes the trace easier to understand and prevents the truncation that can occur. 
- The setting of log levels from a service is now also reflected in any Python code loaded by the service. 
- The reporting of issues related to failure to load plugins has been improved. 
- When upgrading the version of a plugin any new configuration items are added to the relevant configuration categories. However the operation was not correctly reported as a configuration change in the audit log. This behavior has now been corrected. 
- An issue which could occasionally result in the bearer token used for authentication between the various services expiring before the completion of the renewal process has been resolved. This could result in the failure of services to communicate with each other. 
- The configuration category C++ API has been enhanced in the retrieval and setting of all the attributes of a configuration item. 
- The support bundle has been updated to include a list of the Python packages installed on the machine. 
- The documentation regarding handling and updating certificates used for authentication has been updated. 
- Added documentation for the performance counters in the tuning guide. 
 
- Bug Fix: - An issue with the SQLite in-memory and the SQLiteLB storage plugins that could result in incorrect data being stored has been resolved. 
- An erroneous message was being produced when starting the system using the SQLite in-memory storage plugin. This has now been resolved. 
- Support has been improved for switching between different storage plugins that allows for correct schema creation when using different sqlite plugin variants for configuration and readings storage. 
- An issue that could cause health metrics to not be correctly returned when using the Postgres storage engine has been resolved. 
- An issue in one of the storage plugins that caused spurious warnings to appear in the logs during a backup has been resolved. 
- A memory leak in one of the storage plugins has been fixed. This caused the storage service to consume large amounts of memory over time which could result in the operating system killing the service. 
- An update has been done to the default SQLite storage plugin to enable it to handle a large number of distinct asset codes in the readings. Previously the plugin was limited in the number of assets it could support. When the number of asset codes gets large the performance of the plugin will be reduced slightly, however it will continue to ingest data. 
- An issue with memory usage in Python plugins used in south services has been resolved. 
- A number of issues regarding the usage of memory have been resolved, including some small memory leaks. The overall memory footprint of north services should also be reduced in some circumstances. 
- An issue that causes log messages to not be recorded has been resolved. 
- An issue that could cause the statistics to be displayed with a timestamp in the wrong time zone has been resolved. 
- A bug in the statistics rate API that would result in incorrect data being returned has been fixed. 
- An empty statistics entry would erroneously be added for an asset or a service if the advanced parameter to control the statistics was modified from the default before the service was started. This has now been resolved. 
- A problem with statistics counter overflow that could cause a crash in the statistics collector has been resolved. 
- An issue that caused the retrieval of system logs for services with white space in the name of the service has been resolved. 
- The control dispatcher now has access to the audit logging system. 
- An issue that required the north service to be restarted if the source of data to send was changed in a running service has been resolved. Changing the data source no longer requires a restart of the north service. 
- An issue that could sometimes cause a running north service to fail if the configuration for that service is updated has been resolved. 
- A problem that prevents an updated service from restarting after an upgrade if HTTPS is used for the interface between services has been resolved. 
- An issue that limited the update of additional services to just the notification service has been resolved. The update mechanism can now update any service that is added to the base system installation. 
- The Python south plugin mechanism has been updated to fix an issue with ingestion of nested data point values. 
- When switching a south plugin from a slow poll rate to a faster one the new poll rate does not take effect until the end of the current poll cycle. This could be a very long time. This has now been changed so that the south service will take the new poll rate as soon as possible rather than waiting for the end of the current poll cycle. 
- A bug that prevented notification rules from being executed for readings with asset codes starting with numeric values has been resolved. 
- The data sent to notification rules that register for audit information has been updated to include the complete audit record. This allows for notification rules to be written that trigger on the particular auditable operations within the system. 
- The notification service would sometimes shutdown without removing all of the subscriptions it holds with the storage service. This could cause issues for the storage service. Subscriptions are now correctly removed. 
- The command line interface to view the status of the system has been updated to correctly show the statistics history collection task when it is running. 
- An issue with incorrect timestamps in the readings graphs when the time zone of the machine was something other than UTC has been resolved. 
- An issue with the code update mechanism that could cause multiple updates to occur has been resolved. Only a single update should be executed and then the flag allowing for updates to be applied should be removed. This prevents the update mechanism triggering on each restart of the system. 
- A problem that prevented the modbusC south plugin from being updated in the same way as other plugins has been resolved. 
- An issue with trying to create a new user that shares the same user name with a previous user that was removed from the system failing has been resolved. 
- A problem with converting very long integers from JSON has been resolved. This would have manifested itself as a crash when handling datapoints that contain 64 bit integers above a certain value. 
- An update has been made to prevent the creation of service with empty service name. 
 
 
- GUI - New Features: - New controls have been added to the asset browser to pause the automatic refresh of the data and to allow shuffling back and forth along the timeline. 
- The user interface has been updated such that if the backend system is not available then the user interface components are made non-interactive & blur. 
- A new user interface option has been added to the control menu to create control pipelines. 
- The interface for updating the filters has been improved when multiple filters are being updated at once. 
- New controls have been added in the menu pane of the GUI to allow nested commands to be collapsed or expanded, resulting in a smaller menu display. 
- The ability to move backwards and forwards in the timeline of the asset browser graph has been added. 
- The facility that pauses the automatic update of the asset browser graph has been added. 
- The ability to graph multiple readings on a single graph has been added to the asset browser graph. 
- A facility to allow a user to define the default time duration shown in the asset browser graph has been added to the user interface settings page. 
- The date format has been made more flexible in the asset and readings graph. 
- The display of image attributes for image type data points has been added to the latest reading display. 
- The ability to select an area on the graph shown in the asset browser and zoom into the time period defined by that area has been added. 
- The reading graph time granularity has been improved in the asset browser. 
 
- Bug Fix: - The user interface for configuring plugins has been improved to make it more obvious when mandatory items are missing. 
- An issue that allowed view users to update configuration when logged in using certificate based authentication has been resolved. 
- An issue with the handling of script type items whose name was not also script in the user interface that meant that scripts with different names were incorrectly handled has been resolved. 
- An issue with editing large scripts or JSON items in the configuration has been resolved. 
- An issue that caused services with quotes in the name to disappear from the user interface has been resolved. 
- The latest reading display issue that resulted in non image data not being shown when one or more image data points are in the reading has been resolved. 
- A text wrapping issue in the system log viewer has been resolved. 
- An occasional error that appeared on the Control Script and ACL pages has been resolved. 
 
 
- Services & Plugins - New Features: - A new south plugin (flir-south-rtsp) has been added to capture images from RTSP network cameras. 
- A new south plugin (flir-south-armfield) has been developed for an ArmField FM51 Pump Demonstration Unit. 
- A new north plugin (flir-north-aws-redshift) has been created that can send data from Flir into the Amazon Web Services (AWS) Redshift database. 
- A new north plugin (flir-north-aws-iot) for sending data to the Amazon Web Services (AWS) IoT Core has been created. 
- A new north plugin (flir-north-azure-iot) has been added that allows data to be stored in the Azure Blob Storage Service. 
- A new notification rule (flir-rule-match) which is specifically aimed at use with audit log data and can be used to match certain internal events within the system. 
- A new generic REST notification action/delivery plugin (flir-notify-rest) has been added to the notification plugins available. 
- A new notification action/delivery plugin (flir-notify-microsoft-teams) has been added that will send a message to Microsoft Teams users. 
- A new hint plugin for AWS Redshift has been added that allows specific assets to be sent to specific Redshift tables. 
- A new filter plugin (flir-filter-regex) has been added that is designed for filtering string type data points and allows string match and replace functionality in the values of the data points using regular expression. 
- A new filter plugin (flir-filter-normalise) has been added that will allow data to be normalized to a particular reading rate within a stream. 
- A new filter plugin (flir-filter-asset-join) has been added that will allow two assets to be joined with a pipeline. 
- An update has been done to the OMF north plugin to correctly handle the set of reserved characters in PI tag names when using the new linked data method for inserting data in the PI Server. 
- The OMF north plugin has been updated to make an additional test for the server hostname when it is configured. This will give clearer feedback in the error log if a bad hostname is entered or the hostname can not be resolved. This will also confirm that IP addresses entered are in the correct format. 
- Some enhancements have been made to the OMF north plugin to improve the performance when there are large numbers of distinct assets to send to the PI Server. 
- There have been improvements to the OMF north plugin to prevent an issue that could cause the plugin to stop sending data if the type of an individual datapoint changed repeatedly between integer and floating point values. The logging of the plugin has also been improved, with clearer messages and less repetition of error conditions that persist for long periods. 
- Support for multiple data centers for OSIsoft Cloud Services (OCS) has been added in the OMF north plugin. OCS is hosted in the US-West and EU-West regions. 
- When processing data updates from the PI Server at high rates, the PI Server Update Manager queue might overflow. This is caused by the PI Server not retrieving data updates until all registrations were complete. To address this, the PI Server South plugin has been updated to interleave registration and retrieval of data updates so that data retrieval begins immediately. 
- Macro substitution has been added to the OMFHint filter allowing the contents of datapoints and metadata to be incorporated into the values of the OMF Hint, for example in the Asset Framework location can now include data read from the data source in the location. 
- The PI Server south plugin now allows the Asset Framework location to be added as a datapoint. This can then be used in the OMFHint filter to create the location in the destination PI server or otters north destination for the data. If going to another PI server the macro substitution feature that has been added to the OMF Hint filter can be used. 
- The PI Server South plugin responds properly if AF Attributes are edited or edited, and if PI Points are deleted. Unfortunately, it is not possible to detect PI Point attribute edits. It is not possible to detect creation of new AF Attributes or PI Points that match the query parameters. If this occurs, you must restart your PI Server South instance. 
- The asset filter has been updated to allow it to split assets into multiple assets, with the different data points in the original asset being assigned to one or more of the new assets created. 
- The asset filter has been enhanced to allow it to flatten a complex asset structure. This allows nested data to be moved to the root level of the asset. 
- The asset filter has been enhanced to allow it to remove data points from readings. 
- Windowed averages in the notification service preserve the type of the input data when creating the averages. This does not work well for integer values and has been changed such that integer values are promoted to floating point when using windowed averages for notification rule input. 
- The CSV writer filter plugin has been updated to improve the options available for defining the file names to use. 
- The sigma cleanse filter has been enhanced to persist the calculated sigma value when shutdown. This allow the learnt sigma values to be persisted across restarts of Flir or the individual services. 
- A problem that prevented filters being used with the notify-north plugin has been fixed. 
- The spectrogram filter has been updated to support conditional forwarding. 
- ADM LD prediction filter plugin and the autoencoder model inside it have been updated to make use of latest vibration data from more accelerometers and an improved data preprocessing pipeline. 
- A new feature has been added that allows pipelines to be defined that may be applied to control operations. This allows the filter pipelines to manipulate the control requests that arrive from various sources within Flir. 
- The documentation for the control notification plugin has been updated to include examples for all destinations of control requests. 
- The notification mechanism has been updated to accept raw statistics and statistics rates as an input for notification rules. This allows alerts to be raised for pipeline flows and other internal tasks that generate statistics. 
- Notifications can now register for audit log entries to be sent to notification rules. This allows notification to be made based on internal state changes of the system. 
- The flir-north-opcuaclient plugin has been updated to support multiple values in a single write as well as to support OPC UA security mode and security policies. 
- The HTTP North C plugin now supports sending audit log data as well as readings and statistics. 
- The flir-north-kafka plugin has been updated to allow for username and password authentication to be supplied when connecting to the Kafka server and Compression functionality has been added 
- The average and watchdog rules have been updated to allow selection of data sources other than the readings to be sent to the rules. 
- The email notification plugin has been updated to allow custom alert messages to be created. 
- The email notification delivery plugin has been updated to hide the password from view. 
- Some devices were not compatible with the optimized block reading of registers performed by the ModbusC south plugin. The ModbusC plugin has been updated to provide controls that can determine how it reads data from the modbus device. This allows single register reads, single object reads and the current optimized block reads. 
- The S2OPCUA South plugin now supports an optional datapoint in its Readings that shows the full path of the OPC UA Variable in the server’s namespace. 
- An option to configure and use a username and password for authentication to the MQTT broker has been added to the flir-south-mqtt plugin. 
- The North service could crash if it retrieved invalid JSON while processing a reconfiguration request. This was addressed by adding an exception handler to prevent the crash. 
- The audit logger has been made available to plugins running within the notification service. 
- The etherip south plugin has been updated to allow multiple tag items to be ingested in a single poll call. 
- The Simple REST south plugin documentation has been updated to include the new authentication options. The plugin configuration has also been updated to make use of the new tab based display, grouping related configuration options together. 
- The notification service documentation has been updated to include examples of notifications based on statistics and audit logs. 
- Documentation of the AF Location OMFHint in the OMF North plugin page has been updated to include an outline of differences in behaviors between Complex Types and the new Linked Types configuration. 
- The documentation of the OMF North plugin has been updated to conform with the latest look and feel of the configuration user interface. It also contains notes regarding the use of complex types versus the OMF 1.2 linked types. 
- The documentation for the asset filter has been improved to include more examples and explanations for the various uses of the plugin and to include all the different operations that can be performed with the filter. 
 
- Bug Fix: - The OMF North plugin that is used to send Data to the AVEVA PI Server has been updated to improve the performance of the plugin. 
- The OMF North plugin sent basic data type definitions to AVEVA Data Hub (ADH) that could not be processed resulting in a loss of all time series data. This has been fixed. 
- A product version check was made incorrectly if the OMF endpoint type was not PI Web API. This has been fixed. 
- The PI Server South plugin would start and run normally but would crash during shutdown. The crash did not affect configuration data persisted by the plugin. This has been fixed. 
- The PI Server South plugin had a memory leak which caused memory usage to grow significantly and never recover. This has been fixed. 
- PI Server South responds properly if the PI Web API or PI Server is not available at plugin startup: it will wait until the server is reachable and then continue. The plugin also handles PI Servers restarting while processing data updates. 
- The PI Server South plugin now has a configurable limit on the number of data streams loaded by the plugin. When this limit is reached, the plugin will not load any more streams and will log a warning. Setting the limit to 0 disables this limit check. 
- If a query for AF Attributes includes a search string token that does not exist, PI Web API returns an HTTP 400 error. PI Server South now retrieves error messages if this occurs and logs them. 
- Recent changes in the OMF North plugin caused the data streaming to the Edge Data Store (EDS) to fail. This has been fixed. The fix has been tested with EDS 2020 (Version 1.0.0.609). 
- The north OPC UA client plugin has been updated to support higher data transfer rates. 
- The Flir S2OPCUA South plugin has been updated to support large numbers of Monitored Items. 
- An issue with NULL string data being returned from OPC UA servers has been resolved. NULL strings will not be represented in the readings, no data point will be created for the NULL string. 
- The Flir S2OPCUA South plugin would become unresponsive if the OPC UA server was unavailable or if the server URL was incorrect. The only way to stop the plugin in this state was to shut down Flir. This has been fixed. 
- An issue related to using averaging with the statistics history input to the notification rules has been fixed. 
- An issue with set point control operations occurring before a south plugin is fully ready has been resolved. 
- An issue with the S2OPCUA South plugin that allowed a negative value to be entered for the minimum reporting interval has been resolved. The plugin has also been updated to use the new tab format for configuration item grouping. 
- An issue with reconfiguring a Kafka north plugin has been resolved, this now behaves correctly in all cases. 
- An issue with sending data to Kafka that included image data points has been resolved. There is no support in Kafka for images and they will be removed while allowing the remainder of the data to be sent to Kafka. 
- An issue with the Modbus-TCP & S7 plugins which caused the polling to fail has been resolved. 
- An issue with the statistics filter that could cause the median statistics to be incorrect in certain cases has been resolved. 
- An issue with the reconfiguration of the statistics filter which caused the filter to always output all statistics has been resolved. 
- A problem with the J1708 & J1939 plugins that caused them to fail if added disabled and then later enabling them has been resolved. 
- A problem that caused the Azure IoT Core north plugin to fail to send data has been corrected. 
- A problem that prevented the installation of the sigfns filter plugin has been resolved. 
- A problem with the asset delivery plugin that would sometimes result in stopping the notification service has been resolved. 
- A problem with installation of the person detection plugin on Ubuntu 20 has been resolved. 
- An issue that could cause notification to not trigger correctly when used with conditional forwarding has been resolved. 
- An issue with using multiple Python based plugins in a north conditional forwarding pipeline has been resolved. 
- The notification sent an audit log entry was created even when the delivery failed. It should only be created on successful delivery. This has been fixed. 
- Changing the name of an asset in a notification rule could sometimes cause an error to be incorrectly logged. This has now been resolved. 
- The asset notification delivery plugin was not previously creating entries in the asset tracker. This has now been resolved. 
- Various filters summarize data over time, these have been standardized to use the times of the summary calculation. 
- A packaging issue with the flir-filter-image-resize plugin has been resolved. 
- A packaging issue with the flir-filter-image-bounding-box plugin has been resolved. 
- The threshold filter interface has been tidied up, removing duplicate information. 
- The control map configuration item of the Modbus C plugin was incorrectly described. This has now been resolved. 
- flir-filter-specgram & flir-notify-jsonconfig plugins have been updated to have default values for mandatory configuration items. 
 
 
v2.1.0¶
Release Date: 2022-12-26
- Flir Core - New Features: - North plugins run as a task rather than a service would be run by the Python sending task rather than the C++ sending task. This resulted in filter pipelines not being applied to the task. This has now been resolved. 
- A new mechanism has been introduced that allows configuration items within a category to have a group associated with them. This allows items that relate to a particular mechanism be recognised as related by clients of the API and display decisions to be taken based on these groups. 
- The asset browser APIs have been enhanced to allow for a window of data in the past to be returned. In conjunction a new timespan entry point has been added to allow the oldest and newest date for which an asset exists within the reading buffer to be returned. 
- An option has been added to the advanced configuration of south services that allow the statistics that are generated by the south service to be tailored. Statistics may be kept for the service as a whole, each asset ingested by the service or both. This setting relates to a given service and may be different in different south services. Full details are available in the tuning guide within the documentation. 
- Two new types of user are now available in Flir; users that can view the configuration only and users that can view the data only. 
 
- Bug Fix: - The reset and purge scripts have been improved such that if the reading plugin is different from the storage plugin the data will be removed from the appropriate plugins. 
- A problem that prevented items from being disabled in the user interface when they were not valid for the current configuration has been resolved. 
- An issue that would sometimes cause the error Not all updates in a transaction succeeded to be logged when updating the users access token has been resolved. 
- An issue that could cause properties of configuration items to be lost or incorrectly updated has been resolved. 
 
 
- GUI - New Features: - The graphical user interface for viewing the configuration of the south and north services and tasks has now been updated to display the configuration items in multiple tabs. 
- The user interface now supports two types of view only users; those that can view the configuration and those that can view the data only. 
 
- Bug Fix: - An issue that could leave two menu items selected in the menu pane of the user interface has been resolved. 
- The tab view of tabular data in the user interface has been updated to show the date as well as the time related to readings. 
 
 
- Services & Plugins - New Features: - A new north plugin, flir-north-mqtt-scritped, has been created to send data north using MQTT. It provides a mechanism to use a Python script to format the payload of the MQTT messages. The plugin also supports the flow of control messages that trigger writes and operations from MQTT messages at the plugin. 
- A new north plugin, flir-north-opcuaclient, has been created to send data with OPC UA Client to an OPC UA Server. 
- The asset filter has been updated to support the ability to map datapoint names for an asset. 
- The OMF north plugin now supports all ADH regions. 
- The OMF north plugin has been updated to allow support for OMF 1.2 features. This allows for better control of types within OMF resulting in the OMF plugin now dealing more cleanly with assets with different datapoints in different readings. Any assets that are already being sent to an OMF endpoint will continue to use the previous type mechanism. A number of new OMF hints are also supported. 
- The S2OPCUA south plugin has been updated to allow the timestamp for readings to be taken from the OPC UA server itself rather than the time that it was received by Flir. 
- Support has been added to the Suez Water and the Samotics south plugin to configure an HTTP proxy to be used to connect to the API services. 
- The simple REST south plugin has been updated to allow the definition of the basic authentication mechanism, including the entry of a username and password. 
 
- Bug Fix: - An issue with building of the DNP3 plugin on the Raspberry Pi platform has been resolved. 
- The S2OPCUA south plugin has been updated to resolve an issue with duplicate browse names causing data from two OPC UA variables being stored in the same Flir datapoint. The plugin has also been updated to give more options for how the assets are structured. The option of a single asset for all datapoints and an asset put OPC UA object have been added. It is also possible to use the OPC UA object name as the prefix for asset names in the case of a single variable per asset as well as the current option of a fixed prefix for the browse name of the variable. 
 
 
v2.0.1¶
Release Date: 2022-10-20
- Flir Core - New Features: - A new option, healthcheck has been added to the command line script used to start, stop and monitor the instance. This runs a number of checks against the system to detect common misconfigurations and issues with the environment that have been observed to cause issues with the system. 
- A third source of data is now available for sending to the north plugins, the internal audit log. This contains information such as configuration changes, services failures and other significant events within the Flir instance. Note that a plugin must indicate it is able to handle audit data before it will be available within the plugin, currently the OPCUA north plugin is able to accept audit data. 
- The SQLite storage plugins have been updated to periodically reclaim free storage. This is useful for installations that experience short term peaks in storage demand as it will release the storage used during those peaks back to the operating system. 
- The API to fetch audit log entries has been enhanced to allow a time based filter to be applied. This allows only audit log entries since a given date to be returned to the caller. 
- A new API has been added that will fetch the list of packages that are available to be updated on the system. 
- Two new API entry points have been added that return health data for the logging subsystems and the storage service. These are used by the healthcheck option of the flir command script. 
- The nesting of JSON objects that represent readings was previously limited to two levels within JSON, this limitation has now been lifted in line with the internal representation of nested objects. This is particularly important when handling audit log data in north plugins and now allows full audit log entries to be transmitted via north plugins. 
- Improvements have been made to error logs to diagnose certain storage faults. Also the ability to recover from some storage faults connected to gathering of statistics has been added. 
- Some improvements to the diagnostics for control operations within the system have been made to aid in the development of control pipelines within the system. 
- The public REST API documentation has been updated to cover more of the entry points supported and also to include examples of calling the asset browsing and statistics APIs using Grafana. 
 
- Bug Fix: - An issue with incorrectly formed JSON when control operations are triggered from the north service has been resolved. 
- A fix has been added to prevent a crash when the incorrect number of arguments is given to get_plugin_info. Also the function name to extract has been defaulted to be plugin_info. 
- An issue with control operation parameters which had embedded quotes within the parameter values has been resolved. This previously caused some control operations from north services to not be processed by the control dispatcher service. 
- When modifying a schedule the audit log entry, SCHCH for that changed, was previously added twice. This has now been resolved. 
- An issue that prevented a change to the units used for reading rate, e.g. per second, per minute or per hour, not being actioned until a service was restarted has now been fixed. If the rate was also changed then this change would be actioned. 
- It was possible to set a reading rate of 0 readings, this would cause the south service to fail. It is now not possible to set a rate of 0. 
 
 
- Services & Plugins - New Features: - Support has been added to the OMF north plugin that allows the AVEVA Data Hub to be specified as a destination. 
- The flir-south-simple-rest plugin has been updated to allow for use of an HTTP proxy. 
- The Samotics4 south plugin was previously unable to add metadata to the incident reports, this has now been added to the plugin. 
- Documentation has been added for the GCP Pub/Sub north plugin. 
 
- Bug Fix: - The service dispatcher was previously looking at the wrong service type when sending operation messages to south service, this has now been resolved. 
- A bug in the scale-set filter that caused integer values to remain as integers when scaled to a value that could not be represented in an integer, e.g. scaling down or scaling by a non-integer factor, has been resolved. 
- The S2OPCUA south plugin provides a configuration option, minimum reporting interval that is used to slow the rate of reporting down for busy item. No reports of changes will be recorded when the change happens more frequently than the value set. In the case of the S2OPCUA plugin this was being ignored. It is now actioned correctly within the plugin. 
- The flir-south-mqtt-scripted plugin has been made more robust to loss of connection to the MQTT broker. It has also become more resilient to incorrectly entered broker addresses and more responsive when the broker is not reachable. 
 
 
v2.0.0¶
Release Date: 2022-09-09
- Flir Core - New Features: - The storage interface used to query generic configuration tables has been improved to support tests for null and non-null column values. 
- The ability for north services to support control inputs coming from systems north of FLir has been introduced. 
- The handling of a failed storage service has been improved. The client now attempt to re-connect and if that fails they will down. The logging produced is now much less verbose, removing the repeated messages previously seen. 
- A new service has been added to Flir to facilitate the routing of control messages within Flir. This service is responsible for determining which south services to send control requests to and also for the security aspects of those requests. 
- Ensure that new Flir data types not supported by OMF are not processed. 
- The storage service now supports a richer set of queries against the generic table interface. In particular, joins between tables are now supported. 
- South services that have a slow poll rate can take a long time to shutdown, this sometimes resulted in those services not shutting down cleanly. The shutdown process has been modified such that these services now shutdown promptly regardless of polling rate. 
- A new configuration item type has been added for the selection of access control lists. 
- Support has been added to the Python query builder for NULL and NOT NULL columns. 
- The Python query builder has been updated to support nested database queries. 
- The third party packages on which Flir is built have been updated to use the latest versions to resolve issues with vulnerabilities in these underlying packages. 
- When the data stream from a south plugin included an OMF Hint of AFLocation, performance of the OMF North plugin would degrade. In addition, process memory would grow over time. These issues have been fixed. 
- The version of the PostgreSQL database used by the Postgres storage plugin has been updated to PostgreSQL 13. 
- An enhancement has been added to the North service to allow the user to specify the block size to use when sending data to the plugin. This helps tune the north services and is described in the tuning guide within the documentation. 
- The notification server would previously output warning messages when it was starting, these were not an indication of a problem and should have been information messages. This has now been resolved. 
- The backup mechanism has been improved to include some external items in the backup and provide a more secure backup. 
- The purge option that controls if unsent assets can be purged or not has been enhanced to provide options for sent to any destination or sent to all destinations as well as sent to no destinations. 
- It is now possible to add control features to Python south plugins. 
- Certificate based authentication is now possible between services in a single instance. This allows for secure control messages to be implemented between services. 
- Performance improvements have been made such that the display of south service data when large numbers of assets are in use. 
- The new micro service, control dispatcher, is now available as a package that can be installed via the package manager. 
- New data types are now supported for data points within an asset and are encoded into various Python types when passed to Python plugins or scripts run within standard plugin. This includes numpy arrays for images and data buffers, 2 dimensional Python lists and others. Details of the type encoding can be found in the plugin developers guide of the online product documentation. 
- The mechanism for online update of configuration has been extended to allow for more configuration to be modified without the need to restart any services. 
- Support has been added for the Raspberry Pi Bullseye release. 
- A problem with a file descriptor leak in Python that could cause Flir to fail has been resolved. 
- The control of logging levels has now been added to the Python code run within a service such that the advanced settings option is now honoured by the Python code. 
- Enhancements have been made to the asset tracker API to retrieve the service responsive for the ingest of a given asset. 
- A new API has been added to allow external viewing and managing of the data that various plugins persist. 
- A new REST API entry point has been added that allows all instances of a specified asset to be purged from the buffer. A further entry point has also been added to purge all data from the reading buffer. These entry points should be used with care as they will cause data to be discarded. 
- A new parameter has been added to the asset retrieval API that allows image data to be returned, images=include. By default image type datapoints will be replaced with a message, “Image removed for brevity”, in order to reduce the size of the returned payload. 
- A new API has been added to the management API that allows services to request that URL’s in the public API are proxied to the service API. This is used when extending the functionality of the system with custom microservices. 
- A new set of API calls have been added to the public REST API of the product to support the control dispatcher and for the creation and management of control scripts. 
- A new API has been added to the public API that will return the latest reading for a given asset. This will return all data types including images. 
- A new API has been added that allows asset tracking records to be marked as deprecated. This allows the flushing of relationships between assets and the services that have processed them. It is useful only in development systems and should not be used in production systems. 
- A new API call has been added that allows the persisted data related to a plugin to be retrieved via the public REST API. The is intended for use by plugin writers and to allow for better tracking of data persisted between service executions. 
- A new query parameter has been added to the API used to fetch log messages from the system log, nontotals. This will increase the performance of the call at the expense of not returning the total number of logs that match the search criteria. 
- New API entry points have been added for the management of Python packages. 
- Major performance improvements have been made to the code for retrieving log messages from the system log. This is mainly an issue on systems with very large log files. 
- The storage service API has been extended to support the creation of private schemas for the use of optional micro services registered to a Flir instance. 
- Filtering by service type has now been added to the API that retrieve service information via the public REST API. 
- A number of new features have been added to the user interface to aid developers creating data pipelines and plugins. These features allow for manual purging of data, deprecating the relationship between the services and the assets they have ingested and viewing the persisted data of the plugins. These are all documented in the section on developing pipelines within the online documentation. 
- A new section has been added to the documentation which discusses the process and best practices for building data pipelines in Flir. 
- A glossary has been added to the documentation for the product. 
- The documentation that describes the writing of asynchronous Python plugins has been updated in line with the latest code changes. 
- The documentation has been updated to reflect the new tabs available in the Flir user interface for editing the configuration of services and tasks. 
- A new introduction section has been added to the Flir documentation that describes the new features and some typical use cases of Flir. 
- A new section has been added to the Flir Tuning guide that discusses the tuning of North services and tasks. Also scheduler tuning has been added to the tuning guide along with the tuning of the service monitor which is used to detect failures of services within Flir. 
- The Tuning Flir section of the documentation has been updated to include information on tuning the Flir service monitor that is used to monitor and restart Flir services. A section has also been added that describes the tuning of north services and tasks. A new section describes the different storage plugins available, when they should be used and how to tune them. 
- Added an article on Developing with Windows Subsystem for Linux (WSL2) to the Plugin Developer Guide. WSL2 allows you to run a Linux environment directly on Windows without the overhead of Windows Hyper-V. You can run Flir and develop plugins on WSL2. 
- Documentation has been added for the purge process and the new options recently added. 
- Documentation has been added to the plugin developer guides that explain what needs to be done to allow the packaging mechanism to be able to package a plugin. 
- Documentation has been added to the Building Pipelines section of the documentation for the new UI feature that allows Python packages to be installed via the user interface. 
- Documentation has been updated to show how to build Flir using the requirements.sh script. 
- The documentation ordering has been changed to make the section order more logical. 
- The plugin developers guide has been updated to include information on the various flags that are used to communicate the options implemented by a plugin. 
- Updated OMF North plugin documentation to include current OSIsoft (AVEVA) product names. 
- Fixed a typo in the quick start guide. 
- Improved north plugin developers documentation is now available. 
 
- Bug Fix: - The Flir control script has options for purge and reset that requires a confirmation before it will continue. The message that was produced if this confirmation was not given was unclear. This has now been improved. 
- An issue that could cause a north service or task that had been disabled for a long period of time to fail to send data when it was re-enabled has been resolved. 
- S2OPCUA Toolkit changes required an update in build procedures for the S2OPCUA South Plugin. 
- Previously it has not been possible to configure the advanced configuration of a south service until it has been run at least once. This has now been resolved and it is possible to add a south service in disable mode and edit the advanced configuration. 
- The diagnostics when a plugin fails to load have been improved. 
- The South Plugin shutdown problem was caused by errors in the plugin startup procedure which would throw an exception for any error. The plugin startup has been fixed so errors are reported properly. The problem of plugin shutdown when adding a filter has been resolved. 
- The update process has been optimised to remove an unnecessary restart if no new version of the software are available. 
- An issue that could on rare occasions cause the SQLite plugin to silently discard readings has been resolved. 
- An issue with the automatic renewal of authentication certificates has been resolved. 
- Deleting a service which had a filter pipeline could cause some orphaned configuration information to be left stored. This prevented creating filters of the same name in the future. This has now been resolved. 
- The error reporting has been improved when downloading backups from the system. 
- An issue that could cause north plugins to occasionally fail to shutdown correctly has now been resolved. 
- Some fixes are made in Package update API that allows the core package to be updated. 
- Improvements have been made to the exponential moving average filter to resolve issues seen when data is heavily delayed before passing through the filter. 
- The documentation has been updated to correct a statement regarding running the south side as a task. 
 
 
- GUI - New Features: - A new Developer item has been added to the user interface to allow for the management of Python packages via the UI. This is enabled by turning on developer features in the user interface Settings page. 
- A control has been added that allows the display of assets in the South screen to be collapsed or expanded. This allows for more services to be seen when services ingest multiple assets. 
- A new feature has been added to the south page that allows the relationship between an asset and a service to be deprecated. This is a special feature enabled with the Developer Features option. See the documentation on building pipelines for a full description. 
- A new feature has been added to the Assets and Readings page that allows for manual purging of named assets or all assets. This is a developer only feature and should not be used on production systems. The feature is enabled, along with other developer features via the Settings page. 
- A new feature has been added to the South and North pages for each service that allows the user to view, import, export and delete the data persisted by a plugin. This is a developer only feature and should not be used on production systems. It is enabled via the Setting page. 
- A new configuration type, Access Control List, is now supported in user interface. This allows for selection of an ACL from those already created. 
- A new tabbed layout has been adopted for the editing of south and north services and tasks. Configuration, Advanced and Security tabs are supported as our tabs for developer features if enabled. 
- The user interface for displaying system logs has been modified to improve the performance of log viewing. 
- The User Interface has been updated to use the latest versions of a number of packages it depends upon, due to vulnerabilities reported in those packages. 
- With the introduction of image data types to the readings supported by the system the user interface has been updated to add visualisation features for these images. A new feature also allows the latest reading for a given asset to be shown. 
- A new feature has been added to the south and north pages that allows the user to view the logs for the service. 
- The service status display now includes the Control Dispatcher service if it has been installed. 
- The user interface now supports the new control dispatcher service. This includes the graphical creation and editing of control scripts and access control lists used by control features. 
- An option has been added to the Asset and Readings page to show just the latest values for a given asset. 
- The notification user interface now links to the relevant sections of the online documentation allowing users to navigate to the help based on the current context. 
- Some timezone inconsistencies in the user interface have been resolved. 
 
- Bug Fix: - An issue that would cause the GUI to not always allow JSON data to be saved has been resolved. 
- An issue with the auto refresh in the systems log page that made selecting the service to filter difficult has been resolved. 
- The sorting of services and tasks in the South and North pages has been improved such that enabled services appear above disabled services. 
- An issue the prevented gaps in the data from appearing int he groans displayed by the GUI has now been resolved. 
- Entering times in the GUI could sometimes be difficult and result in unexpected results. This has now been improved to ease the entry of time values. 
- An issue that made the editing of scripts in the user interface for south plugins has been resolved. 
 
 
- Plugins - New Features: - A new flir-filter-contrast has been added that allows the contrast of image type datapoints to be altered. 
- A new flir-filter-mirror plugin has been added that will mirror image data points in a reading either vertically or horizontally. 
- A new flir-filter-rotate plugin has been added that allows for images in data points to be rotated by 90, 180 or 270 degrees. 
- A new flir-filter-greyscale plugin has been added that will convert 24bit RGB images in the reading data to either 8bit or 16bit greyscale images. All non-image and on-24bit images are left unaltered by the plugin.- A new flir-notify-control plugin has been added that allows notifications to be delivered via the control dispatcher service. This allows the full features of the control dispatcher to be used with the edge notification path. 
- A new flir-rule-watchdog plugin has been added that allows notifications to be send if data stops being ingress for specified assets. 
- A new flir-south-video4linux has been created that uses the Video4Linux interface to support the capture of image data from a variety of of video sources supported by Linux. 
- A new flir-south-etherip plugin has been added to retrieve data for a number of different Allan Bradley PLCs. Also it has enable control features. This allows Flir to write data back to PLC’s using the etherip protocol. 
- Support has been added for proxy servers in the north HTTP-C plugin. 
- Add options for choosing the Flir Asset name: Browser Name, Subscription Path and Full Path. Use the OPC UA Source timestamp as the User Timestamp in Flir. 
- OPC UA Security has been enhanced. This plugin now supports Security Policies Basic256 and Basic256Sha256, with Security Modes Sign and Sign & Encrypt. Authentication types are anonymous and username/password. 
- The OPCUA north plugin has been updated to include the ability for systems outside of Flir to write to the server that Flir advertises. These write are taken as control input into the Flir system. 
- The HTTPC North plugin has been enhanced to add an optional Python script that can be used to format the payload of the data sent in the HTTP REST request. 
- The SQLite storage plugins have been updated to support service extension schemas. This is a mechanism that allows services within the Flir system to add new schemas within the storage service that are exclusive to that service. 
- The Python35 filter has been updated to use the common Python interpreter. This allows for packages such as numpy to be used. The resilience and error reporting of this plugin have also been improved. 
- A set of developer only features designed to aid the process of developing data pipelines and plugins has been added in this release. These features are turned on and off via a toggle setting on the Settings page. 
- A new option has been added to the Python35 filter that changes the way datapoint names are used in the JSOn readings. Previously there had to be encoded and decode by use of the b’xxx’ mechanism. There is now a toggle that allows for either this to be required or simple text string use to be enabled. 
- The API of the storage service has been updated to allow for custom schemas to be created by services that extend the core functionality of the system. 
- New image type datapoints can now be sent between instances using the http north and south plugins. 
- The ability to define response headers in the http south plugin has been added to aid certain circumstances where CORS provided data flows. 
- The documentation of the Python35 filter has been updated to include a fuller description of how to make use of the configuration data block supported by the plugin. 
- The documentation describing how to run services under the debugger has been improved along with other improvements to the documentation aimed at plugin developers. 
- Documentation has been added for the Azure north plugin. 
- Documentation has now been added for flir-north-harperdb. 
- Documentation has been added for the custom asset notification plugin. 
- The documentation has been updated to include the new watchdog notification rule. 
- Documentation has been added for the Suez Water south plugin 
- Documentation has been added for the flir-rule-periodic plugin. 
- Documentation has been added for the flir-filter-asset-split plugin. 
- Documentation has been added for the flir-filter-specgram plugin. 
- Documentation has been added for the flir-filter-fft2 plugin. 
 
- Bug Fix: - Build procedures were updated to accommodate breaking changes in the S2OPC OPCUA Toolkit. 
- Occasionally switching from the sqlite to the sqlitememory plugin for the storage of readings would cause a fatal error in the storage layer. This has now been fixed and it is possible to change to sqlitememory without an error. 
- A race condition within the modbus south plugin that could cause unfair scheduling of read versus write operations has been resolved. This could cause write operations to be delayed in some circumstances. The scheduling of set point write operations is now fairly interleaved between the read operations in all cases. 
- A problem that caused the HTTPC North plugin to fail if the path component of the URL was omitted has been resolved. 
- The modbus-c south plugin documentation has been enhanced to include details of the function codes used to read modbus data. 
- An incorrect error message in the modbus-c south plugin has been fixed and others have been improved to aid resolving configuration issues. The documentation has been updated to include descriptive text for the error messages that may occur. 
- The Python35 filter plugin has been updated such that if no data is to be passed onwards it may now simply return the None Python constant or an empty list. 
- The Python35 plugin which allows simple Python scripts to be added into filter pipelines has had a number of updates to improve the robustness of the plugin in the event of incorrect script code being provided by the user. The behaviour of the plugin has also been updated such that any errors run the script will prevent data being passed onwards the filter pipeline. 
- The Average rule has been updated to improve the user interaction during the configuration of the rule. 
- The first time a plugin that persisted data is executed erroneous errors and warnings would be written to the system log. This has now been resolved. 
- Python35 filter code that failed to return a properly formed asset in the response would previously crash rather than fail gracefully. An error explaining the exact cause of the failure is now logged in the system log. 
- An issue with the Kafka north plugin not sending data in certain circumstances has been resolved. 
- Adding some notification plugins would cause incorrect errors to be logged to the system log. The functioning of the notifications was not affected. This has now been resolved and the error logs no longer appear. 
- The Simple-REST south plugin has been enhanced to allow it to return no records using the Python None mechanism. Also its error reporting has been improved for cases where the script is missing or incorrectly named. 
- A problem with installing the csvplayback plugin on aarch64 platforms has been resolved. 
- The MQTT Scripted south plugin has been updated to give improved error messages when problems are found with the supplied convert script. The documentation has also been updated to include these messages and typical causes of the errors. 
- The S2OPCUA South Plugin would throw an exception for any error during startup. This would cause the core system to shut down the plugin permanently after a few retries. This has been fixed. Error messages has been recategorized to properly reflect informational, warning and error messages. 
- The OMF North plugin was unable to process configuration changes or shut down if the PI Web API hostname was not correct. This has been fixed. 
- S2OPC South plugin builds have been updated to explicitly reference S2OPC Toolkit Version 1.2.0. 
- The documentation for the flir-rule-delta plugin has been corrected. 
- The documentation for the Python35 filter has been updated to discuss Python package imports and issues when removing previously used imports. 
 
 
Flir v1¶
v1.9.2¶
Release Date: 2021-09-29
- Flir Core - New Features: - The ability for south plugins to persist data between executions of south services has been added for plugins written in C/C++. This follows the same model as already available for north plugins. 
- Notification delivery plugins now also receive the data that caused the rule to trigger. This can be used to deliver values in the notification delivery plugins. 
- A new option has been added to the sqlite storage plugin only that allows assets to be excluded from consideration in the purge process. 
- A new purge process has been added to control the growth of statistics history and audit trails. This new process is known as the “System Purge” process. 
- The support bundle has been updated to include details of the packages installed. 
- The package repository API endpoint has been updated to support Ubuntu 20.04 repository end point. 
- The handling of updates from RPM package repositories has been improved. 
- The certificate store has been updated to support more formats of certificates, including DER, P12 and PFX format certificates. 
- The documentation has been updated to include an improved & detailed introduction to filters. 
- The OMF north plugin documentation has been re-organised and updated to include the latest features that have been introduced to this plugin. 
- A new section has been added to the documentation that discusses the tuning of the edge based control path. 
 
- Bug Fix:
- A rare race condition during ingestion of readings would cause the south service to terminate and restart. This has now been resolved. 
- In some circumstances it was seen that north services could send the same data more than once. This has now been corrected. 
- An issue that caused an intermittent error in the tracking of data sent north has been resolved. This only impacted north services and not north tasks. 
- An optimisation has been added to prevent north plugins being sent empty data sets when the filter chain removes all the data in a reading set. 
- An issue that prevented a north service restarting correctly when certain combinations of filters were present has been resolved. 
- The API for retrieving the list of backups on the system has been improved to honour the limit and offset parameters. 
- An issue with the restore operation always restoring the latest backup rather than the chosen backup has been resolved. 
- The support package failed to include log data if binary data had been written to syslog. This has now been resolved. 
- The configuration category for the system purge was in the incorrect location with the configuration category tree, this has now been correctly placed underneath the “Utilities” item. 
- It was not possible to set a notification to always retrigger as there was a limitation that there must always be 1 second between notification triggers. This restriction has now been removed and it is possible to set a retrigger time of zero. 
- An error in the documentation for the plugin developers guide which incorrectly documented how to build debug binaries has been corrected. 
 
 
 
- GUI - New Features: - The user interface has been updated to improve the filtering of logs when a large number of services have been defined within the instance. 
- The user interface input validation for hostnames and port has been improved in the setup screen. A message is now displayed when an incorrect port or address is entered. 
- The user interface now prompts to accept a self signed certificate if one is configured. 
 
- Bug Fix: - If a south or north plugin included a script type configuration item the GUI failed to allow the service or task using this plugin to be created correctly. This has now been resolved. 
- The ability to paste into password fields has been enabled in order to allow copy/paste of keys, tokens etc into configuration of the south and north services. 
- An issue that could result in filters not being correctly removed from a pipeline of 2 or more filters has been resolved. 
 
 
- Plugins - New Features: - A new south plugin has been added that can be used to support a number of REST based APIs. The plugin allows processing of JSON payloads or with the addition of Python scripting other payload formats may also be supported. This plugin also supports a choice of methods to control the set of readings data that will be returned. 
- A new OPC/UA south plugin has been created based on the Safe and Secure OPC/UA library. This plugin supports authentication and encryption mechanisms. 
- A new plugin has been added to fetch data from the Suez Water cloud API service. 
- Control features have now been added to the modbus south plugin that allows the writing of registers and coils via the south service control channel. 
- The modbus south control flow has been updated to use both 0x06 and 0x10 function codes. This allows items that are split across multiple modbus registers to be written in a single write operation. 
- The MQTT Scripted south plugin has been updated to allow multiple assets to be ingested in a single plugin. 
- The MQTT Scripted south plugin has been enhanced to support MQTTS as well as MQTT. 
- The MQTT scripted plugin has been updated to support the return of a specific asset as well as values. 
- The OMF plugin has been updated to support more complex scenarios for the placement of assets with the PI Asset Framework. 
- The OMF north plugin hinting mechanism has been extended to support asset framework hierarchy hints. 
- The OMF north plugin now defaults to using a concise naming scheme for tags in the PI server. 
- The Kafka north plugin has been updated to allow timestamps of higher granularity than 1 second, previously timestamps would be truncated to the previous second. 
- The Kafka north plugin has been enhanced to give the option of sending JSON objects as strings to Kafka, as previously the default, or sending them as JSON objects. 
- The HTTP-C north plugin has been updated to allow the inclusion of customer HTTP headers. 
- The Python35 Filter plugin did not correctly handle string type data points. This has now been resolved. 
- The vibration velocity filter has been updated to support multiple channel data. 
- The MQTT broker package now supports RPM platforms. 
- The OMF Hint filter documentation has been updated to describe the use of regular expressions when defining the asset name to which the hint should be applied. 
- The Beckhoff south plugin documentation has been updated to include details on how to create the AMS route in a number of different scenarios. 
 
- Bug Fix: - An issue with string data that had quote characters embedded within the reading data has been resolved. This would cause data to be discarded with a bad formatting message in the log. 
- An issue that could result in the configuration for the incorrect plugin being displayed has now been resolved. 
- An issue with the modbus south plugin that could cause resource starvation in the threads used for set point write operations has been resolved. 
- A race condition in the modbus south that could cause an issue if the plugin configuration is changed during a set point operation. 
- Importing the Pandas Python library into the script within the MQTT scripted plugin previously failed due to the way Pandas uses global variables. This has now been resolved such that Pandas can be imported, however it should be noted that a filter can not import Pandas if the south plugin already imports Pandas. 
- When using the South MQTT Scripted plugin, if the Python script returned an asset name as well as a reading the asset name would be corrupted on second and subsequent calls. This has now been resolved. 
- The MQTT scripted plugin would occasionally fail to shutdown cleanly. This issue has now been resolved. 
- The MQTT Scripted plugin could not previously deal with payloads that consisted of a simple negative number. This has now been corrected. 
- An issue with the MQTT notification plugin and the MQTT scripted plugin when installing with RPM packages has been resolved. 
- The CSV playback south plugin installation on CentOS 7 platforms has now been corrected. 
- The digiducer south plugin has been updated to support the latest release of the underlying libraries that support it. 
- The error handling of the OMF north plugin has been improved such that assets that contain data types that are not supported by the OMF endpoint of the PI Server are removed and other data continues to be sent to the PI Server. 
- The Kafka north plugin was not always able to reconnect if the Kafka service was not available when it was first started. This issue has now been resolved. 
- The Kafka north plugin would on occasion duplicate data if a connection failed and was later reconnected. This has been resolved. 
- A number of fixes have been made to the Kafka north plugin, these include; fixing issues caused by quoted data in the Kafka payload, sending timestamps accurate to the millisecond, fixing an issue that caused data duplication and switching the user timestamp. 
- A problem with the quoting of string type data points on the North HTTP-C plugin has been fixed. 
- String type variables in the OPC/UA north plugin were incorrectly having extra quotes added to them. This has now been resolved. 
- The delta filter previously did not manage calculating delta values when a datapoint changed from being an integer to a floating point value or vice versa. This has now been resolved and delta values are correctly calculated when these changes occur. 
- The vibration features plugin has been updated to run on Ubuntu 20 platforms. 
- The signal processing filter plugin now installs correctly on CentOS platforms. 
- The data frames filter plugin is now supported on RPM based platforms. 
- An issue with the vibration features filter on Ubuntu 18 has been resolved. 
- The example path shown in the DHT11 plugin in the developers guide was incorrect, this has now been fixed. 
 
 
v1.9.1¶
Release Date: 2021-05-27
- Flir Core - New Features: - Support has been added for Ubuntu 20.04 LTS. 
- The core components have been ported to build and run on CentOS 8 
- A new option has been added to the command line tool that controls the system. This option, called purge, allows all readings related data to be purged from the system whilst retaining the configuration. This allows a system to be tested and then reset without losing the configuration. 
- A new service interface has been added to the south service that allows set point control and operations to be performed via the south interface. This is the first phase of the set point control feature in the product. 
- The documentation has been improved to include the new control functionality in the south plugin developers guide. 
- An improvement has been made to the documentation layout for default plugins to make the GUI able to find the plugin documentation. 
- Documentation describing the installation of PostgreSQL on CentOS has been updated. 
- The documentation has been updated to give more detail around the topic of self-signed certificates. 
 
- Bug Fix: - A security flaw that allowed non-privileged users to update the certificate store has been resolved. 
- A bug that prevented users being created with certificate based authentication rather than password based authentication has been fixed. 
- Switching storage plugins from SQLite to PostgreSQL caused errors in some circumstances. This has now been resolved. 
- The HTTP code returned by the ping command has been updated to correctly report 401 errors if the option to allow ping without authentication is turned off. 
- The HTTP error code returned when the notification service is not available has been corrected. 
- Disabling and re-enabling the backup and restore task schedules sometimes caused a restart of the system. This has now been resolved. 
- The error message returned when schedules could not be enabled or disabled has been improved. 
- A problem related to readings with nested data not correctly getting copied has been resolved. 
- An issue that caused problems if a service was deleted and then a new service was recreated using the name of the previously deleted service has been resolved. 
 
 
- GUI - New Features: - Links to the online help have been added on a number of screens in the user interface. 
- Improvements have been made to the user management screens of the GUI. 
 
 
- Plugins - New Features: - North services now support Python as well as C++ plugins. 
- A new south plugin has been created to read data from the ABB cloud service. 
- A new south plugin has been added for getting vibration data from a set of FLIR GW65 vibration sensors. 
- A new delivery notification plugin has been added that uses the set point control mechanism to invoke an action in the south plugin. 
- A new notification delivery mechanism has been implemented that uses the set point control mechanism to assert control on a south service. The plugin allows you to set the values of one or more control items on the notification triggered and set a different set of values when the notification rule clears. 
- Support has been added in the OPC/UA north plugin for array data. This allows FFT spectrum data to be represented in the OPC/UA server. 
- The documentation for the OPC/UA north plugin has been updated to recommend running the plugin as a service. 
- A new storage plugin has been added that uses SQLite. This is designed for situations with low bandwidth sensors and stores all the readings within a single SQLite file. 
- The CSV Writer filter has been updated to support writing encrypted files. 
- Support has been added to use RTSP video streams in the person detection plugin. 
- The delta filter has been updated to allow an optional set of asset specific tolerances to be added in addition to the global tolerance used by the plugin when deciding to forward data. 
- The Python script run by the MQTT scripted plugin now receives the topic as well as the message. 
- The OMF plugin has been updated in line with recommendations from the OMF group regarding the use of SCRF Defense. 
- The OMFHint plugin has been updated to support wildcarding of asset names in the rules for the plugin. 
- New documentation has been added to help in troubleshooting PI connection issues. 
- The pi_server and ocs north plugins are deprecated in favour of the newer and more feature rich OMF north plugin. These deprecated plugins cannot be used in north services and are only provided for backward compatibility when run as north tasks. These plugins will be removed in a future release. 
 
- Bug Fix: - The OMF plugin has been updated to better deal with nested data. 
- Some improvements to error handling have been added to the InfluxDB north plugin for version 1.x of InfluxDB. 
- The Python 35 filter stated it used the Python version 3.5 always, in reality it uses whatever Python 3 version is installed on your system. The documentation has been updated to reflect this. 
- The Asset Split filter plugin previously logged debug messages by default, this has now been resolved. 
- Fixed a bug that treated arrays of bytes as if they were strings in the OPC/UA south plugin. 
- The FFT2 filter used a single asset name for all output FFT’s. If an incoming asset had multiple data points they would each have a separate FFT applied to them and then output with the same asset name. This caused confusion. Now if there are multiple data points each will have a unique asset name for the output FFT. This asset name is made up of the configured output asset name with the data point name appended. For example an inout asset having X, Y and Z data points with the output asset configured to be FFT will result in 3 assets, FFTX, FFTY and FFTZ. 
- The HTTP North C plugin would not correctly shutdown, this effected reconfiguration when run as an always on service. This issue has now been resolved. 
- The description of the statistics filter was incorrect, this has now been corrected. 
- An issue with the SQLite In Memory storage plugin that caused database locks under high load conditions has been resolved.