arkos 1.3.1-beta → 1.3.2-beta
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/cjs/app.js +139 -1
- package/dist/cjs/exports/auth/index.js +6 -1
- package/dist/cjs/exports/controllers/index.js +11 -1
- package/dist/cjs/exports/error-handler/index.js +11 -1
- package/dist/cjs/exports/index.js +12 -1
- package/dist/cjs/exports/middlewares/index.js +7 -1
- package/dist/cjs/exports/prisma/index.js +13 -1
- package/dist/cjs/exports/services/index.js +48 -1
- package/dist/cjs/exports/utils/index.js +44 -1
- package/dist/cjs/exports/validation/index.js +11 -1
- package/dist/cjs/modules/auth/auth.controller.js +229 -1
- package/dist/cjs/modules/auth/auth.controller.js.map +1 -1
- package/dist/cjs/modules/auth/auth.router.js +82 -1
- package/dist/cjs/modules/auth/auth.router.js.map +1 -1
- package/dist/cjs/modules/auth/auth.service.js +226 -1
- package/dist/cjs/modules/auth/utils/auth-error-objects.js +10 -1
- package/dist/cjs/modules/auth/utils/helpers/auth.controller.helpers.js +83 -1
- package/dist/cjs/modules/auth/utils/services/auth-action.service.js +92 -1
- package/dist/cjs/modules/auth/utils/services/auth-action.service.js.map +1 -1
- package/dist/cjs/modules/base/base.controller.js +172 -1
- package/dist/cjs/modules/base/base.middlewares.js +92 -1
- package/dist/cjs/modules/base/base.router.js +22 -1
- package/dist/cjs/modules/base/base.service.js +507 -1
- package/dist/cjs/modules/base/base.service.js.map +1 -1
- package/dist/cjs/modules/base/types/base.service.types.js +3 -1
- package/dist/cjs/modules/base/types/base.service.types.js.map +1 -1
- package/dist/cjs/modules/base/utils/helpers/base.controller.helpers.js +80 -1
- package/dist/cjs/modules/base/utils/helpers/base.middlewares.helpers.js +50 -1
- package/dist/cjs/modules/base/utils/helpers/base.router.helpers.js +104 -1
- package/dist/cjs/modules/base/utils/helpers/base.service.helpers.js +208 -1
- package/dist/cjs/modules/base/utils/router-validator.js +16 -1
- package/dist/cjs/modules/base/utils/service-hooks-manager.js +19 -1
- package/dist/cjs/modules/email/email.service.js +104 -1
- package/dist/cjs/modules/error-handler/error-handler.controller.js +146 -4
- package/dist/cjs/modules/error-handler/utils/app-error.js +17 -1
- package/dist/cjs/modules/error-handler/utils/catch-async.js +21 -1
- package/dist/cjs/modules/error-handler/utils/error-handler.helpers.js +205 -3
- package/dist/cjs/modules/file-upload/file-upload.controller.js +233 -1
- package/dist/cjs/modules/file-upload/file-upload.router.js +60 -1
- package/dist/cjs/modules/file-upload/file-upload.service.js +322 -1
- package/dist/cjs/modules/file-upload/utils/helpers/file-upload.helpers.js +97 -1
- package/dist/cjs/modules/swagger/swagger.router.js +38 -1
- package/dist/cjs/modules/swagger/utils/helpers/get-authentication-json-schema-paths.js +338 -1
- package/dist/cjs/modules/swagger/utils/helpers/get-swagger-default-configs.js +64 -1
- package/dist/cjs/modules/swagger/utils/helpers/get-system-json-schema-paths.js +37 -1
- package/dist/cjs/modules/swagger/utils/helpers/json-schema-generators/generate-class-validator-json-schemas.js +48 -1
- package/dist/cjs/modules/swagger/utils/helpers/json-schema-generators/generate-prisma-json-schemas.js +32 -1
- package/dist/cjs/modules/swagger/utils/helpers/json-schema-generators/generate-system-json-schemas.js +49 -1
- package/dist/cjs/modules/swagger/utils/helpers/json-schema-generators/generate-zod-json-schemas.js +34 -1
- package/dist/cjs/modules/swagger/utils/helpers/json-schema-generators/prisma-models/generate-prisma-model-main-routes-paths.js +471 -1
- package/dist/cjs/modules/swagger/utils/helpers/json-schema-generators/prisma-models/generate-prisma-model-parent-routes-paths.js +572 -1
- package/dist/cjs/modules/swagger/utils/helpers/missing-json-schemas-generator.js +260 -1
- package/dist/cjs/modules/swagger/utils/helpers/swagger.router.helpers.js +112 -1
- package/dist/cjs/paths.js +9 -1
- package/dist/cjs/server.js +94 -5
- package/dist/cjs/types/arkos-config.js +3 -1
- package/dist/cjs/types/arkos-config.js.map +1 -1
- package/dist/cjs/types/auth.js +3 -1
- package/dist/cjs/types/index.js +11 -1
- package/dist/cjs/types/router-config.js +3 -1
- package/dist/cjs/utils/arkos-env.js +9 -1
- package/dist/cjs/utils/cli/build.js +214 -5
- package/dist/cjs/utils/cli/dev.js +154 -3
- package/dist/cjs/utils/cli/generate.js +109 -1
- package/dist/cjs/utils/cli/index.js +104 -1
- package/dist/cjs/utils/cli/index.js.map +1 -1
- package/dist/cjs/utils/cli/prisma-generate.js +120 -0
- package/dist/cjs/utils/cli/prisma-generate.js.map +1 -0
- package/dist/cjs/utils/cli/start.js +103 -1
- package/dist/cjs/utils/cli/utils/cli.helpers.js +24 -1
- package/dist/cjs/utils/cli/utils/smart-fs-watcher.js +73 -1
- package/dist/cjs/utils/cli/utils/template-generator/templates/auth-configs-template.js +36 -0
- package/dist/cjs/utils/cli/utils/template-generator/templates/auth-configs-template.js.map +1 -0
- package/dist/cjs/utils/cli/utils/template-generator/templates/controller-template.js +21 -0
- package/dist/cjs/utils/cli/utils/template-generator/templates/controller-template.js.map +1 -0
- package/dist/cjs/utils/cli/utils/template-generator/templates/hooks-template.js +201 -0
- package/dist/cjs/utils/cli/utils/template-generator/templates/hooks-template.js.map +1 -0
- package/dist/cjs/utils/cli/utils/template-generator/templates/middlewares-template.js +288 -0
- package/dist/cjs/utils/cli/utils/template-generator/templates/{generate-middlewares.js.map → middlewares-template.js.map} +1 -1
- package/dist/cjs/utils/cli/utils/template-generator/templates/query-options-template.js +64 -0
- package/dist/cjs/utils/cli/utils/template-generator/templates/query-options-template.js.map +1 -0
- package/dist/cjs/utils/cli/utils/template-generator/templates/router-template.js +45 -0
- package/dist/cjs/utils/cli/utils/template-generator/templates/router-template.js.map +1 -0
- package/dist/cjs/utils/cli/utils/template-generator/templates/service-template.js +29 -0
- package/dist/cjs/utils/cli/utils/template-generator/templates/service-template.js.map +1 -0
- package/dist/cjs/utils/cli/utils/template-generators.js +34 -2
- package/dist/cjs/utils/cli/utils/template-generators.js.map +1 -1
- package/dist/cjs/utils/cli/utils/watermark-stamper.js +17 -3
- package/dist/cjs/utils/dotenv.helpers.js +43 -1
- package/dist/cjs/utils/dynamic-loader.js +270 -9
- package/dist/cjs/utils/features/api.features.js +169 -1
- package/dist/cjs/utils/features/change-case.features.js +67 -1
- package/dist/cjs/utils/features/port-and-host-allocator.js +105 -1
- package/dist/cjs/utils/helpers/api.features.helpers.js +112 -1
- package/dist/cjs/utils/helpers/change-case.helpers.js +177 -1
- package/dist/cjs/utils/helpers/deepmerge.helper.js +115 -1
- package/dist/cjs/utils/helpers/dynamic-loader.helpers.js +76 -1
- package/dist/cjs/utils/helpers/fs.helpers.js +57 -1
- package/dist/cjs/utils/helpers/global.helpers.js +94 -1
- package/dist/cjs/utils/helpers/prisma.helpers.js +40 -1
- package/dist/cjs/utils/helpers/query-parser.helpers.js +45 -1
- package/dist/cjs/utils/helpers/routers.helpers.js +37 -1
- package/dist/cjs/utils/helpers/text.helpers.js +28 -1
- package/dist/cjs/utils/prisma/prisma-json-schema-generator.js +455 -1
- package/dist/cjs/utils/prisma/prisma-schema-parser.js +216 -4
- package/dist/cjs/utils/prisma/types.js +3 -1
- package/dist/cjs/utils/sheu.js +120 -1
- package/dist/cjs/utils/validate-dto.js +17 -1
- package/dist/cjs/utils/validate-schema.js +15 -1
- package/dist/esm/app.js +132 -1
- package/dist/esm/exports/auth/index.js +2 -1
- package/dist/esm/exports/controllers/index.js +4 -1
- package/dist/esm/exports/error-handler/index.js +4 -1
- package/dist/esm/exports/index.js +8 -1
- package/dist/esm/exports/middlewares/index.js +2 -1
- package/dist/esm/exports/prisma/index.js +6 -1
- package/dist/esm/exports/services/index.js +9 -1
- package/dist/esm/exports/utils/index.js +4 -1
- package/dist/esm/exports/validation/index.js +4 -1
- package/dist/esm/modules/auth/auth.controller.js +222 -1
- package/dist/esm/modules/auth/auth.controller.js.map +1 -1
- package/dist/esm/modules/auth/auth.router.js +76 -1
- package/dist/esm/modules/auth/auth.router.js.map +1 -1
- package/dist/esm/modules/auth/auth.service.js +219 -1
- package/dist/esm/modules/auth/utils/auth-error-objects.js +4 -1
- package/dist/esm/modules/auth/utils/helpers/auth.controller.helpers.js +73 -1
- package/dist/esm/modules/auth/utils/services/auth-action.service.js +90 -1
- package/dist/esm/modules/auth/utils/services/auth-action.service.js.map +1 -1
- package/dist/esm/modules/base/base.controller.js +165 -1
- package/dist/esm/modules/base/base.middlewares.js +81 -1
- package/dist/esm/modules/base/base.router.js +15 -1
- package/dist/esm/modules/base/base.service.js +500 -1
- package/dist/esm/modules/base/base.service.js.map +1 -1
- package/dist/esm/modules/base/types/base.service.types.js +2 -1
- package/dist/esm/modules/base/types/base.service.types.js.map +1 -1
- package/dist/esm/modules/base/utils/helpers/base.controller.helpers.js +76 -1
- package/dist/esm/modules/base/utils/helpers/base.middlewares.helpers.js +44 -1
- package/dist/esm/modules/base/utils/helpers/base.router.helpers.js +96 -1
- package/dist/esm/modules/base/utils/helpers/base.service.helpers.js +198 -1
- package/dist/esm/modules/base/utils/router-validator.js +14 -1
- package/dist/esm/modules/base/utils/service-hooks-manager.js +17 -1
- package/dist/esm/modules/email/email.service.js +97 -1
- package/dist/esm/modules/error-handler/error-handler.controller.js +107 -4
- package/dist/esm/modules/error-handler/utils/app-error.js +15 -1
- package/dist/esm/modules/error-handler/utils/catch-async.js +19 -1
- package/dist/esm/modules/error-handler/utils/error-handler.helpers.js +163 -3
- package/dist/esm/modules/file-upload/file-upload.controller.js +228 -1
- package/dist/esm/modules/file-upload/file-upload.router.js +54 -1
- package/dist/esm/modules/file-upload/file-upload.service.js +314 -1
- package/dist/esm/modules/file-upload/utils/helpers/file-upload.helpers.js +87 -1
- package/dist/esm/modules/swagger/swagger.router.js +32 -1
- package/dist/esm/modules/swagger/utils/helpers/get-authentication-json-schema-paths.js +333 -1
- package/dist/esm/modules/swagger/utils/helpers/get-swagger-default-configs.js +58 -1
- package/dist/esm/modules/swagger/utils/helpers/get-system-json-schema-paths.js +34 -1
- package/dist/esm/modules/swagger/utils/helpers/json-schema-generators/generate-class-validator-json-schemas.js +42 -1
- package/dist/esm/modules/swagger/utils/helpers/json-schema-generators/generate-prisma-json-schemas.js +26 -1
- package/dist/esm/modules/swagger/utils/helpers/json-schema-generators/generate-system-json-schemas.js +46 -1
- package/dist/esm/modules/swagger/utils/helpers/json-schema-generators/generate-zod-json-schemas.js +28 -1
- package/dist/esm/modules/swagger/utils/helpers/json-schema-generators/prisma-models/generate-prisma-model-main-routes-paths.js +465 -1
- package/dist/esm/modules/swagger/utils/helpers/json-schema-generators/prisma-models/generate-prisma-model-parent-routes-paths.js +566 -1
- package/dist/esm/modules/swagger/utils/helpers/missing-json-schemas-generator.js +255 -1
- package/dist/esm/modules/swagger/utils/helpers/swagger.router.helpers.js +101 -1
- package/dist/esm/paths.js +3 -1
- package/dist/esm/server.js +85 -5
- package/dist/esm/types/arkos-config.js +2 -1
- package/dist/esm/types/arkos-config.js.map +1 -1
- package/dist/esm/types/auth.js +2 -1
- package/dist/esm/types/index.js +8 -1
- package/dist/esm/types/router-config.js +2 -1
- package/dist/esm/utils/arkos-env.js +7 -1
- package/dist/esm/utils/cli/build.js +208 -5
- package/dist/esm/utils/cli/dev.js +147 -3
- package/dist/esm/utils/cli/generate.js +103 -1
- package/dist/esm/utils/cli/index.js +94 -1
- package/dist/esm/utils/cli/index.js.map +1 -1
- package/dist/esm/utils/cli/prisma-generate.js +114 -0
- package/dist/esm/utils/cli/prisma-generate.js.map +1 -0
- package/dist/esm/utils/cli/start.js +96 -1
- package/dist/esm/utils/cli/utils/cli.helpers.js +16 -1
- package/dist/esm/utils/cli/utils/smart-fs-watcher.js +68 -1
- package/dist/esm/utils/cli/utils/template-generator/templates/auth-configs-template.js +33 -0
- package/dist/esm/utils/cli/utils/template-generator/templates/auth-configs-template.js.map +1 -0
- package/dist/esm/utils/cli/utils/template-generator/templates/controller-template.js +18 -0
- package/dist/esm/utils/cli/utils/template-generator/templates/controller-template.js.map +1 -0
- package/dist/esm/utils/cli/utils/template-generator/templates/hooks-template.js +198 -0
- package/dist/esm/utils/cli/utils/template-generator/templates/hooks-template.js.map +1 -0
- package/dist/esm/utils/cli/utils/template-generator/templates/middlewares-template.js +285 -0
- package/dist/esm/utils/cli/utils/template-generator/templates/{generate-middlewares.js.map → middlewares-template.js.map} +1 -1
- package/dist/esm/utils/cli/utils/template-generator/templates/query-options-template.js +61 -0
- package/dist/esm/utils/cli/utils/template-generator/templates/query-options-template.js.map +1 -0
- package/dist/esm/utils/cli/utils/template-generator/templates/router-template.js +39 -0
- package/dist/esm/utils/cli/utils/template-generator/templates/router-template.js.map +1 -0
- package/dist/esm/utils/cli/utils/template-generator/templates/service-template.js +26 -0
- package/dist/esm/utils/cli/utils/template-generator/templates/service-template.js.map +1 -0
- package/dist/esm/utils/cli/utils/template-generators.js +28 -2
- package/dist/esm/utils/cli/utils/template-generators.js.map +1 -1
- package/dist/esm/utils/cli/utils/watermark-stamper.js +15 -3
- package/dist/esm/utils/dotenv.helpers.js +37 -1
- package/dist/esm/utils/dynamic-loader.js +254 -9
- package/dist/esm/utils/features/api.features.js +162 -1
- package/dist/esm/utils/features/change-case.features.js +31 -1
- package/dist/esm/utils/features/port-and-host-allocator.js +67 -1
- package/dist/esm/utils/helpers/api.features.helpers.js +106 -1
- package/dist/esm/utils/helpers/change-case.helpers.js +161 -1
- package/dist/esm/utils/helpers/deepmerge.helper.js +113 -1
- package/dist/esm/utils/helpers/dynamic-loader.helpers.js +69 -1
- package/dist/esm/utils/helpers/fs.helpers.js +48 -1
- package/dist/esm/utils/helpers/global.helpers.js +51 -1
- package/dist/esm/utils/helpers/prisma.helpers.js +32 -1
- package/dist/esm/utils/helpers/query-parser.helpers.js +40 -1
- package/dist/esm/utils/helpers/routers.helpers.js +29 -1
- package/dist/esm/utils/helpers/text.helpers.js +22 -1
- package/dist/esm/utils/prisma/prisma-json-schema-generator.js +448 -1
- package/dist/esm/utils/prisma/prisma-schema-parser.js +209 -4
- package/dist/esm/utils/prisma/types.js +2 -1
- package/dist/esm/utils/sheu.js +118 -1
- package/dist/esm/utils/validate-dto.js +11 -1
- package/dist/esm/utils/validate-schema.js +9 -1
- package/dist/types/modules/auth/utils/services/auth-action.service.d.ts +1 -1
- package/dist/types/modules/base/types/base.service.types.d.ts +12 -9
- package/dist/types/types/arkos-config.d.ts +3 -2
- package/dist/types/utils/cli/prisma-generate.d.ts +1 -0
- package/package.json +2 -2
- package/dist/cjs/utils/cli/utils/template-generator/templates/generate-auth-configs-template.js +0 -21
- package/dist/cjs/utils/cli/utils/template-generator/templates/generate-auth-configs-template.js.map +0 -1
- package/dist/cjs/utils/cli/utils/template-generator/templates/generate-controller-template.js +0 -12
- package/dist/cjs/utils/cli/utils/template-generator/templates/generate-controller-template.js.map +0 -1
- package/dist/cjs/utils/cli/utils/template-generator/templates/generate-hooks-template.js +0 -144
- package/dist/cjs/utils/cli/utils/template-generator/templates/generate-hooks-template.js.map +0 -1
- package/dist/cjs/utils/cli/utils/template-generator/templates/generate-middlewares.js +0 -256
- package/dist/cjs/utils/cli/utils/template-generator/templates/generate-prisma-query-options.js +0 -36
- package/dist/cjs/utils/cli/utils/template-generator/templates/generate-prisma-query-options.js.map +0 -1
- package/dist/cjs/utils/cli/utils/template-generator/templates/generate-router-template.js +0 -18
- package/dist/cjs/utils/cli/utils/template-generator/templates/generate-router-template.js.map +0 -1
- package/dist/cjs/utils/cli/utils/template-generator/templates/generate-service-template.js +0 -9
- package/dist/cjs/utils/cli/utils/template-generator/templates/generate-service-template.js.map +0 -1
- package/dist/esm/utils/cli/utils/template-generator/templates/generate-auth-configs-template.js +0 -21
- package/dist/esm/utils/cli/utils/template-generator/templates/generate-auth-configs-template.js.map +0 -1
- package/dist/esm/utils/cli/utils/template-generator/templates/generate-controller-template.js +0 -12
- package/dist/esm/utils/cli/utils/template-generator/templates/generate-controller-template.js.map +0 -1
- package/dist/esm/utils/cli/utils/template-generator/templates/generate-hooks-template.js +0 -144
- package/dist/esm/utils/cli/utils/template-generator/templates/generate-hooks-template.js.map +0 -1
- package/dist/esm/utils/cli/utils/template-generator/templates/generate-middlewares.js +0 -256
- package/dist/esm/utils/cli/utils/template-generator/templates/generate-prisma-query-options.js +0 -36
- package/dist/esm/utils/cli/utils/template-generator/templates/generate-prisma-query-options.js.map +0 -1
- package/dist/esm/utils/cli/utils/template-generator/templates/generate-router-template.js +0 -18
- package/dist/esm/utils/cli/utils/template-generator/templates/generate-router-template.js.map +0 -1
- package/dist/esm/utils/cli/utils/template-generator/templates/generate-service-template.js +0 -9
- package/dist/esm/utils/cli/utils/template-generator/templates/generate-service-template.js.map +0 -1
- /package/dist/types/utils/cli/utils/template-generator/templates/{generate-auth-configs-template.d.ts → auth-configs-template.d.ts} +0 -0
- /package/dist/types/utils/cli/utils/template-generator/templates/{generate-controller-template.d.ts → controller-template.d.ts} +0 -0
- /package/dist/types/utils/cli/utils/template-generator/templates/{generate-hooks-template.d.ts → hooks-template.d.ts} +0 -0
- /package/dist/types/utils/cli/utils/template-generator/templates/{generate-middlewares.d.ts → middlewares-template.d.ts} +0 -0
- /package/dist/types/utils/cli/utils/template-generator/templates/{generate-prisma-query-options.d.ts → query-options-template.d.ts} +0 -0
- /package/dist/types/utils/cli/utils/template-generator/templates/{generate-router-template.d.ts → router-template.d.ts} +0 -0
- /package/dist/types/utils/cli/utils/template-generator/templates/{generate-service-template.d.ts → service-template.d.ts} +0 -0
|
@@ -1,3 +1,205 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
|
|
3
|
-
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
exports.handleJWTError = handleJWTError;
|
|
7
|
+
exports.handleJWTExpired = handleJWTExpired;
|
|
8
|
+
exports.handlePrismaClientValidationError = handlePrismaClientValidationError;
|
|
9
|
+
exports.handleAuthenticationError = handleAuthenticationError;
|
|
10
|
+
exports.handleServerNotReachableError = handleServerNotReachableError;
|
|
11
|
+
exports.handleConnectionTimeoutError = handleConnectionTimeoutError;
|
|
12
|
+
exports.handleDatabaseNotFoundError = handleDatabaseNotFoundError;
|
|
13
|
+
exports.handleEnvironmentVariableError = handleEnvironmentVariableError;
|
|
14
|
+
exports.handleFieldValueTooLargeError = handleFieldValueTooLargeError;
|
|
15
|
+
exports.handleRecordNotFoundError = handleRecordNotFoundError;
|
|
16
|
+
exports.handleUniqueConstraintError = handleUniqueConstraintError;
|
|
17
|
+
exports.handleForeignKeyConstraintError = handleForeignKeyConstraintError;
|
|
18
|
+
exports.handleConstraintFailedError = handleConstraintFailedError;
|
|
19
|
+
exports.handleInvalidFieldValueError = handleInvalidFieldValueError;
|
|
20
|
+
exports.handleInvalidFieldProvidedError = handleInvalidFieldProvidedError;
|
|
21
|
+
exports.handleDataValidationError = handleDataValidationError;
|
|
22
|
+
exports.handleQueryParsingError = handleQueryParsingError;
|
|
23
|
+
exports.handleInvalidQueryFormatError = handleInvalidQueryFormatError;
|
|
24
|
+
exports.handleRawQueryExecutionError = handleRawQueryExecutionError;
|
|
25
|
+
exports.handleNullConstraintViolationError = handleNullConstraintViolationError;
|
|
26
|
+
exports.handleSchemaCreationFailedError = handleSchemaCreationFailedError;
|
|
27
|
+
exports.handleMigrationAlreadyAppliedError = handleMigrationAlreadyAppliedError;
|
|
28
|
+
exports.handleMigrationScriptFailedError = handleMigrationScriptFailedError;
|
|
29
|
+
exports.handleVersionMismatchError = handleVersionMismatchError;
|
|
30
|
+
exports.handleMigrationFileReadError = handleMigrationFileReadError;
|
|
31
|
+
exports.handleSchemaDriftError = handleSchemaDriftError;
|
|
32
|
+
exports.handleSchemaSyntaxError = handleSchemaSyntaxError;
|
|
33
|
+
exports.handleClientTypeError = handleClientTypeError;
|
|
34
|
+
exports.handleDynamicQueryError = handleDynamicQueryError;
|
|
35
|
+
exports.handleRelationLoadingError = handleRelationLoadingError;
|
|
36
|
+
exports.handleBinaryError = handleBinaryError;
|
|
37
|
+
exports.handleNetworkError = handleNetworkError;
|
|
38
|
+
exports.handleUnhandledPromiseError = handleUnhandledPromiseError;
|
|
39
|
+
exports.handleDataTypeError = handleDataTypeError;
|
|
40
|
+
exports.handleEmptyResultError = handleEmptyResultError;
|
|
41
|
+
exports.handleNonExistingRecord = handleNonExistingRecord;
|
|
42
|
+
exports.handlePrismaClientInitializationError = handlePrismaClientInitializationError;
|
|
43
|
+
const app_error_1 = __importDefault(require("./app-error"));
|
|
44
|
+
function handleJWTError() {
|
|
45
|
+
return new app_error_1.default("Invalid token. Please log in again!", 401);
|
|
46
|
+
}
|
|
47
|
+
function handleJWTExpired() {
|
|
48
|
+
return new app_error_1.default("Your token has expired, Please log again!", 401);
|
|
49
|
+
}
|
|
50
|
+
function handlePrismaClientValidationError(err) {
|
|
51
|
+
const message = err?.message?.split("\n")[err?.message.split("\n").length - 1];
|
|
52
|
+
return new app_error_1.default(message, 400);
|
|
53
|
+
}
|
|
54
|
+
function handleAuthenticationError(_) {
|
|
55
|
+
const message = "Authentication failed against the database server. Please check your credentials.";
|
|
56
|
+
return new app_error_1.default(message, 401);
|
|
57
|
+
}
|
|
58
|
+
function handleServerNotReachableError(_) {
|
|
59
|
+
const message = "The database server is not reachable. Verify your connection string or ensure the server is online.";
|
|
60
|
+
return new app_error_1.default(message, 503);
|
|
61
|
+
}
|
|
62
|
+
function handleConnectionTimeoutError(_) {
|
|
63
|
+
const message = "Connection to the database timed out. Please check server performance or network connectivity.";
|
|
64
|
+
return new app_error_1.default(message, 504);
|
|
65
|
+
}
|
|
66
|
+
function handleDatabaseNotFoundError(_) {
|
|
67
|
+
const message = "The specified database does not exist on the server.";
|
|
68
|
+
return new app_error_1.default(message, 404);
|
|
69
|
+
}
|
|
70
|
+
function handleEnvironmentVariableError(err) {
|
|
71
|
+
const missingVars = err?.missing || "unknown environment variables";
|
|
72
|
+
const message = `Missing or invalid environment variables: ${missingVars}. Please check your configuration.`;
|
|
73
|
+
return new app_error_1.default(message, 500);
|
|
74
|
+
}
|
|
75
|
+
function handleFieldValueTooLargeError(err) {
|
|
76
|
+
const message = `The value for the field "${err?.meta?.field_name}" is too large. Please provide a smaller value.`;
|
|
77
|
+
return new app_error_1.default(message, 400);
|
|
78
|
+
}
|
|
79
|
+
function handleRecordNotFoundError(_) {
|
|
80
|
+
const message = "No record found for the given query. Ensure the query parameters are correct.";
|
|
81
|
+
return new app_error_1.default(message, 404);
|
|
82
|
+
}
|
|
83
|
+
function handleUniqueConstraintError(err) {
|
|
84
|
+
const field = err?.meta?.target || "unknown field";
|
|
85
|
+
const message = `Duplicate value detected for the unique field(s): ${field}. Please use a different value.`;
|
|
86
|
+
return new app_error_1.default(message, 409);
|
|
87
|
+
}
|
|
88
|
+
function handleForeignKeyConstraintError(_) {
|
|
89
|
+
const message = "Foreign key constraint violation. Ensure that the referenced record exists.";
|
|
90
|
+
return new app_error_1.default(message, 400);
|
|
91
|
+
}
|
|
92
|
+
function handleConstraintFailedError(err) {
|
|
93
|
+
const constraint = err?.meta?.constraint || "unknown constraint";
|
|
94
|
+
const message = `A database constraint "${constraint}" failed. Please review your input data.`;
|
|
95
|
+
return new app_error_1.default(message, 400);
|
|
96
|
+
}
|
|
97
|
+
function handleInvalidFieldValueError(err) {
|
|
98
|
+
const fieldName = err?.meta?.field_name || "unknown field";
|
|
99
|
+
const message = `Invalid value provided for the field "${fieldName}". Please provide a valid value.`;
|
|
100
|
+
return new app_error_1.default(message, 400);
|
|
101
|
+
}
|
|
102
|
+
function handleInvalidFieldProvidedError(err) {
|
|
103
|
+
const fieldName = err?.meta?.field_name || "unknown field";
|
|
104
|
+
const message = `The field "${fieldName}" has been provided with an invalid value. Check the data and try again.`;
|
|
105
|
+
return new app_error_1.default(message, 400);
|
|
106
|
+
}
|
|
107
|
+
function handleDataValidationError(_) {
|
|
108
|
+
const message = "Data validation error occurred. Please ensure all fields meet the required criteria.";
|
|
109
|
+
return new app_error_1.default(message, 400);
|
|
110
|
+
}
|
|
111
|
+
function handleQueryParsingError(err) {
|
|
112
|
+
const query = err?.meta?.query || "unknown query";
|
|
113
|
+
const message = `Failed to parse the query: "${query}". Check the syntax and structure.`;
|
|
114
|
+
return new app_error_1.default(message, 400);
|
|
115
|
+
}
|
|
116
|
+
function handleInvalidQueryFormatError(err) {
|
|
117
|
+
const query = err?.meta?.query || "unknown query";
|
|
118
|
+
const message = `The query format is invalid: "${query}". Ensure the query adheres to the expected format.`;
|
|
119
|
+
return new app_error_1.default(message, 400);
|
|
120
|
+
}
|
|
121
|
+
function handleRawQueryExecutionError(_) {
|
|
122
|
+
const message = "An error occurred during the execution of a raw query. Verify the query and try again.";
|
|
123
|
+
return new app_error_1.default(message, 500);
|
|
124
|
+
}
|
|
125
|
+
function handleNullConstraintViolationError(err) {
|
|
126
|
+
const fieldName = err?.meta?.field_name || "unknown field";
|
|
127
|
+
const message = `The field "${fieldName}" cannot be null. Please provide a value.`;
|
|
128
|
+
return new app_error_1.default(message, 400);
|
|
129
|
+
}
|
|
130
|
+
function handleSchemaCreationFailedError(_) {
|
|
131
|
+
const message = "Failed to create the database schema. Verify the schema definition and try again.";
|
|
132
|
+
return new app_error_1.default(message, 500);
|
|
133
|
+
}
|
|
134
|
+
function handleMigrationAlreadyAppliedError(err) {
|
|
135
|
+
const migrationName = err?.meta?.migration || "unknown migration";
|
|
136
|
+
const message = `The migration "${migrationName}" has already been applied to the database.`;
|
|
137
|
+
return new app_error_1.default(message, 409);
|
|
138
|
+
}
|
|
139
|
+
function handleMigrationScriptFailedError(err) {
|
|
140
|
+
const migrationName = err?.meta?.migration || "unknown migration";
|
|
141
|
+
const message = `The migration script "${migrationName}" failed. Review the script and resolve any issues.`;
|
|
142
|
+
return new app_error_1.default(message, 500);
|
|
143
|
+
}
|
|
144
|
+
function handleVersionMismatchError(_) {
|
|
145
|
+
const message = `Version mismatch: The database schema and migration versions are inconsistent. Please check and resolve this issue.`;
|
|
146
|
+
return new app_error_1.default(message, 400);
|
|
147
|
+
}
|
|
148
|
+
function handleMigrationFileReadError(err) {
|
|
149
|
+
const migrationFile = err?.meta?.migration_file || "unknown file";
|
|
150
|
+
const message = `Failed to read the migration file "${migrationFile}". Ensure the file exists and is accessible.`;
|
|
151
|
+
return new app_error_1.default(message, 500);
|
|
152
|
+
}
|
|
153
|
+
function handleSchemaDriftError(_) {
|
|
154
|
+
const message = `Schema drift detected: The database schema differs from the expected state. Run migrations or sync schema to resolve.`;
|
|
155
|
+
return new app_error_1.default(message, 400);
|
|
156
|
+
}
|
|
157
|
+
function handleSchemaSyntaxError(_) {
|
|
158
|
+
const message = `Syntax error in the schema file. Please check for typos or invalid syntax in your schema definition.`;
|
|
159
|
+
return new app_error_1.default(message, 500);
|
|
160
|
+
}
|
|
161
|
+
function handleClientTypeError(_) {
|
|
162
|
+
const message = `Type error, Ensure proper usage of methods and correct data types.`;
|
|
163
|
+
return new app_error_1.default(message, 400);
|
|
164
|
+
}
|
|
165
|
+
function handleDynamicQueryError(_) {
|
|
166
|
+
const message = `Error constructing or executing a dynamic query. Verify query structure and parameters.`;
|
|
167
|
+
return new app_error_1.default(message, 400);
|
|
168
|
+
}
|
|
169
|
+
function handleRelationLoadingError(err) {
|
|
170
|
+
const relation = err?.meta?.relation || "unknown relation";
|
|
171
|
+
const message = `Error loading relation "${relation}". Ensure it is correctly defined and included in the query.`;
|
|
172
|
+
return new app_error_1.default(message, 400);
|
|
173
|
+
}
|
|
174
|
+
function handleBinaryError(err) {
|
|
175
|
+
const binaryName = err?.meta?.binary || "unknown binary";
|
|
176
|
+
const message = `Error with Prisma binary "${binaryName}". Ensure the binary is properly installed and compatible.`;
|
|
177
|
+
return new app_error_1.default(message, 500);
|
|
178
|
+
}
|
|
179
|
+
function handleNetworkError(_) {
|
|
180
|
+
const message = `Network error: Unable to connect to the database or internet. Please check your network connection.`;
|
|
181
|
+
return new app_error_1.default(message, 500);
|
|
182
|
+
}
|
|
183
|
+
function handleUnhandledPromiseError(_) {
|
|
184
|
+
const message = `Unhandled promise rejection detected. Please check asynchronous code for proper error handling.`;
|
|
185
|
+
return new app_error_1.default(message, 500);
|
|
186
|
+
}
|
|
187
|
+
function handleDataTypeError(err) {
|
|
188
|
+
const field = err?.meta?.field || "unknown field";
|
|
189
|
+
const expectedType = err?.meta?.expected_type || "unknown type";
|
|
190
|
+
const message = `Invalid data type for field "${field}". Expected type: ${expectedType}.`;
|
|
191
|
+
return new app_error_1.default(message, 400);
|
|
192
|
+
}
|
|
193
|
+
function handleEmptyResultError(_) {
|
|
194
|
+
const message = `Empty result: No data was found for the given query. Ensure the query criteria are correct.`;
|
|
195
|
+
return new app_error_1.default(message, 404);
|
|
196
|
+
}
|
|
197
|
+
function handleNonExistingRecord(err) {
|
|
198
|
+
const message = err?.meta?.cause ||
|
|
199
|
+
`Operation could not be completed as the required record was not found`;
|
|
200
|
+
return new app_error_1.default(message, 404, err.meta || {}, "RecordNotFound");
|
|
201
|
+
}
|
|
202
|
+
function handlePrismaClientInitializationError(_) {
|
|
203
|
+
return new app_error_1.default("Service temporarily unavailable", 503, {}, "DatabaseNotAvailable");
|
|
204
|
+
}
|
|
205
|
+
//# sourceMappingURL=error-handler.helpers.js.map
|
|
@@ -1 +1,233 @@
|
|
|
1
|
-
"use strict";
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
const app_error_1 = __importDefault(require("../error-handler/utils/app-error"));
|
|
7
|
+
const file_upload_service_1 = require("./file-upload.service");
|
|
8
|
+
const path_1 = __importDefault(require("path"));
|
|
9
|
+
const fs_1 = __importDefault(require("fs"));
|
|
10
|
+
const catch_async_1 = __importDefault(require("../error-handler/utils/catch-async"));
|
|
11
|
+
const server_1 = require("../../server");
|
|
12
|
+
const file_upload_helpers_1 = require("./utils/helpers/file-upload.helpers");
|
|
13
|
+
const dynamic_loader_1 = require("../../utils/dynamic-loader");
|
|
14
|
+
class FileUploadController {
|
|
15
|
+
constructor() {
|
|
16
|
+
this.uploadFile = (0, catch_async_1.default)(async (req, res, next) => {
|
|
17
|
+
this.interceptors =
|
|
18
|
+
(0, dynamic_loader_1.getModuleComponents)("file-upload")?.interceptors || {};
|
|
19
|
+
const { fileType } = req.params;
|
|
20
|
+
const { format, width, height, resizeTo } = req.query;
|
|
21
|
+
const options = { format, width, height, resizeTo };
|
|
22
|
+
const { documentUploadService, fileUploadService, imageUploadService, videoUploadService, } = (0, file_upload_service_1.getFileUploadServices)();
|
|
23
|
+
const { fileUpload } = (0, server_1.getArkosConfig)();
|
|
24
|
+
const baseUploadDir = fileUpload?.baseUploadDir || "/uploads";
|
|
25
|
+
const uploadPath = path_1.default.resolve(process.cwd(), baseUploadDir, fileType);
|
|
26
|
+
try {
|
|
27
|
+
await fs_1.default.promises.access(uploadPath);
|
|
28
|
+
}
|
|
29
|
+
catch (err) {
|
|
30
|
+
await fs_1.default.promises.mkdir(uploadPath, { recursive: true });
|
|
31
|
+
}
|
|
32
|
+
let uploader;
|
|
33
|
+
switch (fileType) {
|
|
34
|
+
case "images":
|
|
35
|
+
uploader = imageUploadService;
|
|
36
|
+
break;
|
|
37
|
+
case "videos":
|
|
38
|
+
uploader = videoUploadService;
|
|
39
|
+
break;
|
|
40
|
+
case "documents":
|
|
41
|
+
uploader = documentUploadService;
|
|
42
|
+
break;
|
|
43
|
+
case "files":
|
|
44
|
+
uploader = fileUploadService;
|
|
45
|
+
break;
|
|
46
|
+
default:
|
|
47
|
+
return next(new app_error_1.default("Invalid file type", 400));
|
|
48
|
+
}
|
|
49
|
+
uploader.handleMultipleUpload()(req, res, async (err) => {
|
|
50
|
+
if (err)
|
|
51
|
+
return next(err);
|
|
52
|
+
let data;
|
|
53
|
+
if (req.files && Array.isArray(req.files) && req.files.length > 0) {
|
|
54
|
+
if (fileType === "images") {
|
|
55
|
+
data = await Promise.all(req.files.map((file) => (0, file_upload_helpers_1.processImage)(req, file.path, options)));
|
|
56
|
+
}
|
|
57
|
+
else {
|
|
58
|
+
data = await Promise.all(req.files.map((file) => (0, file_upload_helpers_1.processFile)(req, file.path)));
|
|
59
|
+
}
|
|
60
|
+
data = data.filter((url) => url !== null);
|
|
61
|
+
}
|
|
62
|
+
else if (req.file) {
|
|
63
|
+
if (fileType === "images") {
|
|
64
|
+
data = await (0, file_upload_helpers_1.processImage)(req, req.file.path, options);
|
|
65
|
+
}
|
|
66
|
+
else {
|
|
67
|
+
data = await (0, file_upload_helpers_1.processFile)(req, req.file.path);
|
|
68
|
+
}
|
|
69
|
+
}
|
|
70
|
+
else {
|
|
71
|
+
return next(new app_error_1.default("No file uploaded", 400));
|
|
72
|
+
}
|
|
73
|
+
const jsonContent = {
|
|
74
|
+
success: true,
|
|
75
|
+
data,
|
|
76
|
+
message: Array.isArray(data)
|
|
77
|
+
? `${data.length} files uploaded successfully`
|
|
78
|
+
: "File uploaded successfully",
|
|
79
|
+
};
|
|
80
|
+
if (this.interceptors?.afterUploadFile) {
|
|
81
|
+
req.responseData = jsonContent;
|
|
82
|
+
req.responseStatus = 200;
|
|
83
|
+
return next();
|
|
84
|
+
}
|
|
85
|
+
res.status(200).json(jsonContent);
|
|
86
|
+
});
|
|
87
|
+
});
|
|
88
|
+
this.deleteFile = (0, catch_async_1.default)(async (req, res, next) => {
|
|
89
|
+
this.interceptors =
|
|
90
|
+
(0, dynamic_loader_1.getModuleComponents)("file-upload")?.interceptors || {};
|
|
91
|
+
const { fileType, fileName } = req.params;
|
|
92
|
+
const { documentUploadService, fileUploadService, imageUploadService, videoUploadService, } = (0, file_upload_service_1.getFileUploadServices)();
|
|
93
|
+
let uploader;
|
|
94
|
+
switch (fileType) {
|
|
95
|
+
case "images":
|
|
96
|
+
uploader = imageUploadService;
|
|
97
|
+
break;
|
|
98
|
+
case "videos":
|
|
99
|
+
uploader = videoUploadService;
|
|
100
|
+
break;
|
|
101
|
+
case "documents":
|
|
102
|
+
uploader = documentUploadService;
|
|
103
|
+
break;
|
|
104
|
+
case "files":
|
|
105
|
+
uploader = fileUploadService;
|
|
106
|
+
break;
|
|
107
|
+
default:
|
|
108
|
+
return next(new app_error_1.default("Invalid file type", 400));
|
|
109
|
+
}
|
|
110
|
+
try {
|
|
111
|
+
const { fileUpload } = (0, server_1.getArkosConfig)();
|
|
112
|
+
const baseUploadRoute = fileUpload?.baseRoute || "/api/uploads";
|
|
113
|
+
const urlPattern = new RegExp(`${baseUploadRoute}/${fileType}/${fileName}`);
|
|
114
|
+
const isExpectedUrlPattern = urlPattern.test(req.originalUrl);
|
|
115
|
+
if (isExpectedUrlPattern) {
|
|
116
|
+
const fullUrl = `${req.protocol}://${req.get("host")}${req.originalUrl}`;
|
|
117
|
+
await uploader.deleteFileByUrl(fullUrl);
|
|
118
|
+
}
|
|
119
|
+
else {
|
|
120
|
+
await uploader.deleteFileByName(fileName, fileType);
|
|
121
|
+
}
|
|
122
|
+
if (this.interceptors.afterDeleteFile) {
|
|
123
|
+
req.responseStatus = 204;
|
|
124
|
+
return next();
|
|
125
|
+
}
|
|
126
|
+
res.status(204).json();
|
|
127
|
+
}
|
|
128
|
+
catch (error) {
|
|
129
|
+
if (error instanceof app_error_1.default) {
|
|
130
|
+
return next(error);
|
|
131
|
+
}
|
|
132
|
+
return next(new app_error_1.default("File not found", 404));
|
|
133
|
+
}
|
|
134
|
+
});
|
|
135
|
+
this.updateFile = (0, catch_async_1.default)(async (req, res, next) => {
|
|
136
|
+
this.interceptors =
|
|
137
|
+
(0, dynamic_loader_1.getModuleComponents)("file-upload")?.interceptors || {};
|
|
138
|
+
const { fileType, fileName } = req.params;
|
|
139
|
+
const { format, width, height, resizeTo } = req.query;
|
|
140
|
+
const options = { format, width, height, resizeTo };
|
|
141
|
+
const { documentUploadService, fileUploadService, imageUploadService, videoUploadService, } = (0, file_upload_service_1.getFileUploadServices)();
|
|
142
|
+
const { fileUpload } = (0, server_1.getArkosConfig)();
|
|
143
|
+
const baseUploadDir = fileUpload?.baseUploadDir || "/uploads";
|
|
144
|
+
const uploadPath = path_1.default.resolve(process.cwd(), baseUploadDir, fileType);
|
|
145
|
+
try {
|
|
146
|
+
await fs_1.default.promises.access(uploadPath);
|
|
147
|
+
}
|
|
148
|
+
catch (err) {
|
|
149
|
+
await fs_1.default.promises.mkdir(uploadPath, { recursive: true });
|
|
150
|
+
}
|
|
151
|
+
let uploader;
|
|
152
|
+
switch (fileType) {
|
|
153
|
+
case "images":
|
|
154
|
+
uploader = imageUploadService;
|
|
155
|
+
break;
|
|
156
|
+
case "videos":
|
|
157
|
+
uploader = videoUploadService;
|
|
158
|
+
break;
|
|
159
|
+
case "documents":
|
|
160
|
+
uploader = documentUploadService;
|
|
161
|
+
break;
|
|
162
|
+
case "files":
|
|
163
|
+
uploader = fileUploadService;
|
|
164
|
+
break;
|
|
165
|
+
default:
|
|
166
|
+
return next(new app_error_1.default("Invalid file type", 400));
|
|
167
|
+
}
|
|
168
|
+
uploader.handleMultipleUpload()(req, res, async (err) => {
|
|
169
|
+
if (err)
|
|
170
|
+
return next(err);
|
|
171
|
+
if (!req.file &&
|
|
172
|
+
(!req.files || !Array.isArray(req.files) || req.files.length === 0)) {
|
|
173
|
+
return next(new app_error_1.default("No new file uploaded", 400));
|
|
174
|
+
}
|
|
175
|
+
if (fileName && fileName.trim() !== "") {
|
|
176
|
+
try {
|
|
177
|
+
const baseUploadRoute = fileUpload?.baseRoute || "/api/uploads";
|
|
178
|
+
const urlPattern = new RegExp(`${baseUploadRoute}/${fileType}/${fileName}`);
|
|
179
|
+
const isExpectedUrlPattern = urlPattern.test(req.originalUrl);
|
|
180
|
+
if (isExpectedUrlPattern) {
|
|
181
|
+
const oldFileUrl = `${req.protocol}://${req.get("host")}${req.originalUrl}`;
|
|
182
|
+
await uploader.deleteFileByUrl(oldFileUrl);
|
|
183
|
+
}
|
|
184
|
+
else {
|
|
185
|
+
await uploader.deleteFileByName(fileName, fileType);
|
|
186
|
+
}
|
|
187
|
+
}
|
|
188
|
+
catch (error) {
|
|
189
|
+
console.warn(`Could not delete old file: ${fileName}`, error);
|
|
190
|
+
}
|
|
191
|
+
}
|
|
192
|
+
let data;
|
|
193
|
+
if (req.files && Array.isArray(req.files) && req.files.length > 0) {
|
|
194
|
+
if (fileType === "images") {
|
|
195
|
+
data = await Promise.all(req.files.map((file) => (0, file_upload_helpers_1.processImage)(req, file.path, options)));
|
|
196
|
+
}
|
|
197
|
+
else {
|
|
198
|
+
data = await Promise.all(req.files.map((file) => (0, file_upload_helpers_1.processFile)(req, file.path)));
|
|
199
|
+
}
|
|
200
|
+
data = data.filter((url) => url !== null);
|
|
201
|
+
}
|
|
202
|
+
else if (req.file) {
|
|
203
|
+
if (fileType === "images") {
|
|
204
|
+
data = await (0, file_upload_helpers_1.processImage)(req, req.file.path, options);
|
|
205
|
+
}
|
|
206
|
+
else {
|
|
207
|
+
data = await (0, file_upload_helpers_1.processFile)(req, req.file.path);
|
|
208
|
+
}
|
|
209
|
+
}
|
|
210
|
+
const jsonContent = {
|
|
211
|
+
success: true,
|
|
212
|
+
data,
|
|
213
|
+
message: Array.isArray(data)
|
|
214
|
+
? fileName && fileName.trim() !== ""
|
|
215
|
+
? `File updated successfully. ${data.length} new files uploaded`
|
|
216
|
+
: `${data.length} files uploaded successfully`
|
|
217
|
+
: fileName && fileName.trim() !== ""
|
|
218
|
+
? "File updated successfully"
|
|
219
|
+
: "File uploaded successfully",
|
|
220
|
+
};
|
|
221
|
+
if (this.interceptors.afterUpdateFile) {
|
|
222
|
+
req.responseData = jsonContent;
|
|
223
|
+
req.responseStatus = 200;
|
|
224
|
+
return next();
|
|
225
|
+
}
|
|
226
|
+
res.status(200).json(jsonContent);
|
|
227
|
+
});
|
|
228
|
+
});
|
|
229
|
+
}
|
|
230
|
+
}
|
|
231
|
+
const fileUploadController = new FileUploadController();
|
|
232
|
+
exports.default = fileUploadController;
|
|
233
|
+
//# sourceMappingURL=file-upload.controller.js.map
|
|
@@ -1 +1,60 @@
|
|
|
1
|
-
"use strict";
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
exports.getFileUploadRouter = getFileUploadRouter;
|
|
7
|
+
const express_1 = require("express");
|
|
8
|
+
const dynamic_loader_1 = require("../../utils/dynamic-loader");
|
|
9
|
+
const auth_service_1 = __importDefault(require("../auth/auth.service"));
|
|
10
|
+
const file_upload_controller_1 = __importDefault(require("./file-upload.controller"));
|
|
11
|
+
const path_1 = __importDefault(require("path"));
|
|
12
|
+
const express_2 = __importDefault(require("express"));
|
|
13
|
+
const deepmerge_helper_1 = __importDefault(require("../../utils/helpers/deepmerge.helper"));
|
|
14
|
+
const base_middlewares_1 = require("../base/base.middlewares");
|
|
15
|
+
const routers_helpers_1 = require("../../utils/helpers/routers.helpers");
|
|
16
|
+
const file_upload_helpers_1 = require("./utils/helpers/file-upload.helpers");
|
|
17
|
+
const base_router_helpers_1 = require("../base/utils/helpers/base.router.helpers");
|
|
18
|
+
const router = (0, express_1.Router)();
|
|
19
|
+
async function getFileUploadRouter(arkosConfig) {
|
|
20
|
+
const { fileUpload } = arkosConfig;
|
|
21
|
+
const moduleComponents = (0, dynamic_loader_1.getModuleComponents)("file-upload");
|
|
22
|
+
let { interceptors = {}, authConfigs = {}, router: customRouterModule, } = {};
|
|
23
|
+
if ((moduleComponents)) {
|
|
24
|
+
({
|
|
25
|
+
interceptors = {},
|
|
26
|
+
authConfigs = {},
|
|
27
|
+
router: customRouterModule,
|
|
28
|
+
} = moduleComponents);
|
|
29
|
+
}
|
|
30
|
+
const routerConfig = customRouterModule?.config || {};
|
|
31
|
+
if (routerConfig?.disable === true)
|
|
32
|
+
return router;
|
|
33
|
+
let basePathname = fileUpload?.baseRoute || "/api/uploads/";
|
|
34
|
+
if (!basePathname.startsWith("/"))
|
|
35
|
+
basePathname = "/" + basePathname;
|
|
36
|
+
if (!basePathname.endsWith("/"))
|
|
37
|
+
basePathname = basePathname + "/";
|
|
38
|
+
if (!(0, base_router_helpers_1.isEndpointDisabled)(routerConfig, "findFile")) {
|
|
39
|
+
router.get(`${basePathname}*`, auth_service_1.default.handleAuthenticationControl("View", authConfigs.authenticationControl), auth_service_1.default.handleAccessControl("View", "file-upload", authConfigs.accessControl), ...(0, routers_helpers_1.processMiddleware)(interceptors?.beforeFindFile), file_upload_helpers_1.adjustRequestUrl, express_2.default.static(path_1.default.resolve(process.cwd(), fileUpload?.baseUploadDir || "uploads"), (0, deepmerge_helper_1.default)({
|
|
40
|
+
maxAge: "1y",
|
|
41
|
+
etag: true,
|
|
42
|
+
lastModified: true,
|
|
43
|
+
dotfiles: "ignore",
|
|
44
|
+
fallthrough: true,
|
|
45
|
+
index: false,
|
|
46
|
+
cacheControl: true,
|
|
47
|
+
}, fileUpload?.expressStaticOptions || {})), ...(0, routers_helpers_1.processMiddleware)(interceptors?.onFindFileError, { type: "error" }));
|
|
48
|
+
}
|
|
49
|
+
if (!(0, base_router_helpers_1.isEndpointDisabled)(routerConfig, "uploadFile")) {
|
|
50
|
+
router.post(`${basePathname}:fileType`, auth_service_1.default.handleAuthenticationControl("Create", authConfigs.authenticationControl), auth_service_1.default.handleAccessControl("Create", "file-upload", authConfigs.accessControl), ...(0, routers_helpers_1.processMiddleware)(interceptors?.beforeUploadFile), file_upload_controller_1.default.uploadFile, ...(0, routers_helpers_1.processMiddleware)(interceptors?.afterUploadFile), base_middlewares_1.sendResponse, ...(0, routers_helpers_1.processMiddleware)(interceptors?.onUploadFileError, { type: "error" }));
|
|
51
|
+
}
|
|
52
|
+
if (!(0, base_router_helpers_1.isEndpointDisabled)(routerConfig, "updateFile")) {
|
|
53
|
+
router.patch(`${basePathname}:fileType/:fileName`, auth_service_1.default.handleAuthenticationControl("Update", authConfigs.authenticationControl), auth_service_1.default.handleAccessControl("Update", "file-upload", authConfigs.accessControl), ...(0, routers_helpers_1.processMiddleware)(interceptors?.beforeUpdateFile), file_upload_controller_1.default.updateFile, ...(0, routers_helpers_1.processMiddleware)(interceptors?.afterUpdateFile), base_middlewares_1.sendResponse, ...(0, routers_helpers_1.processMiddleware)(interceptors?.onUpdateFileError, { type: "error" }));
|
|
54
|
+
}
|
|
55
|
+
if (!(0, base_router_helpers_1.isEndpointDisabled)(routerConfig, "deleteFile")) {
|
|
56
|
+
router.delete(`${basePathname}:fileType/:fileName`, auth_service_1.default.handleAuthenticationControl("Delete", authConfigs.authenticationControl), auth_service_1.default.handleAccessControl("Delete", "file-upload", authConfigs.accessControl), ...(0, routers_helpers_1.processMiddleware)(interceptors?.beforeDeleteFile), file_upload_controller_1.default.deleteFile, ...(0, routers_helpers_1.processMiddleware)(interceptors?.afterDeleteFile), base_middlewares_1.sendResponse, ...(0, routers_helpers_1.processMiddleware)(interceptors?.onDeleteFileError, { type: "error" }));
|
|
57
|
+
}
|
|
58
|
+
return router;
|
|
59
|
+
}
|
|
60
|
+
//# sourceMappingURL=file-upload.router.js.map
|