Merge pull request #13447 from Budibase/fix/update-openapi-definitions

Improving public API documentation for row search
This commit is contained in:
Michael Drury 2024-04-10 17:10:02 +01:00 committed by GitHub
commit f7f7ee1a70
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
4 changed files with 110 additions and 4 deletions

View File

@ -853,6 +853,7 @@
"array", "array",
"datetime", "datetime",
"attachment", "attachment",
"attachment_single",
"link", "link",
"formula", "formula",
"auto", "auto",
@ -1059,6 +1060,7 @@
"array", "array",
"datetime", "datetime",
"attachment", "attachment",
"attachment_single",
"link", "link",
"formula", "formula",
"auto", "auto",
@ -1276,6 +1278,7 @@
"array", "array",
"datetime", "datetime",
"attachment", "attachment",
"attachment_single",
"link", "link",
"formula", "formula",
"auto", "auto",
@ -1752,7 +1755,7 @@
}, },
"fuzzy": { "fuzzy": {
"type": "object", "type": "object",
"description": "A fuzzy search, only supported by internal tables." "description": "Searches for a sub-string within a string column, e.g. searching for 'dib' will match 'Budibase'."
}, },
"range": { "range": {
"type": "object", "type": "object",
@ -1786,6 +1789,36 @@
"oneOf": { "oneOf": {
"type": "object", "type": "object",
"description": "Searches for rows which have a column value that is any of the specified values. The format of this must be columnName -> [value1, value2]." "description": "Searches for rows which have a column value that is any of the specified values. The format of this must be columnName -> [value1, value2]."
},
"contains": {
"type": "object",
"description": "Searches for a value, or set of values in array column types (such as a multi-select). If an array of search options is provided then it must match all.",
"example": {
"arrayColumn": [
"a",
"b"
]
}
},
"notContains": {
"type": "object",
"description": "The logical inverse of contains. Only works on array column types. If an array of values is passed, the row must not match any of them to be returned in the response.",
"example": {
"arrayColumn": [
"a",
"b"
]
}
},
"containsAny": {
"type": "object",
"description": "As with the contains search, only works on array column types and searches for any of the provided values when given an array.",
"example": {
"arrayColumn": [
"a",
"b"
]
}
} }
} }
}, },

View File

@ -775,6 +775,7 @@ components:
- array - array
- datetime - datetime
- attachment - attachment
- attachment_single
- link - link
- formula - formula
- auto - auto
@ -940,6 +941,7 @@ components:
- array - array
- datetime - datetime
- attachment - attachment
- attachment_single
- link - link
- formula - formula
- auto - auto
@ -1112,6 +1114,7 @@ components:
- array - array
- datetime - datetime
- attachment - attachment
- attachment_single
- link - link
- formula - formula
- auto - auto
@ -1492,7 +1495,8 @@ components:
description: The value to search for in the column. description: The value to search for in the column.
fuzzy: fuzzy:
type: object type: object
description: A fuzzy search, only supported by internal tables. description: Searches for a sub-string within a string column, e.g. searching
for 'dib' will match 'Budibase'.
range: range:
type: object type: object
description: Searches within a range, the format of this must be in the format description: Searches within a range, the format of this must be in the format
@ -1524,6 +1528,32 @@ components:
description: Searches for rows which have a column value that is any of the description: Searches for rows which have a column value that is any of the
specified values. The format of this must be columnName -> specified values. The format of this must be columnName ->
[value1, value2]. [value1, value2].
contains:
type: object
description: Searches for a value, or set of values in array column types (such
as a multi-select). If an array of search options is provided
then it must match all.
example:
arrayColumn:
- a
- b
notContains:
type: object
description: The logical inverse of contains. Only works on array column types.
If an array of values is passed, the row must not match any of
them to be returned in the response.
example:
arrayColumn:
- a
- b
containsAny:
type: object
description: As with the contains search, only works on array column types and
searches for any of the provided values when given an array.
example:
arrayColumn:
- a
- b
paginate: paginate:
type: boolean type: boolean
description: Enables pagination, by default this is disabled. description: Enables pagination, by default this is disabled.

View File

@ -27,7 +27,8 @@ export default new Resource().setSchemas({
}, },
fuzzy: { fuzzy: {
type: "object", type: "object",
description: "A fuzzy search, only supported by internal tables.", description:
"Searches for a sub-string within a string column, e.g. searching for 'dib' will match 'Budibase'.",
}, },
range: { range: {
type: "object", type: "object",
@ -67,6 +68,30 @@ export default new Resource().setSchemas({
description: description:
"Searches for rows which have a column value that is any of the specified values. The format of this must be columnName -> [value1, value2].", "Searches for rows which have a column value that is any of the specified values. The format of this must be columnName -> [value1, value2].",
}, },
contains: {
type: "object",
description:
"Searches for a value, or set of values in array column types (such as a multi-select). If an array of search options is provided then it must match all.",
example: {
arrayColumn: ["a", "b"],
},
},
notContains: {
type: "object",
description:
"The logical inverse of contains. Only works on array column types. If an array of values is passed, the row must not match any of them to be returned in the response.",
example: {
arrayColumn: ["a", "b"],
},
},
containsAny: {
type: "object",
description:
"As with the contains search, only works on array column types and searches for any of the provided values when given an array.",
example: {
arrayColumn: ["a", "b"],
},
},
}, },
}, },
paginate: { paginate: {

View File

@ -273,6 +273,7 @@ export interface components {
| "array" | "array"
| "datetime" | "datetime"
| "attachment" | "attachment"
| "attachment_single"
| "link" | "link"
| "formula" | "formula"
| "auto" | "auto"
@ -381,6 +382,7 @@ export interface components {
| "array" | "array"
| "datetime" | "datetime"
| "attachment" | "attachment"
| "attachment_single"
| "link" | "link"
| "formula" | "formula"
| "auto" | "auto"
@ -491,6 +493,7 @@ export interface components {
| "array" | "array"
| "datetime" | "datetime"
| "attachment" | "attachment"
| "attachment_single"
| "link" | "link"
| "formula" | "formula"
| "auto" | "auto"
@ -693,7 +696,7 @@ export interface components {
* @example [object Object] * @example [object Object]
*/ */
string?: { [key: string]: string }; string?: { [key: string]: string };
/** @description A fuzzy search, only supported by internal tables. */ /** @description Searches for a sub-string within a string column, e.g. searching for 'dib' will match 'Budibase'. */
fuzzy?: { [key: string]: unknown }; fuzzy?: { [key: string]: unknown };
/** /**
* @description Searches within a range, the format of this must be in the format of an object with a "low" and "high" property. * @description Searches within a range, the format of this must be in the format of an object with a "low" and "high" property.
@ -713,6 +716,21 @@ export interface components {
notEmpty?: { [key: string]: unknown }; notEmpty?: { [key: string]: unknown };
/** @description Searches for rows which have a column value that is any of the specified values. The format of this must be columnName -> [value1, value2]. */ /** @description Searches for rows which have a column value that is any of the specified values. The format of this must be columnName -> [value1, value2]. */
oneOf?: { [key: string]: unknown }; oneOf?: { [key: string]: unknown };
/**
* @description Searches for a value, or set of values in array column types (such as a multi-select). If an array of search options is provided then it must match all.
* @example [object Object]
*/
contains?: { [key: string]: unknown };
/**
* @description The logical inverse of contains. Only works on array column types. If an array of values is passed, the row must not match any of them to be returned in the response.
* @example [object Object]
*/
notContains?: { [key: string]: unknown };
/**
* @description As with the contains search, only works on array column types and searches for any of the provided values when given an array.
* @example [object Object]
*/
containsAny?: { [key: string]: unknown };
}; };
/** @description Enables pagination, by default this is disabled. */ /** @description Enables pagination, by default this is disabled. */
paginate?: boolean; paginate?: boolean;