120 lines
2.6 KiB
JavaScript
120 lines
2.6 KiB
JavaScript
const rowController = require("../../api/controllers/row")
|
|
const tableController = require("../../api/controllers/table")
|
|
const { FieldTypes } = require("../../constants")
|
|
|
|
const SortOrders = {
|
|
ASCENDING: "ascending",
|
|
DESCENDING: "descending",
|
|
}
|
|
|
|
const SortOrdersPretty = {
|
|
[SortOrders.ASCENDING]: "Ascending",
|
|
[SortOrders.DESCENDING]: "Descending",
|
|
}
|
|
|
|
exports.definition = {
|
|
description: "Query rows from the database",
|
|
icon: "Search",
|
|
name: "Query rows",
|
|
tagline: "Query rows from {{inputs.enriched.table.name}} table",
|
|
type: "ACTION",
|
|
stepId: "QUERY_ROWS",
|
|
internal: true,
|
|
inputs: {},
|
|
schema: {
|
|
inputs: {
|
|
properties: {
|
|
tableId: {
|
|
type: "string",
|
|
customType: "table",
|
|
title: "Table",
|
|
},
|
|
filters: {
|
|
type: "object",
|
|
customType: "filters",
|
|
title: "Filtering",
|
|
},
|
|
sortColumn: {
|
|
type: "string",
|
|
title: "Sort Column",
|
|
customType: "column",
|
|
},
|
|
sortOrder: {
|
|
type: "string",
|
|
title: "Sort Order",
|
|
enum: Object.values(SortOrders),
|
|
pretty: Object.values(SortOrdersPretty),
|
|
},
|
|
limit: {
|
|
type: "number",
|
|
title: "Limit",
|
|
},
|
|
},
|
|
required: ["tableId"],
|
|
},
|
|
outputs: {
|
|
properties: {
|
|
rows: {
|
|
type: "array",
|
|
customType: "rows",
|
|
description: "The rows that were found",
|
|
},
|
|
success: {
|
|
type: "boolean",
|
|
description: "Whether the deletion was successful",
|
|
},
|
|
},
|
|
required: ["rows", "success"],
|
|
},
|
|
},
|
|
}
|
|
|
|
async function getTable(appId, tableId) {
|
|
const ctx = {
|
|
params: {
|
|
id: tableId,
|
|
},
|
|
appId,
|
|
}
|
|
await tableController.find(ctx)
|
|
return ctx.body
|
|
}
|
|
|
|
exports.run = async function ({ inputs, appId }) {
|
|
const { tableId, filters, sortColumn, sortOrder, limit } = inputs
|
|
const table = await getTable(appId, tableId)
|
|
let sortType = FieldTypes.STRING
|
|
if (table && table.schema && sortColumn) {
|
|
const fieldType = table.schema[sortColumn].type
|
|
sortType =
|
|
fieldType === FieldTypes.NUMBER ? FieldTypes.NUMBER : FieldTypes.STRING
|
|
}
|
|
const ctx = {
|
|
params: {
|
|
tableId,
|
|
},
|
|
request: {
|
|
body: {
|
|
sortOrder,
|
|
sortType,
|
|
sort: sortColumn,
|
|
query: filters || {},
|
|
limit,
|
|
},
|
|
},
|
|
appId,
|
|
}
|
|
try {
|
|
await rowController.search(ctx)
|
|
return {
|
|
rows: ctx.body ? ctx.body.rows : [],
|
|
success: ctx.status === 200,
|
|
}
|
|
} catch (err) {
|
|
return {
|
|
success: false,
|
|
response: err,
|
|
}
|
|
}
|
|
}
|