budibase/packages/server/src/definitions/datasource.ts

162 lines
2.5 KiB
TypeScript
Raw Normal View History

2021-09-27 15:57:22 +02:00
import { Table } from "./common"
export enum Operation {
CREATE = "CREATE",
READ = "READ",
UPDATE = "UPDATE",
DELETE = "DELETE",
}
export enum SortDirection {
ASCENDING = "ASCENDING",
DESCENDING = "DESCENDING",
}
export enum QueryTypes {
SQL = "sql",
JSON = "json",
FIELDS = "fields",
}
export enum DatasourceFieldTypes {
STRING = "string",
BOOLEAN = "boolean",
NUMBER = "number",
PASSWORD = "password",
LIST = "list",
OBJECT = "object",
JSON = "json",
}
export enum SourceNames {
POSTGRES = "POSTGRES",
DYNAMODB = "DYNAMODB",
MONGODB = "MONGODB",
ELASTICSEARCH = "ELASTICSEARCH",
COUCHDB = "COUCHDB",
SQL_SERVER = "SQL_SERVER",
S3 = "S3",
AIRTABLE = "AIRTABLE",
MYSQL = "MYSQL",
ARANGODB = "ARANGODB",
REST = "REST",
}
export enum IncludeRelationships {
INCLUDE = 1,
2021-09-06 17:24:51 +02:00
EXCLUDE = 0,
}
export interface QueryDefinition {
2021-06-25 19:34:21 +02:00
type: QueryTypes
displayName?: string
readable?: boolean
customisable?: boolean
fields?: object
urlDisplay?: boolean
}
export interface ExtraQueryConfig {
[key: string]: {
2021-07-29 11:11:52 +02:00
displayName: string
type: string
required: boolean
data?: object
}
}
export interface Integration {
2021-06-25 19:34:21 +02:00
docs: string
plus?: boolean
description: string
friendlyName: string
datasource: {}
query: {
2021-06-25 19:34:21 +02:00
[key: string]: QueryDefinition
}
extra?: ExtraQueryConfig
}
export interface SearchFilters {
allOr?: boolean
string?: {
2021-06-25 19:34:21 +02:00
[key: string]: string
}
fuzzy?: {
2021-06-25 19:34:21 +02:00
[key: string]: string
}
range?: {
[key: string]: {
2021-06-25 19:34:21 +02:00
high: number | string
low: number | string
}
}
equal?: {
2021-06-25 19:34:21 +02:00
[key: string]: any
}
notEqual?: {
2021-06-25 19:34:21 +02:00
[key: string]: any
}
empty?: {
2021-06-25 19:34:21 +02:00
[key: string]: any
}
notEmpty?: {
2021-06-25 19:34:21 +02:00
[key: string]: any
}
2021-07-01 15:10:44 +02:00
oneOf?: {
[key: string]: any[]
}
}
export interface SortJson {
[key: string]: SortDirection
}
export interface PaginationJson {
limit: number
page: string | number
}
export interface RelationshipsJson {
through?: string
from?: string
to?: string
2021-06-25 19:34:21 +02:00
tableName: string
column: string
}
export interface QueryJson {
endpoint: {
2021-06-25 19:34:21 +02:00
datasourceId: string
entityId: string
operation: Operation
}
resource: {
2021-06-25 19:34:21 +02:00
fields: string[]
}
filters?: SearchFilters
sort?: SortJson
paginate?: PaginationJson
2021-06-25 19:34:21 +02:00
body?: object
meta?: {
2021-09-27 15:57:22 +02:00
table?: Table
}
extra?: {
2021-06-25 19:34:21 +02:00
idFilter?: SearchFilters
}
relationships?: RelationshipsJson[]
}
export interface SqlQuery {
2021-06-25 19:34:21 +02:00
sql: string
2021-07-13 18:11:11 +02:00
bindings?:
| string[]
| {
[key: string]: any
}
}
export interface QueryOptions {
2021-06-25 19:34:21 +02:00
disableReturning?: boolean
2021-06-24 19:17:26 +02:00
}