@thing-description-playground/td_to_asyncapi

1.1.1 • Public • Published

@thing-description-playground/TD_TO_ASYNCAPI

The package providing support for AsyncAPI instance generation (output as json or yaml), using a Thing Description (TD) as input.

Limitations

This conversion package should be seen as a first draft. It is currently limited to the mqtt protocol and converting observable properties or subscribable events of a Thing Description instance to channels of an AsyncAPI instance. Furthermore it converts some general information of the documents, e.g., an id if available. Due to the structure of both specifications there occur other limitations, e.g., an AsyncAPI document does not allow specifying servers only for some channels or security restrictions for specific channels/operations/messages.

Possible Extensions

Resulting from the current Limitations there are possible extensions for the future:

  • Supporting the http protocol:
    Both the TD and the AsyncAPI specification support describing http based operations. But they are doing so in a quite different way, which is the tricky part if one wants to convert from one to another. The Thing Description supports http not only event based but also synchronously, the subprotocols longpoll, ws (WebSockets) and sse (ServerSideEvents) are used to describe asynchronous operations. In the AsyncAPI tutorials and specification the http protocol is always mentioned to support "http streaming APIs", which could refer to SSE implementations but also something else. The specification does not mention certain subprotocols but allows defining http messages (as request/response and with method) so one way of converting could be to specify necessary messages for every subprotocol. Still this does probably not really represent the real implementations properly.

  • Supporting the ws (WebSockets) protocol:
    AsyncAPI treats WebSocket connections as independent protocol with given restrictions, e.g., only one websocket connection is possible per AsyncAPI instance (because routing channels to certain servers is not possible and WebSocket does not support channels/topics/...). This should be taken into account for the conversion, one promising approach for converting protocols other then mqtt-like, could be to generate one AsyncAPI instance per available server to deal with the in this case more expressive TDs.

  • Adding security support:
    The focus of AsyncAPI is hardly on security (since event-based solutions are often used in closed systems) but still it supports quite some mechanisms. The more complicated part in converting this from TD to AsyncAPI is that TDs support different security mechanisms for every operation, while AsyncAPI allows only defining them per Server (and there is no server to channel/operation/message mapping).

  • Add further use cases:
    Currently only two types of TD interactions are mapped to their AsyncAPI equivalents:

    • Properties with the op observeproperty indicating that the property can be watched asynchronously
    • Events to which a client can subscribe (subscribeevent)

    But there could be other use cases that should be taken into account, e.g., reading (possible with retain option) variables via mqtt that might not be an asynchronous operation itself but useful to support since mqtt operations cannot be represented with OpenAPI instances.

  • Think about how to treat interactions with the same path (-> same AsyncAPI channel), e.g., a property and an event that both interact with thing.example.com/status

Comments

A TD hasn't necessarily to be valid in order to be converted to an AsyncAPI instance. This converter will only throw an Error if the invalid part has a strong effect on the conversion result, but tries to ignore the most cases. This is by purpose, since there is the possibility to validate a TD using, e.g., the playground core package and the conversion of experimental TDs for example to create new TD features, should be supported.

Usage

You can use this package to integrate AsyncAPI instance generation from a TD in your application.

  • Install this package via NPM (npm install @thing-description-playground/td_to_asyncapi) (or clone repo and install the package with npm install)

  • Node.js or Browser import:

    • Node.js: Require the package and use the functions
    const tdToAsyncAPI = require("@thing-description-playground/td_to_asyncapi")
    • Browser: Import the tdToAsyncAPI object as a global by adding a script tag to your html.
    <script src="./node_modules/@thing-description-playground/td_to_asyncapi/dist/web-bundle.min.js"></script>
  • Now you can convert a TD to an AsyncAPI instance.

    tdToAsyncAPI(td).then( AsyncAPI => {
      console.log(JSON.stringify(AsyncAPI.json, undefined, 2))
      console.log(AsyncAPI.yaml)
    })

    You can find usage examples in the tests folder, or the web and cli packages.

License

Licensed under the MIT license, see License.

Versions

Current Tags

  • Version
    Downloads (Last 7 Days)
    • Tag
  • 1.1.1
    0
    • latest

Version History

  • Version
    Downloads (Last 7 Days)
    • Published
  • 1.1.1
    0
  • 1.0.2
    0
  • 1.0.1
    0
  • 1.0.0
    0

Package Sidebar

Install

npm i @thing-description-playground/td_to_asyncapi

Weekly Downloads

0

Version

1.1.1

License

MIT

Unpacked Size

2.77 MB

Total Files

20

Last publish

Collaborators

  • egeko
  • tumeiesi