Plugin API typing.
This commit is contained in:
parent
d0179ed815
commit
3446b1c678
|
@ -3,8 +3,12 @@ import {
|
||||||
getPluginMetadata,
|
getPluginMetadata,
|
||||||
extractTarball,
|
extractTarball,
|
||||||
} from "../../../utilities/fileSystem"
|
} from "../../../utilities/fileSystem"
|
||||||
|
import { FileType } from "@budibase/types"
|
||||||
|
|
||||||
export async function fileUpload(file: { name: string; path: string }) {
|
export async function fileUpload(file: FileType) {
|
||||||
|
if (!file.name || !file.path) {
|
||||||
|
throw new Error("File is not valid - cannot upload.")
|
||||||
|
}
|
||||||
if (!file.name.endsWith(".tar.gz")) {
|
if (!file.name.endsWith(".tar.gz")) {
|
||||||
throw new Error("Plugin must be compressed into a gzipped tarball.")
|
throw new Error("Plugin must be compressed into a gzipped tarball.")
|
||||||
}
|
}
|
||||||
|
|
|
@ -2,26 +2,37 @@ import { npmUpload, urlUpload, githubUpload } from "./uploaders"
|
||||||
import { plugins as pluginCore } from "@budibase/backend-core"
|
import { plugins as pluginCore } from "@budibase/backend-core"
|
||||||
import {
|
import {
|
||||||
PluginType,
|
PluginType,
|
||||||
FileType,
|
|
||||||
PluginSource,
|
PluginSource,
|
||||||
Ctx,
|
|
||||||
CreatePluginRequest,
|
CreatePluginRequest,
|
||||||
CreatePluginResponse,
|
CreatePluginResponse,
|
||||||
|
UserCtx,
|
||||||
|
UploadPluginRequest,
|
||||||
|
Plugin,
|
||||||
|
UploadPluginResponse,
|
||||||
|
FetchPluginResponse,
|
||||||
|
DeletePluginResponse,
|
||||||
} from "@budibase/types"
|
} from "@budibase/types"
|
||||||
import env from "../../../environment"
|
import env from "../../../environment"
|
||||||
import { clientAppSocket } from "../../../websockets"
|
import { clientAppSocket } from "../../../websockets"
|
||||||
import sdk from "../../../sdk"
|
import sdk from "../../../sdk"
|
||||||
import { sdk as pro } from "@budibase/pro"
|
import { sdk as pro } from "@budibase/pro"
|
||||||
|
|
||||||
export async function upload(ctx: any) {
|
export async function upload(
|
||||||
const plugins: FileType[] =
|
ctx: UserCtx<UploadPluginRequest, UploadPluginResponse>
|
||||||
ctx.request.files.file.length > 1
|
) {
|
||||||
? Array.from(ctx.request.files.file)
|
const files = ctx.request.files
|
||||||
: [ctx.request.files.file]
|
const plugins =
|
||||||
|
files && Array.isArray(files.file) && files.file.length > 1
|
||||||
|
? Array.from(files.file)
|
||||||
|
: [files?.file]
|
||||||
|
|
||||||
try {
|
try {
|
||||||
let docs = []
|
let docs: Plugin[] = []
|
||||||
// can do single or multiple plugins
|
// can do single or multiple plugins
|
||||||
for (let plugin of plugins) {
|
for (let plugin of plugins) {
|
||||||
|
if (!plugin || Array.isArray(plugin)) {
|
||||||
|
continue
|
||||||
|
}
|
||||||
const doc = await sdk.plugins.processUploaded(plugin, PluginSource.FILE)
|
const doc = await sdk.plugins.processUploaded(plugin, PluginSource.FILE)
|
||||||
docs.push(doc)
|
docs.push(doc)
|
||||||
}
|
}
|
||||||
|
@ -37,7 +48,7 @@ export async function upload(ctx: any) {
|
||||||
}
|
}
|
||||||
|
|
||||||
export async function create(
|
export async function create(
|
||||||
ctx: Ctx<CreatePluginRequest, CreatePluginResponse>
|
ctx: UserCtx<CreatePluginRequest, CreatePluginResponse>
|
||||||
) {
|
) {
|
||||||
const { source, url, headers, githubToken } = ctx.request.body
|
const { source, url, headers, githubToken } = ctx.request.body
|
||||||
|
|
||||||
|
@ -91,11 +102,11 @@ export async function create(
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
export async function fetch(ctx: any) {
|
export async function fetch(ctx: UserCtx<void, FetchPluginResponse>) {
|
||||||
ctx.body = await sdk.plugins.fetch()
|
ctx.body = await sdk.plugins.fetch()
|
||||||
}
|
}
|
||||||
|
|
||||||
export async function destroy(ctx: any) {
|
export async function destroy(ctx: UserCtx<void, DeletePluginResponse>) {
|
||||||
const { pluginId } = ctx.params
|
const { pluginId } = ctx.params
|
||||||
|
|
||||||
try {
|
try {
|
||||||
|
|
|
@ -10,7 +10,7 @@ import env from "../../environment"
|
||||||
import { clientAppSocket } from "../../websockets"
|
import { clientAppSocket } from "../../websockets"
|
||||||
import { sdk as pro } from "@budibase/pro"
|
import { sdk as pro } from "@budibase/pro"
|
||||||
|
|
||||||
export async function fetch(type?: PluginType) {
|
export async function fetch(type?: PluginType): Promise<Plugin[]> {
|
||||||
const db = tenancy.getGlobalDB()
|
const db = tenancy.getGlobalDB()
|
||||||
const response = await db.allDocs(
|
const response = await db.allDocs(
|
||||||
dbCore.getPluginParams(null, {
|
dbCore.getPluginParams(null, {
|
||||||
|
|
|
@ -1,4 +1,10 @@
|
||||||
import { PluginSource } from "../../documents"
|
import { PluginSource, Plugin } from "../../documents"
|
||||||
|
|
||||||
|
export interface UploadPluginRequest {}
|
||||||
|
export interface UploadPluginResponse {
|
||||||
|
message: string
|
||||||
|
plugins: Plugin[]
|
||||||
|
}
|
||||||
|
|
||||||
export interface CreatePluginRequest {
|
export interface CreatePluginRequest {
|
||||||
source: PluginSource
|
source: PluginSource
|
||||||
|
@ -10,3 +16,9 @@ export interface CreatePluginRequest {
|
||||||
export interface CreatePluginResponse {
|
export interface CreatePluginResponse {
|
||||||
plugin: any
|
plugin: any
|
||||||
}
|
}
|
||||||
|
|
||||||
|
export type FetchPluginResponse = Plugin[]
|
||||||
|
|
||||||
|
export interface DeletePluginResponse {
|
||||||
|
message: string
|
||||||
|
}
|
||||||
|
|
|
@ -13,8 +13,8 @@ export enum PluginSource {
|
||||||
FILE = "File Upload",
|
FILE = "File Upload",
|
||||||
}
|
}
|
||||||
export interface FileType {
|
export interface FileType {
|
||||||
path: string
|
path: string | null
|
||||||
name: string
|
name: string | null
|
||||||
}
|
}
|
||||||
|
|
||||||
export interface Plugin extends Document {
|
export interface Plugin extends Document {
|
||||||
|
|
Loading…
Reference in New Issue