Skip to content

Latest commit

 

History

History
178 lines (143 loc) · 7.93 KB

README.md

File metadata and controls

178 lines (143 loc) · 7.93 KB

Description

The origin of the project is the desire for an easily accessible place for data exchange on the Internet. Inspired by JSON-Storages the idea of a feature-rich equivalent based on XML, XPath and XSLT was born. The focus should be on a public, volatile and short-term data exchange for (static) web-applications and IoT.

Just exchange data without an own server landscape.
Just exchange data without knowing and managing all clients.

XML-Micro-Exchange is a volatile NoSQL stateless micro datasource for the Internet. It is designed for easy communication and data exchange of web-applications and for IoT or for other Internet-based modules and components. The XML based datasource is volatile and lives through continuous use and expires through inactivity. They are designed for active and near real-time data exchange but not as a real-time capable long-term storage. Compared to a JSON storage, this datasource supports more dynamics, partial data access, data transformation, and volatile short-term storage.

Why all this?

  • Static web-applications on different clients want to communicate with each other, e.g. for games, chats and collaboration.
  • Smart sensors want to share their data and smart devices want to access this data and also exchange data with each other.
  • Clients can establish dynamically volatile networks.

In this communication are all participants.
No one is a server or master, all are equal and no one has to know the other.
All meet without obligation.

Features

  • RESTful
    The REST API supports the HTTP methods CONNECT, OPTIONS, GET, POST, PUT, PATCH, DELETE. The CONNECT method is not a standard and the function can be used alternatively via TOUCH or PUT without XPath.
  • XPath
    XPath axes and functions are used for access, navigation and addressing of targets in the data source and it is an integral part of the URI with dynamic and functional effects.
  • Multiple axes and targets
    An XPath axis can address several elements and attributes simultaneously, which can be changed with one call.
  • XPath Functions
    PUT and PATCH support XML structures and static values (text), as well as XPath functions that allow dynamic values.
  • Data Query
    Data can be queried in the form of XML structure or substructure if the XPath notation represents an axis, otherwise the XPath is interpreted as an XPath function and responded with the result as text. Thus XPath provides a dynamic syntax for queries.
  • Data Transformation
    The POST method supports data transformation via XSLT. Similar to GET, data can be queried and then transformed with an XSLT template transmitted via POST.
  • JSON Support
    All requests can be responded by the service in JSON format.
  • Security
    This aspect was deliberately considered and implemented here only in a very rudimentary form. The storage name with a length of 1 - 64 characters and the individual root element can be regarded as secret. For further security the approach of Basic Authentication, Digest Access Authentication and/or Server/Client certificates is followed, which is configured outside of the XMEX (XML-Micro-Exchange) at the web server.

Licence Agreement

LIZENZBEDINGUNGEN - Seanox Software Solutions ist ein Open-Source-Projekt, im Folgenden Seanox Software Solutions oder kurz Seanox genannt.

Diese Software unterliegt der Version 2 der Apache License.

Copyright (C) 2024 Seanox Software Solutions

Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at

http://www.apache.org/licenses/LICENSE-2.0

Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License.

System Requirement

  • PHP 8.x or higher (+xsl)

Downloads

Seanox XML-Micro-Exchange 1.6.0

curl -LO https://github.com/seanox/xml-micro-exchange-php/releases/latest/download/seanox-xmex-latest.zip

Docker Image

https://hub.docker.com/r/seanox/xmex

docker run -d -p 80:80/tcp --rm --name xmex seanox/xmex:php

Free XML-Micro-Exchange

Before using, you must read, understand and agree to Terms of Service and Privacy Policy.

Web site and documentation
https://xmex.seanox.com/

Service Endpoint URL
https://xmex.seanox.com/xmex!
65536 Storages x 64 kB
Please do not get confused, the API is online.
Requests without storage identifier (see manual) are responded with status 400.

See also OpenAPI YAML or open OpenAPI YAML in a GUI.

It is a small server (1 vCore, 1 GB RAM, 10 GB SSD) in a big data center -- but apparently enough.
Sponsors are always welcome.
It costs about 5 Euro per month for 1,000,000 storages x 64 kB with double CPU cores and double memory.

Example Multiplayer Snake (Online)
https://xmex.seanox.com/snake.html

Manual

Changes

1.6.0 20241223

BF: Service: Correction of REQUEST_URI for requests without protocol
BF: Service: Review and optimization
CR: Content: Added snake.html as example and little gimmick
CR: Service: Omission of the HTTP method TOUCH
CR: Service: Change from status code to 304 when creating
CR: Service: JSON transformation uses the Accept header

Read more

Contact

Issues
Requests
Mail