@budibase/worker 2.8.29-alpha.5 → 2.8.30
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/jest.config.ts +2 -0
- package/package.json +12 -11
- package/src/api/controllers/global/configs.ts +3 -3
- package/src/api/controllers/global/email.ts +3 -3
- package/src/api/controllers/global/roles.ts +1 -1
- package/src/api/controllers/global/self.ts +1 -1
- package/src/api/controllers/global/users.ts +1 -1
- package/src/api/routes/global/tests/scim.spec.ts +2 -2
- package/src/api/routes/index.ts +0 -7
- package/src/api/controllers/system/logs.ts +0 -13
- package/src/api/routes/system/logs.ts +0 -9
package/jest.config.ts
CHANGED
|
@@ -1,7 +1,9 @@
|
|
|
1
1
|
import { Config } from "@jest/types"
|
|
2
2
|
import * as fs from "fs"
|
|
3
|
+
const preset = require("ts-jest/jest-preset")
|
|
3
4
|
|
|
4
5
|
const config: Config.InitialOptions = {
|
|
6
|
+
...preset,
|
|
5
7
|
preset: "@trendyol/jest-testcontainers",
|
|
6
8
|
setupFiles: ["./src/tests/jestEnv.ts"],
|
|
7
9
|
setupFilesAfterEnv: ["./src/tests/jestSetup.ts"],
|
package/package.json
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@budibase/worker",
|
|
3
3
|
"email": "hi@budibase.com",
|
|
4
|
-
"version": "2.8.
|
|
4
|
+
"version": "2.8.30",
|
|
5
5
|
"description": "Budibase background service",
|
|
6
6
|
"main": "src/index.ts",
|
|
7
7
|
"repository": {
|
|
@@ -38,10 +38,10 @@
|
|
|
38
38
|
"author": "Budibase",
|
|
39
39
|
"license": "GPL-3.0",
|
|
40
40
|
"dependencies": {
|
|
41
|
-
"@budibase/backend-core": "2.8.
|
|
42
|
-
"@budibase/pro": "2.8.
|
|
43
|
-
"@budibase/string-templates": "2.8.
|
|
44
|
-
"@budibase/types": "2.8.
|
|
41
|
+
"@budibase/backend-core": "2.8.30",
|
|
42
|
+
"@budibase/pro": "2.8.30",
|
|
43
|
+
"@budibase/string-templates": "2.8.30",
|
|
44
|
+
"@budibase/types": "2.8.30",
|
|
45
45
|
"@koa/router": "8.0.8",
|
|
46
46
|
"@sentry/node": "6.17.7",
|
|
47
47
|
"@techpass/passport-openidconnect": "0.3.2",
|
|
@@ -74,10 +74,10 @@
|
|
|
74
74
|
"server-destroy": "1.0.1"
|
|
75
75
|
},
|
|
76
76
|
"devDependencies": {
|
|
77
|
-
"@swc/core": "1.3.
|
|
78
|
-
"@swc/jest": "0.2.
|
|
79
|
-
"@trendyol/jest-testcontainers": "2.1.1",
|
|
80
|
-
"@types/jest": "
|
|
77
|
+
"@swc/core": "^1.3.25",
|
|
78
|
+
"@swc/jest": "^0.2.24",
|
|
79
|
+
"@trendyol/jest-testcontainers": "^2.1.1",
|
|
80
|
+
"@types/jest": "28.1.1",
|
|
81
81
|
"@types/jsonwebtoken": "8.5.1",
|
|
82
82
|
"@types/koa": "2.13.4",
|
|
83
83
|
"@types/koa__router": "8.0.8",
|
|
@@ -91,13 +91,14 @@
|
|
|
91
91
|
"@typescript-eslint/parser": "5.45.0",
|
|
92
92
|
"copyfiles": "2.4.1",
|
|
93
93
|
"eslint": "6.8.0",
|
|
94
|
-
"jest": "
|
|
94
|
+
"jest": "28.1.1",
|
|
95
95
|
"lodash": "4.17.21",
|
|
96
96
|
"nodemon": "2.0.15",
|
|
97
97
|
"pouchdb-adapter-memory": "7.2.2",
|
|
98
98
|
"rimraf": "3.0.2",
|
|
99
99
|
"supertest": "6.2.2",
|
|
100
100
|
"timekeeper": "2.2.0",
|
|
101
|
+
"ts-jest": "28.0.4",
|
|
101
102
|
"ts-node": "10.8.1",
|
|
102
103
|
"tsconfig-paths": "4.0.0",
|
|
103
104
|
"typescript": "4.7.3",
|
|
@@ -117,5 +118,5 @@
|
|
|
117
118
|
}
|
|
118
119
|
}
|
|
119
120
|
},
|
|
120
|
-
"gitHead": "
|
|
121
|
+
"gitHead": "0bb17a32b1120c5b2526983870dbec4ee8cd6086"
|
|
121
122
|
}
|
|
@@ -507,17 +507,17 @@ export async function configChecklist(ctx: Ctx) {
|
|
|
507
507
|
smtp: {
|
|
508
508
|
checked: !!smtpConfig,
|
|
509
509
|
label: "Set up email",
|
|
510
|
-
link: "/builder/portal/
|
|
510
|
+
link: "/builder/portal/manage/email",
|
|
511
511
|
},
|
|
512
512
|
adminUser: {
|
|
513
513
|
checked: userExists,
|
|
514
514
|
label: "Create your first user",
|
|
515
|
-
link: "/builder/portal/
|
|
515
|
+
link: "/builder/portal/manage/users",
|
|
516
516
|
},
|
|
517
517
|
sso: {
|
|
518
518
|
checked: !!googleConfig || !!oidcConfig,
|
|
519
519
|
label: "Set up single sign-on",
|
|
520
|
-
link: "/builder/portal/
|
|
520
|
+
link: "/builder/portal/manage/auth",
|
|
521
521
|
},
|
|
522
522
|
}
|
|
523
523
|
}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { sendEmail as sendEmailFn } from "../../../utilities/email"
|
|
2
2
|
import { tenancy } from "@budibase/backend-core"
|
|
3
|
-
import { BBContext
|
|
3
|
+
import { BBContext } from "@budibase/types"
|
|
4
4
|
|
|
5
5
|
export async function sendEmail(ctx: BBContext) {
|
|
6
6
|
let {
|
|
@@ -16,10 +16,10 @@ export async function sendEmail(ctx: BBContext) {
|
|
|
16
16
|
automation,
|
|
17
17
|
invite,
|
|
18
18
|
} = ctx.request.body
|
|
19
|
-
let user
|
|
19
|
+
let user
|
|
20
20
|
if (userId) {
|
|
21
21
|
const db = tenancy.getGlobalDB()
|
|
22
|
-
user = await db.get
|
|
22
|
+
user = await db.get(userId)
|
|
23
23
|
}
|
|
24
24
|
const response = await sendEmailFn(email, purpose, {
|
|
25
25
|
workspaceId,
|
|
@@ -35,7 +35,7 @@ export async function find(ctx: BBContext) {
|
|
|
35
35
|
const appId = ctx.params.appId
|
|
36
36
|
await context.doInAppContext(dbCore.getDevAppID(appId), async () => {
|
|
37
37
|
const db = context.getAppDB()
|
|
38
|
-
const app = await db.get
|
|
38
|
+
const app = await db.get(dbCore.DocumentType.APP_METADATA)
|
|
39
39
|
ctx.body = {
|
|
40
40
|
roles: await roles.getAllRoles(),
|
|
41
41
|
name: app.name,
|
|
@@ -412,7 +412,7 @@ export const inviteAccept = async (
|
|
|
412
412
|
|
|
413
413
|
const saved = await userSdk.save(request)
|
|
414
414
|
const db = tenancy.getGlobalDB()
|
|
415
|
-
const user = await db.get
|
|
415
|
+
const user = await db.get(saved._id)
|
|
416
416
|
await events.user.inviteAccepted(user)
|
|
417
417
|
return saved
|
|
418
418
|
})
|
|
@@ -314,7 +314,7 @@ describe("scim", () => {
|
|
|
314
314
|
|
|
315
315
|
const user = await config.getUser(email)
|
|
316
316
|
expect(user).toBeDefined()
|
|
317
|
-
expect(user
|
|
317
|
+
expect(user.email).toEqual(email)
|
|
318
318
|
})
|
|
319
319
|
|
|
320
320
|
it("if multiple emails are provided, the first primary one is used as email", async () => {
|
|
@@ -345,7 +345,7 @@ describe("scim", () => {
|
|
|
345
345
|
|
|
346
346
|
const user = await config.getUser(email)
|
|
347
347
|
expect(user).toBeDefined()
|
|
348
|
-
expect(user
|
|
348
|
+
expect(user.email).toEqual(email)
|
|
349
349
|
})
|
|
350
350
|
|
|
351
351
|
it("if no email is provided and the user name is not an email, an exception is thrown", async () => {
|
package/src/api/routes/index.ts
CHANGED
|
@@ -16,9 +16,6 @@ import licenseRoutes from "./global/license"
|
|
|
16
16
|
import migrationRoutes from "./system/migrations"
|
|
17
17
|
import accountRoutes from "./system/accounts"
|
|
18
18
|
import restoreRoutes from "./system/restore"
|
|
19
|
-
import systemLogRoutes from "./system/logs"
|
|
20
|
-
|
|
21
|
-
import env from "../../environment"
|
|
22
19
|
|
|
23
20
|
export const routes: Router[] = [
|
|
24
21
|
configRoutes,
|
|
@@ -41,7 +38,3 @@ export const routes: Router[] = [
|
|
|
41
38
|
eventRoutes,
|
|
42
39
|
pro.scim,
|
|
43
40
|
]
|
|
44
|
-
|
|
45
|
-
if (env.SELF_HOSTED) {
|
|
46
|
-
routes.push(systemLogRoutes)
|
|
47
|
-
}
|
|
@@ -1,13 +0,0 @@
|
|
|
1
|
-
import { UserCtx } from "@budibase/types"
|
|
2
|
-
import { installation, logging } from "@budibase/backend-core"
|
|
3
|
-
|
|
4
|
-
export async function getLogs(ctx: UserCtx) {
|
|
5
|
-
const logReadStream = logging.system.getLogReadStream()
|
|
6
|
-
|
|
7
|
-
const { installId } = await installation.getInstall()
|
|
8
|
-
|
|
9
|
-
const fileName = `${installId}-${Date.now()}.log`
|
|
10
|
-
|
|
11
|
-
ctx.set("content-disposition", `attachment; filename=${fileName}`)
|
|
12
|
-
ctx.body = logReadStream
|
|
13
|
-
}
|
|
@@ -1,9 +0,0 @@
|
|
|
1
|
-
import Router from "@koa/router"
|
|
2
|
-
import { middleware } from "@budibase/backend-core"
|
|
3
|
-
import * as controller from "../../controllers/system/logs"
|
|
4
|
-
|
|
5
|
-
const router: Router = new Router()
|
|
6
|
-
|
|
7
|
-
router.get("/api/system/logs", middleware.adminOnly, controller.getLogs)
|
|
8
|
-
|
|
9
|
-
export default router
|