2020-11-09 16:24:29 +01:00
|
|
|
require("svelte/register")
|
|
|
|
|
2020-05-07 11:53:34 +02:00
|
|
|
const send = require("koa-send")
|
2020-11-12 11:25:25 +01:00
|
|
|
const { resolve, join } = require("../../../utilities/centralPath")
|
2020-09-16 13:18:47 +02:00
|
|
|
const uuid = require("uuid")
|
2021-05-07 15:27:46 +02:00
|
|
|
const { ObjectStoreBuckets } = require("../../../constants")
|
2021-01-20 14:32:15 +01:00
|
|
|
const { processString } = require("@budibase/string-templates")
|
2021-05-11 18:49:26 +02:00
|
|
|
const { getDeployedApps } = require("../../../utilities/workerRequests")
|
2020-11-12 11:25:25 +01:00
|
|
|
const CouchDB = require("../../../db")
|
2021-04-01 17:19:31 +02:00
|
|
|
const {
|
|
|
|
loadHandlebarsFile,
|
|
|
|
NODE_MODULES_PATH,
|
2021-04-01 17:36:27 +02:00
|
|
|
TOP_LEVEL_PATH,
|
2021-04-01 17:19:31 +02:00
|
|
|
} = require("../../../utilities/fileSystem")
|
2020-11-12 11:25:25 +01:00
|
|
|
const env = require("../../../environment")
|
2021-09-01 12:41:48 +02:00
|
|
|
const { clientLibraryPath } = require("../../../utilities")
|
2021-05-11 18:53:54 +02:00
|
|
|
const { upload } = require("../../../utilities/fileSystem")
|
|
|
|
const { attachmentsRelativeURL } = require("../../../utilities")
|
2021-05-16 22:25:37 +02:00
|
|
|
const { DocumentTypes } = require("../../../db/utils")
|
2021-05-11 18:53:54 +02:00
|
|
|
|
|
|
|
async function prepareUpload({ s3Key, bucket, metadata, file }) {
|
|
|
|
const response = await upload({
|
|
|
|
bucket,
|
|
|
|
metadata,
|
|
|
|
filename: s3Key,
|
|
|
|
path: file.path,
|
|
|
|
type: file.type,
|
|
|
|
})
|
|
|
|
|
|
|
|
// don't store a URL, work this out on the way out as the URL could change
|
|
|
|
return {
|
|
|
|
size: file.size,
|
|
|
|
name: file.name,
|
|
|
|
url: attachmentsRelativeURL(response.Key),
|
|
|
|
extension: [...file.name.split(".")].pop(),
|
|
|
|
key: response.Key,
|
|
|
|
}
|
|
|
|
}
|
2020-09-17 17:36:39 +02:00
|
|
|
|
2021-01-14 18:01:31 +01:00
|
|
|
async function checkForSelfHostedURL(ctx) {
|
|
|
|
// the "appId" component of the URL may actually be a specific self hosted URL
|
2021-01-14 18:31:17 +01:00
|
|
|
let possibleAppUrl = `/${encodeURI(ctx.params.appId).toLowerCase()}`
|
2021-04-09 16:11:49 +02:00
|
|
|
const apps = await getDeployedApps(ctx)
|
2021-01-14 18:01:31 +01:00
|
|
|
if (apps[possibleAppUrl] && apps[possibleAppUrl].appId) {
|
|
|
|
return apps[possibleAppUrl].appId
|
|
|
|
} else {
|
|
|
|
return ctx.params.appId
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2021-05-03 09:31:09 +02:00
|
|
|
exports.serveBuilder = async function (ctx) {
|
2021-04-01 17:36:27 +02:00
|
|
|
let builderPath = resolve(TOP_LEVEL_PATH, "builder")
|
2021-03-31 20:55:55 +02:00
|
|
|
await send(ctx, ctx.file, { root: builderPath })
|
2020-04-14 16:14:57 +02:00
|
|
|
}
|
|
|
|
|
2021-05-03 09:31:09 +02:00
|
|
|
exports.uploadFile = async function (ctx) {
|
2021-03-22 18:19:45 +01:00
|
|
|
let files =
|
2020-09-23 17:15:09 +02:00
|
|
|
ctx.request.files.file.length > 1
|
|
|
|
? Array.from(ctx.request.files.file)
|
|
|
|
: [ctx.request.files.file]
|
|
|
|
|
2021-05-04 12:32:22 +02:00
|
|
|
const uploads = files.map(async file => {
|
2020-09-23 18:02:06 +02:00
|
|
|
const fileExtension = [...file.name.split(".")].pop()
|
2021-03-22 18:19:45 +01:00
|
|
|
// filenames converted to UUIDs so they are unique
|
2020-09-23 17:15:09 +02:00
|
|
|
const processedFileName = `${uuid.v4()}.${fileExtension}`
|
2020-09-15 17:22:13 +02:00
|
|
|
|
2021-03-19 20:07:47 +01:00
|
|
|
return prepareUpload({
|
|
|
|
file,
|
2021-06-10 12:34:37 +02:00
|
|
|
s3Key: `${ctx.appId}/attachments/${processedFileName}`,
|
2021-05-07 14:55:30 +02:00
|
|
|
bucket: ObjectStoreBuckets.APPS,
|
2020-09-23 18:29:32 +02:00
|
|
|
})
|
2021-03-19 20:07:47 +01:00
|
|
|
})
|
2020-09-23 18:29:32 +02:00
|
|
|
|
2021-03-19 20:07:47 +01:00
|
|
|
ctx.body = await Promise.all(uploads)
|
2020-09-23 18:02:06 +02:00
|
|
|
}
|
|
|
|
|
2021-05-03 09:31:09 +02:00
|
|
|
exports.serveApp = async function (ctx) {
|
2021-01-14 18:01:31 +01:00
|
|
|
let appId = ctx.params.appId
|
|
|
|
if (env.SELF_HOSTED) {
|
|
|
|
appId = await checkForSelfHostedURL(ctx)
|
|
|
|
}
|
2020-11-09 16:24:29 +01:00
|
|
|
const App = require("./templates/BudibaseApp.svelte").default
|
2021-01-14 18:01:31 +01:00
|
|
|
const db = new CouchDB(appId, { skip_setup: true })
|
2021-05-16 22:25:37 +02:00
|
|
|
const appInfo = await db.get(DocumentTypes.APP_METADATA)
|
2020-11-09 16:24:29 +01:00
|
|
|
|
2020-11-12 11:25:25 +01:00
|
|
|
const { head, html, css } = App.render({
|
|
|
|
title: appInfo.name,
|
2021-03-24 19:21:23 +01:00
|
|
|
production: env.isProd(),
|
2021-01-14 18:01:31 +01:00
|
|
|
appId,
|
2021-04-01 13:48:38 +02:00
|
|
|
clientLibPath: clientLibraryPath(appId),
|
2020-11-12 11:25:25 +01:00
|
|
|
})
|
2020-11-09 16:24:29 +01:00
|
|
|
|
2021-03-19 20:07:47 +01:00
|
|
|
const appHbs = loadHandlebarsFile(`${__dirname}/templates/app.hbs`)
|
2021-01-20 14:32:15 +01:00
|
|
|
ctx.body = await processString(appHbs, {
|
2020-11-12 11:25:25 +01:00
|
|
|
head,
|
|
|
|
body: html,
|
|
|
|
style: css.code,
|
2021-01-14 18:01:31 +01:00
|
|
|
appId,
|
2020-11-12 11:25:25 +01:00
|
|
|
})
|
2020-11-09 16:24:29 +01:00
|
|
|
}
|
|
|
|
|
2021-05-03 09:31:09 +02:00
|
|
|
exports.serveClientLibrary = async function (ctx) {
|
2021-04-01 13:48:38 +02:00
|
|
|
return send(ctx, "budibase-client.js", {
|
2021-04-01 17:36:27 +02:00
|
|
|
root: join(NODE_MODULES_PATH, "@budibase", "client", "dist"),
|
2021-04-01 13:48:38 +02:00
|
|
|
})
|
|
|
|
}
|