Budibase is an open-source low-code platform for creating internal apps in minutes. Supports PostgreSQL, MySQL, MSSQL, MongoDB, Rest API, Docker, K8s 🚀
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 

80 lines
1.7 KiB

const couchdb = require("../../db")
const {
events,
schemaValidator
} = require("../../../common");
exports.save = async function(ctx) {
const db = new CouchDB(ctx.params.instanceId);
const record = ctx.request.body;
// validation with ajv
const model = await db.get(ctx.params.modelId);
const validate = schemaValidator.compile({
properties: model.schema
});
const valid = validate(record);
if (!valid) {
ctx.status = 400;
ctx.body = {
status: 400,
errors: validate.errors
};
return;
}
const existingRecord = record._id && await db.get(record._id);
if (existingRecord) {
const response = await db.put({ ...record, _id: existingRecord._id });
ctx.body = {
message: "Record updated successfully.",
status: 200,
record: response
}
return;
}
const response = await db.post({
modelId: ctx.params.modelId,
type: "record",
...record
})
// await ctx.publish(events.recordApi.save.onRecordCreated, {
// record: record,
// })
ctx.body = {
message: "Record created successfully.",
status: 200,
record: response
};
}
exports.fetch = async function(ctx) {
const db = new CouchDB(ctx.params.instanceId)
const response = await db.query(
`database/${ctx.params.viewName}`,
{
include_docs: true
}
)
ctx.body = response.rows.map(row => row.doc);
}
exports.find = async function(ctx) {
const db = couchdb.db.use(ctx.params.databaseId)
const record = await db.get(ctx.params.recordId);
ctx.body = record;
ctx.status = 200;
}
exports.destroy = async function(ctx) {
const databaseId = ctx.params.instanceId;
const db = new CouchDB(databaseId)
ctx.body = await db.destroy(ctx.params.recordId, ctx.params.revId);
};