Use SE2's APIs from JS/TS
You can find a detailed specification of SE2's APIs here.
Use our JavaScript SDK to easily interact with SE2's APIs using JavaScript or Typescript.
Install SE2 for JS/TS
Install it via yarn
or npm
:
yarn add @suborbital/se2
or:
npm install @suborbital/se2
Setup
Import the library and configure the client. The default configuration will point the client at SE2's default production URLs in your cluster.
A configuration for local development is also provided.
Default Config
By default, the client will point to the control plane and data plane within your Kubernetes cluster.
import { Suborbital } from "@suborbital/se2";
const suborbital = new Suborbital();
Local config
For local development with SE2 running in docker-compose, the local configuration will point to the services running on your local machine.
import { Suborbital, localConfig } from "@suborbital/se2";
const suborbital = new Suborbital(localConfig);
Custom API URLs or ports
import { Suborbital } from "@suborbital/se2";
const configuration = {
adminUri: "https://acme.co:8081",
execUri: "https://acme.co:8080",
builderUri: "https://acme.co/builder",
};
const suborbital = new Suborbital(configuration);
Getting started
Using the SE2 APIs, this guide will use the Administrative and Execution APIs to get a list of available extensions and execute one.
The Administrative APIs getExtensions
method takes an object with a userId
and a namespace
and returns a list of available extensions for that user in the provided namespace.
async extension listAvailableExtensions() {
const extensionList = await suborbital.admin.getExtensions({
userId: "1234",
namespace: "default",
});
console.log("Extensions:", extensions);
}
Example output
{
"extensions": [
{
"name": "foo",
"namespace": "...",
"lang": "...",
"version": "...",
"draftVersion": "...",
"apiVersion": "...",
"fqext": "...",
"fqextURI": "...",
}
]
}
The result includes a extension named foo
(which for this tutorial already exists) and which we will execute using the Execution APIs run
method.
The run
method takes an object with the environment
, userId
, namespace
, extName
, and version
, and returns the result of the executed extension.
async extension runExtension() {
const result = await suborbital.exec.run({
environment: "com.acmeco",
userId: "1234",
namespace: "default",
extName: "foo",
version: "v1.0.0",
});
console.log("Extension output:", result);
}
Full API
These are all of the available methods.
Admin
suborbital.admin.getToken
Description: Retrieves an authentication token for the given extension, typically used to authenticate calls to the Builder API.
Args: An object containing environment
, userId
, namespace
, extName
.
Result: A string containing the token used for authorization.
suborbital.admin.getExtensions
Description: Returns a list of available extensions for the given user in the given namespace.
Args: An object containing userId
, namespace
.
Result:
{
"extensions": [
{
"name": "foo",
"namespace": "...",
"lang": "...",
"version": "...",
"draftVersion": "...",
"apiVersion": "...",
"fqmn": "...",
"fqmnURI": "...",
}
]
}
suborbital.admin.getExtensionResults
Description: Returns the most recent results (up to 5) produced by the execution of the given extension.
Args: An object containing environment
, userId
, namespace
, extName
, version
.
Result:
{
"results": [
{
"uuid": "...",
"timestamp": "...",
"response": "..."
}
]
}
suborbital.admin.getExtensionErrors
Description: Returns the most recent errors (up to 5) produced by the execution of the given extension.
Args: An object containing environment
, userId
, namespace
, extName
, version
.
Result:
{
"errors": [
{
"uuid": "...",
"timestamp": "...",
"code": 400,
"message": "..."
}
]
}
Exec
suborbital.exec.run
Description: Executes the given extension, with the provided body, params and state loaded into the extension at runtime.
Args: An object containing environment
,userId
,namespace
, extName
,version
.
Result: The result of the executed extension.
Builder
suborbital.builder.build
Description: Builds the provided code using the specified language toolchain.
Args: An object containing language
, environment
, userId
, namespace
, extName
, token
.
Result: A string containing the logs for the build.
suborbital.builder.getDraft
Description: Gets the draft for the specified runnable.
Args: An object containing environment
, userId
, namespace
, extName
, token
.
Result: A specified runnable.
suborbital.builder.deployDraft
Description: Deploys the specified runnable.
Args: An object containing environment
, userId
, namespace
, extName
, token
.
Result: A string containing the version.
suborbital.builder.testDraft
Description: Tests the draft for the specified runnable.
Args: An object containing environment
, userId
, namespace
, extName
.
Result: A string containing the result.
suborbital.builder.getTemplate
Description: Gets the template (which controls what your users see when they create a new extension) for a new extension of the given language.
Args: An object containing extName
, language
.
Result:
import { logInfo } from "@suborbital/suborbital"
export extension run(input: ArrayBuffer): ArrayBuffer {
let inStr = String.UTF8.decode(input)
let out = "Hello there, " + inStr
return String.UTF8.encode(out)
}