Web Content with server-side script

The Neuronยฎ supports server-side script in multiple types of documents that are used in web applications. This article provides a short overview.

File types supporting server-side script
Extension Type Description
.md Markdown Markdown files can embed server-side script in two forms, both inline, between single { and }, or preprocessed between {{ and }}.
.cssx CSS Extended (x) CSS files that can include preprocessed script between ยค characters. Inline script is not supported.
.htmlx HTML Extended (x) HTML files that can include preprocessed script between {{ and }}. Inline script is not supported.
.jsx JavaScript Extended (x) JavaScript files that can include preprocessed script between {{ and }}. Inline script is not supported.
.ws Web Service A script file that can be executed when called as a web service.

Note: Preprocessed script can alter the structure of the document, as it is processed before the document is parsed. Inline script however, is embedded into the document after the document structure has been parsed, and can therefore not alter the underlying document structure.

#new, #features, #neuron, #web


Adding custom HTTP headers to web resources

You can add custom HTTP response headers to content hosted by the TAG Neuron® in different ways: If you publish content using Markdown you can use (meta-data tags)(/Markdown.mdmetadata) to add custom HTTP response headers when the page is displayed. But if you publish other types of content which the Neuron® simply forwards to web clients (such as HTML pages) you can configure custom default HTTP Response headers anyway. You can define them in general, for all content in the Root folder, or you can specify them specifically for content in specific file folders. All these configurations are done in the Gateway.config file in the program data folder, and require the Neuron® to be restarted after configuration. You can edit the contents of this configuration file from the web-based Admin interface (or other admin interfaces) available on the Neuron®.

Note: One reason to configure custom default HTTP headers, is if you want to configure Cross-Origin Resource Sharing (CORS) for your site.

To edit the configuration file, find the Sources & Nodes command in the Data section on the main menu:

Data Menu
Data Menu

When clicking on the button, a new page appears with available Data Sources and their nodes, in a tree structure. What data sources and nodes are available here, depends on earlier configuration and available software modules, as they can extend the types of sources and nodes you can use. Find the Gateway configuration data source, and expand it, and then select the WebServer node, and then click the Add button. This command will display types of nodes you can add to the Web Server.

WebServer Node
WebServer Node

To add the CORS header Access-Control-Allow-Origin, and allow javascript to call resources on any domain, click the Default HTTP Header button. This will add a new node of this type to the selected node (the WebServer node). Adding a Default HTTP Header to the Web Server node, will create a default HTTP header for all resources in the Neuron® root folder. You can also add Default HTTP Header nodes to specific file folder nodes. In that case, the default HTTP header will only be added for resources in that file folder.

Adding Default HTTP Header
Adding Default HTTP Header

Press the Create button to create the node. The rule will not be applied before you restart the Neuron®, so restart it when you are ready. After a restart, you can navigate to any resource in the root folder and check the HTTP headers in the response, using the browser’s developer tools, to see that your custom default HTTP response header is available in your responses.

Example HTTP Response Headers
Example HTTP Response Headers

#new, #features, #web, #admin, #neuron, #cors


Web folders for sub-domains

The the Neuron® now facilitates distribution of content packages for sub-domains. The integrated web server publishes files from in the C:\ProgramData\IoT Gateway\Root folder (a.k.a. the Root folder) on the web. If the Neuron® supports multiple domains, you can put domain-specific files in subfolders having the same name as the corresponding domain name. A Neuron® with domain name example.com and alternative domain name example.org would publish the contents of the Root folder on both names. But files in the Root\example.org folder would be accessible only to clients getting files from the example.org domain name. (Files are also accessible from the example.com domain name, if the file names are preceded by the alterantive domain name. For example, https://example.org/Folder/File.html would also be accessible on https://example.com/example.org/Folder/File.html).

From build 2023-08-25, this feature has been extended to sub-domains. If the Neuron® also has an alternative domain sub.example.com, files in the Root\sub folder would be available when viewing contents on the sub.example.com domain.

This simplifies the distribution of software packages across the Neuron®-network, whose content is supposed to be accessible on sub-domains on the corresponding Neurons. As all Neurons have different domain names, folders using the full domain name would complicate distribution. However, by using on the subdomain as folder name, the software package would be successfully delivered to all neurons, regardless of each one’s main domain name.

Note: If adding a domain or a subdomain to a Neuron®, don’t forget to add the domain (or subdomain) to the list of alternative domain names, under Admin / Communication / Domain, and create a new certificate.

#new, #features, #neuron, #web


Semantic Web technologies for real-time Web of Things

The following video is a recording of a presentation, where I introduce the new support for Semantic Web technologies in the TAG Neuron®, and how it can be used to query, join and consolidate information that is available in both external and local data sources (graphs), as well as real-time communication devices, such as sensors and actuators. The Semantic Web technologies presented are standardized by the W3C, so the solution (the only solution in the world?) provides a query language for stored and real-time information in a federated network that is 100% built on standards. No proprietary languages or APIs necessary, reducing costs and complexity of implementaton.

#new, #features, #tutorial, #semantic, #web, #iot


Neurons now incorporate a SPARQL endpoint

TAG Neuron®s now incorporate a SPARQL endpoint (as of build-time 2023-07-03). SPARQL is a standardized SQL-like federated query language for information in the semantic web. SPARQL allows you to ask the entire federated network a query, which is processed in a decentralized manner, and consolidated into one response, without having to resort to collecting information into centralized repositories. With this new SPARQL endpoint, you can build systems and services that use 100% standardized interoperable queries to process information in a decentralized federated Neuron®-network. Processing information in this way represents the highest category of linked data for the web, sometimes also referred to as the five stars of open data. Combining federated web standards for the semantic web with the federated and secure nature of XMPP allows for both flexibility, interoperability and security.

Use cases

SPARQL is suitable for a wide range of applications: Consolidating information across boundaries, for instance in open data or smart city solutions, where data from different organizations need to be joined. As the semantic web standards are joined with XMPP (using the httpx URI scheme from XEP-0332), confidential and personal information can also be processed securely, without risking the data end up in the wrong hands. Queries can be processed in the secure context of digital identities of users, processors and controllers, assuring access is only granted to authorized entities.

Real-time data

The TAG Neuron® also provides access to real-time data from devices via semantic resources, making it possible to join data stored in graph data stores, with real-time data directly from the devices, without collecting and storing them in data lakes. This maximizes privacy and security, minimizes latency, and saves on communication resources and bandwith, as access to devices is only necessary when someone actually requires access, not as a means to have a relatively recent value available in a database, should someone want to access it.

Access

Access to the SPARQL endpoint is through the standardized /sparql resource on the Neuron®. Access rights to the resource needs to be granted. On a TAG Neuron® you can request access via the /Feedback.md page. You can access these on the Lab-Neuron®, via the following links:

Graph Store (Graph Database)

The TAG Neuron® also supports the SPARQL Graph Store Protocol, which allows authorized entities to use the Neuron® to store semantic graphs on the Neuron®. They can add, update, retrieve, delete, and query such graphs. Once a graph has been added to the graph store, the URI of that graph will point to the graph stored in the graph store, and no HTTP GET to the URL will be performed, when querying the graph. This also allows for the creation of graphs with URIs that do not point to actual semantic data sources.

The resource used for accessing the graph store, is the /rdf-graph-store resource, as shown in the W3C standard specification of the graph store protocol. On the Lab Neuron®, this corresponds to https://lab.tagroot.io/rdf-graph-store. There’s a web form you can use, that interacts with the underlying graph store API also.

The default graph in the graph store consists of references to graphs in the graph store. This can be used to loop through graphs in queries, using the GRAPH pattern.

Privileges

To access the different featured mentioned, the following privileges are required to be held by the entity performing the actions:

Action Privilege Required
SPARQL Query Admin.Graphs.Query
Create Graph Admin.Graphs.Add
Update Graph Admin.Graphs.Update
Delete Graph Admin.Graphs.Delete
Get Graph Admin.Graphs.Get

Standardized/Interoperable Data formats

Data formats for semantic information vary. Apart from internal processing and transformation (for example for real-time data from sensors), and bespoke data formats, the following formats/representations are supported in federated queries, for interoperability:

Data representation format is indicated using the HTTP Header Content-Type, while response type is requested using the Accept header.

Example

The following example shows a simple query for a sensor data from semantic information stored in a graph, hosted in a GitHub repository. The query does not select the graph in this example, instead it is provided via an additional input on the form. (Graphs can be specified both in the query directly, or via one or more input fields.)

SPARQL Query Example.png
SPARQL Query Example.png

Click Execute to execute the query. The result is shown dynamically below the buttons, in the format requested.

SPARQL Example Response.png
SPARQL Example Response.png

While this example is done via the web form available on the Neuron®, it can be automated via the standardized /sparql resource as well.

#neuron, #features, #api, #semantic, #web, #sparql


Posts tagged #web

No more posts with the given tag could be found. You can go back to the main view by selecting Home in the menu above.