Skip to content

Latest commit

 

History

History
703 lines (554 loc) · 115 KB

README.md

File metadata and controls

703 lines (554 loc) · 115 KB

IoTGateway

IoTGateway is a C# implementation of an IoT gateway. It is self-contained, and includes all libraries and frameworks it needs to operate.

Apart from the IoT Gateway projects, the solution is divided into different groups of projects and modules:

License

You should carefully read the following terms and conditions before using this software. Your use of this software indicates your acceptance of this license agreement and warranty. If you do not agree with the terms of this license, or if the terms of this license contradict with your local laws, you must remove any files from the IoT Gateway from your storage devices and cease to use it. The terms of this license are subjects of changes in future versions of the IoT Gateway.

You may not use, copy, emulate, clone, rent, lease, sell, modify, decompile, disassemble, otherwise reverse engineer, or transfer the licensed program, or any subset of the licensed program, except as provided for in this agreement. Any such unauthorised use shall result in immediate and automatic termination of this license and may result in criminal and/or civil prosecution.

The source code and libraries provided in this repository is provided open for the following uses:

  • For Personal evaluation. Personal evaluation means evaluating the code, its libraries and underlying technologies, including learning about underlying technologies.

  • For Academic use. If you want to use the following code for academic use, all you need to do is to inform the author of who you are, what academic institution you work for (or study for), and in what projects you intend to use the code. All that is asked in return is for an acknowledgement and visible attribution to this repository, including a link, and that you do not redistribute the source code, or parts thereof in the solutions you develop. If any solutions developed in an academic setting, become commercial, it will need a commercial license.

  • For Security analysis. If you perform any security analysis on the code, to see what security aspects the code might have, all that is asked of you, is that you inform the author of any findings at least forty-five days before publication of the findings, so that any vulnerabilities might be addressed. Such contributions are much appreciated and will be acknowledged.

Commercial use of the code, in part or in full, in compiled binary form, or its source code, requires a Commercial License. Contact the author for details.

Note: Distribution of code in source or compiled form, for purposes other than mentioned above, is not considered personal use and requires a commercial license, even if distribution is made under an apparently free license. It facilitates the development of competing software, without the investment in actually performing the corresponding coding. It also can make the use of the original libraries obsolete, as free code apparently doing the same, based on the original libraries, would be available under an apparently free license. (Thus, making distribution free does not mitigate this effect.) Developers using the libraries to enhance their own projects (brands, offerings or businesses, even if the software itself is free), should therefore consider sponsoring the development of such software. It is the express intent of the developer of these libraries to create libraries that facilitate the development of great software for IoT. Also, the commercial license includes options to request customizations of the libraries.

All rights to the source code are reserved and exclusively owned by Waher Data AB. Any contributions made to the IoT Gateway repository become the intellectual property of Waher Data AB. If you're interested in using the source code, as a whole, or in part, you need a license agreement with the author. You can contact him through LinkedIn.

This software is provided by the copyright holder and contributors "as is" and any express or implied warranties, including, but not limited to, the implied warranties of merchantability and fitness for a particular purpose are disclaimed. In no event shall the copyright owner or contributors be liable for any direct, indirect, incidental, special, exemplary, or consequential damages (including, but not limited to, procurement of substitute goods or services; loss of use, data, or profits; or business interruption) however caused and on any theory of liability, whether in contract, strict liability, or tort (including negligence or otherwise) arising in any way out of the use of this software, even if advised of the possibility of such damage.

The IoT Gateway is © Waher Data AB 2016-2025. All rights reserved.

Mastering Internet of Things

Many of the libraries available in this repository contains are described and explained in the book Mastering Internet of Things by Peter Waher. You can find the book on Packt, Amazon, Bokus and other stores.

Mastering Internet of Things Book Cover

The examples described in this book are available in a separate repository: MIoT

Solution Files

The repository contains multiple solution files. Since the repo contains many different pojects, different solution files different subsets of projects, making it easier to work with different aspects of the gateway, or on different platforms.

Solution File Description
IoTGateway.sln Main repository. Contains references to all gateway projects, for most platforms.
IoTGatewayCore.sln Solution file that contains core repositories only (i.e. .NET Standard and .NET Core projects). Can be compiled using VS Code on multiple platforms.
Cluster.sln Contains repositories related to the cluster networking library, and their dependecies.
Content.sln Contains Content-related repositories, and their dependecies.
HTTP.sln Contains repositories related to the HTTP networking library, and their dependecies.
Layout.sln Contains Layout-related repositories, and their dependecies.
Persistence.sln Contains Persistence-related repositories, and their dependecies.
Runtime.sln Contains Runtime-related repositories, and their dependecies.
Script.sln Contains Script-related repositories, and their dependecies.
XMPP.sln Contains repositories related to the XMPP networking libraries, and their dependecies.

IoT Gateway

The IoT Gateway is represented by the following set of projects. They are back-end server applications and perform communiction with devices, as well as host online content.

Project Type Link Project description
Waher.IoTClient.Setup Wix (Obsolete) The Waher.IoTClient.Setup project creates a Windows setup application that bootstraps several bundles into one setup application. Apart from installing the IoT Client, it also installs any prerequisites, such as the correct .NET framework. It is based on in Wix framework.
Waher.IoTClient.Win32 Wix (Obsolete) The Waher.IoTClient.Win32 project creates a Windows MSI package that installs the Windows 32-bit files for the IoT Client. Project is based on in Wix framework.
Waher.IoTGateway .NET Std 2.0 NuGet The Waher.IoTGateway project is a class library that defines the IoT Gateway. The gateway can host any web content. It converts markdown to HTML in real-time. It can be administrated over XMPP using the Waher.Client.WPF application.
Waher.IoTGateway.App UWP The Waher.IoTGateway.App project is a Universal Windows Platform application version of the IoT Gateway. It can be installed on IoT devices running Windows 10 IoT.
Waher.IoTGateway.Build .NET 8.0 The Waher.IoTGateway.Build project contains MSBuild script for building setup files. Can be used in an auto-build environment.
Waher.IoTGateway.Console .NET 8.0 The Waher.IoTGateway.Console project is a console application version of the IoT Gateway. It's easy to use and experiment with.
Waher.IoTGateway.Installers .NET 4.6.2 The Waher.IoTGateway.Installers project defines custom actions used by the setup application to install the IoT Gateway and dependencies propertly.
Waher.IoTGateway.Resources .NET Std 2.0 The Waher.IoTGateway.Resources project contains resource files that are common to all IoT Gateway embodiments.
Waher.IoTGateway.Setup Wix The Waher.IoTGateway.Setup project creates a Windows setup application that bootstraps several bundles into one setup application. Apart from installing the IoT Gateway, it also installs any prerequisites, such as the correct .NET framework. It is based on in Wix framework.
Waher.IoTGateway.Svc .NET 8.0 The Waher.IoTGateway.Svc project is a Windows Service version version of the IoT Gateway.
Waher.IoTGateway.Win32 Wix The Waher.IoTGateway.Win32 project creates a Windows MSI package that installs the Windows 32-bit files for the IoT Gateway. Project is based on in Wix framework.

Clients

The Clients folder contains projects starting with Waher.Client. and denote client projects. Clients are front-end applications that can be run by users to perform different types of interaction with things or the network.

Project Type Project description
Waher.Client.WPF .NET 8.0 The Waher.Client.WPF project is a simple IoT client that allows you to interact with things and users. If you connect to the network, you can chat with users and things. The client GUI is built using Windows Presentation Foundation (WPF). Chat sessions support normal plain text content, and rich content based on markdown.
Waher.Client.MqttEventViewer .NET 8.0 The Waher.Client.MqttEventViewer project defines a simple WPF client application that subscribes to an MQTT topic and displays any events it receivs. Events are parsed as XML fragments, according to the schema defined in XEP-0337.
Waher.Script.Lab .NET 8.0 The Waher.Script.Lab project is a WPF application that allows you to experiment and work with script.

Content

The Content folder contains libraries that handle Internet Content including parsing and rendering, using their corresponding Internet Content Type encodings and decodings.

Project Type Link Project description
Waher.Content .NET Std 2.0 NuGet The Waher.Content project is a class library that provides basic abstraction for Internet Content Type, and basic encodings and decodings. This includes handling and parsing of common data types.
Waher.Content.Asn1 .NET Std 2.0 NuGet The Waher.Content.Asn1 project implements a simple ASN.1 (Abstract Syntax Notation One) parser. The library supports generation of C# code from ASN.1 schemas. Encoding/Decoding schemes supported: BER, CER, DER.
Waher.Content.Dsn .NET Std 2.0 NuGet The Waher.Content.Dsn project provides encoding and decoding of Delivery Status Notification (DSN) messages and message reports, as defined in RFC 3462 and 3464.
Waher.Content.Emoji .NET Std 2.0 NuGet The Waher.Content.Emoji project contains utilities for working with emojis.
Waher.Content.Emoji.Emoji1 .NET Std 2.0 NuGet The Waher.Content.Emoji.Emoji1 project provide free emojis from Emoji One to content applications.
Waher.Content.Html .NET Std 2.0 NuGet The Waher.Content.Html project provides a simple HTML document parser that can be used to extract information from web pages. Social Meta-data can be easily extracted from page. Information is taken from Open Graph meta data or Twitter Card meta data, as well as standard HTML meta data.
Waher.Content.Images .NET Std 2.0 NuGet The Waher.Content.Images project contains encoders and decoders for images. It uses SkiaSharp for cross-platform 2D graphics manipulation. Contains extraction of EXIF meta-data from images.
Waher.Content.Markdown .NET Std 2.0 NuGet The Waher.Content.Markdown project can be used to parse Markdown documents and transforms them to other formats, such as HTML, Plain text and XAML. For a description of the markdown flavour supported by the parser, see Markdown documentation. The library can also compare Markdown documents, and provide Markdown-based difference documents, showing how one version of a document is edited to produce a second version. Reference
Waher.Content.Markdown.Consolidation .NET Std 2.1 NuGet The Waher.Content.Markdown.Consolidation project helps clients working with Markdown defined with the Markdown engine in Waher.Content.Markdown to consolidate Markdown content originating from multiple sources, generating composite documents for more intuitive presentation.
Waher.Content.Markdown.Contracts .NET Std 2.0 NuGet The Waher.Content.Markdown.Contracts project extends the rendering capabilities of the Markdown library defined in Waher.Content.Markdown, by providing a renderer to Smart Contract XML, as defined by the Neuro-Foundation (neuro-foundation.io).
Waher.Content.Markdown.GraphViz .NET Std 2.0 NuGet The Waher.Content.Markdown.GraphViz project extends the capabilities of the Markdown engine defined in Waher.Content.Markdown. It allows for real-time inclusion and generation of GraphViz diagrams, if the software is installed on the system. Markdown documentation.
Waher.Content.Markdown.JavaScript .NET Std 2.0 NuGet The Waher.Content.Markdown.JavaScript project extends the rendering capabilities of the Markdown library defined in Waher.Content.Markdown, by providing a renderer to JavaScript. Code generated can be used in browsers (for example) to dynamically generate DOM objects necessary to present the Markdown dynamically in a HTML page.
Waher.Content.Markdown.Latex .NET Std 2.0 NuGet The Waher.Content.Markdown.Latex project extends the rendering capabilities of the Markdown library defined in Waher.Content.Markdown, by providing a renderer to LaTeX.
Waher.Content.Markdown.Layout2D .NET Std 2.0 NuGet The Waher.Content.Markdown.Layout2D project extends the capabilities of the Markdown engine defined in Waher.Content.Markdown. It allows for real-time inclusion and generation of Waher.Layout.Layout2D diagrams. Markdown documentation.
Waher.Content.Markdown.PlantUml .NET Std 2.0 NuGet The Waher.Content.Markdown.PlantUml project extends the capabilities of the Markdown engine defined in Waher.Content.Markdown. It allows for real-time inclusion and generation of PlantUML diagrams, if the software is installed on the system. Markdown documentation.
Waher.Content.Markdown.SystemFiles .NET Std 2.0 NuGet The Waher.Content.Markdown.SystemFiles project helps modules to find files and applications installed on the system, for integration purposes.
Waher.Content.Markdown.Web .NET Std 2.1 NuGet The Waher.Content.Markdown.Web project allows the publishing of web content using Markdown. The library converts Markdown documents in real-time to HTML when hosted using the web server defined in Waher.Networking.HTTP.
Waher.Content.Markdown.Web.UWP UWP NuGet The Waher.Content.Markdown.Web.UWP project allows the publishing of web content using Markdown. The library converts Markdown documents in real-time to HTML when hosted using the web server defined in Waher.Networking.HTTP.UWP.
Waher.Content.Markdown.Wpf .NET Std 2.0 NuGet The Waher.Content.Markdown.Wpf project extends the rendering capabilities of the Markdown library defined in Waher.Content.Markdown, by providing a renderer to XAML (WPF flavour).
Waher.Content.Markdown.Xamarin .NET Std 2.0 NuGet The Waher.Content.Markdown.Xamarin project extends the rendering capabilities of the Markdown library defined in Waher.Content.Markdown, by providing a renderer to XAML (Xamarin Forms flavour).
Waher.Content.Markdown.Xml .NET Std 2.0 NuGet The Waher.Content.Markdown.Xml project extends the rendering capabilities of the Markdown library defined in Waher.Content.Markdown, by providing a renderer to XML.
Waher.Content.QR .NET Std 2.0 NuGet The Waher.Content.QR contains a light-weight managed encoder of QR codes. It can generate both text-based output (using block characters) for display on text devices, as well as images and color-coded codes.
Waher.Content.Rss .NET Std 2.0 NuGet The Waher.Content.Rss contains encoders and decoders of syndicalized information available in the RSS format. Architecture is extensible, allowing for customized encoding and decoding of content based on fully qualified names. The library supports RSS v0.91, v0.92, v2.0 and v2.0.1.
Waher.Content.Semantic .NET Std 2.0 NuGet The Waher.Content.Semantic contains encoders and decoders of semantic information, using well-known formats defined by the W3C for the semantic web, such as Turtle, RDF/XML and SPARQL results. Library also contains abstraction layer and extensiblea architecture for literals, as well as interfaces for semantic cubes for procedural access of semantic information.
Waher.Content.SystemFiles .NET Std 2.0 NuGet The Waher.Content.SystemFiles helps modules to find files and applications installed on the system, for integration purposes.
Waher.Content.Xml .NET Std 2.0 NuGet The Waher.Content.Xml project helps with encoding and decoding of XML. It integrates with the architecture defined in Waher.Content.
Waher.Content.Xsl .NET Std 2.0 NuGet The Waher.Content.Xsl project helps with validating and transforming XML documents. It integrates with the architecture defined in Waher.Content.

The folder also contains the following unit test projects:

Project Type Project description
Waher.Content.Asn1.Test .NET 8.0 The Waher.Content.Asn1.Test project contains unit tests for the Waher.Content.Asn1 project.
Waher.Content.Html.Test .NET 8.0 The Waher.Content.Html.Test project contains unit tests for the Waher.Content.Html project.
Waher.Content.Images.Test .NET 8.0 The Waher.Content.Images.Test project contains unit tests for the Waher.Content.Images project.
Waher.Content.Markdown.Test .NET 8.0 The Waher.Content.Markdown.Test project contains unit tests for the Waher.Content.Markdown project.
Waher.Content.QR.Test .NET 8.0 The Waher.Content.QR.Test project contains unit tests for the Waher.Content.QR project.
Waher.Content.Rss.Test .NET 8.0 The Waher.Content.Rss.Test project contains unit tests for the Waher.Content.Rss project.
Waher.Content.Semantic.Test .NET 8.0 The Waher.Content.Semantic.Test project contains unit tests for the Waher.Content.Semantic project.
Waher.Content.Test .NET 8.0 The Waher.Content.Test project contains unit tests for the Waher.Content project.

Events

The Events folder contains libraries that manage different aspects of event logging in networks.

Project Type Link Project description
Waher.Events .NET Std 2.0 NuGet The Waher.Events project provides the basic architecture and framework for event logging in applications. It uses the static class Log as a hub for all type of event logging in applications. To this hub you can register any number of Event Sinks that receive events and distribute them according to implementation details in each one. By logging all events to Log you have a configurable environment where you can change logging according to specific needs of the project.
Waher.Events.Console .NET Std 2.0 NuGet The Waher.Events.Console project provides a simple event sink, that outputs events to the console standard output. Useful, if creating simple console applications.
Waher.Events.Documentation XML The Waher.Events.Documentation project contains documentation of specific important events. This documentation includes Event IDs and any parameters they are supposed to include.
Waher.Events.Files .NET Std 2.0 NuGet The Waher.Events.Files project defines event sinks that outputs events to files. Supported formats are plain text and XML. XML files can be transformed using XSLT to other formats, such as HTML.
Waher.Events.Filter .NET Std 2.0 NuGet The Waher.Events.Filter project defines an event sink that filters incoming events before propagating them allowed events to another event sink. Use this in conjunction with another event sink to process only a subset of logged events using the second event sink.
Waher.Events.MQTT .NET Std 2.1 NuGet The Waher.Events.MQTT project defines an event sink that sends events to an MQTT topic. Events are sent as XML fragments, according to the schema defined in XEP-0337.
Waher.Events.MQTT.UWP UWP NuGet The Waher.Events.MQTT.UWP project provides a Universal Windows Platform compatible version of the Waher.Events.MQTT Library. This library can be used to develop applications for Windows 10, on for instance Rasperry Pi.
Waher.Events.Persistence .NET Std 2.0 NuGet The Waher.Events.Persistence project creates an even sink that stores incoming (logged) events in the local object database, as defined by Waher.Persistence. Event life time in the database is defined in the constructor. Searches can be made for historical events.
Waher.Events.Pipe .NET Std 2.1 NuGet The Waher.Events.Pipe project creates an even sink that sends incoming (logged) events to a pipe. An event reader is also available, making it easy to transport logged events from one process to another on the same machine.
Waher.Events.Socket .NET Std 2.1 NuGet The Waher.Events.Socket project defines an event sink that sends events to a TCP listener socket. Events are sent as XML fragments.
Waher.Events.Socket.UWP UWP NuGet The Waher.Events.Socket.UWP project provides a Universal Windows Platform compatible version of the Waher.Events.Socket Library. This library can be used to develop applications for Windows 10, on for instance Rasperry Pi.
Waher.Events.Statistics .NET Std 2.0 NuGet The Waher.Events.Statistics project defines an event sink that computes statistics of events being logged.
Waher.Events.WindowsEventLog .NET Std 2.0 NuGet The Waher.Events.WindowsEventLog project defines an event sink that logs events to a Windows Event Log.
Waher.Events.XMPP .NET Std 2.1 NuGet The Waher.Events.XMPP project defines an event sink that distributes events over XMPP, according to XEP-0337.
Waher.Events.XMPP.UWP UWP NuGet The Waher.Events.XMPP.UWP project provides a reduced Universal Windows Platform compatible version of the Waher.Events.XMPP Library. This library can be used to develop applications for Windows 10, on for instance Rasperry Pi.

The folder also contains the following unit test projects:

Project Type Project description
Waher.Events.Pipe.Test .NET 8.0 The Waher.Events.Pipe.Test project contains unit tests for the Waher.Events.Pipe project.
Waher.Events.Socket.Test .NET 8.0 The Waher.Events.Socket.Test project contains unit tests for the Waher.Events.Socket project.

Layout

The Layout folder contains libraries for laying out objects visually.

Project Type Link Project description
Waher.Layout.Layout2D .NET Std 2.0 NuGet The Waher.Layout.Layout2D project provides an object model for laying out graphical objects in two dimensions. These models can then be used to generate images. The models can be represented in XML, and contains an XML schema that can be used to validate documents, as well as provide support when editing layout documents.

The folder also contains the following unit test projects:

Project Type Project description
Waher.Layout.Layout2D.Test .NET 8.0 The Waher.Layout.Layout2D.Test project contains unit tests for the Waher.Layout.Layout2D project.

Mocks

The Mocks folder contains projects that implement different mock devices. These can be used as development tools to test technologies, implementation, networks and tools.

Project Type Link Project description
Waher.Mock .NET Std 2.1 NuGet The Waher.Mock project is a class library that provides support for simple mock applications. This includes simple network configuration.
Waher.Mock.Lamp .NET 8.0 The Waher.Mock.Lamp project simulates a simple lamp switch with an XMPP interface.
Waher.Mock.Lamp.UWP UWP The Waher.Mock.Lamp.UWP project provides a Universal Windows Platform compatible version of the Waher.Mock.Lamp mock application. This application can be run on Windows 10, including on Rasperry Pi.
Waher.Mock.Temperature .NET 8.0 The Waher.Mock.Temperature project simulates a simple temperature sensor with an XMPP interface.
Waher.Mock.Temperature.UWP UWP The Waher.Mock.Temperature.UWP project provides a Universal Windows Platform compatible version of the Waher.Mock.Temperature mock application. This application can be run on Windows 10, including on Rasperry Pi.
Waher.Mock.UWP UWP NuGet The Waher.Mock.UWP project provides a reduced Universal Windows Platform compatible version of the Waher.Mock Library. This library can be used to develop applications for Windows 10, on for instance Rasperry Pi. It is limited in that it does not provide a console dialog for editing connection parameters if none exist. It does not include schema validation of XML configuration files either.

Networking

The Networking folder contains libraries that manage different aspects of network communication.

Project Type Link Project description
Waher.Networking .NET Std 2.1 NuGet The Waher.Networking project provides the basic architecture and tools for all networking libraries. This includes sniffers, etc., as well as classes for building client and server applications.
Waher.Networking.Cluster .NET Std 2.1 NuGet The Waher.Networking.Cluster project provides a framework for building applications that can cooperate and solve problems in clusters. Communication between endpoints in clusters is performed using AES-256 encrypted datagrams over a predefined UDP Multicast channel. Only participants with access to the shared key can participate in the cluster. Supports Unacknowledged, Acknowledged and Assured Message transfers in clusters, as well as Request/Response command executions, Locking of singleton resources, serialization of objects, etc.
Waher.Networking.Cluster.ConsoleSandbox .NET 8.0 The Waher.Networking.Cluster.ConsoleSandbox project provides a simple console application that allows you to interactively test the cluster protocol in the network.
Waher.Networking.CoAP .NET Std 2.1 NuGet The Waher.Networking.CoAP project provides a simple CoAP endpoint client with DTLS support.
Waher.Networking.CoAP.UWP UWP NuGet The Waher.Networking.CoAP.UWP project provides a Universal Windows Platform compatible version of the Waher.Networking.CoAP Library. This library can be used to develop applications for Windows 10, on for instance Rasperry Pi.
Waher.Networking.DNS .NET Std 2.1 NuGet The Waher.Networking.DNS project provides a class library for resolving DNS host, mailbox and service names on the network. It also supports reverse address lookups, International Domain Names (IDN), DNS Black Lists (DNSBL), text records, and maintains a local Resource Record cache.
Waher.Networking.HTTP .NET Std 2.1 NuGet The Waher.Networking.HTTP project provides a simple HTTP server for publishing dynamic content and managing user authentication based on a customizable set of users and privileges. Supports the WebSocket protocol.
Waher.Networking.HTTP.Brotli .NET Std 2.1 NuGet The Waher.Networking.HTTP.Brotli project adds Brotli-compression capabilities to the HTTP server defined in the Waher.Networking.HTTP Library.
Waher.Networking.HTTP.UWP UWP NuGet The Waher.Networking.HTTP.UWP project provides a Universal Windows Platform compatible version of the Waher.Networking.HTTP Library. This library can be used to develop applications for Windows 10, on for instance Rasperry Pi.
Waher.Networking.LWM2M .NET Std 2.1 NuGet The Waher.Networking.LWM2M project provides LWM2M interfaces for your application, using the CoAP library defined in Waher.Networking.CoAP.
Waher.Networking.LWM2M.UWP UWP NuGet The Waher.Networking.LWM2M.UWP project provides a Universal Windows Platform compatible version of the Waher.Networking.LWM2M Library. This library can be used to develop applications for Windows 10, on for instance Rasperry Pi.
Waher.Networking.Modbus .NET Std 2.1 NuGet The Waher.Networking.Modbus project provides a simple Modbus client.
Waher.Networking.Modbus.UWP UWP NuGet The Waher.Networking.Modbus.UWP project provides a Universal Windows Platform compatible version of the Waher.Networking.Modbus Library. This library can be used to develop applications for Windows 10, on for instance Rasperry Pi.
Waher.Networking.MQTT .NET Std 2.1 NuGet The Waher.Networking.MQTT project provides a simple MQTT client.
Waher.Networking.MQTT.UWP UWP NuGet The Waher.Networking.MQTT.UWP project provides a Universal Windows Platform compatible version of the Waher.Networking.MQTT Library. This library can be used to develop applications for Windows 10, on for instance Rasperry Pi.
Waher.Networking.PeerToPeer .NET Std 2.1 NuGet The Waher.Networking.PeerToPeer project provides tools for peer-to-peer and multi-player communication.
Waher.Networking.SASL .NET Std 2.1 NuGet The Waher.Networking.SASL project implements Simple Authentication and Security Layer (SASL) mechanisms.
Waher.Networking.SMTP .NET Std 2.1 NuGet The Waher.Networking.SMTP project implements a simple e-mail client based on the SMTP protocol, that can send formatted e-mail messages with attachments.
Waher.Networking.UPnP .NET Std 2.1 NuGet The Waher.Networking.UPnP project provides tools for searching and interacting with devices in the local area network using the UPnP protocol.
Waher.Networking.WHOIS .NET Std 2.1 NuGet The Waher.Networking.WHOIS project implements a WHOIS client that can be used to query Regional Internet Registries for information relating to IP addresses, etc.
Waher.Networking.WHOIS.UWP UWP NuGet The Waher.Networking.WHOIS.UWP project provides a Universal Windows Platform compatible version of the Waher.Networking.WHOIS Library. This library can be used to develop applications for Windows 10, on for instance Rasperry Pi.
Waher.Networking.XMPP .NET Std 2.1 NuGet The Waher.Networking.XMPP project provides a simple XMPP client.
Waher.Networking.XMPP.Avatar .NET Std 2.1 NuGet The Waher.Networking.XMPP.Avatar project provides an add-on to the XMPP client defined in Waher.Networking.XMPP. This add-on helps the client manage avatars.
Waher.Networking.XMPP.Avatar.UWP UWP NuGet The Waher.Networking.XMPP.Avatar.UWP project provides a reduced Universal Windows Platform compatible version of the Waher.Networking.XMPP.Avatar Library. This library can be used to develop applications for Windows 10, on for instance Rasperry Pi.
Waher.Networking.XMPP.BOSH .NET Std 2.1 NuGet The Waher.Networking.XMPP.BOSH project provides support for the HTTP altenative binding based on BOSH (defined in XEP-0124 and XEP-0206) to the XMPP client defined in Waher.Networking.XMPP.
Waher.Networking.XMPP.BOSH.UWP UWP NuGet The Waher.Networking.XMPP.BOSH.UWP project provides a reduced Universal Windows Platform compatible version of the Waher.Networking.XMPP.BOSH Library. This library can be used to develop applications for Windows 10, on for instance Rasperry Pi.
Waher.Networking.XMPP.Chat .NET Std 2.1 NuGet The Waher.Networking.XMPP.Chat project provides a simple XMPP chat server bot for things, that is added to the XMPP client defined in Waher.Networking.XMPP. It supports markdown, and follows the chat semantics outlined in this proto-XEP: Chat Interface for Internet of Things Devices
Waher.Networking.XMPP.Chat.UWP UWP NuGet The Waher.Networking.XMPP.Chat.UWP project provides a reduced Universal Windows Platform compatible version of the Waher.Networking.XMPP.Chat Library. This library can be used to develop applications for Windows 10, on for instance Rasperry Pi.
Waher.Networking.XMPP.Concentrator .NET Std 2.1 NuGet The Waher.Networking.XMPP.Concentrator project provides an add-on to the XMPP client defined in Waher.Networking.XMPP. This add-on provides client and server concentrator capabilities, as defined in XEP-0326. The concentrator interface allows a device to manage a set of internal virtual devices, all sharing the same XMPP connection.
Waher.Networking.XMPP.Concentrator.UWP UWP NuGet The Waher.Networking.XMPP.Concentrator.UWP project provides a reduced Universal Windows Platform compatible version of the Waher.Networking.XMPP.Concentrator Library. This library can be used to develop applications for Windows 10, on for instance Rasperry Pi.
Waher.Networking.XMPP.Contracts .NET Std 2.1 NuGet The Waher.Networking.XMPP.Contracts project provides an add-on to the XMPP client defined in Waher.Networking.XMPP. This add-on provides client interfaces for managing legal identities, smart contracts and signatures, as defined in the Neuro-Foundation.
Waher.Networking.XMPP.Control .NET Std 2.1 NuGet The Waher.Networking.XMPP.Control project provides an add-on to the XMPP client defined in Waher.Networking.XMPP. This add-on provides client and server control capabilities, as defined in the Neuro-Foundation.
Waher.Networking.XMPP.Control.UWP UWP NuGet The Waher.Networking.XMPP.Control.UWP project provides a reduced Universal Windows Platform compatible version of the Waher.Networking.XMPP.Control Library. This library can be used to develop applications for Windows 10, on for instance Rasperry Pi.
Waher.Networking.XMPP.HTTPX .NET Std 2.1 NuGet The Waher.Networking.XMPP.HTTPX project provides an add-on to the XMPP client defined in Waher.Networking.XMPP. This add-on provides client and server HTTPX support, as defined in XEP-0332. It also provides an HTTP proxy for tunneling HTTPX content through an HTTP(S)-based web server hosted by Waher.Networking.HTTP.
Waher.Networking.XMPP.Interoperability .NET Std 2.1 The Waher.Networking.XMPP.Interoperability project provides an add-on to the XMPP client defined in Waher.Networking.XMPP. This add-on provides client and server interoperability capabilities, as defined in this proto-XEP: Internet of Things - Interoperability
Waher.Networking.XMPP.Interoperability.UWP UWP The Waher.Networking.XMPP.Interoperability.UWP project provides a reduced Universal Windows Platform compatible version of the Waher.Networking.XMPP.Interoperability Library. This library can be used to develop applications for Windows 10, on for instance Rasperry Pi.
Waher.Networking.XMPP.Mail .NET Std 2.1 NuGet The Waher.Networking.XMPP.Mail project provides an add-on to the XMPP client defined in Waher.Networking.XMPP. This add-on provides client support for mail extensions on XMPP servers.
Waher.Networking.XMPP.MUC .NET Std 2.1 NuGet The Waher.Networking.XMPP.MUC project adds support for the Multi-User-Chat (MUC) extension (XEP-0045) to the XMPP Client library defined in Waher.Networking.XMPP. Direct invitations (XEP-0249), and Self-Ping (XEP-410) are also supported.
Waher.Networking.XMPP.MUC.UWP UWP NuGet The Waher.Networking.XMPP.MUC.UWP project provides a reduced Universal Windows Platform compatible version of the Waher.Networking.XMPP.MUC Library. This library can be used to develop applications for Windows 10, on for instance Rasperry Pi.
Waher.Networking.XMPP.P2P .NET Std 2.1 NuGet The Waher.Networking.XMPP.P2P project provides classes that help the application do servless XMPP (peer-to-peer) communication, as defined in XEP-0174.
Waher.Networking.XMPP.PEP .NET Std 2.1 NuGet The Waher.Networking.XMPP.PEP project adds support for the Personal Eventing Protocol extension (XEP-0163) to the XMPP Client library defined in Waher.Networking.XMPP.
Waher.Networking.XMPP.PEP.UWP UWP NuGet The Waher.Networking.XMPP.PEP.UWP project provides a reduced Universal Windows Platform compatible version of the Waher.Networking.XMPP.PEP Library. This library can be used to develop applications for Windows 10, on for instance Rasperry Pi.
Waher.Networking.XMPP.Provisioning .NET Std 2.1 NuGet The Waher.Networking.XMPP.Provisioning project provides an add-on to the XMPP client defined in Waher.Networking.XMPP. This add-on provides client support for provisioning and delegation of trust, as defined in the Neuro-Foundation.
Waher.Networking.XMPP.Provisioning.UWP UWP NuGet The Waher.Networking.XMPP.Provisioning.UWP project provides a reduced Universal Windows Platform compatible version of the Waher.Networking.XMPP.Provisioning Library. This library can be used to develop applications for Windows 10, on for instance Rasperry Pi.
Waher.Networking.XMPP.PubSub .NET Std 2.1 NuGet The Waher.Networking.XMPP.PubSub project adds support for the Publish/Subscribe extension (XEP-0060) to the XMPP Client library defined in Waher.Networking.XMPP.
Waher.Networking.XMPP.PubSub.UWP UWP NuGet The Waher.Networking.XMPP.PubSub.UWP project provides a reduced Universal Windows Platform compatible version of the Waher.Networking.XMPP.PubSub Library. This library can be used to develop applications for Windows 10, on for instance Rasperry Pi.
Waher.Networking.XMPP.Push .NET Std 2.1 NuGet The Waher.Networking.XMPP.Push project adds client-side support for Push Notification when the client is not connected over XMPP. Implemented for the XMPP Client library defined in Waher.Networking.XMPP. Push Notification provided by the TAG Neuron. Allows the client to forward different types of messages, and contents, into different notification channels, as defined by mobile platforms, when client is offline.
Waher.Networking.XMPP.RDP .NET Std 2.1 NuGet The Waher.Networking.XMPP.RDP project provides an add-on to the XMPP client defined in Waher.Networking.XMPP. This add-on provides client-side support for Remote Desktop over XMPP.
Waher.Networking.XMPP.Sensor .NET Std 2.1 NuGet The Waher.Networking.XMPP.Sensor project provides an add-on to the XMPP client defined in Waher.Networking.XMPP. This add-on provides client and server sensor capabilities, as defined in the Neuro-Foundation.
Waher.Networking.XMPP.Sensor.UWP UWP NuGet The Waher.Networking.XMPP.Sensor.UWP project provides a reduced Universal Windows Platform compatible version of the Waher.Networking.XMPP.Sensor Library. This library can be used to develop applications for Windows 10, on for instance Rasperry Pi.
Waher.Networking.XMPP.Software .NET Std 2.1 NuGet The Waher.Networking.XMPP.Software project provides a client for managing and downloading software packages and software updates, as defined in the Neuro-Foundation.
Waher.Networking.XMPP.Synchronization .NET Std 2.1 NuGet The Waher.Networking.XMPP.Synchronization project provides an add-on to the XMPP client defined in Waher.Networking.XMPP. This add-on provides clock synchronization capabilities, as defined in the Neuro-Foundation.
Waher.Networking.XMPP.Synchronization.UWP UWP NuGet The Waher.Networking.XMPP.Synchronization.UWP project provides a reduced Universal Windows Platform compatible version of the Waher.Networking.XMPP.Synchronization Library. This library can be used to develop applications for Windows 10, on for instance Rasperry Pi.
Waher.Networking.XMPP.UWP UWP NuGet The Waher.Networking.XMPP.UWP project provides a reduced Universal Windows Platform compatible version of the Waher.Networking.XMPP Library. This library can be used to develop applications for Windows 10, on for instance Rasperry Pi.
Waher.Networking.XMPP.WebSocket .NET Std 2.1 NuGet The Waher.Networking.XMPP.WebSocket project provides support for the websocket altenative binding based on BOSH (defined in RFC-7395) to the XMPP client defined in Waher.Networking.XMPP.
Waher.Networking.XMPP.WebSocket.UWP UWP NuGet The Waher.Networking.XMPP.WebSocket.UWP project provides a reduced Universal Windows Platform compatible version of the Waher.Networking.XMPP.WebSocket Library. This library can be used to develop applications for Windows 10, on for instance Rasperry Pi.

The folder also contains the following unit test projects:

Project Type Project description
Waher.Networking.Cluster.Test .NET 8.0 The Waher.Networking.Cluster.Test project contains unit-tests for the Waher.Networking.Cluster library.
Waher.Networking.CoAP.Test .NET 8.0 The Waher.Networking.CoAP.Test project contains unit-tests for the Waher.Networking.CoAP library.
Waher.Networking.DNS.Test .NET 8.0 The Waher.Networking.DNS.Test project contains unit-tests for the Waher.Networking.DNS library.
Waher.Networking.HTTP.Test .NET 8.0 The Waher.Networking.HTTP.Test project contains unit-tests for the Waher.Networking.HTTP library.
Waher.Networking.HTTP.TestServer .NET 8.0 The Waher.Networking.HTTP.TestServer project is a console application that hosts a simple web server using the Waher.Networking.HTTP library, for testing purposes using external unit test tools, such as the h2spec tool and similar.
Waher.Networking.Modbus.Test .NET 8.0 The Waher.Networking.Modbus.Test project contains unit-tests for the Waher.Networking.Modbus library.
Waher.Networking.MQTT.Test .NET 8.0 The Waher.Networking.MQTT.Test project contains unit-tests for the Waher.Networking.MQTT library.
Waher.Networking.WHOIS.Test .NET 8.0 The Waher.Networking.WHOIS.Test project contains unit-tests for the Waher.Networking.WHOIS library.
Waher.Networking.XMPP.Test .NET 8.0 The Waher.Networking.XMPP.Test project contains unit-tests for the Waher.Networking.XMPP library and add-ons.

Persistence

The Persistence folder contains libraries that create an infrastructure for persistence of objects in applications. This includes a simple embedded encrypted local object database, as well as integration with external databases. Objects are persisted based on their annotated class definitions.

Project Type Link Project description
Waher.Persistence .NET Std 2.0 NuGet The Waher.Persistence project provides the central interfaces for interaction with object databases. All modules can use the static Database class to persist and find objects in the preconfigured object database.
Waher.Persistence.Files .NET Std 2.0 NuGet The Waher.Persistence.Files project defines a library that provides an object database that stores objects in local AES-256 encrypted files. Storage, indices, searching and retrieval is based solely on meta-data provided through the corresponding class definitions. Object serializers are created dynamically. Dynamic code is compiled. Access is provided through the Waher.Persistence library.
Waher.Persistence.FilesLW .NET Std 2.0 NuGet The Waher.Persistence.FilesLW project defines a library that provides an object database that stores objects in local files. Storage, indices, searching and retrieval is based solely on meta-data provided through the corresponding class definitions. Object serializers are created dynamically. Access is provided through the Waher.Persistence library.
Waher.Persistence.FullTextSearch .NET Std 2.0 NuGet The Waher.Persistence.FullTextSearch project provides full-text-search capabilities to the data you persist using the Waher.Persistence library, regardless of what database provider you use. The full-text-search engine can both index objects, through their class definitions, objects generated ex-nihilo through the script engine, or content available in files. Architecture is pluggable, and you can extend the tokenization process by providing cusrtom tokenizers for different classes and file types.
Waher.Persistence.MongoDB .NET Std 2.0 NuGet The Waher.Persistence.MongoDB project provides a MongoDB database provider that can be used for object persistence through the Waher.Persistence library.
Waher.Persistence.Serialization .NET Std 2.0 NuGet The Waher.Persistence.Serialization project defines a library that serializes objects to binary form using meta-data provided through the corresponding class definitions. Object serializers are created dynamically. Compatible with Waher.Persistence.Serialization.Compiled.
Waher.Persistence.Serialization.Compiled .NET Std 2.0 NuGet The Waher.Persistence.Serialization.Compiled project defines a library that serializes objects to binary form using meta-data provided through the corresponding class definitions. Object serializers are created dynamically. Dynamic code is compiled. Compatible with Waher.Persistence.Serialization.
Waher.Persistence.XmlLedger .NET Std 2.0 NuGet The Waher.Persistence.XmlLedger project provides a simple ledger that records anything that happens in the database to XML files in the program data folder. Files are kept of a configurable amount of time.

The folder also contains the following unit test projects:

Project Type Project description
Waher.Persistence.Files.Test .NET 8.0 The Waher.Persistence.Files.Test project contains unit tests for the Waher.Persistence.Files project.
Waher.Persistence.FilesLW.Test .NET 8.0 The Waher.Persistence.FilesLW.Test project contains unit tests for the Waher.Persistence.FilesLW project.
Waher.Persistence.FullTextSearch.Test .NET 8.0 The Waher.Persistence.FullTextSearch.Test project contains unit tests for the Waher.Persistence.FullTextSearch project.
Waher.Persistence.MongoDB.Test .NET 8.0 The Waher.Persistence.MongoDB.Test project contains unit tests for the Waher.Persistence.MongoDB project.
Waher.Persistence.XmlLedger.Test .NET 8.0 The Waher.Persistence.XmlLedger.Test project contains unit tests for the Waher.Persistence.XmlLedger project.

Runtime

The Runtime folder contains libraries that help applications with common runtime tasks, such as caching, maintaining a type inventory, language localization, runtime settings, timing and scheduling.

Project Type Link Project description
Waher.Runtime.Cache .NET Std 2.0 NuGet The Waher.Runtime.Cache project provides tools for in-memory caching.
Waher.Runtime.Console .NET Std 2.0 NuGet The Waher.Runtime.Console class library helps with queueing and serialization of input and output to and from the Console in a multi-threaded environment, avoiding dead-locks when console is locked.
Waher.Runtime.Counters .NET Std 2.0 NuGet The Waher.Runtime.Counters project helps with counting events in runtime environments in a persistent and efficient and platform-independent manner.
Waher.Runtime.Inventory .NET Std 2.0 NuGet The Waher.Runtime.Inventory project keeps an inventory of types and interfaces available in your code. It also provides a means to access available types given an interface, and can find the best implementation to process a task or item. It can be used to implement an Inversion of Control Pattern, and helps instantiate interfaces, abstract classes and normal classes, including recursively instantiating constructor arguments. Handles singleton types.
Waher.Runtime.Inventory.Loader .NET Std 2.0 NuGet The Waher.Runtime.Inventory.Loader project dynamically loads modules from a folder, and initiates the inventory defined in Waher.Runtime.Inventory with all loaded and referenced assemblies.
Waher.Runtime.IO .NET Std 2.0 NuGet The Waher.Runtime.IO project contains a small set of IO extensions and tools simplifying stream, file, string and certificate management.
Waher.Runtime.Language .NET Std 2.0 NuGet The Waher.Runtime.Language project helps applications with language localization.
Waher.Runtime.Profiling .NET Std 2.0 NuGet The Waher.Runtime.Profiling project contains tools for profiling sequences of actions in multiple threads. Results are accumulated, and can be exported to XML or as PlantUML Diagrams.
Waher.Runtime.Queue .NET Std 2.0 NuGet The Waher.Runtime.Queue project contains a specialised FIFO Queue for asynchronous transport of items between tasks. You can have multiple working tasks adding items to the queue, as well as multiple working tasks subscribing to items from the queue.
Waher.Runtime.ServiceRegistration .NET Std 2.1 NuGet The Waher.Runtime.ServiceRegistration library allows applications to register themselves with an XMPP-based Service Registry, such as the IoT Broker.
Waher.Runtime.Settings .NET Std 2.0 NuGet The Waher.Runtime.Settings project helps applications maintain a set of persistent settings.
Waher.Runtime.Text .NET Std 2.0 NuGet The Waher.Runtime.Text project provides classes working with text and text documents, particularly find differences between texts, or sequences of symbols, or mapping strings to a harmonized set of strings (or tokens).
Waher.Runtime.Temporary .NET Std 2.0 NuGet The Waher.Runtime.Temporary project contains classes simplifying working with temporary in-memory and file streams.
Waher.Runtime.Threading .NET Std 2.0 NuGet The Waher.Runtime.Threading project provides classes for usage in multi-threaded asynchronous environments providing multiple-read/single-write capabilities.
Waher.Runtime.Threading.Sync .NET Std 2.0 NuGet The Waher.Runtime.Threading.Sync project provides classes for executing tasks that need to be synchronized from the same thread, asynchronously, in an asynchronous environment. Includes an asynchronous Mutex class.
Waher.Runtime.Timing .NET Std 2.0 NuGet The Waher.Runtime.Timing project provides tools for timing and scheduling.
Waher.Runtime.Transactions .NET Std 2.0 NuGet The Waher.Runtime.Transactions project defines an architecture for processing transactions to help protect the integrity of data in asynchronous or distributed environments.

The folder also contains the following unit test projects:

Project Type Project description
Waher.Runtime.Inventory.Test .NET 8.0 The Waher.Runtime.Inventory.Test project contains unit tests for the Waher.Runtime.Inventory project.
Waher.Runtime.Language.Test .NET 8.0 The Waher.Runtime.Language.Test project contains unit tests for the Waher.Runtime.Language project.
Waher.Runtime.Profiling.Test .NET 8.0 The Waher.Runtime.Profiling.Test project contains unit tests for the Waher.Runtime.Profiling project.
Waher.Runtime.Settings.Test .NET 8.0 The Waher.Runtime.Settings.Test project contains unit tests for the Waher.Runtime.Settings project.
Waher.Runtime.Text.Test .NET 8.0 The Waher.Runtime.Text.Test project contains unit tests for the Waher.Runtime.Text project.
Waher.Runtime.Threading.Test .NET 8.0 The Waher.Runtime.Threading.Test project contains unit tests for the Waher.Runtime.Threading project.

Script

The Script folder contains libraries that define an extensible execution envionment for script supporting canonical extensions, .NET integration, graphs, physical units and unit conversions, etc. For more information about the script engine supported by these libraries, see the script reference.

Project Type Link Project description
Waher.Script .NET Std 2.0 NuGet The Waher.Script project is a class library that provides basic abstraction and execution model for symbolic math and scripting. It also manages pluggable modules and easy dynamic access to runtime namespaces and types. Reference
Waher.Script.Content .NET Std 2.0 NuGet The Waher.Script.Content project is a class library that adds content functions to the script engine, suitable for loading, fetching or processing content from files or online resources.
Waher.Script.Cryptography .NET Std 2.0 NuGet The Waher.Script.Cryptography project is a class library that adds cryptography functions to the script engine.
Waher.Script.Data .NET Std 2.0 NuGet The Waher.Script.Data project is a class library that extends the script engine with functions for accessing external MS SQL, OleDB or OBDC databases.
Waher.Script.Data.MySQL .NET Std 2.0 NuGet The Waher.Script.Data.MySQL project is a class library that extends the script engine with functions for accessing external MySQL databases.
Waher.Script.Data.PostgreSQL .NET Std 2.0 NuGet The Waher.Script.Data.PostgreSQL project is a class library that extends the script engine with functions for accessing external PostgreSQL databases.
Waher.Script.Fractals .NET Std 2.0 NuGet The Waher.Script.Fractals project is a class library that adds fractal image functions to the script engine, suitable for generating backgound images. It uses SkiaSharp for cross-platform 2D graphics manipulation.
Waher.Script.FullTextSearch .NET Std 2.0 NuGet The Waher.Script.FullTextSearch project is a class library that adds full-text-search functions to the script engine. Full-text-search is provided by the Waher.Persistence.FullTextSearch library.
Waher.Script.Graphs .NET Std 2.0 NuGet The Waher.Script.Graphs project is a class library that adds graphing functions to the script engine. It uses SkiaSharp for cross-platform 2D graphics manipulation.
Waher.Script.Graphs3D .NET Std 2.0 NuGet The Waher.Script.Graphs3D project is a class library that adds 3D-graphing functions to the script engine. It uses SkiaSharp for cross-platform 2D graphics manipulation.
Waher.Script.Networking .NET Std 2.1 NuGet The Waher.Script.Networking project is a class library that extends the script engine with functions for different network protocols.
Waher.Script.Persistence .NET Std 2.0 NuGet The Waher.Script.Persistence project is a class library that contains script extensions for the persistence layer (defined in Waher.Persistence). Allows for searching for, creating, updating and deleting objects in the object database from script. Includes support for SQL queries against the object database persistence layer, and SPARQL queries for semantic-web queries using graph notation, linked data and graph databases.
Waher.Script.Statisics .NET Std 2.0 NuGet The Waher.Script.Statisics project is a class library that adds statistical functions to the script engine.
Waher.Script.System .NET Std 2.0 NuGet The Waher.Script.System project is a class library that extends the script engine with functions for accessing the system, including executing processes.
Waher.Script.Threading .NET Std 2.0 NuGet The Waher.Script.Threading project is a class library that adds functions to the script engine for executing script in a threaded environmet. This includes parallel execution, as well as protected serialized execution.
Waher.Script.Xml .NET Std 2.0 NuGet The Waher.Script.Xml project is a class library that contains script extensions for parsing XML.
Waher.Script.XmlDSig .NET Std 2.0 NuGet The Waher.Script.XmlDSig project is a class library that contains script extensions for signing and verifying XML documents using the XMLDSIG standard.

The folder also contains the following unit test projects:

Project Type Project description
Waher.Script.Test .NET 8.0 The Waher.Script.Test project contains unit tests for the script-related projects in this section.

Security

The Security folder contains libraries that are dedicated at solving particular security or data protection such as authentication, authorization and encryption.

Project Type Link Project description
Waher.Security .NET Std 2.0 NuGet The Waher.Security project provides a basic security model based on users, roles and privileges. It's not based on operating system features, to allow code to be platform independent.
Waher.Security.ACME .NET Std 2.0 NuGet The Waher.Security.ACME project contains a class library implementing the ACME v2 protocol for the generation of certificates using ACME-compliant certificate servers, as defined in the ACME draft.
Waher.Security.CallStack .NET Std 2.0 NuGet The Waher.Security.CallStack project provide tools for securing access to methods and properties in code, by limiting access to them to a given set of callers. This prevents unintentional leaks of information through code running in the same process.
Waher.Security.ChaChaPoly .NET Std 2.0 NuGet The Waher.Security.ChaChaPoly project implements the ChaCha20, Poly1305 and AEAD_CHACHA20_POLY1305 algorithms, as defined in RFC 8439.
Waher.Security.DTLS .NET Std 2.1 NuGet The Waher.Security.DTLS project contains a class library implementing the Datagram Transport Layer Security (DTLS) Version 1.2, as defined in RFC 6347.
Waher.Security.DTLS.UWP UWP NuGet The Waher.Security.DTLS.UWP project provides a Universal Windows Platform compatible version of the Waher.Security.DTLS Library. This library can be used to develop applications for Windows 10, on for instance Rasperry Pi.
Waher.Security.EllipticCurves .NET Std 2.0 NuGet The Waher.Security.EllipticCurves project contains a class library implementing algorithms for Elliptic Curve Cryptography, such as ECDH, ECDSA, EdDSA, NIST P-192, NIST P-224, NIST P-256, NIST P-384, NIST P-521, Curve25519, Curve448, Edwards25519 and Edwards448.
Waher.Security.JWS .NET Std 2.0 NuGet The Waher.Security.JWS project implements a framework for JSON Web Signatures (JWS), as defined in RFC 7515.
Waher.Security.JWT .NET Std 2.1 NuGet The Waher.Security.JWT project helps applications with the creation and validation of Java Web Tokens (JWT), as defined in RFC 7519.
Waher.Security.JWT.UWP UWP NuGet The Waher.Security.JWT.UWP project provides a Universal Windows Platform compatible version of the Waher.Security.JWT Library. This library can be used to develop applications for Windows 10, on for instance Rasperry Pi.
Waher.Security.LoginMonitor .NET Std 2.1 NuGet The Waher.Security.LoginMonitor helps applications monitor login activity, and help block malicious entities from the system.
Waher.Security.LoginMonitor.UWP UWP NuGet The Waher.Security.LoginMonitor.UWP project provides a Universal Windows Platform compatible version of the Waher.Security.LoginMonitor Library. This library can be used to develop applications for Windows 10, on for instance Rasperry Pi.
Waher.Security.PKCS .NET Std 2.0 NuGet The Waher.Security.PKCS project contains classes and tools for working with Public Key Cryptography Standards (PKCS).
Waher.Security.SHA3 .NET Std 2.0 NuGet The Waher.Security.SHA3 project implements SHA-3, as defined in NIST FIPS 202, including the general KECCAK algorithm and the SHAKE128, SHAKE256, RawSHAKE128 and RawSHAKE256 XOF functions.
Waher.Security.SPF .NET Std 2.1 NuGet The Waher.Security.SPF project contains a class library for resolving Sender Policy Framework (SPF) strings as defined in RFC 7208.
Waher.Security.Users .NET Std 2.1 NuGet The Waher.Security.Users project defines an architecture of persistent users, roles and privileges that can be used to provide detailed authorization in applications. Privileges are ordered in a tree structure. Roles contains a list of allowed privileges (nodes or entire branches), or explicitly prohibited privileges (nodes or branches). Each user can be assigned one or more roles. Credentials are protected using hash digests. Objects are persisted through the object database abstraction layer, defined in Waher.Persistence.

The folder also contains the following unit test projects:

Project Type Project description
Waher.Security.ACME.Test .NET 8.0 The Waher.Security.ACME.Test project contains unit tests for the Waher.Security.ACME project.
Waher.Security.ChaChaPoly.Test .NET 8.0 The Waher.Security.ChaChaPoly.Test project contains unit tests for the Waher.Security.ChaChaPoly project.
Waher.Security.DTLS.Test .NET 8.0 The Waher.Security.DTLS.Test project contains unit tests for the Waher.Security.DTLS project.
Waher.Security.EllipticCurves.Test .NET 8.0 The Waher.Security.EllipticCurves.Test project contains unit tests for the Waher.Security.EllipticCurves project.
Waher.Security.JWT.Test .NET 8.0 The Waher.Security.JWT.Test project contains unit tests for the Waher.Security.JWT project.
Waher.Security.LoginMonitor.Test .NET 8.0 The Waher.Security.LoginMonitor.Test project contains unit tests for the Waher.Security.LoginMonitor project.
Waher.Security.PKCS.Test .NET 8.0 The Waher.Security.PKCS.Test project contains unit tests for the Waher.Security.PKCS project.
Waher.Security.SHA3.Test .NET 8.0 The Waher.Security.SHA3.Test project contains unit tests for the Waher.Security.SHA3 project.
Waher.Security.SPF.Test .NET 8.0 The Waher.Security.SPF.Test project contains unit tests for the Waher.Security.SPF project.

Services

The Services folder contains standalone service applications.

Project Type Link Project description
Waher.Service.PcSensor .NET 8.0 The Waher.Service.PcSensor project defines an application that converts your PC into an IoT sensor, by publishing performace counters as sensor values. Full Screen Shot 1. Full Screen Shot 2. Full Screen Shot 3.

The following project has been discontinued:

Project Type Link Project description
Waher.Service.GPIO UWP The Waher.Service.GPIO project defines a Universal Windows Platform application that can be installed on Windows 10 IoT devices. It will publish available GPIO inputs/outputs over XMPP sensor, control and chat interfaces. It will also publish Digital and Analog Arduino interfaces, if an Arduino using the Firmata protocol is connected to an USB port of the device. The application can be used to elaborate with GPIO peripherals using a simple chat client.

Themes

The Themes folder contains libraries that contain content files for different visual themes.

Project Type Link Project description
Waher.Theme.CactusRose .NET Std 2.0 NuGet The Waher.Theme.CactusRose project contains content files for the Cactus Rose theme.
Waher.Theme.GothicPeacock .NET Std 2.0 NuGet The Waher.Theme.GothicPeacock project contains content files for the Gothic Peacock theme.
Waher.Theme.Retro64 .NET Std 2.0 NuGet The Waher.Theme.Retro64 project contains content files for the Retro-64 theme.
Waher.Theme.SpaceGravel .NET Std 2.0 NuGet The Waher.Theme.SpaceGravel project contains content files for the Space Gravel theme.
Waher.Theme.WinterDawn .NET Std 2.0 NuGet The Waher.Theme.WinterDawn project contains content files for the Winter Dawn theme.

Things

The Things folder contains libraries that define a hardware and data abstraction layer for interacting with things. This includes describing sensor data, control parameters, attributes, displayable parameters, commands, queries and data sources. It also includes embedding things dynamically, to form more complex devices, such as concentrators or bridges.

Project Type Link Project description
Waher.Things .NET Std 2.0 NuGet The Waher.Things project is a class library that provides basic abstraction of things, errors, sensor data and control operations.
Waher.Things.Ieee1451 .NET Std 2.1 NuGet The Waher.Things.Ieee1451 project is a class library that publishes nodes that communicate using the IEEE 1451 family of standards.
Waher.Things.Files .NET Std 2.1 NuGet The Waher.Things.Files project publishes nodes that permit you to define sensor and actuator nodes in the network based on files in the file-system.
Waher.Things.Ip .NET Std 2.1 NuGet The Waher.Things.Ip project is a class library that publishes nodes representing nodes on an IP network.
Waher.Things.Metering .NET Std 2.1 NuGet The Waher.Things.Metering project is a class library that defines a basic metering infrastructure.
Waher.Things.Modbus .NET Std 2.1 NuGet The Waher.Things.Modbus project is a class library that publishes nodes representing Modbus devices.
Waher.Things.Mqtt .NET Std 2.1 NuGet The Waher.Things.Mqtt project is a class library that publishes nodes representing devices connected to MQTT brokers.
Waher.Things.Script .NET Std 2.1 NuGet The Waher.Things.Script project is a class library that publishes nodes that permit you to define sensors and actuators using script.
Waher.Things.Semantic .NET Std 2.1 NuGet The Waher.Things.Semantic project is a class library that publishes nodes representing Semantic Web devices. It also makes other non-semantic metering devices available via semantic web interfaces, such as SPARQL queries.
Waher.Things.Snmp .NET Std 2.0 NuGet The Waher.Things.Snmp project is a class library that publishes nodes representing SNMP devices on the local area network.
Waher.Things.Virtual .NET Std 2.1 NuGet The Waher.Things.Virtual project is a class library that publishes virtual nodes that can act as placeholders for software that wishes to publish nodes on the network.
Waher.Things.Xmpp .NET Std 2.1 NuGet The Waher.Things.Xmpp project is a class library that publishes nodes for communication with devices over XMPP.

The folder also contains the following unit test projects:

Project Type Project description
Waher.Things.Test .NET 8.0 The Waher.Things.Test project contains unit tests related to the thing libraries.

The following projects have been discontinued:

Project Type Project description
Waher.Things.Arduino UWP NuGet
Waher.Things.Gpio UWP NuGet

Utilities

The Utilities folder contains applications that help the developer or administrator with different tasks.

Project Type Link Project description
Waher.Utility.Acme .NET 8.0 The Waher.Utility.Acme is a command-line tool that helps you create certificates using the Automatic Certificate Management Environment (ACME) v2 protocol.
Waher.Utility.AnalyzeClock .NET 8.0 The Waher.Utility.AnalyzeClock is a command-line tool that helps you analyze the difference in clocks between machines compatible with the Neuro-Foundation.
Waher.Utility.AnalyzeDB .NET 8.0 The Waher.Utility.AnalyzeDB is a command-line tool that helps you analyze an object database created by the Waher.Persistence.Files or Waher.Persistence.FilesLW libraries, such as the IoT Gateway database.
Waher.Utility.Asn1ToCSharp .NET 8.0 The Waher.Utility.Asn1ToCSharp is a command-line tool that creates C# files from definitions made in ASN.1 files.
Waher.Utility.Csp .NET 8.0 The Waher.Utility.Csp is a command-line tool that helps you perform operations on keys managed by the system Cryptographic Service Provider CSP.
Waher.Utility.DeleteDB .NET 8.0 The Waher.Utility.DeleteDB is a command-line tool that helps you delete an object database created by the Waher.Persistence.Files or Waher.Persistence.FilesLW libraries, such as the IoT Gateway database, including any cryptographic keys stored in the CSP.
Waher.Utility.ExStat .NET 8.0 The Waher.Utility.ExStat is a command-line tool that helps you extract statistical information about exceptions occurring in an IoT Gateway, with logging of exceptions activated.
Waher.Utility.Extract .NET 8.0 The Waher.Utility.Extract is a command-line tool that helps you extract information from a backup file generated by the IoT Gateway.
Waher.Utility.GenManifest .NET 8.0 The Waher.Utility.GenManifest project provides a command-line tool that can generate manifest files from files existing in folders.
Waher.Utility.GetEmojiCatalog .NET 8.0 The Waher.Utility.GetEmojiCatalog project downloads an emoji catalog and extracts the information and generates code for handling emojis.
Waher.Utility.Install .NET 8.0 The Waher.Utility.Install is a command-line tool that helps you install pluggable modules into the IoT Gateway.
Waher.Utility.RegEx .NET 8.0 The Waher.Utility.RegEx is a command-line tool that helps you find content in files using regular expressions, and optionally either export the findings or replace them with something else.
Waher.Utility.RunScript .NET 8.0 The Waher.Utility.RunScript is a command-line tool that allows you to execute script.
Waher.Utility.Sign .NET 8.0 The Waher.Utility.Sign is a command-line tool that helps you sign files using asymmetric keys.
Waher.Utility.TextDiff .NET 8.0 The Waher.Utility.TextDiff is a command-line tool that compares two text files and outputs the differences between them.
Waher.Utility.Transform .NET 8.0 The Waher.Utility.Transform is a command-line tool that transforms an XML file utilizing an XSL Transform (XSLT).
Waher.Utility.Translate .NET 8.0 The Waher.Utility.Translate is a command-line tool that helps translating resource strings from one language to another. It uses an internal database to check for updates, and performs translations only of new or updated strings accordingly.

Web Services

The WebServices folder contains modules that add web service capabilities to projects they are used in.

Project Type Link Project description
Waher.WebService.Script .NET Std 2.1 The Waher.WebService.Script project provides a web service that can be used to execute script on the server, from the client.
Waher.WebService.Sparql .NET Std 2.1 The Waher.WebService.Sparql project provides a SPARQL endpoint that can be used to execute federated queries on the server and across the network.
Waher.WebService.Tesseract .NET Std 2.1 The Waher.WebService.Tesseract project provides a web service that can act as a gateway to Tesseract, installed on the server.

The folder also contains the following unit test projects:

Project Type Project description
Waher.Webservice.Tesseract.Test .NET 8.0 The Waher.Security.SPF.Test project contains unit tests for the Waher.Security.SPF project.

Environment Variables

During intial configuration and setup of the IoT Gateway, and any hosted services, a sequence of configuration steps have to be processed. The operator of the Gateway, and hosted services, can choose to enter the information manually in each step via the web interface, or provide the information via environment variables, allowing for the automation of the configuration and setup procedure.

Web setup

The default method of configuring the IoT Gateway is via the web interface. The first time the gateway is run, the web interface is overridden to display the configuration steps required to be completed. The user can choose a simplified or a detailed configuration. The detailed configuration shows each step in the configuration process, while the simplified only shows required steps, while the others receive a default configuration. As soon as all steps have been completed, the setup override is removed, and the gateway starts operating in a configured state.

Automated setup

The setup procedure can be automated, by providing the values required for the setup in Environment Variables. This permits the operator to automate the configuration, and to create containers with preprogrammed configurations. Available Environment Variables depends on the amount of services hosted by the gateway. This repository contains a list of Environment Variables that can be used to automate the setup, in the Configuration Steps article.

Mixed setup

An operator can choose to partially pre-configure the gateway using only a subset of available Environment Variables necessary for a complete configuration. During initial start of the gateway, the configuraiton steps with these preconfigured values will be skipped, as they will be seen as completed. Only the configuration steps without preconfigured values will be shown.

Compiling solution

You need to setup the build environment properly before you can compile the projects in this repository. The following subsections describe the configurations that need to be made:

Instances

The IoT Gateway can be executed in multiple instances. The default instance uses the empty instance name. Each other instance, has a given instance name that is assigned to the executable via a command-line argument. When building the IoT Gateway, it is assumed the instance name is Dev. This allows you to have a default installed version of the Gateway (or multiple installed instances), while your development version is running as a separate instance named Dev in parallel.

Project Folders

Build events and script available in solutions assume the projects reside certain folders. On a Windows machine, the IoT Gateway repository is assumed to be cloned into the C:\My Projects\IoTGateway folder. On a MAC, that folder is assumed to be /My Projects/IoT Gateway.

Virtual root folders on MAC computers

To create a root folder on a MAC you need to create a virtual folder that appears in the root folder, due to restrictions in the operating system. To create the /My Projects folder, follow these steps:

  1. Open the Terminal app.

  2. Type sudo nano /etc/synthetic.conf and press Enter. You may need to enter your administrator password.

  3. In the nano text editor, enter:

     My Projects	/Users/yourusername/My Projects
    

    There should be a space between My and Projects, but a TAB character between My Projects and /Users.... Also, replace the yourusername with the name of your user name.

  4. Press Control + O to write the file, then Enter to confirm, and Control + X to exit nano.

  5. Reboot your Mac.

After rebooting, you should see the virtual folder /My Projects in the root directory.

Windows

To compile projects on Windows, use Visual Studio 2022 (or later). The IoT Gateway separates executable and compiled code (which is later installed in any of the computer's Program Files folder(s)), and application data, which the application can read and write. The latter is stored in the corresponding ProgramData folder. The default installation of IoT Gateway, stores data in C:\ProgramData\IoT Gateway. A non-default instance, stores its application data in C:\ProgramData\IoT Gateway INST, where INST is replaced by the instance name. So before you can compile, you need to make sure the folder C:\ProgramData\IoT Gateway Dev exists, and that the user performing the build has access to this folder.

MAC

The following sections list the preparations that need to be performed before you can compile and run the IoT Gateway on a MAC:

Application data folder

To compile projects on MAC, use VS Code for MAC. The IoT Gateway separates executable and compiled code (which is later installed in a computer's /Applications folder), and application data, which the application can read and write. The latter is stored in the corresponding /usr/share folder. The default installation of IoT Gateway, stores data in /usr/share/IoT Gateway. A non-default instance, stores its application data in /usr/share/IoT Gateway INST, where INST is replaced by the instance name. So before you can compile, you need to make sure the folder /usr/share/IoT Gateway Dev exists, and that the user performing the build has access to this folder.

Note: You might not be permitted to create a folder under /usr/share for security reasons, even if using sudo. In such cases, you can create a folder under /usr/local/share instead. This folder will be valid for development purposes. Once the gateway is placed in an installation package, the package tool will be able to create the proper share folder for you.

Terminal script to create and configure folder:

sudo mkdir -p "/usr/share/IoT Gateway Dev"
sudo chown yourusername "/usr/share/IoT Gateway Dev"
sudo chmod 755 "/usr/share/IoT Gateway Dev"

In case you are not permitted to execute the above script, you can create a development folder instead:

sudo mkdir -p "/usr/local/share/IoT Gateway Dev"
sudo chown yourusername "/usr/local/share/IoT Gateway Dev"
sudo chmod 755 "/usr/local/share/IoT Gateway Dev"

Database enryption

You also need to create an environment variable named FILES_DB_SALT. Since the MAC computer does not provide access to cryptographic resources, database encryption requires a salt that needs to be unique for each machine. The value can be anything, but cannot change, as it would render existing information unreadable.

To set an environment variable in mac OS, you can follow this procedure:

  1. Open the Terminal app.

  2. Edit the shell configuration file, such as ~/.bash_profile for Bash or ~/.zshrc for Zsh (the default shell in newer macOS versions), using a text editor like nano or vim:

    nano ~/.bash_profile
    

    or

    nano ~/.zshrc
    
  3. Add the export command to the end of the file:

    export FILES_DB_SALT="value"
    

    You need to replace the value with a random string you keep unique for the machine.

  4. Save the file and exit the editor.

  5. To apply the changes immediately, source the file:

    source ~/.bash_profile
    

    or

    source ~/.zshrc
    

    (You can also reboot the computer.)

Running IoT Gateway

You have to have the correct .NET Core framework installed on your machine to run the gateway: Download .NET 6.

When the gateway starts up, it reads the gateway.config file from the program data folder (see above) corresponding to the instance, if available. If not available, it reads the one provided in the build. This file contains information about what ports to open for different protocols, and any web folders to use. Review the file and its corresponding XML schema to get acquainted with options available. To modify this file, copy the file (if one does not exist) from the build output to the program data folder, and edit it there. Then restart the gateway.