const env = require("../environment") const { DocumentTypes, SEPARATOR } = require("../db/utils") const APP_PREFIX = DocumentTypes.APP + SEPARATOR exports.wait = ms => new Promise(resolve => setTimeout(resolve, ms)) exports.isDev = () => { return ( !env.CLOUD && env.NODE_ENV !== "production" && env.NODE_ENV !== "jest" && env.NODE_ENV !== "cypress" ) } /** * Given a request tries to find the appId, which can be located in various places * @param {object} ctx The main request body to look through. * @returns {string|undefined} If an appId was found it will be returned. */ exports.getAppId = ctx => { let appId = ctx.headers["x-budibase-app-id"] if (!appId) { appId = env.CLOUD ? ctx.subdomains[1] : ctx.params.appId } // look in body if can't find it in subdomain if (!appId && ctx.request.body && ctx.request.body.appId) { appId = ctx.request.body.appId } let appPath = ctx.request.headers.referrer || ctx.path.split("/").filter(subPath => subPath.startsWith(APP_PREFIX)) if (!appId && appPath.length !== 0) { appId = appPath[0] } return appId } /** * Get the name of the cookie which is to be updated/retrieved * @param {string|undefined|null} name OPTIONAL can specify the specific app if previewing etc * @returns {string} The name of the token trying to find */ exports.getCookieName = (name = "builder") => { let environment = env.CLOUD ? "cloud" : "local" return `budibase:${name}:${environment}` } /** * Store a cookie for the request, has a hardcoded expiry. * @param {object} ctx The request which is to be manipulated. * @param {string} name The name of the cookie to set. * @param {string|object} value The value of cookie which will be set. */ exports.setCookie = (ctx, name, value) => { const expires = new Date() expires.setDate(expires.getDate() + 1) ctx.cookies.set(exports.getCookieName(name), value, { expires, path: "/", httpOnly: false, overwrite: true, }) }