Backend Plugins
This document provides a brief outline for extending the Stratos backend (Jetstream).
Currently, to create an extension to the backend:
- Create a folder for your plugin, in the folder - src/jetstream/plugins
- Edit - src/jetstream/load_plugins.goand:- Add your plugin's package to the importblock at the top of the file
- Add your plugin to the list of plugins to be initialized in the loadPluginsfunction, e.g.
 {"myplugin", myplugin.Init},
- Add your plugin's package to the 
- Build Jetstream 
There are a few plugins in the
src/jetstream/pluginsfolder that should help serve as examples of how to write a plugin.
Jetstream uses the Echo web server from Labstack - some familiarity with this is required when developing backend plugins.
Plugin Interface
All plugins must implement the interface interfaces.StratosPlugin - this is defined in src/jetstream/repository/interfaces/plugin.go.
A plugin can implement one or all of the following plugin interfaces - Middleware, Endpoint and Route.
This interface defines 4 functions:
- Init() error- This is called to initialize the plugin. If an error is returned then the plugin will not be added to the backend.
- GetMiddlewarePlugin() (MiddlewarePlugin, error)- Provides the middleware that this plugin wishes to add to Stratos, if any. Return an error if your plugin does not need to add middleware.
- GetEndpointPlugin() (EndpointPlugin, error)- Provides the endpoint that this plugin wishes to add to Stratos, if any. Return an error if your plugin does not need to add middleware.
- GetRoutePlugin() (RoutePlugin, error)- Provides the route that this plugin wishes to add to Stratos, if any. Return an error if your plugin does not need to add middleware.
Each of the three plugin interfaces are described below.
Middleware
The MiddlewarePlugin interface provides a plugin with a mechanism to add custom middleware to the Jetstream web server (Echo). This allows it to add upfront processing/filtering/handling of all API requests to the backend. There are two handlers that are required to be provided:
- EchoMiddleware- This is added as middleware to the echo web server for all requests that are not guarded by the session gate - i.e. requests that a non-logged-in user can access
- SessionEchoMiddleware- This is added as middleware to the echo web server for all requests that are guarded by the session gate - i.e. requests that only a logged-in user can access
This interface is defined in the file src/jetstream/repository/interfaces/general.go:
Endpoint
The EndpointPlugin should be used when a plugin wishes to add a new type of Endpoint. An example of this is the Metrics plugin in the folder src/jetstream/plugins/metrics.
This interface is defined in the file src/jetstream/repository/interfaces/endpoints.go:
Adding a new Endpoint type is more involved than other plugin types and will be documented in more detail later.
For now, briefly:
- GetTypeis used to return the endpoint type - a unique ID for the endpoint type - e.g. "metrics"
- Infois used to obtain information for the given endpoint URL
- Registeris called when the user wants to register a new Endpoint of this type
- Connectis called when the user wants to connect a new Endpoint of this type
- UpdateMetadatais called when the- inforequest is made to the backend and gives each endpoint plugin the opportunity to update the metadata returned. For example, in the case of metrics, the plugin will update endpoints to indicate which have metrics metadata available.
Routes
The RoutePlugin interface provides a plugin with a mechanism to add custom handlers to the Jetstream web server (Echo). This allows it to add any custom API processing. There are two handlers that are required to be provided:
- AddSessionGroupRoutes- This is added as a handler to the echo web server and is guarded so that only logged-in users can access.
- AddAdminGroupRoutes- This is added as a handler to the echo web server and is guarded so that only logged-in users who are Stratos Administrators can access.
This interface is defined in the file src/jetstream/repository/interfaces/endpoints.go:
The primary purpose of the RoutePlugin is to add new APIs to Jetstream.
All handlers are added under the /v1 URL prefix.