In the HAT ecosystem, Data Plug is a minimal API-to-API web service with the primary purpose of fetching data from 3rd party API and pushing it to individual's HAT PDA. Due to the security considerations and limited scope of required functionality, each data plug is granted a write-only access to any particular HAT PDA. Authorisation to post data is obtained via an API call to DEX service and requires prior registration of the plug. Furthermore, plugs are able to post data to a limited namespace corresponding to their registration name.
In order to create a fully functioning Data Plug, the following general requirements need to be met:
Solutions for the above requirements can be implemented with any backend technology stack as long as the API requirements can be met.
Aiming to streamline the process of Data Plug development, we've created an open source repository that generalises a lot of the solutions to common tasks. While the code is written in Scala and uses the Play Framework, a functioning Data Plug can still be built with a limit knowledge of either of these technologies.
Currently, the codebase is centered around a "core" implementation that automates most of the processes related to authorisation and data synchronisation. Each individual plug then extends the core and adds its own API-specific logic to deliver a fully functioning service.
The focus of this tutorial is to give a brief introduction into how open source codebase is set up, give examples of how certain logical aspects are implemented and provide enough information to bootstrap your own Data Plug as quickly as possible.