Fix for #9778 - there was an issue with operationId in the OpenAPI spec, these need to be unique to be compliant with the spec as brought up in the issue. Also re-writing the spec generation to Typescript to be compliant with how backend code is now written.

This commit is contained in:
mike12345567 2023-02-28 18:10:56 +00:00
parent 982a7a17aa
commit cb39053b12
23 changed files with 650 additions and 235 deletions

View File

@ -25,7 +25,7 @@
"dev:stack:down": "node scripts/dev/manage.js down", "dev:stack:down": "node scripts/dev/manage.js down",
"dev:stack:nuke": "node scripts/dev/manage.js nuke", "dev:stack:nuke": "node scripts/dev/manage.js nuke",
"dev:builder": "yarn run dev:stack:up && nodemon", "dev:builder": "yarn run dev:stack:up && nodemon",
"specs": "node specs/generate.js && openapi-typescript specs/openapi.yaml --output src/definitions/openapi.ts", "specs": "ts-node specs/generate.ts && openapi-typescript specs/openapi.yaml --output src/definitions/openapi.ts",
"initialise": "node scripts/initialise.js", "initialise": "node scripts/initialise.js",
"env:multi:enable": "node scripts/multiTenancy.js enable", "env:multi:enable": "node scripts/multiTenancy.js enable",
"env:multi:disable": "node scripts/multiTenancy.js disable", "env:multi:disable": "node scripts/multiTenancy.js disable",

View File

@ -1,9 +1,9 @@
import { join } from "path"
import { writeFileSync } from "fs"
import { examples, schemas } from "./resources"
import * as parameters from "./parameters"
import * as security from "./security"
const swaggerJsdoc = require("swagger-jsdoc") const swaggerJsdoc = require("swagger-jsdoc")
const { join } = require("path")
const { writeFileSync } = require("fs")
const { examples, schemas } = require("./resources")
const parameters = require("./parameters")
const security = require("./security")
const VARIABLES = {} const VARIABLES = {}
@ -60,7 +60,7 @@ const options = {
apis: [join(__dirname, "..", "src", "api", "routes", "public", "*.ts")], apis: [join(__dirname, "..", "src", "api", "routes", "public", "*.ts")],
} }
function writeFile(output, filename) { function writeFile(output: any, filename: string) {
try { try {
const path = join(__dirname, filename) const path = join(__dirname, filename)
let spec = output let spec = output
@ -79,7 +79,7 @@ function writeFile(output, filename) {
} }
} }
function run() { export function run() {
const outputJSON = swaggerJsdoc(options) const outputJSON = swaggerJsdoc(options)
options.format = ".yaml" options.format = ".yaml"
const outputYAML = swaggerJsdoc(options) const outputYAML = swaggerJsdoc(options)
@ -90,5 +90,3 @@ function run() {
if (require.main === module) { if (require.main === module) {
run() run()
} }
module.exports = run

View File

@ -1829,7 +1829,7 @@
"paths": { "paths": {
"/applications": { "/applications": {
"post": { "post": {
"operationId": "create", "operationId": "appCreate",
"summary": "Create an application", "summary": "Create an application",
"tags": [ "tags": [
"applications" "applications"
@ -1870,7 +1870,7 @@
}, },
"/applications/{appId}": { "/applications/{appId}": {
"put": { "put": {
"operationId": "update", "operationId": "appUpdate",
"summary": "Update an application", "summary": "Update an application",
"tags": [ "tags": [
"applications" "applications"
@ -1909,7 +1909,7 @@
} }
}, },
"delete": { "delete": {
"operationId": "destroy", "operationId": "appDestroy",
"summary": "Delete an application", "summary": "Delete an application",
"tags": [ "tags": [
"applications" "applications"
@ -1938,7 +1938,7 @@
} }
}, },
"get": { "get": {
"operationId": "getById", "operationId": "appGetById",
"summary": "Retrieve an application", "summary": "Retrieve an application",
"tags": [ "tags": [
"applications" "applications"
@ -1969,7 +1969,7 @@
}, },
"/applications/{appId}/unpublish": { "/applications/{appId}/unpublish": {
"post": { "post": {
"operationId": "unpublish", "operationId": "appUnpublish",
"summary": "Unpublish an application", "summary": "Unpublish an application",
"tags": [ "tags": [
"applications" "applications"
@ -1988,7 +1988,7 @@
}, },
"/applications/{appId}/publish": { "/applications/{appId}/publish": {
"post": { "post": {
"operationId": "publish", "operationId": "appPublish",
"summary": "Unpublish an application", "summary": "Unpublish an application",
"tags": [ "tags": [
"applications" "applications"
@ -2019,7 +2019,7 @@
}, },
"/applications/search": { "/applications/search": {
"post": { "post": {
"operationId": "search", "operationId": "appSearch",
"summary": "Search for applications", "summary": "Search for applications",
"description": "Based on application properties (currently only name) search for applications.", "description": "Based on application properties (currently only name) search for applications.",
"tags": [ "tags": [
@ -2056,7 +2056,7 @@
}, },
"/queries/{queryId}": { "/queries/{queryId}": {
"post": { "post": {
"operationId": "execute", "operationId": "queryExecute",
"summary": "Execute a query", "summary": "Execute a query",
"description": "Queries which have been created within a Budibase app can be executed using this,", "description": "Queries which have been created within a Budibase app can be executed using this,",
"tags": [ "tags": [
@ -2104,7 +2104,7 @@
}, },
"/queries/search": { "/queries/search": {
"post": { "post": {
"operationId": "search", "operationId": "querySearch",
"summary": "Search for queries", "summary": "Search for queries",
"description": "Based on query properties (currently only name) search for queries.", "description": "Based on query properties (currently only name) search for queries.",
"tags": [ "tags": [
@ -2146,7 +2146,7 @@
}, },
"/tables/{tableId}/rows": { "/tables/{tableId}/rows": {
"post": { "post": {
"operationId": "create", "operationId": "rowCreate",
"summary": "Create a row", "summary": "Create a row",
"description": "Creates a row within the specified table.", "description": "Creates a row within the specified table.",
"tags": [ "tags": [
@ -2196,7 +2196,7 @@
}, },
"/tables/{tableId}/rows/{rowId}": { "/tables/{tableId}/rows/{rowId}": {
"put": { "put": {
"operationId": "update", "operationId": "rowUpdate",
"summary": "Update a row", "summary": "Update a row",
"description": "Updates a row within the specified table.", "description": "Updates a row within the specified table.",
"tags": [ "tags": [
@ -2247,7 +2247,7 @@
} }
}, },
"delete": { "delete": {
"operationId": "destroy", "operationId": "rowDestroy",
"summary": "Delete a row", "summary": "Delete a row",
"description": "Deletes a row within the specified table.", "description": "Deletes a row within the specified table.",
"tags": [ "tags": [
@ -2283,7 +2283,7 @@
} }
}, },
"get": { "get": {
"operationId": "getById", "operationId": "rowGetById",
"summary": "Retrieve a row", "summary": "Retrieve a row",
"description": "This gets a single row, it will be enriched with the full related rows, rather than the squashed \"primaryDisplay\" format returned by the search endpoint.", "description": "This gets a single row, it will be enriched with the full related rows, rather than the squashed \"primaryDisplay\" format returned by the search endpoint.",
"tags": [ "tags": [
@ -2321,7 +2321,7 @@
}, },
"/tables/{tableId}/rows/search": { "/tables/{tableId}/rows/search": {
"post": { "post": {
"operationId": "search", "operationId": "rowSearch",
"summary": "Search for rows", "summary": "Search for rows",
"tags": [ "tags": [
"rows" "rows"
@ -2365,7 +2365,7 @@
}, },
"/tables": { "/tables": {
"post": { "post": {
"operationId": "create", "operationId": "tableCreate",
"summary": "Create a table", "summary": "Create a table",
"description": "Create a table, this could be internal or external.", "description": "Create a table, this could be internal or external.",
"tags": [ "tags": [
@ -2411,7 +2411,7 @@
}, },
"/tables/{tableId}": { "/tables/{tableId}": {
"put": { "put": {
"operationId": "update", "operationId": "tableUpdate",
"summary": "Update a table", "summary": "Update a table",
"description": "Update a table, this could be internal or external.", "description": "Update a table, this could be internal or external.",
"tags": [ "tags": [
@ -2458,7 +2458,7 @@
} }
}, },
"delete": { "delete": {
"operationId": "destroy", "operationId": "tableDestroy",
"summary": "Delete a table", "summary": "Delete a table",
"description": "Delete a table, this could be internal or external.", "description": "Delete a table, this could be internal or external.",
"tags": [ "tags": [
@ -2491,7 +2491,7 @@
} }
}, },
"get": { "get": {
"operationId": "getById", "operationId": "tableGetById",
"summary": "Retrieve a table", "summary": "Retrieve a table",
"description": "Lookup a table, this could be internal or external.", "description": "Lookup a table, this could be internal or external.",
"tags": [ "tags": [
@ -2526,7 +2526,7 @@
}, },
"/tables/search": { "/tables/search": {
"post": { "post": {
"operationId": "search", "operationId": "tableSearch",
"summary": "Search for tables", "summary": "Search for tables",
"description": "Based on table properties (currently only name) search for tables. This could be an internal or an external table.", "description": "Based on table properties (currently only name) search for tables. This could be an internal or an external table.",
"tags": [ "tags": [
@ -2568,7 +2568,7 @@
}, },
"/users": { "/users": {
"post": { "post": {
"operationId": "create", "operationId": "userCreate",
"summary": "Create a user", "summary": "Create a user",
"tags": [ "tags": [
"users" "users"
@ -2604,7 +2604,7 @@
}, },
"/users/{userId}": { "/users/{userId}": {
"put": { "put": {
"operationId": "update", "operationId": "userUpdate",
"summary": "Update a user", "summary": "Update a user",
"tags": [ "tags": [
"users" "users"
@ -2643,7 +2643,7 @@
} }
}, },
"delete": { "delete": {
"operationId": "destroy", "operationId": "userDestroy",
"summary": "Delete a user", "summary": "Delete a user",
"tags": [ "tags": [
"users" "users"
@ -2672,7 +2672,7 @@
} }
}, },
"get": { "get": {
"operationId": "getById", "operationId": "userGetById",
"summary": "Retrieve a user", "summary": "Retrieve a user",
"tags": [ "tags": [
"users" "users"
@ -2703,7 +2703,7 @@
}, },
"/users/search": { "/users/search": {
"post": { "post": {
"operationId": "search", "operationId": "userSearch",
"summary": "Search for users", "summary": "Search for users",
"description": "Based on user properties (currently only name) search for users.", "description": "Based on user properties (currently only name) search for users.",
"tags": [ "tags": [

View File

@ -1397,7 +1397,7 @@ security:
paths: paths:
/applications: /applications:
post: post:
operationId: create operationId: appCreate
summary: Create an application summary: Create an application
tags: tags:
- applications - applications
@ -1421,7 +1421,7 @@ paths:
$ref: "#/components/examples/application" $ref: "#/components/examples/application"
"/applications/{appId}": "/applications/{appId}":
put: put:
operationId: update operationId: appUpdate
summary: Update an application summary: Update an application
tags: tags:
- applications - applications
@ -1444,7 +1444,7 @@ paths:
application: application:
$ref: "#/components/examples/application" $ref: "#/components/examples/application"
delete: delete:
operationId: destroy operationId: appDestroy
summary: Delete an application summary: Delete an application
tags: tags:
- applications - applications
@ -1461,7 +1461,7 @@ paths:
application: application:
$ref: "#/components/examples/application" $ref: "#/components/examples/application"
get: get:
operationId: getById operationId: appGetById
summary: Retrieve an application summary: Retrieve an application
tags: tags:
- applications - applications
@ -1479,7 +1479,7 @@ paths:
$ref: "#/components/examples/application" $ref: "#/components/examples/application"
"/applications/{appId}/unpublish": "/applications/{appId}/unpublish":
post: post:
operationId: unpublish operationId: appUnpublish
summary: Unpublish an application summary: Unpublish an application
tags: tags:
- applications - applications
@ -1490,7 +1490,7 @@ paths:
description: The app was published successfully. description: The app was published successfully.
"/applications/{appId}/publish": "/applications/{appId}/publish":
post: post:
operationId: publish operationId: appPublish
summary: Unpublish an application summary: Unpublish an application
tags: tags:
- applications - applications
@ -1508,7 +1508,7 @@ paths:
$ref: "#/components/examples/deploymentOutput" $ref: "#/components/examples/deploymentOutput"
/applications/search: /applications/search:
post: post:
operationId: search operationId: appSearch
summary: Search for applications summary: Search for applications
description: Based on application properties (currently only name) search for description: Based on application properties (currently only name) search for
applications. applications.
@ -1533,7 +1533,7 @@ paths:
$ref: "#/components/examples/applications" $ref: "#/components/examples/applications"
"/queries/{queryId}": "/queries/{queryId}":
post: post:
operationId: execute operationId: queryExecute
summary: Execute a query summary: Execute a query
description: Queries which have been created within a Budibase app can be description: Queries which have been created within a Budibase app can be
executed using this, executed using this,
@ -1562,7 +1562,7 @@ paths:
$ref: "#/components/examples/sqlResponse" $ref: "#/components/examples/sqlResponse"
/queries/search: /queries/search:
post: post:
operationId: search operationId: querySearch
summary: Search for queries summary: Search for queries
description: Based on query properties (currently only name) search for queries. description: Based on query properties (currently only name) search for queries.
tags: tags:
@ -1587,7 +1587,7 @@ paths:
$ref: "#/components/examples/queries" $ref: "#/components/examples/queries"
"/tables/{tableId}/rows": "/tables/{tableId}/rows":
post: post:
operationId: create operationId: rowCreate
summary: Create a row summary: Create a row
description: Creates a row within the specified table. description: Creates a row within the specified table.
tags: tags:
@ -1618,7 +1618,7 @@ paths:
$ref: "#/components/examples/row" $ref: "#/components/examples/row"
"/tables/{tableId}/rows/{rowId}": "/tables/{tableId}/rows/{rowId}":
put: put:
operationId: update operationId: rowUpdate
summary: Update a row summary: Update a row
description: Updates a row within the specified table. description: Updates a row within the specified table.
tags: tags:
@ -1648,7 +1648,7 @@ paths:
row: row:
$ref: "#/components/examples/row" $ref: "#/components/examples/row"
delete: delete:
operationId: destroy operationId: rowDestroy
summary: Delete a row summary: Delete a row
description: Deletes a row within the specified table. description: Deletes a row within the specified table.
tags: tags:
@ -1669,7 +1669,7 @@ paths:
row: row:
$ref: "#/components/examples/row" $ref: "#/components/examples/row"
get: get:
operationId: getById operationId: rowGetById
summary: Retrieve a row summary: Retrieve a row
description: This gets a single row, it will be enriched with the full related description: This gets a single row, it will be enriched with the full related
rows, rather than the squashed "primaryDisplay" format returned by the rows, rather than the squashed "primaryDisplay" format returned by the
@ -1692,7 +1692,7 @@ paths:
$ref: "#/components/examples/enrichedRow" $ref: "#/components/examples/enrichedRow"
"/tables/{tableId}/rows/search": "/tables/{tableId}/rows/search":
post: post:
operationId: search operationId: rowSearch
summary: Search for rows summary: Search for rows
tags: tags:
- rows - rows
@ -1718,7 +1718,7 @@ paths:
$ref: "#/components/examples/rows" $ref: "#/components/examples/rows"
/tables: /tables:
post: post:
operationId: create operationId: tableCreate
summary: Create a table summary: Create a table
description: Create a table, this could be internal or external. description: Create a table, this could be internal or external.
tags: tags:
@ -1746,7 +1746,7 @@ paths:
$ref: "#/components/examples/table" $ref: "#/components/examples/table"
"/tables/{tableId}": "/tables/{tableId}":
put: put:
operationId: update operationId: tableUpdate
summary: Update a table summary: Update a table
description: Update a table, this could be internal or external. description: Update a table, this could be internal or external.
tags: tags:
@ -1773,7 +1773,7 @@ paths:
table: table:
$ref: "#/components/examples/table" $ref: "#/components/examples/table"
delete: delete:
operationId: destroy operationId: tableDestroy
summary: Delete a table summary: Delete a table
description: Delete a table, this could be internal or external. description: Delete a table, this could be internal or external.
tags: tags:
@ -1792,7 +1792,7 @@ paths:
table: table:
$ref: "#/components/examples/table" $ref: "#/components/examples/table"
get: get:
operationId: getById operationId: tableGetById
summary: Retrieve a table summary: Retrieve a table
description: Lookup a table, this could be internal or external. description: Lookup a table, this could be internal or external.
tags: tags:
@ -1812,7 +1812,7 @@ paths:
$ref: "#/components/examples/table" $ref: "#/components/examples/table"
/tables/search: /tables/search:
post: post:
operationId: search operationId: tableSearch
summary: Search for tables summary: Search for tables
description: Based on table properties (currently only name) search for tables. description: Based on table properties (currently only name) search for tables.
This could be an internal or an external table. This could be an internal or an external table.
@ -1838,7 +1838,7 @@ paths:
$ref: "#/components/examples/tables" $ref: "#/components/examples/tables"
/users: /users:
post: post:
operationId: create operationId: userCreate
summary: Create a user summary: Create a user
tags: tags:
- users - users
@ -1860,7 +1860,7 @@ paths:
$ref: "#/components/examples/user" $ref: "#/components/examples/user"
"/users/{userId}": "/users/{userId}":
put: put:
operationId: update operationId: userUpdate
summary: Update a user summary: Update a user
tags: tags:
- users - users
@ -1883,7 +1883,7 @@ paths:
user: user:
$ref: "#/components/examples/user" $ref: "#/components/examples/user"
delete: delete:
operationId: destroy operationId: userDestroy
summary: Delete a user summary: Delete a user
tags: tags:
- users - users
@ -1900,7 +1900,7 @@ paths:
user: user:
$ref: "#/components/examples/user" $ref: "#/components/examples/user"
get: get:
operationId: getById operationId: userGetById
summary: Retrieve a user summary: Retrieve a user
tags: tags:
- users - users
@ -1918,7 +1918,7 @@ paths:
$ref: "#/components/examples/user" $ref: "#/components/examples/user"
/users/search: /users/search:
post: post:
operationId: search operationId: userSearch
summary: Search for users summary: Search for users
description: Based on user properties (currently only name) search for users. description: Based on user properties (currently only name) search for users.
tags: tags:

View File

@ -1,4 +1,4 @@
exports.tableId = { export const tableId = {
in: "path", in: "path",
name: "tableId", name: "tableId",
required: true, required: true,
@ -8,7 +8,7 @@ exports.tableId = {
}, },
} }
exports.rowId = { export const rowId = {
in: "path", in: "path",
name: "rowId", name: "rowId",
required: true, required: true,
@ -18,7 +18,7 @@ exports.rowId = {
}, },
} }
exports.appId = { export const appId = {
in: "header", in: "header",
name: "x-budibase-app-id", name: "x-budibase-app-id",
required: true, required: true,
@ -28,7 +28,7 @@ exports.appId = {
}, },
} }
exports.appIdUrl = { export const appIdUrl = {
in: "path", in: "path",
name: "appId", name: "appId",
required: true, required: true,
@ -38,7 +38,7 @@ exports.appIdUrl = {
}, },
} }
exports.queryId = { export const queryId = {
in: "path", in: "path",
name: "queryId", name: "queryId",
required: true, required: true,
@ -48,7 +48,7 @@ exports.queryId = {
}, },
} }
exports.userId = { export const userId = {
in: "path", in: "path",
name: "userId", name: "userId",
required: true, required: true,

View File

@ -1,6 +1,6 @@
const userResource = require("./user") import userResource from "./user"
const { object } = require("./utils") import { object } from "./utils"
const Resource = require("./utils/Resource") import Resource from "./utils/Resource"
const application = { const application = {
_id: "app_metadata", _id: "app_metadata",
@ -96,7 +96,7 @@ const deploymentOutputSchema = object({
}, },
}) })
module.exports = new Resource() export default new Resource()
.setExamples({ .setExamples({
application: { application: {
value: { value: {

View File

@ -1,11 +1,11 @@
const application = require("./application") import application from "./application"
const row = require("./row") import row from "./row"
const table = require("./table") import table from "./table"
const query = require("./query") import query from "./query"
const user = require("./user") import user from "./user"
const misc = require("./misc") import misc from "./misc"
exports.examples = { export const examples = {
...application.getExamples(), ...application.getExamples(),
...row.getExamples(), ...row.getExamples(),
...table.getExamples(), ...table.getExamples(),
@ -14,7 +14,7 @@ exports.examples = {
...misc.getExamples(), ...misc.getExamples(),
} }
exports.schemas = { export const schemas = {
...application.getSchemas(), ...application.getSchemas(),
...row.getSchemas(), ...row.getSchemas(),
...table.getSchemas(), ...table.getSchemas(),

View File

@ -1,7 +1,7 @@
const { object } = require("./utils") import { object } from "./utils"
const Resource = require("./utils/Resource") import Resource from "./utils/Resource"
module.exports = new Resource().setSchemas({ export default new Resource().setSchemas({
rowSearch: object( rowSearch: object(
{ {
query: { query: {

View File

@ -1,6 +1,6 @@
const Resource = require("./utils/Resource") import Resource from "./utils/Resource"
const { object } = require("./utils") import { object } from "./utils"
const { BaseQueryVerbs } = require("../../src/constants") import { BaseQueryVerbs } from "../../src/constants"
const query = { const query = {
_id: "query_datasource_plus_4d8be0c506b9465daf4bf84d890fdab6_454854487c574d45bc4029b1e153219e", _id: "query_datasource_plus_4d8be0c506b9465daf4bf84d890fdab6_454854487c574d45bc4029b1e153219e",
@ -189,7 +189,7 @@ const executeQueryOutputSchema = object(
{ required: ["data"] } { required: ["data"] }
) )
module.exports = new Resource() export default new Resource()
.setExamples({ .setExamples({
query: { query: {
value: { value: {

View File

@ -1,5 +1,5 @@
const { object } = require("./utils") import { object } from "./utils"
const Resource = require("./utils/Resource") import Resource from "./utils/Resource"
const baseRow = { const baseRow = {
_id: "ro_ta_5b1649e42a5b41dea4ef7742a36a7a70_e6dc7e38cf1343b2b56760265201cda4", _id: "ro_ta_5b1649e42a5b41dea4ef7742a36a7a70_e6dc7e38cf1343b2b56760265201cda4",
@ -56,7 +56,6 @@ const rowSchema = {
const rowOutputSchema = { const rowOutputSchema = {
...rowSchema, ...rowSchema,
properties: { properties: {
...rowSchema.properties,
_id: { _id: {
description: "The ID of the row.", description: "The ID of the row.",
type: "string", type: "string",
@ -93,7 +92,7 @@ const searchOutputSchema = {
}, },
} }
module.exports = new Resource() export default new Resource()
.setExamples({ .setExamples({
inputRow: { inputRow: {
value: inputRow, value: inputRow,

View File

@ -1,10 +1,10 @@
const { import {
FieldTypes, FieldTypes,
RelationshipTypes, RelationshipTypes,
FormulaTypes, FormulaTypes,
} = require("../../src/constants") } from "../../src/constants"
const { object } = require("./utils") import { object } from "./utils"
const Resource = require("./utils/Resource") import Resource from "./utils/Resource"
const table = { const table = {
_id: "ta_5b1649e42a5b41dea4ef7742a36a7a70", _id: "ta_5b1649e42a5b41dea4ef7742a36a7a70",
@ -170,7 +170,7 @@ const tableOutputSchema = {
required: [...tableSchema.required, "_id"], required: [...tableSchema.required, "_id"],
} }
module.exports = new Resource() export default new Resource()
.setExamples({ .setExamples({
table: { table: {
value: { value: {

View File

@ -1,5 +1,5 @@
const { object } = require("./utils") import { object } from "./utils"
const Resource = require("./utils/Resource") import Resource from "./utils/Resource"
const user = { const user = {
_id: "us_693a73206518477283a8d5ae31103252", _id: "us_693a73206518477283a8d5ae31103252",
@ -105,7 +105,7 @@ const userOutputSchema = {
required: [...userSchema.required, "_id"], required: [...userSchema.required, "_id"],
} }
module.exports = new Resource() export default new Resource()
.setExamples({ .setExamples({
user: { user: {
value: { value: {

View File

@ -1,26 +0,0 @@
class Resource {
constructor() {
this.examples = {}
this.schemas = {}
}
setExamples(examples) {
this.examples = examples
return this
}
setSchemas(schemas) {
this.schemas = schemas
return this
}
getExamples() {
return this.examples
}
getSchemas() {
return this.schemas
}
}
module.exports = Resource

View File

@ -0,0 +1,39 @@
type Example = {
[key: string]: {
[key: string]: any
}
}
type Schema = {
[key: string]: {
[key: string]: any
}
}
export default class Resource {
examples: Example
schemas: Schema
constructor() {
this.examples = {}
this.schemas = {}
}
setExamples(examples: Example) {
this.examples = examples
return this
}
setSchemas(schemas: Schema) {
this.schemas = schemas
return this
}
getExamples() {
return this.examples
}
getSchemas() {
return this.schemas
}
}

View File

@ -1,4 +1,4 @@
exports.object = (props, opts) => { export const object = (props: any, opts?: any) => {
const base = { const base = {
type: "object", type: "object",
properties: props, properties: props,

View File

@ -1,4 +1,4 @@
exports.ApiKeyAuth = { export const ApiKeyAuth = {
type: "apiKey", type: "apiKey",
in: "header", in: "header",
name: "x-budibase-api-key", name: "x-budibase-api-key",

View File

@ -9,7 +9,7 @@ const read = [],
* @openapi * @openapi
* /applications: * /applications:
* post: * post:
* operationId: create * operationId: appCreate
* summary: Create an application * summary: Create an application
* tags: * tags:
* - applications * - applications
@ -42,7 +42,7 @@ write.push(
* @openapi * @openapi
* /applications/{appId}: * /applications/{appId}:
* put: * put:
* operationId: update * operationId: appUpdate
* summary: Update an application * summary: Update an application
* tags: * tags:
* - applications * - applications
@ -75,7 +75,7 @@ write.push(
* @openapi * @openapi
* /applications/{appId}: * /applications/{appId}:
* delete: * delete:
* operationId: destroy * operationId: appDestroy
* summary: Delete an application * summary: Delete an application
* tags: * tags:
* - applications * - applications
@ -98,7 +98,7 @@ write.push(new Endpoint("delete", "/applications/:appId", controller.destroy))
* @openapi * @openapi
* /applications/{appId}/unpublish: * /applications/{appId}/unpublish:
* post: * post:
* operationId: unpublish * operationId: appUnpublish
* summary: Unpublish an application * summary: Unpublish an application
* tags: * tags:
* - applications * - applications
@ -116,7 +116,7 @@ write.push(
* @openapi * @openapi
* /applications/{appId}/publish: * /applications/{appId}/publish:
* post: * post:
* operationId: publish * operationId: appPublish
* summary: Unpublish an application * summary: Unpublish an application
* tags: * tags:
* - applications * - applications
@ -141,7 +141,7 @@ write.push(
* @openapi * @openapi
* /applications/{appId}: * /applications/{appId}:
* get: * get:
* operationId: getById * operationId: appGetById
* summary: Retrieve an application * summary: Retrieve an application
* tags: * tags:
* - applications * - applications
@ -164,7 +164,7 @@ read.push(new Endpoint("get", "/applications/:appId", controller.read))
* @openapi * @openapi
* /applications/search: * /applications/search:
* post: * post:
* operationId: search * operationId: appSearch
* summary: Search for applications * summary: Search for applications
* description: Based on application properties (currently only name) search for applications. * description: Based on application properties (currently only name) search for applications.
* tags: * tags:

View File

@ -9,7 +9,7 @@ const read = [],
* @openapi * @openapi
* /queries/{queryId}: * /queries/{queryId}:
* post: * post:
* operationId: execute * operationId: queryExecute
* summary: Execute a query * summary: Execute a query
* description: Queries which have been created within a Budibase app can be executed using this, * description: Queries which have been created within a Budibase app can be executed using this,
* tags: * tags:
@ -43,7 +43,7 @@ write.push(new Endpoint("post", "/queries/:queryId", controller.execute))
* @openapi * @openapi
* /queries/search: * /queries/search:
* post: * post:
* operationId: search * operationId: querySearch
* summary: Search for queries * summary: Search for queries
* description: Based on query properties (currently only name) search for queries. * description: Based on query properties (currently only name) search for queries.
* tags: * tags:

View File

@ -9,7 +9,7 @@ const read = [],
* @openapi * @openapi
* /tables/{tableId}/rows: * /tables/{tableId}/rows:
* post: * post:
* operationId: create * operationId: rowCreate
* summary: Create a row * summary: Create a row
* description: Creates a row within the specified table. * description: Creates a row within the specified table.
* tags: * tags:
@ -44,7 +44,7 @@ write.push(new Endpoint("post", "/tables/:tableId/rows", controller.create))
* @openapi * @openapi
* /tables/{tableId}/rows/{rowId}: * /tables/{tableId}/rows/{rowId}:
* put: * put:
* operationId: update * operationId: rowUpdate
* summary: Update a row * summary: Update a row
* description: Updates a row within the specified table. * description: Updates a row within the specified table.
* tags: * tags:
@ -81,7 +81,7 @@ write.push(
* @openapi * @openapi
* /tables/{tableId}/rows/{rowId}: * /tables/{tableId}/rows/{rowId}:
* delete: * delete:
* operationId: destroy * operationId: rowDestroy
* summary: Delete a row * summary: Delete a row
* description: Deletes a row within the specified table. * description: Deletes a row within the specified table.
* tags: * tags:
@ -109,7 +109,7 @@ write.push(
* @openapi * @openapi
* /tables/{tableId}/rows/{rowId}: * /tables/{tableId}/rows/{rowId}:
* get: * get:
* operationId: getById * operationId: rowGetById
* summary: Retrieve a row * summary: Retrieve a row
* description: This gets a single row, it will be enriched with the full related rows, rather than * description: This gets a single row, it will be enriched with the full related rows, rather than
* the squashed "primaryDisplay" format returned by the search endpoint. * the squashed "primaryDisplay" format returned by the search endpoint.
@ -136,7 +136,7 @@ read.push(new Endpoint("get", "/tables/:tableId/rows/:rowId", controller.read))
* @openapi * @openapi
* /tables/{tableId}/rows/search: * /tables/{tableId}/rows/search:
* post: * post:
* operationId: search * operationId: rowSearch
* summary: Search for rows * summary: Search for rows
* tags: * tags:
* - rows * - rows

View File

@ -9,7 +9,7 @@ const read = [],
* @openapi * @openapi
* /tables: * /tables:
* post: * post:
* operationId: create * operationId: tableCreate
* summary: Create a table * summary: Create a table
* description: Create a table, this could be internal or external. * description: Create a table, this could be internal or external.
* tags: * tags:
@ -46,7 +46,7 @@ write.push(
* @openapi * @openapi
* /tables/{tableId}: * /tables/{tableId}:
* put: * put:
* operationId: update * operationId: tableUpdate
* summary: Update a table * summary: Update a table
* description: Update a table, this could be internal or external. * description: Update a table, this could be internal or external.
* tags: * tags:
@ -83,7 +83,7 @@ write.push(
* @openapi * @openapi
* /tables/{tableId}: * /tables/{tableId}:
* delete: * delete:
* operationId: destroy * operationId: tableDestroy
* summary: Delete a table * summary: Delete a table
* description: Delete a table, this could be internal or external. * description: Delete a table, this could be internal or external.
* tags: * tags:
@ -108,7 +108,7 @@ write.push(new Endpoint("delete", "/tables/:tableId", controller.destroy))
* @openapi * @openapi
* /tables/{tableId}: * /tables/{tableId}:
* get: * get:
* operationId: getById * operationId: tableGetById
* summary: Retrieve a table * summary: Retrieve a table
* description: Lookup a table, this could be internal or external. * description: Lookup a table, this could be internal or external.
* tags: * tags:
@ -133,7 +133,7 @@ read.push(new Endpoint("get", "/tables/:tableId", controller.read))
* @openapi * @openapi
* /tables/search: * /tables/search:
* post: * post:
* operationId: search * operationId: tableSearch
* summary: Search for tables * summary: Search for tables
* description: Based on table properties (currently only name) search for tables. This could be * description: Based on table properties (currently only name) search for tables. This could be
* an internal or an external table. * an internal or an external table.

View File

@ -1,13 +1,14 @@
const jestOpenAPI = require("jest-openapi").default import jestOpenAPI from "jest-openapi"
const generateSchema = require("../../../../../specs/generate") import { run as generateSchema } from "../../../../../specs/generate"
const setup = require("../../tests/utilities") import * as setup from "../../tests/utilities"
const { generateMakeRequest } = require("./utils") import { generateMakeRequest } from "./utils"
import { Table, App, Row, User } from "@budibase/types"
const yamlPath = generateSchema() const yamlPath = generateSchema()
jestOpenAPI(yamlPath) jestOpenAPI(yamlPath!)
let config = setup.getConfig() let config = setup.getConfig()
let apiKey, table, app, makeRequest let apiKey: string, table: Table, app: App, makeRequest: any
beforeAll(async () => { beforeAll(async () => {
app = await config.init() app = await config.init()
@ -25,19 +26,29 @@ describe("check the applications endpoints", () => {
}) })
it("should allow creating an application", async () => { it("should allow creating an application", async () => {
const res = await makeRequest("post", "/applications", { const res = await makeRequest(
name: "new App" "post",
}, null) "/applications",
{
name: "new App",
},
null
)
expect(res).toSatisfyApiSpec() expect(res).toSatisfyApiSpec()
}) })
it("should allow updating an application", async () => { it("should allow updating an application", async () => {
const app = config.getApp() const app = config.getApp()
const appId = config.getAppId() const appId = config.getAppId()
const res = await makeRequest("put", `/applications/${appId}`, { const res = await makeRequest(
...app, "put",
name: "updated app name", `/applications/${appId}`,
}, appId) {
...app,
name: "updated app name",
},
appId
)
expect(res).toSatisfyApiSpec() expect(res).toSatisfyApiSpec()
}) })
@ -47,7 +58,10 @@ describe("check the applications endpoints", () => {
}) })
it("should allow deleting an application", async () => { it("should allow deleting an application", async () => {
const res = await makeRequest("delete", `/applications/${config.getAppId()}`) const res = await makeRequest(
"delete",
`/applications/${config.getAppId()}`
)
expect(res).toSatisfyApiSpec() expect(res).toSatisfyApiSpec()
}) })
}) })
@ -68,8 +82,8 @@ describe("check the tables endpoints", () => {
column1: { column1: {
type: "string", type: "string",
constraints: {}, constraints: {},
} },
} },
}) })
expect(res).toSatisfyApiSpec() expect(res).toSatisfyApiSpec()
}) })
@ -92,12 +106,11 @@ describe("check the tables endpoints", () => {
}) })
describe("check the rows endpoints", () => { describe("check the rows endpoints", () => {
let row let row: Row
it("should allow retrieving rows through search", async () => { it("should allow retrieving rows through search", async () => {
table = await config.updateTable() table = await config.updateTable()
const res = await makeRequest("post", `/tables/${table._id}/rows/search`, { const res = await makeRequest("post", `/tables/${table._id}/rows/search`, {
query: { query: {},
},
}) })
expect(res).toSatisfyApiSpec() expect(res).toSatisfyApiSpec()
}) })
@ -111,9 +124,13 @@ describe("check the rows endpoints", () => {
}) })
it("should allow updating a row", async () => { it("should allow updating a row", async () => {
const res = await makeRequest("put", `/tables/${table._id}/rows/${row._id}`, { const res = await makeRequest(
name: "test row updated", "put",
}) `/tables/${table._id}/rows/${row._id}`,
{
name: "test row updated",
}
)
expect(res).toSatisfyApiSpec() expect(res).toSatisfyApiSpec()
}) })
@ -123,13 +140,16 @@ describe("check the rows endpoints", () => {
}) })
it("should allow deleting a row", async () => { it("should allow deleting a row", async () => {
const res = await makeRequest("delete", `/tables/${table._id}/rows/${row._id}`) const res = await makeRequest(
"delete",
`/tables/${table._id}/rows/${row._id}`
)
expect(res).toSatisfyApiSpec() expect(res).toSatisfyApiSpec()
}) })
}) })
describe("check the users endpoints", () => { describe("check the users endpoints", () => {
let user let user: User
it("should allow retrieving users through search", async () => { it("should allow retrieving users through search", async () => {
user = await config.createUser() user = await config.createUser()
const res = await makeRequest("post", "/users/search") const res = await makeRequest("post", "/users/search")
@ -163,4 +183,3 @@ describe("check the queries endpoints", () => {
expect(res).toSatisfyApiSpec() expect(res).toSatisfyApiSpec()
}) })
}) })

View File

@ -9,7 +9,7 @@ const read = [],
* @openapi * @openapi
* /users: * /users:
* post: * post:
* operationId: create * operationId: userCreate
* summary: Create a user * summary: Create a user
* tags: * tags:
* - users * - users
@ -36,7 +36,7 @@ write.push(new Endpoint("post", "/users", controller.create))
* @openapi * @openapi
* /users/{userId}: * /users/{userId}:
* put: * put:
* operationId: update * operationId: userUpdate
* summary: Update a user * summary: Update a user
* tags: * tags:
* - users * - users
@ -65,7 +65,7 @@ write.push(new Endpoint("put", "/users/:userId", controller.update))
* @openapi * @openapi
* /users/{userId}: * /users/{userId}:
* delete: * delete:
* operationId: destroy * operationId: userDestroy
* summary: Delete a user * summary: Delete a user
* tags: * tags:
* - users * - users
@ -88,7 +88,7 @@ write.push(new Endpoint("delete", "/users/:userId", controller.destroy))
* @openapi * @openapi
* /users/{userId}: * /users/{userId}:
* get: * get:
* operationId: getById * operationId: userGetById
* summary: Retrieve a user * summary: Retrieve a user
* tags: * tags:
* - users * - users
@ -111,7 +111,7 @@ read.push(new Endpoint("get", "/users/:userId", controller.read))
* @openapi * @openapi
* /users/search: * /users/search:
* post: * post:
* operationId: search * operationId: userSearch
* summary: Search for users * summary: Search for users
* description: Based on user properties (currently only name) search for users. * description: Based on user properties (currently only name) search for users.
* tags: * tags:

View File

@ -5,67 +5,73 @@
export interface paths { export interface paths {
"/applications": { "/applications": {
post: operations["create"]; post: operations["appCreate"];
}; };
"/applications/{appId}": { "/applications/{appId}": {
get: operations["getById"]; get: operations["appGetById"];
put: operations["update"]; put: operations["appUpdate"];
delete: operations["destroy"]; delete: operations["appDestroy"];
};
"/applications/{appId}/unpublish": {
post: operations["appUnpublish"];
};
"/applications/{appId}/publish": {
post: operations["appPublish"];
}; };
"/applications/search": { "/applications/search": {
/** Based on application properties (currently only name) search for applications. */ /** Based on application properties (currently only name) search for applications. */
post: operations["search"]; post: operations["appSearch"];
}; };
"/queries/{queryId}": { "/queries/{queryId}": {
/** Queries which have been created within a Budibase app can be executed using this, */ /** Queries which have been created within a Budibase app can be executed using this, */
post: operations["execute"]; post: operations["queryExecute"];
}; };
"/queries/search": { "/queries/search": {
/** Based on query properties (currently only name) search for queries. */ /** Based on query properties (currently only name) search for queries. */
post: operations["search"]; post: operations["querySearch"];
}; };
"/tables/{tableId}/rows": { "/tables/{tableId}/rows": {
/** Creates a row within the specified table. */ /** Creates a row within the specified table. */
post: operations["create"]; post: operations["rowCreate"];
}; };
"/tables/{tableId}/rows/{rowId}": { "/tables/{tableId}/rows/{rowId}": {
/** This gets a single row, it will be enriched with the full related rows, rather than the squashed "primaryDisplay" format returned by the search endpoint. */ /** This gets a single row, it will be enriched with the full related rows, rather than the squashed "primaryDisplay" format returned by the search endpoint. */
get: operations["getById"]; get: operations["rowGetById"];
/** Updates a row within the specified table. */ /** Updates a row within the specified table. */
put: operations["update"]; put: operations["rowUpdate"];
/** Deletes a row within the specified table. */ /** Deletes a row within the specified table. */
delete: operations["destroy"]; delete: operations["rowDestroy"];
}; };
"/tables/{tableId}/rows/search": { "/tables/{tableId}/rows/search": {
post: operations["search"]; post: operations["rowSearch"];
}; };
"/tables": { "/tables": {
/** Create a table, this could be internal or external. */ /** Create a table, this could be internal or external. */
post: operations["create"]; post: operations["tableCreate"];
}; };
"/tables/{tableId}": { "/tables/{tableId}": {
/** Lookup a table, this could be internal or external. */ /** Lookup a table, this could be internal or external. */
get: operations["getById"]; get: operations["tableGetById"];
/** Update a table, this could be internal or external. */ /** Update a table, this could be internal or external. */
put: operations["update"]; put: operations["tableUpdate"];
/** Delete a table, this could be internal or external. */ /** Delete a table, this could be internal or external. */
delete: operations["destroy"]; delete: operations["tableDestroy"];
}; };
"/tables/search": { "/tables/search": {
/** Based on table properties (currently only name) search for tables. This could be an internal or an external table. */ /** Based on table properties (currently only name) search for tables. This could be an internal or an external table. */
post: operations["search"]; post: operations["tableSearch"];
}; };
"/users": { "/users": {
post: operations["create"]; post: operations["userCreate"];
}; };
"/users/{userId}": { "/users/{userId}": {
get: operations["getById"]; get: operations["userGetById"];
put: operations["update"]; put: operations["userUpdate"];
delete: operations["destroy"]; delete: operations["userDestroy"];
}; };
"/users/search": { "/users/search": {
/** Based on user properties (currently only name) search for users. */ /** Based on user properties (currently only name) search for users. */
post: operations["search"]; post: operations["userSearch"];
}; };
} }
@ -102,16 +108,6 @@ export interface components {
lockedBy?: { [key: string]: unknown }; lockedBy?: { [key: string]: unknown };
}; };
}; };
deploymentOutput: {
data: {
/** @description The ID of the deployment. */
_id: string;
/** @description The status of the deployment. */
status: "SUCCESS" | "FAILURE";
/** @description The URL by which the published app is accessed. */
appUrl?: string;
}
};
applicationSearch: { applicationSearch: {
data: { data: {
/** @description The name of the app. */ /** @description The name of the app. */
@ -137,6 +133,19 @@ export interface components {
lockedBy?: { [key: string]: unknown }; lockedBy?: { [key: string]: unknown };
}[]; }[];
}; };
deploymentOutput: {
data: {
/** @description The ID of the app. */
_id: string;
/**
* @description Status of the deployment, whether it succeeded or failed
* @enum {string}
*/
status: "SUCCESS" | "FAILURE";
/** @description The URL of the published app */
appUrl: string;
};
};
/** @description The row to be created/updated, based on the table schema. */ /** @description The row to be created/updated, based on the table schema. */
row: { [key: string]: unknown }; row: { [key: string]: unknown };
searchOutput: { searchOutput: {
@ -231,7 +240,6 @@ export interface components {
*/ */
type?: type?:
| "string" | "string"
| "barcodeqr"
| "longform" | "longform"
| "options" | "options"
| "number" | "number"
@ -243,7 +251,8 @@ export interface components {
| "formula" | "formula"
| "auto" | "auto"
| "json" | "json"
| "internal"; | "internal"
| "barcodeqr";
/** @description A constraint can be applied to the column which will be validated against when a row is saved. */ /** @description A constraint can be applied to the column which will be validated against when a row is saved. */
constraints?: { constraints?: {
/** @enum {string} */ /** @enum {string} */
@ -337,7 +346,6 @@ export interface components {
*/ */
type?: type?:
| "string" | "string"
| "barcodeqr"
| "longform" | "longform"
| "options" | "options"
| "number" | "number"
@ -349,7 +357,8 @@ export interface components {
| "formula" | "formula"
| "auto" | "auto"
| "json" | "json"
| "internal"; | "internal"
| "barcodeqr";
/** @description A constraint can be applied to the column which will be validated against when a row is saved. */ /** @description A constraint can be applied to the column which will be validated against when a row is saved. */
constraints?: { constraints?: {
/** @enum {string} */ /** @enum {string} */
@ -445,7 +454,6 @@ export interface components {
*/ */
type?: type?:
| "string" | "string"
| "barcodeqr"
| "longform" | "longform"
| "options" | "options"
| "number" | "number"
@ -457,7 +465,8 @@ export interface components {
| "formula" | "formula"
| "auto" | "auto"
| "json" | "json"
| "internal"; | "internal"
| "barcodeqr";
/** @description A constraint can be applied to the column which will be validated against when a row is saved. */ /** @description A constraint can be applied to the column which will be validated against when a row is saved. */
constraints?: { constraints?: {
/** @enum {string} */ /** @enum {string} */
@ -717,81 +726,115 @@ export interface components {
} }
export interface operations { export interface operations {
create: { appCreate: {
parameters: {
header: {
/** The ID of the app which this request is targeting. */
"x-budibase-app-id": components["parameters"]["appId"];
};
};
responses: { responses: {
/** Returns the created user. */ /** Returns the created application. */
200: { 200: {
content: { content: {
"application/json": components["schemas"]["userOutput"]; "application/json": components["schemas"]["applicationOutput"];
}; };
}; };
}; };
requestBody: { requestBody: {
content: { content: {
"application/json": components["schemas"]["user"]; "application/json": components["schemas"]["application"];
}; };
}; };
}; };
getById: { appGetById: {
parameters: { parameters: {
path: { path: {
/** The ID of the user which this request is targeting. */ /** The ID of the app which this request is targeting. */
userId: components["parameters"]["userId"]; appId: components["parameters"]["appIdUrl"];
}; };
}; };
responses: { responses: {
/** Returns the retrieved user. */ /** Returns the retrieved application. */
200: { 200: {
content: { content: {
"application/json": components["schemas"]["userOutput"]; "application/json": components["schemas"]["applicationOutput"];
}; };
}; };
}; };
}; };
update: { appUpdate: {
parameters: { parameters: {
path: { path: {
/** The ID of the user which this request is targeting. */ /** The ID of the app which this request is targeting. */
userId: components["parameters"]["userId"]; appId: components["parameters"]["appIdUrl"];
}; };
}; };
responses: { responses: {
/** Returns the updated user. */ /** Returns the updated application. */
200: { 200: {
content: { content: {
"application/json": components["schemas"]["userOutput"]; "application/json": components["schemas"]["applicationOutput"];
}; };
}; };
}; };
requestBody: { requestBody: {
content: { content: {
"application/json": components["schemas"]["user"]; "application/json": components["schemas"]["application"];
}; };
}; };
}; };
destroy: { appDestroy: {
parameters: { parameters: {
path: { path: {
/** The ID of the user which this request is targeting. */ /** The ID of the app which this request is targeting. */
userId: components["parameters"]["userId"]; appId: components["parameters"]["appIdUrl"];
}; };
}; };
responses: { responses: {
/** Returns the deleted user. */ /** Returns the deleted application. */
200: { 200: {
content: { content: {
"application/json": components["schemas"]["userOutput"]; "application/json": components["schemas"]["applicationOutput"];
}; };
}; };
}; };
}; };
/** Based on user properties (currently only name) search for users. */ appUnpublish: {
search: { parameters: {
path: {
/** The ID of the app which this request is targeting. */
appId: components["parameters"]["appIdUrl"];
};
};
responses: { responses: {
/** Returns the found users based on search parameters. */ /** The app was published successfully. */
204: never;
};
};
appPublish: {
parameters: {
path: {
/** The ID of the app which this request is targeting. */
appId: components["parameters"]["appIdUrl"];
};
};
responses: {
/** Returns the deployment object. */
200: { 200: {
content: { content: {
"application/json": components["schemas"]["userSearch"]; "application/json": components["schemas"]["deploymentOutput"];
};
};
};
};
/** Based on application properties (currently only name) search for applications. */
appSearch: {
responses: {
/** Returns the applications that were found based on the search parameters. */
200: {
content: {
"application/json": components["schemas"]["applicationSearch"];
}; };
}; };
}; };
@ -802,7 +845,7 @@ export interface operations {
}; };
}; };
/** Queries which have been created within a Budibase app can be executed using this, */ /** Queries which have been created within a Budibase app can be executed using this, */
execute: { queryExecute: {
parameters: { parameters: {
path: { path: {
/** The ID of the query which this request is targeting. */ /** The ID of the query which this request is targeting. */
@ -827,6 +870,349 @@ export interface operations {
}; };
}; };
}; };
/** Based on query properties (currently only name) search for queries. */
querySearch: {
parameters: {
header: {
/** The ID of the app which this request is targeting. */
"x-budibase-app-id": components["parameters"]["appId"];
};
};
responses: {
/** Returns the queries found based on the search parameters. */
200: {
content: {
"application/json": components["schemas"]["querySearch"];
};
};
};
requestBody: {
content: {
"application/json": components["schemas"]["nameSearch"];
};
};
};
/** Creates a row within the specified table. */
rowCreate: {
parameters: {
path: {
/** The ID of the table which this request is targeting. */
tableId: components["parameters"]["tableId"];
};
header: {
/** The ID of the app which this request is targeting. */
"x-budibase-app-id": components["parameters"]["appId"];
};
};
responses: {
/** Returns the created row, including the ID which has been generated for it. This can be found in the Budibase portal, viewed under the developer information. */
200: {
content: {
"application/json": components["schemas"]["rowOutput"];
};
};
};
requestBody: {
content: {
"application/json": components["schemas"]["row"];
};
};
};
/** This gets a single row, it will be enriched with the full related rows, rather than the squashed "primaryDisplay" format returned by the search endpoint. */
rowGetById: {
parameters: {
path: {
/** The ID of the table which this request is targeting. */
tableId: components["parameters"]["tableId"];
/** The ID of the row which this request is targeting. */
rowId: components["parameters"]["rowId"];
};
header: {
/** The ID of the app which this request is targeting. */
"x-budibase-app-id": components["parameters"]["appId"];
};
};
responses: {
/** Returns the retrieved row. */
200: {
content: {
"application/json": components["schemas"]["rowOutput"];
};
};
};
};
/** Updates a row within the specified table. */
rowUpdate: {
parameters: {
path: {
/** The ID of the table which this request is targeting. */
tableId: components["parameters"]["tableId"];
/** The ID of the row which this request is targeting. */
rowId: components["parameters"]["rowId"];
};
header: {
/** The ID of the app which this request is targeting. */
"x-budibase-app-id": components["parameters"]["appId"];
};
};
responses: {
/** Returns the created row, including the ID which has been generated for it. */
200: {
content: {
"application/json": components["schemas"]["rowOutput"];
};
};
};
requestBody: {
content: {
"application/json": components["schemas"]["row"];
};
};
};
/** Deletes a row within the specified table. */
rowDestroy: {
parameters: {
path: {
/** The ID of the table which this request is targeting. */
tableId: components["parameters"]["tableId"];
/** The ID of the row which this request is targeting. */
rowId: components["parameters"]["rowId"];
};
header: {
/** The ID of the app which this request is targeting. */
"x-budibase-app-id": components["parameters"]["appId"];
};
};
responses: {
/** Returns the deleted row, including the ID which has been generated for it. */
200: {
content: {
"application/json": components["schemas"]["rowOutput"];
};
};
};
};
rowSearch: {
parameters: {
path: {
/** The ID of the table which this request is targeting. */
tableId: components["parameters"]["tableId"];
};
header: {
/** The ID of the app which this request is targeting. */
"x-budibase-app-id": components["parameters"]["appId"];
};
};
responses: {
/** The response will contain an array of rows that match the search parameters. */
200: {
content: {
"application/json": components["schemas"]["searchOutput"];
};
};
};
requestBody: {
content: {
"application/json": components["schemas"]["rowSearch"];
};
};
};
/** Create a table, this could be internal or external. */
tableCreate: {
parameters: {
header: {
/** The ID of the app which this request is targeting. */
"x-budibase-app-id": components["parameters"]["appId"];
};
};
responses: {
/** Returns the created table, including the ID which has been generated for it. This can be internal or external datasources. */
200: {
content: {
"application/json": components["schemas"]["tableOutput"];
};
};
};
requestBody: {
content: {
"application/json": components["schemas"]["table"];
};
};
};
/** Lookup a table, this could be internal or external. */
tableGetById: {
parameters: {
path: {
/** The ID of the table which this request is targeting. */
tableId: components["parameters"]["tableId"];
};
header: {
/** The ID of the app which this request is targeting. */
"x-budibase-app-id": components["parameters"]["appId"];
};
};
responses: {
/** Returns the retrieved table. */
200: {
content: {
"application/json": components["schemas"]["tableOutput"];
};
};
};
};
/** Update a table, this could be internal or external. */
tableUpdate: {
parameters: {
path: {
/** The ID of the table which this request is targeting. */
tableId: components["parameters"]["tableId"];
};
header: {
/** The ID of the app which this request is targeting. */
"x-budibase-app-id": components["parameters"]["appId"];
};
};
responses: {
/** Returns the updated table. */
200: {
content: {
"application/json": components["schemas"]["tableOutput"];
};
};
};
requestBody: {
content: {
"application/json": components["schemas"]["table"];
};
};
};
/** Delete a table, this could be internal or external. */
tableDestroy: {
parameters: {
path: {
/** The ID of the table which this request is targeting. */
tableId: components["parameters"]["tableId"];
};
header: {
/** The ID of the app which this request is targeting. */
"x-budibase-app-id": components["parameters"]["appId"];
};
};
responses: {
/** Returns the deleted table. */
200: {
content: {
"application/json": components["schemas"]["tableOutput"];
};
};
};
};
/** Based on table properties (currently only name) search for tables. This could be an internal or an external table. */
tableSearch: {
parameters: {
header: {
/** The ID of the app which this request is targeting. */
"x-budibase-app-id": components["parameters"]["appId"];
};
};
responses: {
/** Returns the found tables, based on the search parameters. */
200: {
content: {
"application/json": components["schemas"]["tableSearch"];
};
};
};
requestBody: {
content: {
"application/json": components["schemas"]["nameSearch"];
};
};
};
userCreate: {
responses: {
/** Returns the created user. */
200: {
content: {
"application/json": components["schemas"]["userOutput"];
};
};
};
requestBody: {
content: {
"application/json": components["schemas"]["user"];
};
};
};
userGetById: {
parameters: {
path: {
/** The ID of the user which this request is targeting. */
userId: components["parameters"]["userId"];
};
};
responses: {
/** Returns the retrieved user. */
200: {
content: {
"application/json": components["schemas"]["userOutput"];
};
};
};
};
userUpdate: {
parameters: {
path: {
/** The ID of the user which this request is targeting. */
userId: components["parameters"]["userId"];
};
};
responses: {
/** Returns the updated user. */
200: {
content: {
"application/json": components["schemas"]["userOutput"];
};
};
};
requestBody: {
content: {
"application/json": components["schemas"]["user"];
};
};
};
userDestroy: {
parameters: {
path: {
/** The ID of the user which this request is targeting. */
userId: components["parameters"]["userId"];
};
};
responses: {
/** Returns the deleted user. */
200: {
content: {
"application/json": components["schemas"]["userOutput"];
};
};
};
};
/** Based on user properties (currently only name) search for users. */
userSearch: {
responses: {
/** Returns the found users based on search parameters. */
200: {
content: {
"application/json": components["schemas"]["userSearch"];
};
};
};
requestBody: {
content: {
"application/json": components["schemas"]["nameSearch"];
};
};
};
} }
export interface external {} export interface external {}