1
0
Fork 0
mirror of synced 2024-09-30 00:57:16 +13:00
budibase/packages/server/src/api/controllers/instance.js

74 lines
2.5 KiB
JavaScript
Raw Normal View History

2020-09-26 01:47:42 +12:00
const fs = require("fs")
2020-05-07 21:53:34 +12:00
const CouchDB = require("../../db")
const client = require("../../db/clientDb")
2020-05-19 03:22:09 +12:00
const newid = require("../../db/newid")
const { createLinkView } = require("../../db/linkedRecords")
const { join } = require("../../utilities/sanitisedPath")
2020-09-29 05:04:08 +13:00
const { downloadTemplate } = require("../../utilities/templates")
2020-05-15 02:12:30 +12:00
exports.create = async function(ctx) {
2020-05-07 21:53:34 +12:00
const instanceName = ctx.request.body.name
2020-09-26 01:47:42 +12:00
const template = ctx.request.body.template
2020-06-19 03:59:31 +12:00
const { appId } = ctx.user
const appShortId = appId.substring(0, 7)
2020-05-19 03:33:41 +12:00
const instanceId = `inst_${appShortId}_${newid()}`
const masterDb = new CouchDB("client_app_lookup")
2020-06-19 03:59:31 +12:00
const { clientId } = await masterDb.get(appId)
const db = new CouchDB(instanceId)
await db.put({
_id: "_design/database",
metadata: {
clientId,
2020-06-19 03:59:31 +12:00
applicationId: appId,
},
// view collation information, read before writing any complex views:
// https://docs.couchdb.org/en/master/ddocs/views/collation.html#collation-specification
2020-10-03 01:04:44 +13:00
views: {},
2020-05-07 21:53:34 +12:00
})
// add view for linked records
await createLinkView(instanceId)
// Add the new instance under the app clientDB
const clientDb = new CouchDB(client.name(clientId))
2020-06-19 03:59:31 +12:00
const budibaseApp = await clientDb.get(appId)
2020-05-15 02:12:30 +12:00
const instance = { _id: instanceId, name: instanceName }
2020-05-07 21:53:34 +12:00
budibaseApp.instances.push(instance)
await clientDb.put(budibaseApp)
2020-09-26 01:47:42 +12:00
// replicate the template data to the instance DB
if (template) {
2020-09-29 05:04:08 +13:00
const templatePath = await downloadTemplate(...template.key.split("/"))
const dbDumpReadStream = fs.createReadStream(
join(templatePath, "db", "dump.txt")
)
2020-09-26 01:47:42 +12:00
const { ok } = await db.load(dbDumpReadStream)
if (!ok) {
ctx.throw(500, "Error loading database dump from template.")
}
}
2020-05-15 02:12:30 +12:00
ctx.status = 200
ctx.message = `Instance Database ${instanceName} successfully provisioned.`
ctx.body = instance
2020-05-07 21:53:34 +12:00
}
exports.destroy = async function(ctx) {
2020-05-07 21:53:34 +12:00
const db = new CouchDB(ctx.params.instanceId)
const designDoc = await db.get("_design/database")
await db.destroy()
// remove instance from client application document
2020-05-07 21:53:34 +12:00
const { metadata } = designDoc
const clientDb = new CouchDB(client.name(metadata.clientId))
2020-05-07 21:53:34 +12:00
const budibaseApp = await clientDb.get(metadata.applicationId)
budibaseApp.instances = budibaseApp.instances.filter(
instance => instance !== ctx.params.instanceId
)
2020-05-08 00:52:24 +12:00
await clientDb.put(budibaseApp)
2020-05-15 02:12:30 +12:00
ctx.status = 200
ctx.message = `Instance Database ${ctx.params.instanceId} successfully destroyed.`
2020-05-07 21:53:34 +12:00
}