138 lines
4.1 KiB
JavaScript
138 lines
4.1 KiB
JavaScript
"use strict";
|
|
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
return new (P || (P = Promise))(function (resolve, reject) {
|
|
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
});
|
|
};
|
|
const Router = require("@koa/router");
|
|
const compress = require("koa-compress");
|
|
const zlib = require("zlib");
|
|
const { routes } = require("./routes");
|
|
const { buildAuthMiddleware, auditLog, buildTenancyMiddleware, buildCsrfMiddleware, } = require("@budibase/backend-core/auth");
|
|
const { middleware: pro } = require("@budibase/pro");
|
|
const { errors } = require("@budibase/backend-core");
|
|
const PUBLIC_ENDPOINTS = [
|
|
// old deprecated endpoints kept for backwards compat
|
|
{
|
|
route: "/api/admin/auth/google/callback",
|
|
method: "GET",
|
|
},
|
|
{
|
|
route: "/api/admin/auth/oidc/callback",
|
|
method: "GET",
|
|
},
|
|
{
|
|
// this covers all of the POST auth routes
|
|
route: "/api/global/auth/:tenantId",
|
|
method: "POST",
|
|
},
|
|
{
|
|
// this covers all of the GET auth routes
|
|
route: "/api/global/auth/:tenantId",
|
|
method: "GET",
|
|
},
|
|
{
|
|
// this covers all of the public config routes
|
|
route: "/api/global/configs/public",
|
|
method: "GET",
|
|
},
|
|
{
|
|
route: "/api/global/configs/checklist",
|
|
method: "GET",
|
|
},
|
|
{
|
|
route: "/api/global/users/init",
|
|
method: "POST",
|
|
},
|
|
{
|
|
route: "/api/global/users/invite/accept",
|
|
method: "POST",
|
|
},
|
|
{
|
|
route: "api/system/environment",
|
|
method: "GET",
|
|
},
|
|
{
|
|
route: "api/system/status",
|
|
method: "GET",
|
|
},
|
|
{
|
|
route: "/api/global/users/tenant/:id",
|
|
method: "GET",
|
|
},
|
|
];
|
|
const NO_TENANCY_ENDPOINTS = [
|
|
...PUBLIC_ENDPOINTS,
|
|
{
|
|
route: "/api/system",
|
|
method: "ALL",
|
|
},
|
|
{
|
|
route: "/api/global/users/self",
|
|
method: "GET",
|
|
},
|
|
{
|
|
route: "/api/global/self",
|
|
method: "GET",
|
|
},
|
|
];
|
|
// most public endpoints are gets, but some are posts
|
|
// add them all to be safe
|
|
const NO_CSRF_ENDPOINTS = [...PUBLIC_ENDPOINTS];
|
|
const router = new Router();
|
|
router
|
|
.use(compress({
|
|
threshold: 2048,
|
|
gzip: {
|
|
flush: zlib.constants.Z_SYNC_FLUSH,
|
|
},
|
|
deflate: {
|
|
flush: zlib.constants.Z_SYNC_FLUSH,
|
|
},
|
|
br: false,
|
|
}))
|
|
.use("/health", ctx => (ctx.status = 200))
|
|
.use(buildAuthMiddleware(PUBLIC_ENDPOINTS))
|
|
.use(buildTenancyMiddleware(PUBLIC_ENDPOINTS, NO_TENANCY_ENDPOINTS))
|
|
.use(buildCsrfMiddleware({ noCsrfPatterns: NO_CSRF_ENDPOINTS }))
|
|
.use(pro.licensing())
|
|
// for now no public access is allowed to worker (bar health check)
|
|
.use((ctx, next) => {
|
|
if (ctx.publicEndpoint) {
|
|
return next();
|
|
}
|
|
if ((!ctx.isAuthenticated || (ctx.user && !ctx.user.budibaseAccess)) &&
|
|
!ctx.internal) {
|
|
ctx.throw(403, "Unauthorized - no public worker access");
|
|
}
|
|
return next();
|
|
})
|
|
.use(auditLog);
|
|
// error handling middleware - TODO: This could be moved to backend-core
|
|
router.use((ctx, next) => __awaiter(void 0, void 0, void 0, function* () {
|
|
try {
|
|
yield next();
|
|
}
|
|
catch (err) {
|
|
ctx.log.error(err);
|
|
ctx.status = err.status || err.statusCode || 500;
|
|
const error = errors.getPublicError(err);
|
|
ctx.body = {
|
|
message: err.message,
|
|
status: ctx.status,
|
|
error,
|
|
};
|
|
}
|
|
}));
|
|
router.get("/health", ctx => (ctx.status = 200));
|
|
// authenticated routes
|
|
for (let route of routes) {
|
|
router.use(route.routes());
|
|
router.use(route.allowedMethods());
|
|
}
|
|
module.exports = router;
|