@budibase/backend-core 3.2.4 → 3.2.6

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.
Files changed (272) hide show
  1. package/dist/index.js.map +1 -1
  2. package/dist/index.js.meta.json +1 -1
  3. package/dist/package.json +11 -4
  4. package/dist/plugins.js.meta.json +1 -1
  5. package/package.json +11 -4
  6. package/src/accounts/accounts.ts +0 -82
  7. package/src/accounts/api.ts +0 -59
  8. package/src/accounts/index.ts +0 -1
  9. package/src/auth/auth.ts +0 -210
  10. package/src/auth/index.ts +0 -1
  11. package/src/auth/tests/auth.spec.ts +0 -14
  12. package/src/blacklist/blacklist.ts +0 -54
  13. package/src/blacklist/index.ts +0 -1
  14. package/src/blacklist/tests/blacklist.spec.ts +0 -46
  15. package/src/cache/appMetadata.ts +0 -88
  16. package/src/cache/base/index.ts +0 -150
  17. package/src/cache/docWritethrough.ts +0 -105
  18. package/src/cache/generic.ts +0 -33
  19. package/src/cache/index.ts +0 -8
  20. package/src/cache/invite.ts +0 -86
  21. package/src/cache/passwordReset.ts +0 -49
  22. package/src/cache/tests/docWritethrough.spec.ts +0 -296
  23. package/src/cache/tests/user.spec.ts +0 -145
  24. package/src/cache/tests/writethrough.spec.ts +0 -139
  25. package/src/cache/user.ts +0 -154
  26. package/src/cache/writethrough.ts +0 -133
  27. package/src/configs/configs.ts +0 -263
  28. package/src/configs/index.ts +0 -1
  29. package/src/configs/tests/configs.spec.ts +0 -184
  30. package/src/constants/db.ts +0 -75
  31. package/src/constants/index.ts +0 -2
  32. package/src/constants/misc.ts +0 -36
  33. package/src/context/Context.ts +0 -14
  34. package/src/context/identity.ts +0 -58
  35. package/src/context/index.ts +0 -3
  36. package/src/context/mainContext.ts +0 -422
  37. package/src/context/tests/index.spec.ts +0 -255
  38. package/src/context/types.ts +0 -26
  39. package/src/db/Replication.ts +0 -94
  40. package/src/db/couch/DatabaseImpl.ts +0 -511
  41. package/src/db/couch/connections.ts +0 -89
  42. package/src/db/couch/index.ts +0 -4
  43. package/src/db/couch/pouchDB.ts +0 -97
  44. package/src/db/couch/pouchDump.ts +0 -0
  45. package/src/db/couch/tests/DatabaseImpl.spec.ts +0 -118
  46. package/src/db/couch/utils.ts +0 -55
  47. package/src/db/db.ts +0 -34
  48. package/src/db/errors.ts +0 -14
  49. package/src/db/index.ts +0 -12
  50. package/src/db/instrumentation.ts +0 -199
  51. package/src/db/lucene.ts +0 -721
  52. package/src/db/searchIndexes/index.ts +0 -1
  53. package/src/db/searchIndexes/searchIndexes.ts +0 -62
  54. package/src/db/tests/DatabaseImpl.spec.ts +0 -55
  55. package/src/db/tests/connections.spec.ts +0 -22
  56. package/src/db/tests/index.spec.ts +0 -32
  57. package/src/db/tests/lucene.spec.ts +0 -400
  58. package/src/db/tests/pouch.spec.js +0 -62
  59. package/src/db/tests/utils.spec.ts +0 -63
  60. package/src/db/utils.ts +0 -208
  61. package/src/db/views.ts +0 -245
  62. package/src/docIds/conversions.ts +0 -60
  63. package/src/docIds/ids.ts +0 -126
  64. package/src/docIds/index.ts +0 -2
  65. package/src/docIds/newid.ts +0 -5
  66. package/src/docIds/params.ts +0 -189
  67. package/src/docUpdates/index.ts +0 -24
  68. package/src/environment.ts +0 -293
  69. package/src/errors/errors.ts +0 -119
  70. package/src/errors/index.ts +0 -1
  71. package/src/events/analytics.ts +0 -6
  72. package/src/events/asyncEvents/index.ts +0 -2
  73. package/src/events/asyncEvents/publisher.ts +0 -12
  74. package/src/events/asyncEvents/queue.ts +0 -22
  75. package/src/events/backfill.ts +0 -183
  76. package/src/events/documentId.ts +0 -56
  77. package/src/events/events.ts +0 -47
  78. package/src/events/identification.ts +0 -311
  79. package/src/events/index.ts +0 -15
  80. package/src/events/processors/AnalyticsProcessor.ts +0 -64
  81. package/src/events/processors/AuditLogsProcessor.ts +0 -92
  82. package/src/events/processors/LoggingProcessor.ts +0 -36
  83. package/src/events/processors/Processors.ts +0 -52
  84. package/src/events/processors/async/DocumentUpdateProcessor.ts +0 -38
  85. package/src/events/processors/index.ts +0 -19
  86. package/src/events/processors/posthog/PosthogProcessor.ts +0 -118
  87. package/src/events/processors/posthog/index.ts +0 -3
  88. package/src/events/processors/posthog/rateLimiting.ts +0 -106
  89. package/src/events/processors/posthog/tests/PosthogProcessor.spec.ts +0 -164
  90. package/src/events/processors/types.ts +0 -1
  91. package/src/events/publishers/account.ts +0 -41
  92. package/src/events/publishers/ai.ts +0 -21
  93. package/src/events/publishers/app.ts +0 -168
  94. package/src/events/publishers/auditLog.ts +0 -26
  95. package/src/events/publishers/auth.ts +0 -73
  96. package/src/events/publishers/automation.ts +0 -110
  97. package/src/events/publishers/backfill.ts +0 -74
  98. package/src/events/publishers/backup.ts +0 -42
  99. package/src/events/publishers/datasource.ts +0 -48
  100. package/src/events/publishers/email.ts +0 -17
  101. package/src/events/publishers/environmentVariable.ts +0 -38
  102. package/src/events/publishers/group.ts +0 -99
  103. package/src/events/publishers/index.ts +0 -25
  104. package/src/events/publishers/installation.ts +0 -38
  105. package/src/events/publishers/layout.ts +0 -26
  106. package/src/events/publishers/license.ts +0 -84
  107. package/src/events/publishers/org.ts +0 -37
  108. package/src/events/publishers/plugin.ts +0 -47
  109. package/src/events/publishers/query.ts +0 -89
  110. package/src/events/publishers/role.ts +0 -62
  111. package/src/events/publishers/rows.ts +0 -29
  112. package/src/events/publishers/screen.ts +0 -36
  113. package/src/events/publishers/serve.ts +0 -43
  114. package/src/events/publishers/table.ts +0 -70
  115. package/src/events/publishers/user.ts +0 -202
  116. package/src/events/publishers/view.ts +0 -107
  117. package/src/features/features.ts +0 -277
  118. package/src/features/index.ts +0 -2
  119. package/src/features/tests/features.spec.ts +0 -267
  120. package/src/features/tests/utils.ts +0 -64
  121. package/src/helpers.ts +0 -9
  122. package/src/index.ts +0 -59
  123. package/src/installation.ts +0 -115
  124. package/src/logging/alerts.ts +0 -26
  125. package/src/logging/correlation/correlation.ts +0 -15
  126. package/src/logging/correlation/index.ts +0 -1
  127. package/src/logging/correlation/middleware.ts +0 -18
  128. package/src/logging/index.ts +0 -4
  129. package/src/logging/pino/logger.ts +0 -239
  130. package/src/logging/pino/middleware.ts +0 -48
  131. package/src/logging/system.ts +0 -81
  132. package/src/logging/tests/system.spec.ts +0 -61
  133. package/src/middleware/adminOnly.ts +0 -9
  134. package/src/middleware/auditLog.ts +0 -6
  135. package/src/middleware/authenticated.ts +0 -247
  136. package/src/middleware/builderOnly.ts +0 -21
  137. package/src/middleware/builderOrAdmin.ts +0 -21
  138. package/src/middleware/contentSecurityPolicy.ts +0 -113
  139. package/src/middleware/csrf.ts +0 -81
  140. package/src/middleware/errorHandling.ts +0 -43
  141. package/src/middleware/index.ts +0 -24
  142. package/src/middleware/internalApi.ts +0 -23
  143. package/src/middleware/ip.ts +0 -12
  144. package/src/middleware/joi-validator.ts +0 -58
  145. package/src/middleware/matchers.ts +0 -39
  146. package/src/middleware/passport/datasource/google.ts +0 -102
  147. package/src/middleware/passport/local.ts +0 -54
  148. package/src/middleware/passport/sso/google.ts +0 -77
  149. package/src/middleware/passport/sso/oidc.ts +0 -152
  150. package/src/middleware/passport/sso/sso.ts +0 -138
  151. package/src/middleware/passport/sso/tests/google.spec.ts +0 -68
  152. package/src/middleware/passport/sso/tests/oidc.spec.ts +0 -144
  153. package/src/middleware/passport/sso/tests/sso.spec.ts +0 -197
  154. package/src/middleware/passport/utils.ts +0 -38
  155. package/src/middleware/querystringToBody.ts +0 -28
  156. package/src/middleware/tenancy.ts +0 -36
  157. package/src/middleware/tests/builder.spec.ts +0 -181
  158. package/src/middleware/tests/contentSecurityPolicy.spec.ts +0 -75
  159. package/src/middleware/tests/matchers.spec.ts +0 -100
  160. package/src/migrations/definitions.ts +0 -40
  161. package/src/migrations/index.ts +0 -2
  162. package/src/migrations/migrations.ts +0 -186
  163. package/src/migrations/tests/__snapshots__/migrations.spec.ts.snap +0 -11
  164. package/src/migrations/tests/migrations.spec.ts +0 -64
  165. package/src/objectStore/buckets/app.ts +0 -53
  166. package/src/objectStore/buckets/global.ts +0 -29
  167. package/src/objectStore/buckets/index.ts +0 -3
  168. package/src/objectStore/buckets/plugins.ts +0 -71
  169. package/src/objectStore/buckets/tests/app.spec.ts +0 -161
  170. package/src/objectStore/buckets/tests/global.spec.ts +0 -74
  171. package/src/objectStore/buckets/tests/plugins.spec.ts +0 -111
  172. package/src/objectStore/cloudfront.ts +0 -41
  173. package/src/objectStore/index.ts +0 -3
  174. package/src/objectStore/objectStore.ts +0 -585
  175. package/src/objectStore/utils.ts +0 -113
  176. package/src/platform/index.ts +0 -3
  177. package/src/platform/platformDb.ts +0 -6
  178. package/src/platform/tenants.ts +0 -101
  179. package/src/platform/tests/tenants.spec.ts +0 -26
  180. package/src/platform/users.ts +0 -129
  181. package/src/plugin/index.ts +0 -1
  182. package/src/plugin/tests/validation.spec.ts +0 -209
  183. package/src/plugin/utils.ts +0 -175
  184. package/src/queue/constants.ts +0 -8
  185. package/src/queue/inMemoryQueue.ts +0 -189
  186. package/src/queue/index.ts +0 -2
  187. package/src/queue/listeners.ts +0 -199
  188. package/src/queue/queue.ts +0 -84
  189. package/src/redis/index.ts +0 -6
  190. package/src/redis/init.ts +0 -118
  191. package/src/redis/redis.ts +0 -358
  192. package/src/redis/redlockImpl.ts +0 -155
  193. package/src/redis/tests/redis.spec.ts +0 -207
  194. package/src/redis/tests/redlockImpl.spec.ts +0 -105
  195. package/src/redis/utils.ts +0 -128
  196. package/src/security/auth.ts +0 -24
  197. package/src/security/encryption.ts +0 -185
  198. package/src/security/index.ts +0 -1
  199. package/src/security/permissions.ts +0 -166
  200. package/src/security/roles.ts +0 -655
  201. package/src/security/secrets.ts +0 -20
  202. package/src/security/sessions.ts +0 -123
  203. package/src/security/tests/auth.spec.ts +0 -45
  204. package/src/security/tests/encryption.spec.ts +0 -31
  205. package/src/security/tests/permissions.spec.ts +0 -146
  206. package/src/security/tests/secrets.spec.ts +0 -35
  207. package/src/security/tests/sessions.spec.ts +0 -12
  208. package/src/sql/designDoc.ts +0 -17
  209. package/src/sql/index.ts +0 -5
  210. package/src/sql/sql.ts +0 -1854
  211. package/src/sql/sqlTable.ts +0 -319
  212. package/src/sql/utils.ts +0 -193
  213. package/src/tenancy/db.ts +0 -6
  214. package/src/tenancy/index.ts +0 -2
  215. package/src/tenancy/tenancy.ts +0 -148
  216. package/src/tenancy/tests/tenancy.spec.ts +0 -184
  217. package/src/timers/index.ts +0 -1
  218. package/src/timers/timers.ts +0 -22
  219. package/src/users/db.ts +0 -582
  220. package/src/users/events.ts +0 -176
  221. package/src/users/index.ts +0 -4
  222. package/src/users/lookup.ts +0 -99
  223. package/src/users/test/db.spec.ts +0 -188
  224. package/src/users/test/utils.spec.ts +0 -67
  225. package/src/users/users.ts +0 -353
  226. package/src/users/utils.ts +0 -81
  227. package/src/utils/Duration.ts +0 -56
  228. package/src/utils/hashing.ts +0 -15
  229. package/src/utils/index.ts +0 -4
  230. package/src/utils/stringUtils.ts +0 -8
  231. package/src/utils/tests/Duration.spec.ts +0 -19
  232. package/src/utils/tests/utils.spec.ts +0 -204
  233. package/src/utils/utils.ts +0 -249
  234. package/tests/core/logging.ts +0 -34
  235. package/tests/core/users/users.spec.js +0 -53
  236. package/tests/core/utilities/index.ts +0 -7
  237. package/tests/core/utilities/jestUtils.ts +0 -33
  238. package/tests/core/utilities/mocks/alerts.ts +0 -4
  239. package/tests/core/utilities/mocks/date.ts +0 -3
  240. package/tests/core/utilities/mocks/events.ts +0 -132
  241. package/tests/core/utilities/mocks/index.ts +0 -9
  242. package/tests/core/utilities/mocks/licenses.ts +0 -119
  243. package/tests/core/utilities/queue.ts +0 -9
  244. package/tests/core/utilities/structures/Chance.ts +0 -20
  245. package/tests/core/utilities/structures/accounts.ts +0 -80
  246. package/tests/core/utilities/structures/apps.ts +0 -21
  247. package/tests/core/utilities/structures/common.ts +0 -7
  248. package/tests/core/utilities/structures/db.ts +0 -12
  249. package/tests/core/utilities/structures/documents/index.ts +0 -1
  250. package/tests/core/utilities/structures/documents/platform/index.ts +0 -1
  251. package/tests/core/utilities/structures/documents/platform/installation.ts +0 -12
  252. package/tests/core/utilities/structures/generator.ts +0 -3
  253. package/tests/core/utilities/structures/index.ts +0 -15
  254. package/tests/core/utilities/structures/koa.ts +0 -16
  255. package/tests/core/utilities/structures/licenses.ts +0 -190
  256. package/tests/core/utilities/structures/plugins.ts +0 -19
  257. package/tests/core/utilities/structures/quotas.ts +0 -72
  258. package/tests/core/utilities/structures/scim.ts +0 -80
  259. package/tests/core/utilities/structures/sso.ts +0 -118
  260. package/tests/core/utilities/structures/tenants.ts +0 -5
  261. package/tests/core/utilities/structures/userGroups.ts +0 -10
  262. package/tests/core/utilities/structures/users.ts +0 -89
  263. package/tests/core/utilities/testContainerUtils.ts +0 -165
  264. package/tests/core/utilities/utils/index.ts +0 -2
  265. package/tests/core/utilities/utils/queue.ts +0 -27
  266. package/tests/core/utilities/utils/time.ts +0 -3
  267. package/tests/extra/DBTestConfiguration.ts +0 -36
  268. package/tests/extra/index.ts +0 -2
  269. package/tests/extra/testEnv.ts +0 -95
  270. package/tests/index.ts +0 -2
  271. package/tests/jestEnv.ts +0 -10
  272. package/tests/jestSetup.ts +0 -36
@@ -1,184 +0,0 @@
1
- import { TenantResolutionStrategy } from "@budibase/types"
2
- import { addTenantToUrl, isUserInAppTenant, getTenantIDFromCtx } from "../"
3
- import { isMultiTenant, getTenantIDFromAppID } from "../../context"
4
-
5
- jest.mock("../../context", () => ({
6
- getTenantId: jest.fn(() => "budibase"),
7
- isMultiTenant: jest.fn(() => true),
8
- getTenantIDFromAppID: jest.fn(),
9
- getPlatformURL: jest.fn(() => "https://app.com"),
10
- DEFAULT_TENANT_ID: "default",
11
- }))
12
-
13
- const mockedIsMultiTenant = isMultiTenant as jest.MockedFunction<
14
- typeof isMultiTenant
15
- >
16
- const mockedGetTenantIDFromAppID = getTenantIDFromAppID as jest.MockedFunction<
17
- typeof getTenantIDFromAppID
18
- >
19
-
20
- describe("addTenantToUrl", () => {
21
- it("should append tenantId parameter to the URL", () => {
22
- const url = "https://budibase.com"
23
- const expectedUrl = "https://budibase.com?tenantId=budibase"
24
- expect(addTenantToUrl(url)).toEqual(expectedUrl)
25
- })
26
-
27
- it("should append tenantId parameter to the URL query string", () => {
28
- const url = "https://budibase.com?var=test"
29
- const expectedUrl = "https://budibase.com?var=test&tenantId=budibase"
30
- expect(addTenantToUrl(url)).toEqual(expectedUrl)
31
- })
32
-
33
- it("should not append tenantId parameter to the URL if isMultiTenant is false", () => {
34
- mockedIsMultiTenant.mockImplementation(() => false)
35
-
36
- const url = "https://budibase.com"
37
- const expectedUrl = "https://budibase.com"
38
- expect(addTenantToUrl(url)).toEqual(expectedUrl)
39
- })
40
- })
41
-
42
- describe("isUserInAppTenant", () => {
43
- mockedGetTenantIDFromAppID.mockImplementation(() => "budibase")
44
- const mockUser = { tenantId: "budibase" }
45
-
46
- it("returns true if user tenant ID matches app tenant ID", () => {
47
- const appId = "app-budibase"
48
- const result = isUserInAppTenant(appId, mockUser)
49
- expect(result).toBe(true)
50
- })
51
-
52
- it("uses default tenant ID if user is not provided", () => {
53
- const appId = "app-budibase"
54
- const result = isUserInAppTenant(appId)
55
- expect(result).toBe(true)
56
- })
57
-
58
- it("uses default tenant ID if app tenant ID is not found", () => {
59
- const appId = "not-budibase-app"
60
- const result = isUserInAppTenant(appId, mockUser)
61
- expect(result).toBe(true)
62
- })
63
-
64
- it("returns false if user tenant ID does not match app tenant ID", () => {
65
- const appId = "app-budibase"
66
- mockedGetTenantIDFromAppID.mockImplementation(() => "not-budibase")
67
- const result = isUserInAppTenant(appId, mockUser)
68
- expect(result).toBe(false)
69
- })
70
- })
71
-
72
- let mockOpts: any = {}
73
- function createCtx(opts: {
74
- originalUrl?: string
75
- headers?: Record<string, string>
76
- qsTenantId?: string
77
- userTenantId?: string
78
- host?: string
79
- path?: string
80
- }) {
81
- const createdCtx: any = {
82
- originalUrl: opts.originalUrl || "budibase.com",
83
- matched: [{ name: "name" }],
84
- throw: jest.fn(),
85
- request: { headers: {} },
86
- }
87
- if (opts.headers) {
88
- createdCtx.request.headers = opts.headers
89
- }
90
- if (opts.qsTenantId) {
91
- createdCtx.request.query = { tenantId: opts.qsTenantId }
92
- }
93
- if (opts.userTenantId) {
94
- createdCtx.user = { tenantId: opts.userTenantId }
95
- }
96
- if (opts.host) {
97
- createdCtx.host = opts.host
98
- }
99
- if (opts.path) {
100
- createdCtx.matched = [
101
- {
102
- paramNames: [{ name: "tenantId" }],
103
- params: () => ({ tenantId: opts.path }),
104
- captures: jest.fn(),
105
- },
106
- ]
107
- }
108
-
109
- return createdCtx as any
110
- }
111
-
112
- describe("getTenantIDFromCtx", () => {
113
- describe("when tenant can be found", () => {
114
- it("returns the tenant ID from the user object", () => {
115
- mockedIsMultiTenant.mockImplementation(() => true)
116
- const ctx = createCtx({ userTenantId: "budibase" })
117
- expect(getTenantIDFromCtx(ctx, mockOpts)).toEqual("budibase")
118
- })
119
-
120
- it("returns the tenant ID from the header", () => {
121
- mockedIsMultiTenant.mockImplementation(() => true)
122
- const ctx = createCtx({ headers: { "x-budibase-tenant-id": "budibase" } })
123
- mockOpts = { includeStrategies: [TenantResolutionStrategy.HEADER] }
124
- expect(getTenantIDFromCtx(ctx, mockOpts)).toEqual("budibase")
125
- })
126
-
127
- it("returns the tenant ID from the query param", () => {
128
- mockedIsMultiTenant.mockImplementation(() => true)
129
- mockOpts = { includeStrategies: [TenantResolutionStrategy.QUERY] }
130
- const ctx = createCtx({ qsTenantId: "budibase" })
131
- expect(getTenantIDFromCtx(ctx, mockOpts)).toEqual("budibase")
132
- })
133
-
134
- it("returns the tenant ID from the subdomain", () => {
135
- mockedIsMultiTenant.mockImplementation(() => true)
136
- const ctx = createCtx({ host: "bb.app.com" })
137
- mockOpts = { includeStrategies: [TenantResolutionStrategy.SUBDOMAIN] }
138
- expect(getTenantIDFromCtx(ctx, mockOpts)).toEqual("bb")
139
- })
140
-
141
- it("returns the tenant ID from the path", () => {
142
- mockedIsMultiTenant.mockImplementation(() => true)
143
- const ctx = createCtx({ path: "bb" })
144
- mockOpts = { includeStrategies: [TenantResolutionStrategy.PATH] }
145
- expect(getTenantIDFromCtx(ctx, mockOpts)).toEqual("bb")
146
- })
147
- })
148
-
149
- describe("when tenant cannot be found", () => {
150
- it("throws a 403 error if allowNoTenant is false", () => {
151
- const ctx = createCtx({})
152
- mockOpts = {
153
- allowNoTenant: false,
154
- excludeStrategies: [
155
- TenantResolutionStrategy.QUERY,
156
- TenantResolutionStrategy.SUBDOMAIN,
157
- TenantResolutionStrategy.PATH,
158
- ],
159
- }
160
- expect(getTenantIDFromCtx(ctx, mockOpts)).toBeUndefined()
161
- expect(ctx.throw).toHaveBeenCalledTimes(1)
162
- expect(ctx.throw).toHaveBeenCalledWith(403, "Tenant id not set")
163
- })
164
-
165
- it("returns undefined if allowNoTenant is true", () => {
166
- const ctx = createCtx({})
167
- mockOpts = {
168
- allowNoTenant: true,
169
- excludeStrategies: [
170
- TenantResolutionStrategy.QUERY,
171
- TenantResolutionStrategy.SUBDOMAIN,
172
- TenantResolutionStrategy.PATH,
173
- ],
174
- }
175
- expect(getTenantIDFromCtx(ctx, mockOpts)).toBeUndefined()
176
- })
177
- })
178
-
179
- it("returns the default tenant ID when isMultiTenant() returns false", () => {
180
- mockedIsMultiTenant.mockImplementation(() => false)
181
- const ctx = createCtx({})
182
- expect(getTenantIDFromCtx(ctx, mockOpts)).toEqual("default")
183
- })
184
- })
@@ -1 +0,0 @@
1
- export * from "./timers"
@@ -1,22 +0,0 @@
1
- let intervals: NodeJS.Timeout[] = []
2
-
3
- export function set(callback: () => any, period: number) {
4
- const interval = setInterval(callback, period)
5
- intervals.push(interval)
6
- return interval
7
- }
8
-
9
- export function clear(interval: NodeJS.Timeout) {
10
- const idx = intervals.indexOf(interval)
11
- if (idx !== -1) {
12
- intervals.splice(idx, 1)
13
- }
14
- clearInterval(interval)
15
- }
16
-
17
- export function cleanup() {
18
- for (let interval of intervals) {
19
- clearInterval(interval)
20
- }
21
- intervals = []
22
- }