Improve SDK generation and wrap, promisify and simplify SDK client configuration

This commit is contained in:
Andrew Kingston 2022-09-15 15:17:19 +01:00
parent fff32ea167
commit 0b95c2957c
7 changed files with 95 additions and 22 deletions

View File

@ -1,4 +1,4 @@
src sdk
docs docs
node_modules node_modules
dist dist

View File

@ -3,4 +3,31 @@ JS SDK for the Budibase Public API.
This SDK is generated by [swagger-codegen](https://github.com/swagger-api/swagger-codegen). This SDK is generated by [swagger-codegen](https://github.com/swagger-api/swagger-codegen).
Docker is used to run the generator, so Java is not required. Docker is the only requirement to generate the SDK. Docker is used to run the generator, so Java is not required. Docker is the only requirement to generate the SDK.
The generated code will only run in a browser. It is not currently useable in a NodeJS environment.
## Example usage
```js
import { configure, ApplicationsApi } from "@budibase/sdk"
// Configure the API client
configure({
apiKey: "my-api-key",
host: "https://my.budibase.app"
})
// Search for an app.
// We can use the promisified version...
const res = await ApplicationsApi.applicationsSearchPost({ name: "foo" })
console.log("Applications:", res.data)
// ...or the callback version
ApplicationsApi.applicationsSearchPost({ name: "foo" }, ((error, data) => {
if (error) {
console.error("Failed to search:", error)
} else {
console.log("Applications:", data.data)
}
}))
```

View File

@ -4,13 +4,12 @@
"description": "Budibase Public API SDK", "description": "Budibase Public API SDK",
"author": "Budibase", "author": "Budibase",
"license": "MPL-2.0", "license": "MPL-2.0",
"main": "dist/sdk.cjs",
"module": "dist/sdk.mjs", "module": "dist/sdk.mjs",
"type": "module", "type": "module",
"scripts": { "scripts": {
"generate": "cd scripts && bash generate-sdk.sh", "generate": "cd scripts && bash generate-sdk.sh",
"build": "rollup -c", "build": "yarn run generate && rollup -c",
"dev:server": "rollup -c" "dev:builder": "yarn run build"
}, },
"dependencies": { "dependencies": {
"superagent": "^5.3.0" "superagent": "^5.3.0"

View File

@ -1,22 +1,14 @@
import commonjs from "@rollup/plugin-commonjs" import commonjs from "@rollup/plugin-commonjs"
import resolve from "@rollup/plugin-node-resolve" import resolve from "@rollup/plugin-node-resolve"
import { terser } from "rollup-plugin-terser"
import nodePolyfills from "rollup-plugin-polyfill-node" import nodePolyfills from "rollup-plugin-polyfill-node"
const production = !process.env.ROLLUP_WATCH
export default { export default {
input: "src/index.js", input: "src/index.js",
output: [ output: [
{ {
sourcemap: false, sourcemap: false,
format: "esm", format: "esm",
file: `./dist/sdk.mjs`, file: "./dist/sdk.mjs",
},
{
sourcemap: false,
format: "cjs",
file: `./dist/sdk.cjs`,
}, },
], ],
plugins: [ plugins: [

View File

@ -7,11 +7,8 @@ fi
if [[ -d "generated" ]]; then if [[ -d "generated" ]]; then
rm -r generated rm -r generated
fi fi
if [[ -d "../docs" ]]; then if [[ -d "../sdk" ]]; then
rm -r ../docs rm -r ../sdk
fi
if [[ -d "../src" ]]; then
rm -r ../src
fi fi
# Generate new SDK # Generate new SDK
@ -25,10 +22,10 @@ docker run --rm \
-i /openapi.yml \ -i /openapi.yml \
-l javascript \ -l javascript \
-o /generated -o /generated
--additional-properties useES6=false
# Use a subset of the generated files # Use a subset of the generated files
mv generated/docs ../ mv generated/src ../sdk
mv generated/src ../
# Cleanup # Cleanup
if [[ -f "openapi.yaml" ]]; then if [[ -f "openapi.yaml" ]]; then

51
packages/sdk/src/index.js Normal file
View File

@ -0,0 +1,51 @@
import * as BudibaseApi from "../sdk"
let ApiClient = new BudibaseApi.ApiClient()
// Default to current host
ApiClient.basePath = "/api/public/v1"
/**
* Configures the Budibase Public API SDK
* @param apiKey the user's API key
* @param host the Budibase server host
*/
export const configure = ({ apiKey, host }) => {
ApiClient.authentications["ApiKeyAuth"].apiKey = apiKey
ApiClient.basePath = `${host || ""}/api/public/v1`
}
/**
* Promisifies a generated API SDK and turns it into a more traditional async
* function.
* @param apiName the name of the generated API SDK to promisify
*/
const promisify = apiName => {
// Construct an instance of the generated API
let api = new BudibaseApi[apiName](ApiClient)
// Patch each API endpoint and promisify it
let fns = Object.getOwnPropertyNames(Object.getPrototypeOf(api))
fns = fns.filter(x => x !== "constructor")
fns.forEach(fn => {
const generated = api[fn].bind(api)
api[fn] = async (...params) => {
return new Promise((resolve, reject) => {
generated(...params, (error, data) => {
if (error) {
reject(error)
} else {
resolve(data)
}
})
})
}
})
return api
}
export const ApplicationsApi = promisify("ApplicationsApi")
export const QueriesApi = new BudibaseApi.QueriesApi(ApiClient)
export const RowsApi = promisify("RowsApi")
export const TablesApi = promisify("TablesApi")
export const UsersApi = promisify("UsersApi")

View File

@ -85,6 +85,13 @@
estree-walker "^2.0.1" estree-walker "^2.0.1"
magic-string "^0.25.7" magic-string "^0.25.7"
"@rollup/plugin-json@^4.1.0":
version "4.1.0"
resolved "https://registry.yarnpkg.com/@rollup/plugin-json/-/plugin-json-4.1.0.tgz#54e09867ae6963c593844d8bd7a9c718294496f3"
integrity sha512-yfLbTdNS6amI/2OpmbiBoW12vngr5NW2jCJVZSBEz+H5KfUJZ2M7sDjk0U6GOOdCWFVScShte29o9NezJ53TPw==
dependencies:
"@rollup/pluginutils" "^3.0.8"
"@rollup/plugin-node-resolve@^11.2.1": "@rollup/plugin-node-resolve@^11.2.1":
version "11.2.1" version "11.2.1"
resolved "https://registry.yarnpkg.com/@rollup/plugin-node-resolve/-/plugin-node-resolve-11.2.1.tgz#82aa59397a29cd4e13248b106e6a4a1880362a60" resolved "https://registry.yarnpkg.com/@rollup/plugin-node-resolve/-/plugin-node-resolve-11.2.1.tgz#82aa59397a29cd4e13248b106e6a4a1880362a60"
@ -97,7 +104,7 @@
is-module "^1.0.0" is-module "^1.0.0"
resolve "^1.19.0" resolve "^1.19.0"
"@rollup/pluginutils@^3.1.0": "@rollup/pluginutils@^3.0.8", "@rollup/pluginutils@^3.1.0":
version "3.1.0" version "3.1.0"
resolved "https://registry.yarnpkg.com/@rollup/pluginutils/-/pluginutils-3.1.0.tgz#706b4524ee6dc8b103b3c995533e5ad680c02b9b" resolved "https://registry.yarnpkg.com/@rollup/pluginutils/-/pluginutils-3.1.0.tgz#706b4524ee6dc8b103b3c995533e5ad680c02b9b"
integrity sha512-GksZ6pr6TpIjHm8h9lSQ8pi8BE9VeubNT0OMJ3B5uZJ8pz73NPiqOtCog/x2/QzM1ENChPKxMDhiQuRHsqc+lg== integrity sha512-GksZ6pr6TpIjHm8h9lSQ8pi8BE9VeubNT0OMJ3B5uZJ8pz73NPiqOtCog/x2/QzM1ENChPKxMDhiQuRHsqc+lg==