@budibase/backend-core 3.2.5 → 3.2.7

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 (276) hide show
  1. package/dist/index.js +7 -1
  2. package/dist/index.js.map +2 -2
  3. package/dist/index.js.meta.json +1 -1
  4. package/dist/package.json +11 -4
  5. package/dist/plugins.js.meta.json +1 -1
  6. package/dist/src/environment.d.ts +1 -0
  7. package/dist/src/environment.js +6 -1
  8. package/dist/src/environment.js.map +1 -1
  9. package/package.json +11 -4
  10. package/src/accounts/accounts.ts +0 -82
  11. package/src/accounts/api.ts +0 -59
  12. package/src/accounts/index.ts +0 -1
  13. package/src/auth/auth.ts +0 -210
  14. package/src/auth/index.ts +0 -1
  15. package/src/auth/tests/auth.spec.ts +0 -14
  16. package/src/blacklist/blacklist.ts +0 -54
  17. package/src/blacklist/index.ts +0 -1
  18. package/src/blacklist/tests/blacklist.spec.ts +0 -46
  19. package/src/cache/appMetadata.ts +0 -88
  20. package/src/cache/base/index.ts +0 -150
  21. package/src/cache/docWritethrough.ts +0 -105
  22. package/src/cache/generic.ts +0 -33
  23. package/src/cache/index.ts +0 -8
  24. package/src/cache/invite.ts +0 -86
  25. package/src/cache/passwordReset.ts +0 -49
  26. package/src/cache/tests/docWritethrough.spec.ts +0 -296
  27. package/src/cache/tests/user.spec.ts +0 -145
  28. package/src/cache/tests/writethrough.spec.ts +0 -139
  29. package/src/cache/user.ts +0 -154
  30. package/src/cache/writethrough.ts +0 -133
  31. package/src/configs/configs.ts +0 -263
  32. package/src/configs/index.ts +0 -1
  33. package/src/configs/tests/configs.spec.ts +0 -184
  34. package/src/constants/db.ts +0 -75
  35. package/src/constants/index.ts +0 -2
  36. package/src/constants/misc.ts +0 -36
  37. package/src/context/Context.ts +0 -14
  38. package/src/context/identity.ts +0 -58
  39. package/src/context/index.ts +0 -3
  40. package/src/context/mainContext.ts +0 -422
  41. package/src/context/tests/index.spec.ts +0 -255
  42. package/src/context/types.ts +0 -26
  43. package/src/db/Replication.ts +0 -94
  44. package/src/db/couch/DatabaseImpl.ts +0 -511
  45. package/src/db/couch/connections.ts +0 -89
  46. package/src/db/couch/index.ts +0 -4
  47. package/src/db/couch/pouchDB.ts +0 -97
  48. package/src/db/couch/pouchDump.ts +0 -0
  49. package/src/db/couch/tests/DatabaseImpl.spec.ts +0 -118
  50. package/src/db/couch/utils.ts +0 -55
  51. package/src/db/db.ts +0 -34
  52. package/src/db/errors.ts +0 -14
  53. package/src/db/index.ts +0 -12
  54. package/src/db/instrumentation.ts +0 -199
  55. package/src/db/lucene.ts +0 -721
  56. package/src/db/searchIndexes/index.ts +0 -1
  57. package/src/db/searchIndexes/searchIndexes.ts +0 -62
  58. package/src/db/tests/DatabaseImpl.spec.ts +0 -55
  59. package/src/db/tests/connections.spec.ts +0 -22
  60. package/src/db/tests/index.spec.ts +0 -32
  61. package/src/db/tests/lucene.spec.ts +0 -400
  62. package/src/db/tests/pouch.spec.js +0 -62
  63. package/src/db/tests/utils.spec.ts +0 -63
  64. package/src/db/utils.ts +0 -208
  65. package/src/db/views.ts +0 -245
  66. package/src/docIds/conversions.ts +0 -60
  67. package/src/docIds/ids.ts +0 -126
  68. package/src/docIds/index.ts +0 -2
  69. package/src/docIds/newid.ts +0 -5
  70. package/src/docIds/params.ts +0 -189
  71. package/src/docUpdates/index.ts +0 -24
  72. package/src/environment.ts +0 -293
  73. package/src/errors/errors.ts +0 -119
  74. package/src/errors/index.ts +0 -1
  75. package/src/events/analytics.ts +0 -6
  76. package/src/events/asyncEvents/index.ts +0 -2
  77. package/src/events/asyncEvents/publisher.ts +0 -12
  78. package/src/events/asyncEvents/queue.ts +0 -22
  79. package/src/events/backfill.ts +0 -183
  80. package/src/events/documentId.ts +0 -56
  81. package/src/events/events.ts +0 -47
  82. package/src/events/identification.ts +0 -311
  83. package/src/events/index.ts +0 -15
  84. package/src/events/processors/AnalyticsProcessor.ts +0 -64
  85. package/src/events/processors/AuditLogsProcessor.ts +0 -92
  86. package/src/events/processors/LoggingProcessor.ts +0 -36
  87. package/src/events/processors/Processors.ts +0 -52
  88. package/src/events/processors/async/DocumentUpdateProcessor.ts +0 -38
  89. package/src/events/processors/index.ts +0 -19
  90. package/src/events/processors/posthog/PosthogProcessor.ts +0 -118
  91. package/src/events/processors/posthog/index.ts +0 -3
  92. package/src/events/processors/posthog/rateLimiting.ts +0 -106
  93. package/src/events/processors/posthog/tests/PosthogProcessor.spec.ts +0 -164
  94. package/src/events/processors/types.ts +0 -1
  95. package/src/events/publishers/account.ts +0 -41
  96. package/src/events/publishers/ai.ts +0 -21
  97. package/src/events/publishers/app.ts +0 -168
  98. package/src/events/publishers/auditLog.ts +0 -26
  99. package/src/events/publishers/auth.ts +0 -73
  100. package/src/events/publishers/automation.ts +0 -110
  101. package/src/events/publishers/backfill.ts +0 -74
  102. package/src/events/publishers/backup.ts +0 -42
  103. package/src/events/publishers/datasource.ts +0 -48
  104. package/src/events/publishers/email.ts +0 -17
  105. package/src/events/publishers/environmentVariable.ts +0 -38
  106. package/src/events/publishers/group.ts +0 -99
  107. package/src/events/publishers/index.ts +0 -25
  108. package/src/events/publishers/installation.ts +0 -38
  109. package/src/events/publishers/layout.ts +0 -26
  110. package/src/events/publishers/license.ts +0 -84
  111. package/src/events/publishers/org.ts +0 -37
  112. package/src/events/publishers/plugin.ts +0 -47
  113. package/src/events/publishers/query.ts +0 -89
  114. package/src/events/publishers/role.ts +0 -62
  115. package/src/events/publishers/rows.ts +0 -29
  116. package/src/events/publishers/screen.ts +0 -36
  117. package/src/events/publishers/serve.ts +0 -43
  118. package/src/events/publishers/table.ts +0 -70
  119. package/src/events/publishers/user.ts +0 -202
  120. package/src/events/publishers/view.ts +0 -107
  121. package/src/features/features.ts +0 -277
  122. package/src/features/index.ts +0 -2
  123. package/src/features/tests/features.spec.ts +0 -267
  124. package/src/features/tests/utils.ts +0 -64
  125. package/src/helpers.ts +0 -9
  126. package/src/index.ts +0 -59
  127. package/src/installation.ts +0 -115
  128. package/src/logging/alerts.ts +0 -26
  129. package/src/logging/correlation/correlation.ts +0 -15
  130. package/src/logging/correlation/index.ts +0 -1
  131. package/src/logging/correlation/middleware.ts +0 -18
  132. package/src/logging/index.ts +0 -4
  133. package/src/logging/pino/logger.ts +0 -239
  134. package/src/logging/pino/middleware.ts +0 -48
  135. package/src/logging/system.ts +0 -81
  136. package/src/logging/tests/system.spec.ts +0 -61
  137. package/src/middleware/adminOnly.ts +0 -9
  138. package/src/middleware/auditLog.ts +0 -6
  139. package/src/middleware/authenticated.ts +0 -247
  140. package/src/middleware/builderOnly.ts +0 -21
  141. package/src/middleware/builderOrAdmin.ts +0 -21
  142. package/src/middleware/contentSecurityPolicy.ts +0 -113
  143. package/src/middleware/csrf.ts +0 -81
  144. package/src/middleware/errorHandling.ts +0 -43
  145. package/src/middleware/index.ts +0 -24
  146. package/src/middleware/internalApi.ts +0 -23
  147. package/src/middleware/ip.ts +0 -12
  148. package/src/middleware/joi-validator.ts +0 -58
  149. package/src/middleware/matchers.ts +0 -39
  150. package/src/middleware/passport/datasource/google.ts +0 -102
  151. package/src/middleware/passport/local.ts +0 -54
  152. package/src/middleware/passport/sso/google.ts +0 -77
  153. package/src/middleware/passport/sso/oidc.ts +0 -152
  154. package/src/middleware/passport/sso/sso.ts +0 -138
  155. package/src/middleware/passport/sso/tests/google.spec.ts +0 -68
  156. package/src/middleware/passport/sso/tests/oidc.spec.ts +0 -144
  157. package/src/middleware/passport/sso/tests/sso.spec.ts +0 -197
  158. package/src/middleware/passport/utils.ts +0 -38
  159. package/src/middleware/querystringToBody.ts +0 -28
  160. package/src/middleware/tenancy.ts +0 -36
  161. package/src/middleware/tests/builder.spec.ts +0 -181
  162. package/src/middleware/tests/contentSecurityPolicy.spec.ts +0 -75
  163. package/src/middleware/tests/matchers.spec.ts +0 -100
  164. package/src/migrations/definitions.ts +0 -40
  165. package/src/migrations/index.ts +0 -2
  166. package/src/migrations/migrations.ts +0 -186
  167. package/src/migrations/tests/__snapshots__/migrations.spec.ts.snap +0 -11
  168. package/src/migrations/tests/migrations.spec.ts +0 -64
  169. package/src/objectStore/buckets/app.ts +0 -53
  170. package/src/objectStore/buckets/global.ts +0 -29
  171. package/src/objectStore/buckets/index.ts +0 -3
  172. package/src/objectStore/buckets/plugins.ts +0 -71
  173. package/src/objectStore/buckets/tests/app.spec.ts +0 -161
  174. package/src/objectStore/buckets/tests/global.spec.ts +0 -74
  175. package/src/objectStore/buckets/tests/plugins.spec.ts +0 -111
  176. package/src/objectStore/cloudfront.ts +0 -41
  177. package/src/objectStore/index.ts +0 -3
  178. package/src/objectStore/objectStore.ts +0 -585
  179. package/src/objectStore/utils.ts +0 -113
  180. package/src/platform/index.ts +0 -3
  181. package/src/platform/platformDb.ts +0 -6
  182. package/src/platform/tenants.ts +0 -101
  183. package/src/platform/tests/tenants.spec.ts +0 -26
  184. package/src/platform/users.ts +0 -129
  185. package/src/plugin/index.ts +0 -1
  186. package/src/plugin/tests/validation.spec.ts +0 -209
  187. package/src/plugin/utils.ts +0 -175
  188. package/src/queue/constants.ts +0 -8
  189. package/src/queue/inMemoryQueue.ts +0 -189
  190. package/src/queue/index.ts +0 -2
  191. package/src/queue/listeners.ts +0 -199
  192. package/src/queue/queue.ts +0 -84
  193. package/src/redis/index.ts +0 -6
  194. package/src/redis/init.ts +0 -118
  195. package/src/redis/redis.ts +0 -358
  196. package/src/redis/redlockImpl.ts +0 -155
  197. package/src/redis/tests/redis.spec.ts +0 -207
  198. package/src/redis/tests/redlockImpl.spec.ts +0 -105
  199. package/src/redis/utils.ts +0 -128
  200. package/src/security/auth.ts +0 -24
  201. package/src/security/encryption.ts +0 -185
  202. package/src/security/index.ts +0 -1
  203. package/src/security/permissions.ts +0 -166
  204. package/src/security/roles.ts +0 -655
  205. package/src/security/secrets.ts +0 -20
  206. package/src/security/sessions.ts +0 -123
  207. package/src/security/tests/auth.spec.ts +0 -45
  208. package/src/security/tests/encryption.spec.ts +0 -31
  209. package/src/security/tests/permissions.spec.ts +0 -146
  210. package/src/security/tests/secrets.spec.ts +0 -35
  211. package/src/security/tests/sessions.spec.ts +0 -12
  212. package/src/sql/designDoc.ts +0 -17
  213. package/src/sql/index.ts +0 -5
  214. package/src/sql/sql.ts +0 -1854
  215. package/src/sql/sqlTable.ts +0 -319
  216. package/src/sql/utils.ts +0 -193
  217. package/src/tenancy/db.ts +0 -6
  218. package/src/tenancy/index.ts +0 -2
  219. package/src/tenancy/tenancy.ts +0 -148
  220. package/src/tenancy/tests/tenancy.spec.ts +0 -184
  221. package/src/timers/index.ts +0 -1
  222. package/src/timers/timers.ts +0 -22
  223. package/src/users/db.ts +0 -582
  224. package/src/users/events.ts +0 -176
  225. package/src/users/index.ts +0 -4
  226. package/src/users/lookup.ts +0 -99
  227. package/src/users/test/db.spec.ts +0 -188
  228. package/src/users/test/utils.spec.ts +0 -67
  229. package/src/users/users.ts +0 -353
  230. package/src/users/utils.ts +0 -81
  231. package/src/utils/Duration.ts +0 -56
  232. package/src/utils/hashing.ts +0 -15
  233. package/src/utils/index.ts +0 -4
  234. package/src/utils/stringUtils.ts +0 -8
  235. package/src/utils/tests/Duration.spec.ts +0 -19
  236. package/src/utils/tests/utils.spec.ts +0 -204
  237. package/src/utils/utils.ts +0 -249
  238. package/tests/core/logging.ts +0 -34
  239. package/tests/core/users/users.spec.js +0 -53
  240. package/tests/core/utilities/index.ts +0 -7
  241. package/tests/core/utilities/jestUtils.ts +0 -33
  242. package/tests/core/utilities/mocks/alerts.ts +0 -4
  243. package/tests/core/utilities/mocks/date.ts +0 -3
  244. package/tests/core/utilities/mocks/events.ts +0 -132
  245. package/tests/core/utilities/mocks/index.ts +0 -9
  246. package/tests/core/utilities/mocks/licenses.ts +0 -119
  247. package/tests/core/utilities/queue.ts +0 -9
  248. package/tests/core/utilities/structures/Chance.ts +0 -20
  249. package/tests/core/utilities/structures/accounts.ts +0 -80
  250. package/tests/core/utilities/structures/apps.ts +0 -21
  251. package/tests/core/utilities/structures/common.ts +0 -7
  252. package/tests/core/utilities/structures/db.ts +0 -12
  253. package/tests/core/utilities/structures/documents/index.ts +0 -1
  254. package/tests/core/utilities/structures/documents/platform/index.ts +0 -1
  255. package/tests/core/utilities/structures/documents/platform/installation.ts +0 -12
  256. package/tests/core/utilities/structures/generator.ts +0 -3
  257. package/tests/core/utilities/structures/index.ts +0 -15
  258. package/tests/core/utilities/structures/koa.ts +0 -16
  259. package/tests/core/utilities/structures/licenses.ts +0 -190
  260. package/tests/core/utilities/structures/plugins.ts +0 -19
  261. package/tests/core/utilities/structures/quotas.ts +0 -72
  262. package/tests/core/utilities/structures/scim.ts +0 -80
  263. package/tests/core/utilities/structures/sso.ts +0 -118
  264. package/tests/core/utilities/structures/tenants.ts +0 -5
  265. package/tests/core/utilities/structures/userGroups.ts +0 -10
  266. package/tests/core/utilities/structures/users.ts +0 -89
  267. package/tests/core/utilities/testContainerUtils.ts +0 -165
  268. package/tests/core/utilities/utils/index.ts +0 -2
  269. package/tests/core/utilities/utils/queue.ts +0 -27
  270. package/tests/core/utilities/utils/time.ts +0 -3
  271. package/tests/extra/DBTestConfiguration.ts +0 -36
  272. package/tests/extra/index.ts +0 -2
  273. package/tests/extra/testEnv.ts +0 -95
  274. package/tests/index.ts +0 -2
  275. package/tests/jestEnv.ts +0 -10
  276. 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
- }