@budibase/backend-core 2.9.16 → 2.9.18
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/dist/index.js +12544 -0
- package/dist/index.js.map +7 -0
- package/dist/index.js.meta.json +1 -0
- package/dist/package.json +5 -5
- package/dist/plugins.js +288 -16
- package/dist/plugins.js.map +7 -1
- package/dist/plugins.js.meta.json +1 -0
- package/dist/tests.js +8476 -0
- package/dist/tests.js.map +7 -0
- package/dist/tests.js.meta.json +1 -0
- package/dist/tsconfig.build.tsbuildinfo +1 -1
- package/package.json +5 -5
- package/scripts/build.js +6 -0
- package/tsconfig.build.json +5 -1
- package/tsconfig.json +0 -8
- package/dist/jest.config.js +0 -25
- package/dist/jest.config.js.map +0 -1
- package/dist/plugins.d.ts +0 -1
- package/dist/src/accounts/accounts.js +0 -83
- package/dist/src/accounts/accounts.js.map +0 -1
- package/dist/src/accounts/api.js +0 -92
- package/dist/src/accounts/api.js.map +0 -1
- package/dist/src/accounts/index.js +0 -18
- package/dist/src/accounts/index.js.map +0 -1
- package/dist/src/auth/auth.js +0 -189
- package/dist/src/auth/auth.js.map +0 -1
- package/dist/src/auth/index.js +0 -18
- package/dist/src/auth/index.js.map +0 -1
- package/dist/src/blacklist/blacklist.js +0 -76
- package/dist/src/blacklist/blacklist.js.map +0 -1
- package/dist/src/blacklist/index.js +0 -18
- package/dist/src/blacklist/index.js.map +0 -1
- package/dist/src/cache/appMetadata.js +0 -96
- package/dist/src/cache/appMetadata.js.map +0 -1
- package/dist/src/cache/base/index.js +0 -120
- package/dist/src/cache/base/index.js.map +0 -1
- package/dist/src/cache/generic.js +0 -31
- package/dist/src/cache/generic.js.map +0 -1
- package/dist/src/cache/index.js +0 -35
- package/dist/src/cache/index.js.map +0 -1
- package/dist/src/cache/user.js +0 -108
- package/dist/src/cache/user.js.map +0 -1
- package/dist/src/cache/writethrough.js +0 -159
- package/dist/src/cache/writethrough.js.map +0 -1
- package/dist/src/configs/configs.js +0 -278
- package/dist/src/configs/configs.js.map +0 -1
- package/dist/src/configs/index.js +0 -18
- package/dist/src/configs/index.js.map +0 -1
- package/dist/src/constants/db.js +0 -67
- package/dist/src/constants/db.js.map +0 -1
- package/dist/src/constants/index.js +0 -19
- package/dist/src/constants/index.js.map +0 -1
- package/dist/src/constants/misc.js +0 -54
- package/dist/src/constants/misc.js.map +0 -1
- package/dist/src/context/Context.js +0 -14
- package/dist/src/context/Context.js.map +0 -1
- package/dist/src/context/identity.js +0 -72
- package/dist/src/context/identity.js.map +0 -1
- package/dist/src/context/index.js +0 -34
- package/dist/src/context/index.js.map +0 -1
- package/dist/src/context/mainContext.js +0 -331
- package/dist/src/context/mainContext.js.map +0 -1
- package/dist/src/context/types.js +0 -3
- package/dist/src/context/types.js.map +0 -1
- package/dist/src/db/Replication.js +0 -85
- package/dist/src/db/Replication.js.map +0 -1
- package/dist/src/db/constants.js +0 -13
- package/dist/src/db/constants.js.map +0 -1
- package/dist/src/db/couch/DatabaseImpl.js +0 -248
- package/dist/src/db/couch/DatabaseImpl.js.map +0 -1
- package/dist/src/db/couch/connections.js +0 -88
- package/dist/src/db/couch/connections.js.map +0 -1
- package/dist/src/db/couch/index.js +0 -27
- package/dist/src/db/couch/index.js.map +0 -1
- package/dist/src/db/couch/pouchDB.js +0 -108
- package/dist/src/db/couch/pouchDB.js.map +0 -1
- package/dist/src/db/couch/pouchDump.js +0 -2
- package/dist/src/db/couch/pouchDump.js.map +0 -1
- package/dist/src/db/couch/utils.js +0 -55
- package/dist/src/db/couch/utils.js.map +0 -1
- package/dist/src/db/db.js +0 -59
- package/dist/src/db/db.js.map +0 -1
- package/dist/src/db/errors.js +0 -22
- package/dist/src/db/errors.js.map +0 -1
- package/dist/src/db/index.js +0 -48
- package/dist/src/db/index.js.map +0 -1
- package/dist/src/db/lucene.js +0 -650
- package/dist/src/db/lucene.js.map +0 -1
- package/dist/src/db/searchIndexes/index.js +0 -18
- package/dist/src/db/searchIndexes/index.js.map +0 -1
- package/dist/src/db/searchIndexes/searchIndexes.js +0 -77
- package/dist/src/db/searchIndexes/searchIndexes.js.map +0 -1
- package/dist/src/db/utils.js +0 -213
- package/dist/src/db/utils.js.map +0 -1
- package/dist/src/db/views.js +0 -219
- package/dist/src/db/views.js.map +0 -1
- package/dist/src/docIds/conversions.js +0 -62
- package/dist/src/docIds/conversions.js.map +0 -1
- package/dist/src/docIds/ids.js +0 -112
- package/dist/src/docIds/ids.js.map +0 -1
- package/dist/src/docIds/index.js +0 -19
- package/dist/src/docIds/index.js.map +0 -1
- package/dist/src/docIds/newid.js +0 -9
- package/dist/src/docIds/newid.js.map +0 -1
- package/dist/src/docIds/params.js +0 -138
- package/dist/src/docIds/params.js.map +0 -1
- package/dist/src/docUpdates/index.js +0 -36
- package/dist/src/docUpdates/index.js.map +0 -1
- package/dist/src/environment.js +0 -110
- package/dist/src/environment.js.map +0 -1
- package/dist/src/errors/errors.js +0 -97
- package/dist/src/errors/errors.js.map +0 -1
- package/dist/src/errors/index.js +0 -18
- package/dist/src/errors/index.js.map +0 -1
- package/dist/src/events/analytics.js +0 -42
- package/dist/src/events/analytics.js.map +0 -1
- package/dist/src/events/asyncEvents/index.js +0 -19
- package/dist/src/events/asyncEvents/index.js.map +0 -1
- package/dist/src/events/asyncEvents/publisher.js +0 -27
- package/dist/src/events/asyncEvents/publisher.js.map +0 -1
- package/dist/src/events/asyncEvents/queue.js +0 -26
- package/dist/src/events/asyncEvents/queue.js.map +0 -1
- package/dist/src/events/backfill.js +0 -179
- package/dist/src/events/backfill.js.map +0 -1
- package/dist/src/events/documentId.js +0 -28
- package/dist/src/events/documentId.js.map +0 -1
- package/dist/src/events/events.js +0 -73
- package/dist/src/events/events.js.map +0 -1
- package/dist/src/events/identification.js +0 -300
- package/dist/src/events/identification.js.map +0 -1
- package/dist/src/events/index.js +0 -47
- package/dist/src/events/index.js.map +0 -1
- package/dist/src/events/processors/AnalyticsProcessor.js +0 -93
- package/dist/src/events/processors/AnalyticsProcessor.js.map +0 -1
- package/dist/src/events/processors/AuditLogsProcessor.js +0 -86
- package/dist/src/events/processors/AuditLogsProcessor.js.map +0 -1
- package/dist/src/events/processors/LoggingProcessor.js +0 -47
- package/dist/src/events/processors/LoggingProcessor.js.map +0 -1
- package/dist/src/events/processors/Processors.js +0 -52
- package/dist/src/events/processors/Processors.js.map +0 -1
- package/dist/src/events/processors/async/DocumentUpdateProcessor.js +0 -44
- package/dist/src/events/processors/async/DocumentUpdateProcessor.js.map +0 -1
- package/dist/src/events/processors/index.js +0 -23
- package/dist/src/events/processors/index.js.map +0 -1
- package/dist/src/events/processors/posthog/PosthogProcessor.js +0 -139
- package/dist/src/events/processors/posthog/PosthogProcessor.js.map +0 -1
- package/dist/src/events/processors/posthog/index.js +0 -8
- package/dist/src/events/processors/posthog/index.js.map +0 -1
- package/dist/src/events/processors/posthog/rateLimiting.js +0 -119
- package/dist/src/events/processors/posthog/rateLimiting.js.map +0 -1
- package/dist/src/events/processors/types.js +0 -3
- package/dist/src/events/processors/types.js.map +0 -1
- package/dist/src/events/publishers/account.js +0 -43
- package/dist/src/events/publishers/account.js.map +0 -1
- package/dist/src/events/publishers/app.js +0 -153
- package/dist/src/events/publishers/app.js.map +0 -1
- package/dist/src/events/publishers/auditLog.js +0 -34
- package/dist/src/events/publishers/auditLog.js.map +0 -1
- package/dist/src/events/publishers/auth.js +0 -80
- package/dist/src/events/publishers/auth.js.map +0 -1
- package/dist/src/events/publishers/automation.js +0 -117
- package/dist/src/events/publishers/automation.js.map +0 -1
- package/dist/src/events/publishers/backfill.js +0 -85
- package/dist/src/events/publishers/backfill.js.map +0 -1
- package/dist/src/events/publishers/backup.js +0 -41
- package/dist/src/events/publishers/backup.js.map +0 -1
- package/dist/src/events/publishers/datasource.js +0 -54
- package/dist/src/events/publishers/datasource.js.map +0 -1
- package/dist/src/events/publishers/email.js +0 -30
- package/dist/src/events/publishers/email.js.map +0 -1
- package/dist/src/events/publishers/environmentVariable.js +0 -44
- package/dist/src/events/publishers/environmentVariable.js.map +0 -1
- package/dist/src/events/publishers/group.js +0 -107
- package/dist/src/events/publishers/group.js.map +0 -1
- package/dist/src/events/publishers/index.js +0 -55
- package/dist/src/events/publishers/index.js.map +0 -1
- package/dist/src/events/publishers/installation.js +0 -52
- package/dist/src/events/publishers/installation.js.map +0 -1
- package/dist/src/events/publishers/layout.js +0 -34
- package/dist/src/events/publishers/layout.js.map +0 -1
- package/dist/src/events/publishers/license.js +0 -77
- package/dist/src/events/publishers/license.js.map +0 -1
- package/dist/src/events/publishers/org.js +0 -52
- package/dist/src/events/publishers/org.js.map +0 -1
- package/dist/src/events/publishers/plugin.js +0 -55
- package/dist/src/events/publishers/plugin.js.map +0 -1
- package/dist/src/events/publishers/query.js +0 -74
- package/dist/src/events/publishers/query.js.map +0 -1
- package/dist/src/events/publishers/role.js +0 -69
- package/dist/src/events/publishers/role.js.map +0 -1
- package/dist/src/events/publishers/rows.js +0 -32
- package/dist/src/events/publishers/rows.js.map +0 -1
- package/dist/src/events/publishers/screen.js +0 -46
- package/dist/src/events/publishers/screen.js.map +0 -1
- package/dist/src/events/publishers/serve.js +0 -47
- package/dist/src/events/publishers/serve.js.map +0 -1
- package/dist/src/events/publishers/table.js +0 -77
- package/dist/src/events/publishers/table.js.map +0 -1
- package/dist/src/events/publishers/user.js +0 -202
- package/dist/src/events/publishers/user.js.map +0 -1
- package/dist/src/events/publishers/view.js +0 -111
- package/dist/src/events/publishers/view.js.map +0 -1
- package/dist/src/featureFlags/index.js +0 -96
- package/dist/src/featureFlags/index.js.map +0 -1
- package/dist/src/helpers.js +0 -14
- package/dist/src/helpers.js.map +0 -1
- package/dist/src/index.js +0 -82
- package/dist/src/index.js.map +0 -1
- package/dist/src/installation.js +0 -138
- package/dist/src/installation.js.map +0 -1
- package/dist/src/logging/alerts.js +0 -24
- package/dist/src/logging/alerts.js.map +0 -1
- package/dist/src/logging/correlation/correlation.js +0 -17
- package/dist/src/logging/correlation/correlation.js.map +0 -1
- package/dist/src/logging/correlation/index.js +0 -18
- package/dist/src/logging/correlation/index.js.map +0 -1
- package/dist/src/logging/correlation/middleware.js +0 -17
- package/dist/src/logging/correlation/middleware.js.map +0 -1
- package/dist/src/logging/index.js +0 -35
- package/dist/src/logging/index.js.map +0 -1
- package/dist/src/logging/pino/logger.js +0 -218
- package/dist/src/logging/pino/logger.js.map +0 -1
- package/dist/src/logging/pino/middleware.js +0 -47
- package/dist/src/logging/pino/middleware.js.map +0 -1
- package/dist/src/logging/system.js +0 -101
- package/dist/src/logging/system.js.map +0 -1
- package/dist/src/middleware/adminOnly.js +0 -19
- package/dist/src/middleware/adminOnly.js.map +0 -1
- package/dist/src/middleware/auditLog.js +0 -16
- package/dist/src/middleware/auditLog.js.map +0 -1
- package/dist/src/middleware/authenticated.js +0 -204
- package/dist/src/middleware/authenticated.js.map +0 -1
- package/dist/src/middleware/builderOnly.js +0 -33
- package/dist/src/middleware/builderOnly.js.map +0 -1
- package/dist/src/middleware/builderOrAdmin.js +0 -33
- package/dist/src/middleware/builderOrAdmin.js.map +0 -1
- package/dist/src/middleware/csrf.js +0 -81
- package/dist/src/middleware/csrf.js.map +0 -1
- package/dist/src/middleware/errorHandling.js +0 -64
- package/dist/src/middleware/errorHandling.js.map +0 -1
- package/dist/src/middleware/index.js +0 -65
- package/dist/src/middleware/index.js.map +0 -1
- package/dist/src/middleware/internalApi.js +0 -30
- package/dist/src/middleware/internalApi.js.map +0 -1
- package/dist/src/middleware/joi-validator.js +0 -47
- package/dist/src/middleware/joi-validator.js.map +0 -1
- package/dist/src/middleware/matchers.js +0 -43
- package/dist/src/middleware/matchers.js.map +0 -1
- package/dist/src/middleware/passport/datasource/google.js +0 -95
- package/dist/src/middleware/passport/datasource/google.js.map +0 -1
- package/dist/src/middleware/passport/local.js +0 -81
- package/dist/src/middleware/passport/local.js.map +0 -1
- package/dist/src/middleware/passport/sso/google.js +0 -90
- package/dist/src/middleware/passport/sso/google.js.map +0 -1
- package/dist/src/middleware/passport/sso/oidc.js +0 -151
- package/dist/src/middleware/passport/sso/oidc.js.map +0 -1
- package/dist/src/middleware/passport/sso/sso.js +0 -165
- package/dist/src/middleware/passport/sso/sso.js.map +0 -1
- package/dist/src/middleware/passport/utils.js +0 -66
- package/dist/src/middleware/passport/utils.js.map +0 -1
- package/dist/src/middleware/querystringToBody.js +0 -29
- package/dist/src/middleware/querystringToBody.js.map +0 -1
- package/dist/src/middleware/tenancy.js +0 -37
- package/dist/src/middleware/tenancy.js.map +0 -1
- package/dist/src/migrations/definitions.js +0 -39
- package/dist/src/migrations/definitions.js.map +0 -1
- package/dist/src/migrations/index.js +0 -19
- package/dist/src/migrations/index.js.map +0 -1
- package/dist/src/migrations/migrations.js +0 -198
- package/dist/src/migrations/migrations.js.map +0 -1
- package/dist/src/objectStore/buckets/app.js +0 -73
- package/dist/src/objectStore/buckets/app.js.map +0 -1
- package/dist/src/objectStore/buckets/global.js +0 -58
- package/dist/src/objectStore/buckets/global.js.map +0 -1
- package/dist/src/objectStore/buckets/index.js +0 -20
- package/dist/src/objectStore/buckets/index.js.map +0 -1
- package/dist/src/objectStore/buckets/plugins.js +0 -95
- package/dist/src/objectStore/buckets/plugins.js.map +0 -1
- package/dist/src/objectStore/cloudfront.js +0 -40
- package/dist/src/objectStore/cloudfront.js.map +0 -1
- package/dist/src/objectStore/index.js +0 -20
- package/dist/src/objectStore/index.js.map +0 -1
- package/dist/src/objectStore/objectStore.js +0 -382
- package/dist/src/objectStore/objectStore.js.map +0 -1
- package/dist/src/objectStore/utils.js +0 -32
- package/dist/src/objectStore/utils.js.map +0 -1
- package/dist/src/platform/index.js +0 -33
- package/dist/src/platform/index.js.map +0 -1
- package/dist/src/platform/platformDb.js +0 -10
- package/dist/src/platform/platformDb.js.map +0 -1
- package/dist/src/platform/tenants.js +0 -139
- package/dist/src/platform/tenants.js.map +0 -1
- package/dist/src/platform/users.js +0 -96
- package/dist/src/platform/users.js.map +0 -1
- package/dist/src/plugin/index.js +0 -18
- package/dist/src/plugin/index.js.map +0 -1
- package/dist/src/plugin/utils.js +0 -145
- package/dist/src/plugin/utils.js.map +0 -1
- package/dist/src/queue/constants.js +0 -11
- package/dist/src/queue/constants.js.map +0 -1
- package/dist/src/queue/inMemoryQueue.js +0 -145
- package/dist/src/queue/inMemoryQueue.js.map +0 -1
- package/dist/src/queue/index.js +0 -19
- package/dist/src/queue/index.js.map +0 -1
- package/dist/src/queue/listeners.js +0 -186
- package/dist/src/queue/listeners.js.map +0 -1
- package/dist/src/queue/queue.js +0 -92
- package/dist/src/queue/queue.js.map +0 -1
- package/dist/src/redis/index.js +0 -37
- package/dist/src/redis/index.js.map +0 -1
- package/dist/src/redis/init.js +0 -138
- package/dist/src/redis/init.js.map +0 -1
- package/dist/src/redis/redis.js +0 -335
- package/dist/src/redis/redis.js.map +0 -1
- package/dist/src/redis/redlockImpl.js +0 -162
- package/dist/src/redis/redlockImpl.js.map +0 -1
- package/dist/src/redis/utils.js +0 -123
- package/dist/src/redis/utils.js.map +0 -1
- package/dist/src/security/encryption.js +0 -163
- package/dist/src/security/encryption.js.map +0 -1
- package/dist/src/security/permissions.js +0 -151
- package/dist/src/security/permissions.js.map +0 -1
- package/dist/src/security/roles.js +0 -388
- package/dist/src/security/roles.js.map +0 -1
- package/dist/src/security/sessions.js +0 -121
- package/dist/src/security/sessions.js.map +0 -1
- package/dist/src/tenancy/db.js +0 -10
- package/dist/src/tenancy/db.js.map +0 -1
- package/dist/src/tenancy/index.js +0 -19
- package/dist/src/tenancy/index.js.map +0 -1
- package/dist/src/tenancy/tenancy.js +0 -116
- package/dist/src/tenancy/tenancy.js.map +0 -1
- package/dist/src/timers/index.js +0 -18
- package/dist/src/timers/index.js.map +0 -1
- package/dist/src/timers/timers.js +0 -26
- package/dist/src/timers/timers.js.map +0 -1
- package/dist/src/users/db.js +0 -407
- package/dist/src/users/db.js.map +0 -1
- package/dist/src/users/events.js +0 -169
- package/dist/src/users/events.js.map +0 -1
- package/dist/src/users/index.js +0 -23
- package/dist/src/users/index.js.map +0 -1
- package/dist/src/users/lookup.js +0 -112
- package/dist/src/users/lookup.js.map +0 -1
- package/dist/src/users/users.js +0 -261
- package/dist/src/users/users.js.map +0 -1
- package/dist/src/users/utils.js +0 -92
- package/dist/src/users/utils.js.map +0 -1
- package/dist/src/utils/hashing.js +0 -47
- package/dist/src/utils/hashing.js.map +0 -1
- package/dist/src/utils/index.js +0 -20
- package/dist/src/utils/index.js.map +0 -1
- package/dist/src/utils/stringUtils.js +0 -9
- package/dist/src/utils/stringUtils.js.map +0 -1
- package/dist/src/utils/utils.js +0 -247
- package/dist/src/utils/utils.js.map +0 -1
- package/dist/tests/core/logging.js +0 -33
- package/dist/tests/core/logging.js.map +0 -1
- package/dist/tests/core/utilities/index.js +0 -37
- package/dist/tests/core/utilities/index.js.map +0 -1
- package/dist/tests/core/utilities/jestUtils.js +0 -21
- package/dist/tests/core/utilities/jestUtils.js.map +0 -1
- package/dist/tests/core/utilities/mocks/alerts.js +0 -30
- package/dist/tests/core/utilities/mocks/alerts.js.map +0 -1
- package/dist/tests/core/utilities/mocks/date.js +0 -6
- package/dist/tests/core/utilities/mocks/date.js.map +0 -1
- package/dist/tests/core/utilities/mocks/events.js +0 -143
- package/dist/tests/core/utilities/mocks/events.js.map +0 -1
- package/dist/tests/core/utilities/mocks/fetch.js +0 -15
- package/dist/tests/core/utilities/mocks/fetch.js.map +0 -1
- package/dist/tests/core/utilities/mocks/index.js +0 -43
- package/dist/tests/core/utilities/mocks/index.js.map +0 -1
- package/dist/tests/core/utilities/mocks/licenses.js +0 -97
- package/dist/tests/core/utilities/mocks/licenses.js.map +0 -1
- package/dist/tests/core/utilities/mocks/posthog.js +0 -9
- package/dist/tests/core/utilities/mocks/posthog.js.map +0 -1
- package/dist/tests/core/utilities/structures/Chance.js +0 -21
- package/dist/tests/core/utilities/structures/Chance.js.map +0 -1
- package/dist/tests/core/utilities/structures/accounts.js +0 -78
- package/dist/tests/core/utilities/structures/accounts.js.map +0 -1
- package/dist/tests/core/utilities/structures/apps.js +0 -24
- package/dist/tests/core/utilities/structures/apps.js.map +0 -1
- package/dist/tests/core/utilities/structures/common.js +0 -11
- package/dist/tests/core/utilities/structures/common.js.map +0 -1
- package/dist/tests/core/utilities/structures/db.js +0 -16
- package/dist/tests/core/utilities/structures/db.js.map +0 -1
- package/dist/tests/core/utilities/structures/documents/index.js +0 -18
- package/dist/tests/core/utilities/structures/documents/index.js.map +0 -1
- package/dist/tests/core/utilities/structures/documents/platform/index.js +0 -28
- package/dist/tests/core/utilities/structures/documents/platform/index.js.map +0 -1
- package/dist/tests/core/utilities/structures/documents/platform/installation.js +0 -38
- package/dist/tests/core/utilities/structures/documents/platform/installation.js.map +0 -1
- package/dist/tests/core/utilities/structures/generator.js +0 -9
- package/dist/tests/core/utilities/structures/generator.js.map +0 -1
- package/dist/tests/core/utilities/structures/index.js +0 -46
- package/dist/tests/core/utilities/structures/index.js.map +0 -1
- package/dist/tests/core/utilities/structures/koa.js +0 -10
- package/dist/tests/core/utilities/structures/koa.js.map +0 -1
- package/dist/tests/core/utilities/structures/licenses.js +0 -140
- package/dist/tests/core/utilities/structures/licenses.js.map +0 -1
- package/dist/tests/core/utilities/structures/plugins.js +0 -23
- package/dist/tests/core/utilities/structures/plugins.js.map +0 -1
- package/dist/tests/core/utilities/structures/quotas.js +0 -71
- package/dist/tests/core/utilities/structures/quotas.js.map +0 -1
- package/dist/tests/core/utilities/structures/scim.js +0 -63
- package/dist/tests/core/utilities/structures/scim.js.map +0 -1
- package/dist/tests/core/utilities/structures/shared.js +0 -14
- package/dist/tests/core/utilities/structures/shared.js.map +0 -1
- package/dist/tests/core/utilities/structures/sso.js +0 -132
- package/dist/tests/core/utilities/structures/sso.js.map +0 -1
- package/dist/tests/core/utilities/structures/tenants.js +0 -9
- package/dist/tests/core/utilities/structures/tenants.js.map +0 -1
- package/dist/tests/core/utilities/structures/userGroups.js +0 -13
- package/dist/tests/core/utilities/structures/userGroups.js.map +0 -1
- package/dist/tests/core/utilities/structures/users.js +0 -48
- package/dist/tests/core/utilities/structures/users.js.map +0 -1
- package/dist/tests/core/utilities/testContainerUtils.js +0 -84
- package/dist/tests/core/utilities/testContainerUtils.js.map +0 -1
- package/dist/tests/core/utilities/utils/index.js +0 -28
- package/dist/tests/core/utilities/utils/index.js.map +0 -1
- package/dist/tests/core/utilities/utils/time.js +0 -8
- package/dist/tests/core/utilities/utils/time.js.map +0 -1
- package/dist/tests/extra/DBTestConfiguration.js +0 -55
- package/dist/tests/extra/DBTestConfiguration.js.map +0 -1
- package/dist/tests/extra/index.js +0 -33
- package/dist/tests/extra/index.js.map +0 -1
- package/dist/tests/extra/testEnv.js +0 -127
- package/dist/tests/extra/testEnv.js.map +0 -1
- package/dist/tests/index.js +0 -18
- package/dist/tests/index.js.map +0 -1
- package/dist/tests/jestEnv.js +0 -8
- package/dist/tests/jestEnv.js.map +0 -1
- package/dist/tests/jestSetup.js +0 -28
- package/dist/tests/jestSetup.js.map +0 -1
- package/plugins.ts +0 -1
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"system.js","sourceRoot":"","sources":["../../../src/logging/system.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,4CAAmB;AACnB,gDAAuB;AACvB,0DAA2C;AAE3C,iEAAgC;AAChC,gDAAgD;AAEhD,MAAM,YAAY,GAAG,cAAc,CAAA;AACnC,MAAM,2BAA2B,GAAG,2BAA2B,CAAA;AAE/D,MAAM,QAAQ,GAAG,cAAI,CAAC,IAAI,CAAC,IAAA,6BAAe,GAAE,EAAE,YAAY,CAAC,CAAA;AAE3D,SAAS,WAAW,CAAC,QAAgB;IACnC,OAAO,cAAI,CAAC,IAAI,CAAC,QAAQ,EAAE,QAAQ,CAAC,CAAA;AACtC,CAAC;AAED,SAAgB,wBAAwB,CAAC,YAAoB;IAC3D,MAAM,KAAK,GAAG,iBAAiB,CAAA;IAC/B,MAAM,KAAK,GAAG,YAAY,aAAZ,YAAY,uBAAZ,YAAY,CAAE,KAAK,CAAC,KAAK,CAAC,CAAA;IACxC,IAAI,CAAC,KAAK,EAAE;QACV,OAAO,CAAC,IAAI,CAAC,0CAA0C,EAAE;YACvD,YAAY;SACb,CAAC,CAAA;QACF,OAAO,SAAS,CAAA;KACjB;IAED,MAAM,IAAI,GAAG,CAAC,KAAK,CAAC,CAAC,CAAC,CAAA;IACtB,MAAM,IAAI,GAAG,KAAK,CAAC,CAAC,CAAC,CAAA;IACrB,IAAI,IAAI,KAAK,CAAC,EAAE;QACd,QAAQ,IAAI,EAAE;YACZ,KAAK,GAAG;gBACN,OAAO,EAAE,IAAI,EAAE,GAAG,IAAI,GAAG,EAAE,iBAAiB,EAAE,CAAC,EAAE,CAAA;YACnD,KAAK,GAAG;gBACN,OAAO,EAAE,IAAI,EAAE,GAAG,CAAC,IAAI,GAAG,IAAI,CAAC,GAAG,CAAC,GAAG,EAAE,iBAAiB,EAAE,CAAC,EAAE,CAAA;YAChE,KAAK,GAAG;gBACN,OAAO,EAAE,IAAI,EAAE,GAAG,CAAC,IAAI,GAAG,IAAI,CAAC,GAAG,CAAC,GAAG,EAAE,iBAAiB,EAAE,CAAC,EAAE,CAAA;YAChE,KAAK,GAAG;gBACN,OAAO,EAAE,IAAI,EAAE,GAAG,CAAC,IAAI,GAAG,IAAI,CAAC,GAAG,CAAC,GAAG,EAAE,iBAAiB,EAAE,CAAC,EAAE,CAAA;YAChE;gBACE,OAAO,SAAS,CAAA;SACnB;KACF;IAED,IAAI,IAAI,GAAG,CAAC,KAAK,CAAC,EAAE;QAClB,OAAO,EAAE,IAAI,EAAE,GAAG,IAAI,GAAG,CAAC,GAAG,IAAI,EAAE,EAAE,iBAAiB,EAAE,CAAC,EAAE,CAAA;KAC5D;IAED,OAAO,EAAE,IAAI,EAAE,IAAI,IAAI,EAAE,EAAE,iBAAiB,EAAE,IAAI,GAAG,CAAC,EAAE,CAAA;AAC1D,CAAC;AAhCD,4DAgCC;AAED,SAAgB,oBAAoB;IAClC,MAAM,QAAQ,GAAG,wBAAwB,CAAC,qBAAG,CAAC,oBAAoB,CAAC,CAAA;IACnE,MAAM,OAAO,GAAG,GAAG,CAAC,YAAY,CAAC,YAAY,EAAE;QAC7C,0DAA0D;QAC1D,IAAI,EAAE,QAAQ,aAAR,QAAQ,uBAAR,QAAQ,CAAE,IAAI;QACpB,IAAI,EAAE,QAAQ;QACd,QAAQ,EAAE,CAAA,QAAQ,aAAR,QAAQ,uBAAR,QAAQ,CAAE,iBAAiB,KAAI,CAAC;QAC1C,SAAS,EAAE,IAAI;QACf,OAAO,EAAE,2BAA2B;QACpC,eAAe,EAAE,KAAK;KACvB,CAAC,CAAA;IAEF,OAAO,OAAO,CAAA;AAChB,CAAC;AAbD,oDAaC;AAED,SAAgB,gBAAgB;IAC9B,MAAM,OAAO,GAAG,EAAE,CAAA;IAClB,MAAM,WAAW,GAAG,WAAW,CAAC,2BAA2B,CAAC,CAAA;IAC5D,IAAI,YAAE,CAAC,UAAU,CAAC,WAAW,CAAC,EAAE;QAC9B,MAAM,WAAW,GAAG,YAAE,CAAC,YAAY,CAAC,WAAW,EAAE,OAAO,CAAC,CAAA;QACzD,MAAM,YAAY,GAAG,WAAW,CAAC,KAAK,CAAC,IAAI,CAAC,CAAA;QAC5C,KAAK,MAAM,WAAW,IAAI,YAAY,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE;YACrD,OAAO,CAAC,IAAI,CAAC,YAAE,CAAC,YAAY,CAAC,WAAW,CAAC,CAAC,CAAA;SAC3C;KACF;IAED,OAAO,CAAC,IAAI,CAAC,YAAE,CAAC,YAAY,CAAC,WAAW,CAAC,YAAY,CAAC,CAAC,CAAC,CAAA;IAExD,MAAM,eAAe,GAAG,MAAM,CAAC,MAAM,CAAC,OAAO,CAAC,CAAA;IAC9C,OAAO,eAAe,CAAA;AACxB,CAAC;AAfD,4CAeC"}
|
|
@@ -1,19 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
3
|
-
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
4
|
-
return new (P || (P = Promise))(function (resolve, reject) {
|
|
5
|
-
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
6
|
-
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
7
|
-
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
8
|
-
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
9
|
-
});
|
|
10
|
-
};
|
|
11
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
12
|
-
const users_1 = require("../users");
|
|
13
|
-
exports.default = (ctx, next) => __awaiter(void 0, void 0, void 0, function* () {
|
|
14
|
-
if (!ctx.internal && !(0, users_1.isAdmin)(ctx.user)) {
|
|
15
|
-
ctx.throw(403, "Admin user only endpoint.");
|
|
16
|
-
}
|
|
17
|
-
return next();
|
|
18
|
-
});
|
|
19
|
-
//# sourceMappingURL=adminOnly.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"adminOnly.js","sourceRoot":"","sources":["../../../src/middleware/adminOnly.ts"],"names":[],"mappings":";;;;;;;;;;;AACA,oCAAkC;AAElC,kBAAe,CAAO,GAAY,EAAE,IAAS,EAAE,EAAE;IAC/C,IAAI,CAAC,GAAG,CAAC,QAAQ,IAAI,CAAC,IAAA,eAAO,EAAC,GAAG,CAAC,IAAI,CAAC,EAAE;QACvC,GAAG,CAAC,KAAK,CAAC,GAAG,EAAE,2BAA2B,CAAC,CAAA;KAC5C;IACD,OAAO,IAAI,EAAE,CAAA;AACf,CAAC,CAAA,CAAA"}
|
|
@@ -1,16 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
3
|
-
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
4
|
-
return new (P || (P = Promise))(function (resolve, reject) {
|
|
5
|
-
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
6
|
-
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
7
|
-
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
8
|
-
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
9
|
-
});
|
|
10
|
-
};
|
|
11
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
12
|
-
exports.default = (ctx, next) => __awaiter(void 0, void 0, void 0, function* () {
|
|
13
|
-
// Placeholder for audit log middleware
|
|
14
|
-
return next();
|
|
15
|
-
});
|
|
16
|
-
//# sourceMappingURL=auditLog.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"auditLog.js","sourceRoot":"","sources":["../../../src/middleware/auditLog.ts"],"names":[],"mappings":";;;;;;;;;;;AAEA,kBAAe,CAAO,GAAoB,EAAE,IAAS,EAAE,EAAE;IACvD,uCAAuC;IACvC,OAAO,IAAI,EAAE,CAAA;AACf,CAAC,CAAA,CAAA"}
|
|
@@ -1,204 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
-
if (k2 === undefined) k2 = k;
|
|
4
|
-
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
-
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
-
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
-
}
|
|
8
|
-
Object.defineProperty(o, k2, desc);
|
|
9
|
-
}) : (function(o, m, k, k2) {
|
|
10
|
-
if (k2 === undefined) k2 = k;
|
|
11
|
-
o[k2] = m[k];
|
|
12
|
-
}));
|
|
13
|
-
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
-
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
-
}) : function(o, v) {
|
|
16
|
-
o["default"] = v;
|
|
17
|
-
});
|
|
18
|
-
var __importStar = (this && this.__importStar) || function (mod) {
|
|
19
|
-
if (mod && mod.__esModule) return mod;
|
|
20
|
-
var result = {};
|
|
21
|
-
if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
|
|
22
|
-
__setModuleDefault(result, mod);
|
|
23
|
-
return result;
|
|
24
|
-
};
|
|
25
|
-
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
26
|
-
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
27
|
-
return new (P || (P = Promise))(function (resolve, reject) {
|
|
28
|
-
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
29
|
-
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
30
|
-
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
31
|
-
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
32
|
-
});
|
|
33
|
-
};
|
|
34
|
-
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
35
|
-
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
36
|
-
};
|
|
37
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
38
|
-
const constants_1 = require("../constants");
|
|
39
|
-
const utils_1 = require("../utils");
|
|
40
|
-
const user_1 = require("../cache/user");
|
|
41
|
-
const sessions_1 = require("../security/sessions");
|
|
42
|
-
const matchers_1 = require("./matchers");
|
|
43
|
-
const db_1 = require("../db");
|
|
44
|
-
const context_1 = require("../context");
|
|
45
|
-
const encryption_1 = require("../security/encryption");
|
|
46
|
-
const identity = __importStar(require("../context/identity"));
|
|
47
|
-
const environment_1 = __importDefault(require("../environment"));
|
|
48
|
-
const errors_1 = require("../errors");
|
|
49
|
-
const ONE_MINUTE = environment_1.default.SESSION_UPDATE_PERIOD
|
|
50
|
-
? parseInt(environment_1.default.SESSION_UPDATE_PERIOD)
|
|
51
|
-
: 60 * 1000;
|
|
52
|
-
function timeMinusOneMinute() {
|
|
53
|
-
return new Date(Date.now() - ONE_MINUTE).toISOString();
|
|
54
|
-
}
|
|
55
|
-
function finalise(ctx, opts = {}) {
|
|
56
|
-
ctx.publicEndpoint = opts.publicEndpoint || false;
|
|
57
|
-
ctx.isAuthenticated = opts.authenticated || false;
|
|
58
|
-
ctx.user = opts.user;
|
|
59
|
-
ctx.internal = opts.internal || false;
|
|
60
|
-
ctx.version = opts.version;
|
|
61
|
-
}
|
|
62
|
-
function checkApiKey(apiKey, populateUser) {
|
|
63
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
64
|
-
// check both the primary and the fallback internal api keys
|
|
65
|
-
// this allows for rotation
|
|
66
|
-
if ((0, utils_1.isValidInternalAPIKey)(apiKey)) {
|
|
67
|
-
return { valid: true, user: undefined };
|
|
68
|
-
}
|
|
69
|
-
const decrypted = (0, encryption_1.decrypt)(apiKey);
|
|
70
|
-
const tenantId = decrypted.split(db_1.SEPARATOR)[0];
|
|
71
|
-
return (0, context_1.doInTenant)(tenantId, () => __awaiter(this, void 0, void 0, function* () {
|
|
72
|
-
let userId;
|
|
73
|
-
try {
|
|
74
|
-
const db = (0, context_1.getGlobalDB)();
|
|
75
|
-
// api key is encrypted in the database
|
|
76
|
-
userId = (yield (0, db_1.queryGlobalView)(db_1.ViewName.BY_API_KEY, {
|
|
77
|
-
key: apiKey,
|
|
78
|
-
}, db));
|
|
79
|
-
}
|
|
80
|
-
catch (err) {
|
|
81
|
-
userId = undefined;
|
|
82
|
-
}
|
|
83
|
-
if (userId) {
|
|
84
|
-
return {
|
|
85
|
-
valid: true,
|
|
86
|
-
user: yield (0, user_1.getUser)(userId, tenantId, populateUser),
|
|
87
|
-
};
|
|
88
|
-
}
|
|
89
|
-
else {
|
|
90
|
-
throw new errors_1.InvalidAPIKeyError();
|
|
91
|
-
}
|
|
92
|
-
}));
|
|
93
|
-
});
|
|
94
|
-
}
|
|
95
|
-
/**
|
|
96
|
-
* This middleware is tenancy aware, so that it does not depend on other middlewares being used.
|
|
97
|
-
* The tenancy modules should not be used here and it should be assumed that the tenancy context
|
|
98
|
-
* has not yet been populated.
|
|
99
|
-
*/
|
|
100
|
-
function default_1(noAuthPatterns = [], opts = {
|
|
101
|
-
publicAllowed: false,
|
|
102
|
-
}) {
|
|
103
|
-
const noAuthOptions = noAuthPatterns ? (0, matchers_1.buildMatcherRegex)(noAuthPatterns) : [];
|
|
104
|
-
return (ctx, next) => __awaiter(this, void 0, void 0, function* () {
|
|
105
|
-
let publicEndpoint = false;
|
|
106
|
-
const version = ctx.request.headers[constants_1.Header.API_VER];
|
|
107
|
-
// the path is not authenticated
|
|
108
|
-
const found = (0, matchers_1.matches)(ctx, noAuthOptions);
|
|
109
|
-
if (found) {
|
|
110
|
-
publicEndpoint = true;
|
|
111
|
-
}
|
|
112
|
-
try {
|
|
113
|
-
// check the actual user is authenticated first, try header or cookie
|
|
114
|
-
let headerToken = ctx.request.headers[constants_1.Header.TOKEN];
|
|
115
|
-
const authCookie = (0, utils_1.getCookie)(ctx, constants_1.Cookie.Auth) || (0, utils_1.openJwt)(headerToken);
|
|
116
|
-
let apiKey = ctx.request.headers[constants_1.Header.API_KEY];
|
|
117
|
-
if (!apiKey && ctx.request.headers[constants_1.Header.AUTHORIZATION]) {
|
|
118
|
-
apiKey = ctx.request.headers[constants_1.Header.AUTHORIZATION].split(" ")[1];
|
|
119
|
-
}
|
|
120
|
-
const tenantId = ctx.request.headers[constants_1.Header.TENANT_ID];
|
|
121
|
-
let authenticated = false, user = null, internal = false;
|
|
122
|
-
if (authCookie && !apiKey) {
|
|
123
|
-
const sessionId = authCookie.sessionId;
|
|
124
|
-
const userId = authCookie.userId;
|
|
125
|
-
let session;
|
|
126
|
-
try {
|
|
127
|
-
// getting session handles error checking (if session exists etc)
|
|
128
|
-
session = yield (0, sessions_1.getSession)(userId, sessionId);
|
|
129
|
-
if (opts && opts.populateUser) {
|
|
130
|
-
user = yield (0, user_1.getUser)(userId, session.tenantId, opts.populateUser(ctx));
|
|
131
|
-
}
|
|
132
|
-
else {
|
|
133
|
-
user = yield (0, user_1.getUser)(userId, session.tenantId);
|
|
134
|
-
}
|
|
135
|
-
user.csrfToken = session.csrfToken;
|
|
136
|
-
if ((session === null || session === void 0 ? void 0 : session.lastAccessedAt) < timeMinusOneMinute()) {
|
|
137
|
-
// make sure we denote that the session is still in use
|
|
138
|
-
yield (0, sessions_1.updateSessionTTL)(session);
|
|
139
|
-
}
|
|
140
|
-
authenticated = true;
|
|
141
|
-
}
|
|
142
|
-
catch (err) {
|
|
143
|
-
authenticated = false;
|
|
144
|
-
console.error(`Auth Error: ${err.message}`);
|
|
145
|
-
console.error(err);
|
|
146
|
-
// remove the cookie as the user does not exist anymore
|
|
147
|
-
(0, utils_1.clearCookie)(ctx, constants_1.Cookie.Auth);
|
|
148
|
-
}
|
|
149
|
-
}
|
|
150
|
-
// this is an internal request, no user made it
|
|
151
|
-
if (!authenticated && apiKey) {
|
|
152
|
-
const populateUser = opts.populateUser ? opts.populateUser(ctx) : null;
|
|
153
|
-
const { valid, user: foundUser } = yield checkApiKey(apiKey, populateUser);
|
|
154
|
-
if (valid && foundUser) {
|
|
155
|
-
authenticated = true;
|
|
156
|
-
user = foundUser;
|
|
157
|
-
}
|
|
158
|
-
else if (valid) {
|
|
159
|
-
authenticated = true;
|
|
160
|
-
internal = true;
|
|
161
|
-
}
|
|
162
|
-
}
|
|
163
|
-
if (!user && tenantId) {
|
|
164
|
-
user = { tenantId };
|
|
165
|
-
}
|
|
166
|
-
else if (user) {
|
|
167
|
-
delete user.password;
|
|
168
|
-
}
|
|
169
|
-
// be explicit
|
|
170
|
-
if (!authenticated) {
|
|
171
|
-
authenticated = false;
|
|
172
|
-
}
|
|
173
|
-
// isAuthenticated is a function, so use a variable to be able to check authed state
|
|
174
|
-
finalise(ctx, { authenticated, user, internal, version, publicEndpoint });
|
|
175
|
-
if (user && user.email) {
|
|
176
|
-
return identity.doInUserContext(user, ctx, next);
|
|
177
|
-
}
|
|
178
|
-
else {
|
|
179
|
-
return next();
|
|
180
|
-
}
|
|
181
|
-
}
|
|
182
|
-
catch (err) {
|
|
183
|
-
console.error(`Auth Error: ${err.message}`);
|
|
184
|
-
console.error(err);
|
|
185
|
-
// invalid token, clear the cookie
|
|
186
|
-
if ((err === null || err === void 0 ? void 0 : err.name) === "JsonWebTokenError") {
|
|
187
|
-
(0, utils_1.clearCookie)(ctx, constants_1.Cookie.Auth);
|
|
188
|
-
}
|
|
189
|
-
else if ((err === null || err === void 0 ? void 0 : err.code) === errors_1.ErrorCode.INVALID_API_KEY) {
|
|
190
|
-
ctx.throw(403, err.message);
|
|
191
|
-
}
|
|
192
|
-
// allow configuring for public access
|
|
193
|
-
if ((opts && opts.publicAllowed) || publicEndpoint) {
|
|
194
|
-
finalise(ctx, { authenticated: false, version, publicEndpoint });
|
|
195
|
-
return next();
|
|
196
|
-
}
|
|
197
|
-
else {
|
|
198
|
-
ctx.throw(err.status || 403, err);
|
|
199
|
-
}
|
|
200
|
-
}
|
|
201
|
-
});
|
|
202
|
-
}
|
|
203
|
-
exports.default = default_1;
|
|
204
|
-
//# sourceMappingURL=authenticated.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"authenticated.js","sourceRoot":"","sources":["../../../src/middleware/authenticated.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,33 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
3
|
-
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
4
|
-
return new (P || (P = Promise))(function (resolve, reject) {
|
|
5
|
-
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
6
|
-
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
7
|
-
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
8
|
-
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
9
|
-
});
|
|
10
|
-
};
|
|
11
|
-
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
12
|
-
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
13
|
-
};
|
|
14
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
15
|
-
const users_1 = require("../users");
|
|
16
|
-
const context_1 = require("../context");
|
|
17
|
-
const environment_1 = __importDefault(require("../environment"));
|
|
18
|
-
exports.default = (ctx, next) => __awaiter(void 0, void 0, void 0, function* () {
|
|
19
|
-
const appId = (0, context_1.getAppId)();
|
|
20
|
-
const builderFn = environment_1.default.isWorker()
|
|
21
|
-
? users_1.hasBuilderPermissions
|
|
22
|
-
: environment_1.default.isApps()
|
|
23
|
-
? users_1.isBuilder
|
|
24
|
-
: undefined;
|
|
25
|
-
if (!builderFn) {
|
|
26
|
-
throw new Error("Service name unknown - middleware inactive.");
|
|
27
|
-
}
|
|
28
|
-
if (!ctx.internal && !builderFn(ctx.user, appId)) {
|
|
29
|
-
ctx.throw(403, "Builder user only endpoint.");
|
|
30
|
-
}
|
|
31
|
-
return next();
|
|
32
|
-
});
|
|
33
|
-
//# sourceMappingURL=builderOnly.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"builderOnly.js","sourceRoot":"","sources":["../../../src/middleware/builderOnly.ts"],"names":[],"mappings":";;;;;;;;;;;;;;AACA,oCAA2D;AAC3D,wCAAqC;AACrC,iEAAgC;AAEhC,kBAAe,CAAO,GAAY,EAAE,IAAS,EAAE,EAAE;IAC/C,MAAM,KAAK,GAAG,IAAA,kBAAQ,GAAE,CAAA;IACxB,MAAM,SAAS,GAAG,qBAAG,CAAC,QAAQ,EAAE;QAC9B,CAAC,CAAC,6BAAqB;QACvB,CAAC,CAAC,qBAAG,CAAC,MAAM,EAAE;YACd,CAAC,CAAC,iBAAS;YACX,CAAC,CAAC,SAAS,CAAA;IACb,IAAI,CAAC,SAAS,EAAE;QACd,MAAM,IAAI,KAAK,CAAC,6CAA6C,CAAC,CAAA;KAC/D;IACD,IAAI,CAAC,GAAG,CAAC,QAAQ,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,IAAI,EAAE,KAAK,CAAC,EAAE;QAChD,GAAG,CAAC,KAAK,CAAC,GAAG,EAAE,6BAA6B,CAAC,CAAA;KAC9C;IACD,OAAO,IAAI,EAAE,CAAA;AACf,CAAC,CAAA,CAAA"}
|
|
@@ -1,33 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
3
|
-
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
4
|
-
return new (P || (P = Promise))(function (resolve, reject) {
|
|
5
|
-
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
6
|
-
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
7
|
-
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
8
|
-
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
9
|
-
});
|
|
10
|
-
};
|
|
11
|
-
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
12
|
-
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
13
|
-
};
|
|
14
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
15
|
-
const users_1 = require("../users");
|
|
16
|
-
const context_1 = require("../context");
|
|
17
|
-
const environment_1 = __importDefault(require("../environment"));
|
|
18
|
-
exports.default = (ctx, next) => __awaiter(void 0, void 0, void 0, function* () {
|
|
19
|
-
const appId = (0, context_1.getAppId)();
|
|
20
|
-
const builderFn = environment_1.default.isWorker()
|
|
21
|
-
? users_1.hasBuilderPermissions
|
|
22
|
-
: environment_1.default.isApps()
|
|
23
|
-
? users_1.isBuilder
|
|
24
|
-
: undefined;
|
|
25
|
-
if (!builderFn) {
|
|
26
|
-
throw new Error("Service name unknown - middleware inactive.");
|
|
27
|
-
}
|
|
28
|
-
if (!ctx.internal && !builderFn(ctx.user, appId) && !(0, users_1.isAdmin)(ctx.user)) {
|
|
29
|
-
ctx.throw(403, "Admin/Builder user only endpoint.");
|
|
30
|
-
}
|
|
31
|
-
return next();
|
|
32
|
-
});
|
|
33
|
-
//# sourceMappingURL=builderOrAdmin.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"builderOrAdmin.js","sourceRoot":"","sources":["../../../src/middleware/builderOrAdmin.ts"],"names":[],"mappings":";;;;;;;;;;;;;;AACA,oCAAoE;AACpE,wCAAqC;AACrC,iEAAgC;AAEhC,kBAAe,CAAO,GAAY,EAAE,IAAS,EAAE,EAAE;IAC/C,MAAM,KAAK,GAAG,IAAA,kBAAQ,GAAE,CAAA;IACxB,MAAM,SAAS,GAAG,qBAAG,CAAC,QAAQ,EAAE;QAC9B,CAAC,CAAC,6BAAqB;QACvB,CAAC,CAAC,qBAAG,CAAC,MAAM,EAAE;YACd,CAAC,CAAC,iBAAS;YACX,CAAC,CAAC,SAAS,CAAA;IACb,IAAI,CAAC,SAAS,EAAE;QACd,MAAM,IAAI,KAAK,CAAC,6CAA6C,CAAC,CAAA;KAC/D;IACD,IAAI,CAAC,GAAG,CAAC,QAAQ,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,IAAI,EAAE,KAAK,CAAC,IAAI,CAAC,IAAA,eAAO,EAAC,GAAG,CAAC,IAAI,CAAC,EAAE;QACtE,GAAG,CAAC,KAAK,CAAC,GAAG,EAAE,mCAAmC,CAAC,CAAA;KACpD;IACD,OAAO,IAAI,EAAE,CAAA;AACf,CAAC,CAAA,CAAA"}
|
|
@@ -1,81 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
3
|
-
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
4
|
-
return new (P || (P = Promise))(function (resolve, reject) {
|
|
5
|
-
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
6
|
-
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
7
|
-
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
8
|
-
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
9
|
-
});
|
|
10
|
-
};
|
|
11
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
12
|
-
const constants_1 = require("../constants");
|
|
13
|
-
const matchers_1 = require("./matchers");
|
|
14
|
-
/**
|
|
15
|
-
* GET, HEAD and OPTIONS methods are considered safe operations
|
|
16
|
-
*
|
|
17
|
-
* POST, PUT, PATCH, and DELETE methods, being state changing verbs,
|
|
18
|
-
* should have a CSRF token attached to the request
|
|
19
|
-
*/
|
|
20
|
-
const EXCLUDED_METHODS = ["GET", "HEAD", "OPTIONS"];
|
|
21
|
-
/**
|
|
22
|
-
* There are only three content type values that can be used in cross domain requests.
|
|
23
|
-
* If any other value is used, e.g. application/json, the browser will first make a OPTIONS
|
|
24
|
-
* request which will be protected by CORS.
|
|
25
|
-
*/
|
|
26
|
-
const INCLUDED_CONTENT_TYPES = [
|
|
27
|
-
"application/x-www-form-urlencoded",
|
|
28
|
-
"multipart/form-data",
|
|
29
|
-
"text/plain",
|
|
30
|
-
];
|
|
31
|
-
/**
|
|
32
|
-
* Validate the CSRF token generated aganst the user session.
|
|
33
|
-
* Compare the token with the x-csrf-token header.
|
|
34
|
-
*
|
|
35
|
-
* If the token is not found within the request or the value provided
|
|
36
|
-
* does not match the value within the user session, the request is rejected.
|
|
37
|
-
*
|
|
38
|
-
* CSRF protection provided using the 'Synchronizer Token Pattern'
|
|
39
|
-
* https://cheatsheetseries.owasp.org/cheatsheets/Cross-Site_Request_Forgery_Prevention_Cheat_Sheet.html#synchronizer-token-pattern
|
|
40
|
-
*
|
|
41
|
-
*/
|
|
42
|
-
function default_1(opts = { noCsrfPatterns: [] }) {
|
|
43
|
-
const noCsrfOptions = (0, matchers_1.buildMatcherRegex)(opts.noCsrfPatterns);
|
|
44
|
-
return (ctx, next) => __awaiter(this, void 0, void 0, function* () {
|
|
45
|
-
var _a;
|
|
46
|
-
// don't apply for excluded paths
|
|
47
|
-
const found = (0, matchers_1.matches)(ctx, noCsrfOptions);
|
|
48
|
-
if (found) {
|
|
49
|
-
return next();
|
|
50
|
-
}
|
|
51
|
-
// don't apply for the excluded http methods
|
|
52
|
-
if (EXCLUDED_METHODS.indexOf(ctx.method) !== -1) {
|
|
53
|
-
return next();
|
|
54
|
-
}
|
|
55
|
-
// don't apply when the content type isn't supported
|
|
56
|
-
let contentType = ctx.get("content-type")
|
|
57
|
-
? ctx.get("content-type").toLowerCase()
|
|
58
|
-
: "";
|
|
59
|
-
if (!INCLUDED_CONTENT_TYPES.filter(type => contentType.includes(type)).length) {
|
|
60
|
-
return next();
|
|
61
|
-
}
|
|
62
|
-
// don't apply csrf when the internal api key has been used
|
|
63
|
-
if (ctx.internal) {
|
|
64
|
-
return next();
|
|
65
|
-
}
|
|
66
|
-
// apply csrf when there is a token in the session (new logins)
|
|
67
|
-
// in future there should be a hard requirement that the token is present
|
|
68
|
-
const userToken = (_a = ctx.user) === null || _a === void 0 ? void 0 : _a.csrfToken;
|
|
69
|
-
if (!userToken) {
|
|
70
|
-
return next();
|
|
71
|
-
}
|
|
72
|
-
// reject if no token in request or mismatch
|
|
73
|
-
const requestToken = ctx.get(constants_1.Header.CSRF_TOKEN);
|
|
74
|
-
if (!requestToken || requestToken !== userToken) {
|
|
75
|
-
ctx.throw(403, "Invalid CSRF token");
|
|
76
|
-
}
|
|
77
|
-
return next();
|
|
78
|
-
});
|
|
79
|
-
}
|
|
80
|
-
exports.default = default_1;
|
|
81
|
-
//# sourceMappingURL=csrf.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"csrf.js","sourceRoot":"","sources":["../../../src/middleware/csrf.ts"],"names":[],"mappings":";;;;;;;;;;;AAAA,4CAAqC;AACrC,yCAAuD;AAGvD;;;;;GAKG;AACH,MAAM,gBAAgB,GAAG,CAAC,KAAK,EAAE,MAAM,EAAE,SAAS,CAAC,CAAA;AAEnD;;;;GAIG;AACH,MAAM,sBAAsB,GAAG;IAC7B,mCAAmC;IACnC,qBAAqB;IACrB,YAAY;CACb,CAAA;AAED;;;;;;;;;;GAUG;AACH,mBACE,OAA8C,EAAE,cAAc,EAAE,EAAE,EAAE;IAEpE,MAAM,aAAa,GAAG,IAAA,4BAAiB,EAAC,IAAI,CAAC,cAAc,CAAC,CAAA;IAC5D,OAAO,CAAO,GAAoB,EAAE,IAAS,EAAE,EAAE;;QAC/C,iCAAiC;QACjC,MAAM,KAAK,GAAG,IAAA,kBAAO,EAAC,GAAG,EAAE,aAAa,CAAC,CAAA;QACzC,IAAI,KAAK,EAAE;YACT,OAAO,IAAI,EAAE,CAAA;SACd;QAED,4CAA4C;QAC5C,IAAI,gBAAgB,CAAC,OAAO,CAAC,GAAG,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,EAAE;YAC/C,OAAO,IAAI,EAAE,CAAA;SACd;QAED,oDAAoD;QACpD,IAAI,WAAW,GAAG,GAAG,CAAC,GAAG,CAAC,cAAc,CAAC;YACvC,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,cAAc,CAAC,CAAC,WAAW,EAAE;YACvC,CAAC,CAAC,EAAE,CAAA;QACN,IACE,CAAC,sBAAsB,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,CAAC,WAAW,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,CAAC,MAAM,EACzE;YACA,OAAO,IAAI,EAAE,CAAA;SACd;QAED,2DAA2D;QAC3D,IAAI,GAAG,CAAC,QAAQ,EAAE;YAChB,OAAO,IAAI,EAAE,CAAA;SACd;QAED,+DAA+D;QAC/D,yEAAyE;QACzE,MAAM,SAAS,GAAG,MAAA,GAAG,CAAC,IAAI,0CAAE,SAAS,CAAA;QACrC,IAAI,CAAC,SAAS,EAAE;YACd,OAAO,IAAI,EAAE,CAAA;SACd;QAED,4CAA4C;QAC5C,MAAM,YAAY,GAAG,GAAG,CAAC,GAAG,CAAC,kBAAM,CAAC,UAAU,CAAC,CAAA;QAC/C,IAAI,CAAC,YAAY,IAAI,YAAY,KAAK,SAAS,EAAE;YAC/C,GAAG,CAAC,KAAK,CAAC,GAAG,EAAE,oBAAoB,CAAC,CAAA;SACrC;QAED,OAAO,IAAI,EAAE,CAAA;IACf,CAAC,CAAA,CAAA;AACH,CAAC;AA9CD,4BA8CC"}
|
|
@@ -1,64 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
-
if (k2 === undefined) k2 = k;
|
|
4
|
-
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
-
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
-
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
-
}
|
|
8
|
-
Object.defineProperty(o, k2, desc);
|
|
9
|
-
}) : (function(o, m, k, k2) {
|
|
10
|
-
if (k2 === undefined) k2 = k;
|
|
11
|
-
o[k2] = m[k];
|
|
12
|
-
}));
|
|
13
|
-
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
-
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
-
}) : function(o, v) {
|
|
16
|
-
o["default"] = v;
|
|
17
|
-
});
|
|
18
|
-
var __importStar = (this && this.__importStar) || function (mod) {
|
|
19
|
-
if (mod && mod.__esModule) return mod;
|
|
20
|
-
var result = {};
|
|
21
|
-
if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
|
|
22
|
-
__setModuleDefault(result, mod);
|
|
23
|
-
return result;
|
|
24
|
-
};
|
|
25
|
-
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
26
|
-
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
27
|
-
return new (P || (P = Promise))(function (resolve, reject) {
|
|
28
|
-
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
29
|
-
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
30
|
-
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
31
|
-
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
32
|
-
});
|
|
33
|
-
};
|
|
34
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
35
|
-
exports.errorHandling = void 0;
|
|
36
|
-
const errors = __importStar(require("../errors"));
|
|
37
|
-
function errorHandling(ctx, next) {
|
|
38
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
39
|
-
try {
|
|
40
|
-
yield next();
|
|
41
|
-
}
|
|
42
|
-
catch (err) {
|
|
43
|
-
const status = err.status || err.statusCode || 500;
|
|
44
|
-
ctx.status = status;
|
|
45
|
-
if (status >= 400 && status < 500) {
|
|
46
|
-
console.warn(err);
|
|
47
|
-
}
|
|
48
|
-
else {
|
|
49
|
-
console.error(err);
|
|
50
|
-
}
|
|
51
|
-
const error = errors.getPublicError(err);
|
|
52
|
-
const body = {
|
|
53
|
-
message: err.message,
|
|
54
|
-
status: status,
|
|
55
|
-
validationErrors: err.validation,
|
|
56
|
-
error,
|
|
57
|
-
};
|
|
58
|
-
ctx.body = body;
|
|
59
|
-
}
|
|
60
|
-
});
|
|
61
|
-
}
|
|
62
|
-
exports.errorHandling = errorHandling;
|
|
63
|
-
exports.default = errorHandling;
|
|
64
|
-
//# sourceMappingURL=errorHandling.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"errorHandling.js","sourceRoot":"","sources":["../../../src/middleware/errorHandling.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AACA,kDAAmC;AAEnC,SAAsB,aAAa,CAAC,GAAQ,EAAE,IAAS;;QACrD,IAAI;YACF,MAAM,IAAI,EAAE,CAAA;SACb;QAAC,OAAO,GAAQ,EAAE;YACjB,MAAM,MAAM,GAAG,GAAG,CAAC,MAAM,IAAI,GAAG,CAAC,UAAU,IAAI,GAAG,CAAA;YAClD,GAAG,CAAC,MAAM,GAAG,MAAM,CAAA;YAEnB,IAAI,MAAM,IAAI,GAAG,IAAI,MAAM,GAAG,GAAG,EAAE;gBACjC,OAAO,CAAC,IAAI,CAAC,GAAG,CAAC,CAAA;aAClB;iBAAM;gBACL,OAAO,CAAC,KAAK,CAAC,GAAG,CAAC,CAAA;aACnB;YAED,MAAM,KAAK,GAAG,MAAM,CAAC,cAAc,CAAC,GAAG,CAAC,CAAA;YACxC,MAAM,IAAI,GAAa;gBACrB,OAAO,EAAE,GAAG,CAAC,OAAO;gBACpB,MAAM,EAAE,MAAM;gBACd,gBAAgB,EAAE,GAAG,CAAC,UAAU;gBAChC,KAAK;aACN,CAAA;YAED,GAAG,CAAC,IAAI,GAAG,IAAI,CAAA;SAChB;IACH,CAAC;CAAA;AAvBD,sCAuBC;AAED,kBAAe,aAAa,CAAA"}
|
|
@@ -1,65 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
-
if (k2 === undefined) k2 = k;
|
|
4
|
-
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
-
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
-
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
-
}
|
|
8
|
-
Object.defineProperty(o, k2, desc);
|
|
9
|
-
}) : (function(o, m, k, k2) {
|
|
10
|
-
if (k2 === undefined) k2 = k;
|
|
11
|
-
o[k2] = m[k];
|
|
12
|
-
}));
|
|
13
|
-
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
-
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
-
}) : function(o, v) {
|
|
16
|
-
o["default"] = v;
|
|
17
|
-
});
|
|
18
|
-
var __importStar = (this && this.__importStar) || function (mod) {
|
|
19
|
-
if (mod && mod.__esModule) return mod;
|
|
20
|
-
var result = {};
|
|
21
|
-
if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
|
|
22
|
-
__setModuleDefault(result, mod);
|
|
23
|
-
return result;
|
|
24
|
-
};
|
|
25
|
-
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
26
|
-
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
27
|
-
};
|
|
28
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
29
|
-
exports.joiValidator = exports.querystringToBody = exports.errorHandling = exports.correlation = exports.pino = exports.builderOnly = exports.builderOrAdmin = exports.adminOnly = exports.csrf = exports.internalApi = exports.tenancy = exports.auditLog = exports.authenticated = exports.ssoCallbackUrl = exports.authError = exports.datasource = exports.oidc = exports.google = exports.local = void 0;
|
|
30
|
-
exports.local = __importStar(require("./passport/local"));
|
|
31
|
-
exports.google = __importStar(require("./passport/sso/google"));
|
|
32
|
-
exports.oidc = __importStar(require("./passport/sso/oidc"));
|
|
33
|
-
const datasourceGoogle = __importStar(require("./passport/datasource/google"));
|
|
34
|
-
exports.datasource = {
|
|
35
|
-
google: datasourceGoogle,
|
|
36
|
-
};
|
|
37
|
-
var utils_1 = require("./passport/utils");
|
|
38
|
-
Object.defineProperty(exports, "authError", { enumerable: true, get: function () { return utils_1.authError; } });
|
|
39
|
-
Object.defineProperty(exports, "ssoCallbackUrl", { enumerable: true, get: function () { return utils_1.ssoCallbackUrl; } });
|
|
40
|
-
var authenticated_1 = require("./authenticated");
|
|
41
|
-
Object.defineProperty(exports, "authenticated", { enumerable: true, get: function () { return __importDefault(authenticated_1).default; } });
|
|
42
|
-
var auditLog_1 = require("./auditLog");
|
|
43
|
-
Object.defineProperty(exports, "auditLog", { enumerable: true, get: function () { return __importDefault(auditLog_1).default; } });
|
|
44
|
-
var tenancy_1 = require("./tenancy");
|
|
45
|
-
Object.defineProperty(exports, "tenancy", { enumerable: true, get: function () { return __importDefault(tenancy_1).default; } });
|
|
46
|
-
var internalApi_1 = require("./internalApi");
|
|
47
|
-
Object.defineProperty(exports, "internalApi", { enumerable: true, get: function () { return __importDefault(internalApi_1).default; } });
|
|
48
|
-
var csrf_1 = require("./csrf");
|
|
49
|
-
Object.defineProperty(exports, "csrf", { enumerable: true, get: function () { return __importDefault(csrf_1).default; } });
|
|
50
|
-
var adminOnly_1 = require("./adminOnly");
|
|
51
|
-
Object.defineProperty(exports, "adminOnly", { enumerable: true, get: function () { return __importDefault(adminOnly_1).default; } });
|
|
52
|
-
var builderOrAdmin_1 = require("./builderOrAdmin");
|
|
53
|
-
Object.defineProperty(exports, "builderOrAdmin", { enumerable: true, get: function () { return __importDefault(builderOrAdmin_1).default; } });
|
|
54
|
-
var builderOnly_1 = require("./builderOnly");
|
|
55
|
-
Object.defineProperty(exports, "builderOnly", { enumerable: true, get: function () { return __importDefault(builderOnly_1).default; } });
|
|
56
|
-
var middleware_1 = require("../logging/pino/middleware");
|
|
57
|
-
Object.defineProperty(exports, "pino", { enumerable: true, get: function () { return __importDefault(middleware_1).default; } });
|
|
58
|
-
var middleware_2 = require("../logging/correlation/middleware");
|
|
59
|
-
Object.defineProperty(exports, "correlation", { enumerable: true, get: function () { return __importDefault(middleware_2).default; } });
|
|
60
|
-
var errorHandling_1 = require("./errorHandling");
|
|
61
|
-
Object.defineProperty(exports, "errorHandling", { enumerable: true, get: function () { return __importDefault(errorHandling_1).default; } });
|
|
62
|
-
var querystringToBody_1 = require("./querystringToBody");
|
|
63
|
-
Object.defineProperty(exports, "querystringToBody", { enumerable: true, get: function () { return __importDefault(querystringToBody_1).default; } });
|
|
64
|
-
exports.joiValidator = __importStar(require("./joi-validator"));
|
|
65
|
-
//# sourceMappingURL=index.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/middleware/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,0DAAyC;AACzC,gEAA+C;AAC/C,4DAA2C;AAC3C,+EAAgE;AACnD,QAAA,UAAU,GAAG;IACxB,MAAM,EAAE,gBAAgB;CACzB,CAAA;AACD,0CAA4D;AAAnD,kGAAA,SAAS,OAAA;AAAE,uGAAA,cAAc,OAAA;AAClC,iDAA0D;AAAjD,+HAAA,OAAO,OAAiB;AACjC,uCAAgD;AAAvC,qHAAA,OAAO,OAAY;AAC5B,qCAA8C;AAArC,mHAAA,OAAO,OAAW;AAC3B,6CAAsD;AAA7C,2HAAA,OAAO,OAAe;AAC/B,+BAAwC;AAA/B,6GAAA,OAAO,OAAQ;AACxB,yCAAkD;AAAzC,uHAAA,OAAO,OAAa;AAC7B,mDAA4D;AAAnD,iIAAA,OAAO,OAAkB;AAClC,6CAAsD;AAA7C,2HAAA,OAAO,OAAe;AAC/B,yDAA4D;AAAnD,mHAAA,OAAO,OAAQ;AACxB,gEAA0E;AAAjE,0HAAA,OAAO,OAAe;AAC/B,iDAA0D;AAAjD,+HAAA,OAAO,OAAiB;AACjC,yDAAkE;AAAzD,uIAAA,OAAO,OAAqB;AACrC,gEAA+C"}
|
|
@@ -1,30 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
3
|
-
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
4
|
-
return new (P || (P = Promise))(function (resolve, reject) {
|
|
5
|
-
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
6
|
-
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
7
|
-
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
8
|
-
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
9
|
-
});
|
|
10
|
-
};
|
|
11
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
12
|
-
const constants_1 = require("../constants");
|
|
13
|
-
const utils_1 = require("../utils");
|
|
14
|
-
/**
|
|
15
|
-
* API Key only endpoint.
|
|
16
|
-
*/
|
|
17
|
-
exports.default = (ctx, next) => __awaiter(void 0, void 0, void 0, function* () {
|
|
18
|
-
const apiKey = ctx.request.headers[constants_1.Header.API_KEY];
|
|
19
|
-
if (!apiKey) {
|
|
20
|
-
ctx.throw(403, "Unauthorized");
|
|
21
|
-
}
|
|
22
|
-
if (Array.isArray(apiKey)) {
|
|
23
|
-
ctx.throw(403, "Unauthorized");
|
|
24
|
-
}
|
|
25
|
-
if (!(0, utils_1.isValidInternalAPIKey)(apiKey)) {
|
|
26
|
-
ctx.throw(403, "Unauthorized");
|
|
27
|
-
}
|
|
28
|
-
return next();
|
|
29
|
-
});
|
|
30
|
-
//# sourceMappingURL=internalApi.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"internalApi.js","sourceRoot":"","sources":["../../../src/middleware/internalApi.ts"],"names":[],"mappings":";;;;;;;;;;;AAAA,4CAAqC;AAErC,oCAAgD;AAEhD;;GAEG;AACH,kBAAe,CAAO,GAAc,EAAE,IAAS,EAAE,EAAE;IACjD,MAAM,MAAM,GAAG,GAAG,CAAC,OAAO,CAAC,OAAO,CAAC,kBAAM,CAAC,OAAO,CAAC,CAAA;IAClD,IAAI,CAAC,MAAM,EAAE;QACX,GAAG,CAAC,KAAK,CAAC,GAAG,EAAE,cAAc,CAAC,CAAA;KAC/B;IAED,IAAI,KAAK,CAAC,OAAO,CAAC,MAAM,CAAC,EAAE;QACzB,GAAG,CAAC,KAAK,CAAC,GAAG,EAAE,cAAc,CAAC,CAAA;KAC/B;IAED,IAAI,CAAC,IAAA,6BAAqB,EAAC,MAAM,CAAC,EAAE;QAClC,GAAG,CAAC,KAAK,CAAC,GAAG,EAAE,cAAc,CAAC,CAAA;KAC/B;IAED,OAAO,IAAI,EAAE,CAAA;AACf,CAAC,CAAA,CAAA"}
|