@solidxai/core 0.1.10-beta.0 → 0.1.10-beta.10

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (189) hide show
  1. package/dist/commands/run-tests.command.d.ts +2 -0
  2. package/dist/commands/run-tests.command.d.ts.map +1 -1
  3. package/dist/commands/run-tests.command.js +49 -17
  4. package/dist/commands/run-tests.command.js.map +1 -1
  5. package/dist/controllers/action-metadata.controller.js +1 -1
  6. package/dist/controllers/action-metadata.controller.js.map +1 -1
  7. package/dist/controllers/facebook-authentication.controller.js +1 -1
  8. package/dist/controllers/facebook-authentication.controller.js.map +1 -1
  9. package/dist/controllers/google-authentication.controller.js +1 -1
  10. package/dist/controllers/google-authentication.controller.js.map +1 -1
  11. package/dist/controllers/menu-item-metadata.controller.js +1 -1
  12. package/dist/controllers/menu-item-metadata.controller.js.map +1 -1
  13. package/dist/controllers/microsoft-authentication.controller.js +1 -1
  14. package/dist/controllers/microsoft-authentication.controller.js.map +1 -1
  15. package/dist/controllers/mq-message-queue.controller.js +1 -1
  16. package/dist/controllers/mq-message-queue.controller.js.map +1 -1
  17. package/dist/controllers/mq-message.controller.js +1 -1
  18. package/dist/controllers/mq-message.controller.js.map +1 -1
  19. package/dist/controllers/user.controller.d.ts.map +1 -1
  20. package/dist/controllers/user.controller.js.map +1 -1
  21. package/dist/controllers/view-metadata.controller.js +1 -1
  22. package/dist/controllers/view-metadata.controller.js.map +1 -1
  23. package/dist/dtos/update-user.dto.d.ts +1 -0
  24. package/dist/dtos/update-user.dto.d.ts.map +1 -1
  25. package/dist/dtos/update-user.dto.js +7 -1
  26. package/dist/dtos/update-user.dto.js.map +1 -1
  27. package/dist/entities/chatter-message-details.entity.d.ts.map +1 -1
  28. package/dist/entities/chatter-message-details.entity.js +0 -1
  29. package/dist/entities/chatter-message-details.entity.js.map +1 -1
  30. package/dist/entities/user.entity.js +1 -0
  31. package/dist/entities/user.entity.js.map +1 -1
  32. package/dist/helpers/bootstrap.helper.d.ts.map +1 -1
  33. package/dist/helpers/bootstrap.helper.js +2 -0
  34. package/dist/helpers/bootstrap.helper.js.map +1 -1
  35. package/dist/helpers/field-crud-managers/BigIntFieldCrudManager.js.map +1 -1
  36. package/dist/helpers/field-crud-managers/SelectionDynamicFieldCrudManager.js.map +1 -1
  37. package/dist/helpers/module-metadata-helper.service.js.map +1 -1
  38. package/dist/jobs/database/chatter-queue-subscriber-database.service.d.ts.map +1 -1
  39. package/dist/jobs/database/chatter-queue-subscriber-database.service.js +3 -3
  40. package/dist/jobs/database/chatter-queue-subscriber-database.service.js.map +1 -1
  41. package/dist/jobs/database/trigger-mcp-client-subscriber-database.service.js.map +1 -1
  42. package/dist/jobs/rabbitmq/chatter-queue-subscriber.service.d.ts.map +1 -1
  43. package/dist/jobs/rabbitmq/chatter-queue-subscriber.service.js +3 -3
  44. package/dist/jobs/rabbitmq/chatter-queue-subscriber.service.js.map +1 -1
  45. package/dist/jobs/redis/chatter-queue-subscriber-redis.service.d.ts.map +1 -1
  46. package/dist/jobs/redis/chatter-queue-subscriber-redis.service.js +3 -3
  47. package/dist/jobs/redis/chatter-queue-subscriber-redis.service.js.map +1 -1
  48. package/dist/repository/security-rule.repository.js.map +1 -1
  49. package/dist/seeders/module-metadata-seeder.service.js.map +1 -1
  50. package/dist/seeders/module-test-data.service.d.ts +7 -0
  51. package/dist/seeders/module-test-data.service.d.ts.map +1 -1
  52. package/dist/seeders/module-test-data.service.js +94 -18
  53. package/dist/seeders/module-test-data.service.js.map +1 -1
  54. package/dist/seeders/permission-metadata-seeder.service.js.map +1 -1
  55. package/dist/seeders/seed-data/solid-core-metadata.json +34 -2
  56. package/dist/services/authentication.service.d.ts.map +1 -1
  57. package/dist/services/authentication.service.js +5 -5
  58. package/dist/services/authentication.service.js.map +1 -1
  59. package/dist/services/chatter-message.service.d.ts +6 -3
  60. package/dist/services/chatter-message.service.d.ts.map +1 -1
  61. package/dist/services/chatter-message.service.js +23 -35
  62. package/dist/services/chatter-message.service.js.map +1 -1
  63. package/dist/services/crud.service.js.map +1 -1
  64. package/dist/services/csv.service.js.map +1 -1
  65. package/dist/services/dashboard.service.js.map +1 -1
  66. package/dist/services/database/database-bootstrap.service.js.map +1 -1
  67. package/dist/services/excel.service.js.map +1 -1
  68. package/dist/services/export-transaction.service.js.map +1 -1
  69. package/dist/services/field-metadata.service.js +2 -2
  70. package/dist/services/field-metadata.service.js.map +1 -1
  71. package/dist/services/fixtures.service.js.map +1 -1
  72. package/dist/services/import-transaction.service.js.map +1 -1
  73. package/dist/services/list-of-values.service.js.map +1 -1
  74. package/dist/services/model-metadata.service.d.ts.map +1 -1
  75. package/dist/services/model-metadata.service.js +3 -13
  76. package/dist/services/model-metadata.service.js.map +1 -1
  77. package/dist/services/module-metadata.service.js.map +1 -1
  78. package/dist/services/queues/database-publisher.service.js +3 -3
  79. package/dist/services/queues/database-publisher.service.js.map +1 -1
  80. package/dist/services/queues/database-subscriber.service.js +3 -3
  81. package/dist/services/queues/database-subscriber.service.js.map +1 -1
  82. package/dist/services/queues/rabbitmq-publisher.service.js +3 -3
  83. package/dist/services/queues/rabbitmq-publisher.service.js.map +1 -1
  84. package/dist/services/queues/rabbitmq-subscriber.service.js +4 -4
  85. package/dist/services/queues/rabbitmq-subscriber.service.js.map +1 -1
  86. package/dist/services/queues/redis-publisher.service.d.ts.map +1 -1
  87. package/dist/services/queues/redis-publisher.service.js +4 -1
  88. package/dist/services/queues/redis-publisher.service.js.map +1 -1
  89. package/dist/services/queues/redis-subscriber.service.d.ts.map +1 -1
  90. package/dist/services/queues/redis-subscriber.service.js +4 -1
  91. package/dist/services/queues/redis-subscriber.service.js.map +1 -1
  92. package/dist/services/role-metadata.service.js.map +1 -1
  93. package/dist/services/scheduled-jobs/scheduler.service.js.map +1 -1
  94. package/dist/services/settings/default-settings-provider.service.d.ts +58 -8
  95. package/dist/services/settings/default-settings-provider.service.d.ts.map +1 -1
  96. package/dist/services/settings/default-settings-provider.service.js +21 -4
  97. package/dist/services/settings/default-settings-provider.service.js.map +1 -1
  98. package/dist/services/sms/TwilioSMSService.js.map +1 -1
  99. package/dist/services/solid-introspect.service.js.map +1 -1
  100. package/dist/services/user-activity-history.service.js.map +1 -1
  101. package/dist/services/view-metadata.service.d.ts.map +1 -1
  102. package/dist/services/view-metadata.service.js +17 -2
  103. package/dist/services/view-metadata.service.js.map +1 -1
  104. package/dist/solid-core.module.d.ts +1 -0
  105. package/dist/solid-core.module.d.ts.map +1 -1
  106. package/dist/solid-core.module.js +1 -0
  107. package/dist/solid-core.module.js.map +1 -1
  108. package/dist/subscribers/computed-entity-field.subscriber.js.map +1 -1
  109. package/dist/subscribers/security-rule.subscriber.d.ts.map +1 -1
  110. package/dist/subscribers/security-rule.subscriber.js.map +1 -1
  111. package/dist/subscribers/view-metadata.subscriber.js.map +1 -1
  112. package/dist/testing/core/testing-engine.js.map +1 -1
  113. package/dist/testing/reporter/console-reporter.d.ts +10 -0
  114. package/dist/testing/reporter/console-reporter.d.ts.map +1 -1
  115. package/dist/testing/reporter/console-reporter.js +21 -0
  116. package/dist/testing/reporter/console-reporter.js.map +1 -1
  117. package/dist/testing/reporter/reporter.types.d.ts +7 -0
  118. package/dist/testing/reporter/reporter.types.d.ts.map +1 -1
  119. package/dist/testing/reporter/reporter.types.js.map +1 -1
  120. package/dist/testing/reporter/webhook-reporter.d.ts +54 -0
  121. package/dist/testing/reporter/webhook-reporter.d.ts.map +1 -0
  122. package/dist/testing/reporter/webhook-reporter.js +74 -0
  123. package/dist/testing/reporter/webhook-reporter.js.map +1 -0
  124. package/dist/testing/runner/run-from-metadata.d.ts.map +1 -1
  125. package/dist/testing/runner/run-from-metadata.js +20 -1
  126. package/dist/testing/runner/run-from-metadata.js.map +1 -1
  127. package/package.json +5 -1
  128. package/src/commands/run-tests.command.ts +45 -17
  129. package/src/controllers/action-metadata.controller.ts +1 -1
  130. package/src/controllers/facebook-authentication.controller.ts +1 -1
  131. package/src/controllers/google-authentication.controller.ts +1 -1
  132. package/src/controllers/menu-item-metadata.controller.ts +1 -1
  133. package/src/controllers/microsoft-authentication.controller.ts +1 -1
  134. package/src/controllers/mq-message-queue.controller.ts +1 -1
  135. package/src/controllers/mq-message.controller.ts +1 -1
  136. package/src/controllers/user.controller.ts +16 -16
  137. package/src/controllers/view-metadata.controller.ts +1 -1
  138. package/src/dtos/update-user.dto.ts +4 -0
  139. package/src/entities/chatter-message-details.entity.ts +1 -2
  140. package/src/entities/user.entity.ts +1 -1
  141. package/src/helpers/bootstrap.helper.ts +3 -0
  142. package/src/helpers/field-crud-managers/BigIntFieldCrudManager.ts +1 -1
  143. package/src/helpers/field-crud-managers/SelectionDynamicFieldCrudManager.ts +1 -1
  144. package/src/helpers/module-metadata-helper.service.ts +1 -1
  145. package/src/jobs/database/chatter-queue-subscriber-database.service.ts +4 -2
  146. package/src/jobs/database/trigger-mcp-client-subscriber-database.service.ts +1 -1
  147. package/src/jobs/rabbitmq/chatter-queue-subscriber.service.ts +4 -2
  148. package/src/jobs/redis/chatter-queue-subscriber-redis.service.ts +10 -3
  149. package/src/repository/security-rule.repository.ts +1 -1
  150. package/src/seeders/module-metadata-seeder.service.ts +4 -4
  151. package/src/seeders/module-test-data.service.ts +107 -15
  152. package/src/seeders/permission-metadata-seeder.service.ts +1 -1
  153. package/src/seeders/seed-data/solid-core-metadata.json +34 -2
  154. package/src/services/authentication.service.ts +19 -31
  155. package/src/services/chatter-message.service.ts +28 -38
  156. package/src/services/crud.service.ts +3 -3
  157. package/src/services/csv.service.ts +1 -1
  158. package/src/services/dashboard.service.ts +1 -1
  159. package/src/services/database/database-bootstrap.service.ts +1 -1
  160. package/src/services/excel.service.ts +1 -1
  161. package/src/services/export-transaction.service.ts +2 -2
  162. package/src/services/field-metadata.service.ts +3 -3
  163. package/src/services/fixtures.service.ts +2 -2
  164. package/src/services/import-transaction.service.ts +2 -2
  165. package/src/services/list-of-values.service.ts +1 -1
  166. package/src/services/model-metadata.service.ts +22 -21
  167. package/src/services/module-metadata.service.ts +7 -7
  168. package/src/services/queues/database-publisher.service.ts +4 -4
  169. package/src/services/queues/database-subscriber.service.ts +7 -7
  170. package/src/services/queues/rabbitmq-publisher.service.ts +7 -7
  171. package/src/services/queues/rabbitmq-subscriber.service.ts +13 -13
  172. package/src/services/queues/redis-publisher.service.ts +7 -4
  173. package/src/services/queues/redis-subscriber.service.ts +9 -6
  174. package/src/services/role-metadata.service.ts +1 -1
  175. package/src/services/scheduled-jobs/scheduler.service.ts +5 -5
  176. package/src/services/settings/default-settings-provider.service.ts +21 -4
  177. package/src/services/sms/TwilioSMSService.ts +2 -2
  178. package/src/services/solid-introspect.service.ts +2 -2
  179. package/src/services/user-activity-history.service.ts +1 -1
  180. package/src/services/view-metadata.service.ts +25 -8
  181. package/src/solid-core.module.ts +1 -0
  182. package/src/subscribers/computed-entity-field.subscriber.ts +1 -1
  183. package/src/subscribers/security-rule.subscriber.ts +8 -8
  184. package/src/subscribers/view-metadata.subscriber.ts +1 -1
  185. package/src/testing/core/testing-engine.ts +2 -2
  186. package/src/testing/reporter/console-reporter.ts +27 -0
  187. package/src/testing/reporter/reporter.types.ts +7 -0
  188. package/src/testing/reporter/webhook-reporter.ts +116 -0
  189. package/src/testing/runner/run-from-metadata.ts +19 -1
@@ -1 +1 @@
1
- {"version":3,"file":"crud.service.js","sourceRoot":"","sources":["../../src/services/crud.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { BadRequestException, InternalServerErrorException, NotFoundException } from \"@nestjs/common\";\nimport { DiscoveryService, ModuleRef } from \"@nestjs/core\";\nimport { isArray } from \"class-validator\";\nimport { CommonEntity } from \"../entities/common.entity\";\nimport { User } from \"../entities/user.entity\";\nimport { SolidBaseRepository } from \"../repository/solid-base.repository\";\nimport { SettingService } from \"./setting.service\";\nimport { ERROR_MESSAGES } from \"src/constants/error-messages\";\nimport { SUCCESS_MESSAGES } from \"src/constants/success-messages\";\nimport { EntityManager, FindOptionsWhere, In, IsNull, Not, QueryFailedError, SelectQueryBuilder } from \"typeorm\";\nimport { QueryDeepPartialEntity } from \"typeorm/query-builder/QueryPartialEntity\";\nimport { BasicFilterDto } from \"../dtos/basic-filters.dto\";\nimport { ComputedFieldValueType, RelationType, SelectionValueType, SolidFieldType } from \"../dtos/create-field-metadata.dto\";\nimport { MediaStorageProviderType } from \"../dtos/create-media-storage-provider-metadata.dto\";\nimport { FieldMetadata } from \"../entities/field-metadata.entity\";\nimport { ModelMetadata } from \"../entities/model-metadata.entity\";\nimport { BigIntFieldCrudManager } from \"../helpers/field-crud-managers/BigIntFieldCrudManager\";\nimport { BooleanFieldCrudManager } from \"../helpers/field-crud-managers/BooleanFieldCrudManager\";\nimport { ComputedFieldCrudManager } from \"../helpers/field-crud-managers/ComputedFieldCrudManager\";\nimport { DateFieldCrudManager } from \"../helpers/field-crud-managers/DateFieldCrudManager\";\nimport { DecimalFieldCrudManager } from \"../helpers/field-crud-managers/DecimalFieldCrudManager\";\nimport { EmailFieldCrudManager, MAX_EMAIL_LENGTH } from \"../helpers/field-crud-managers/EmailFieldCrudManager\";\nimport { IntFieldCrudManager } from \"../helpers/field-crud-managers/IntFieldCrudManager\";\nimport { JsonFieldCrudManager } from \"../helpers/field-crud-managers/JsonFieldCrudManager\";\nimport { LongTextFieldCrudManager } from \"../helpers/field-crud-managers/LongTextFieldCrudManager\";\nimport { ManyToManyRelationFieldCrudManager, ManyToManyRelationFieldOptions } from \"../helpers/field-crud-managers/ManyToManyRelationFieldCrudManager\";\nimport { ManyToOneRelationFieldCrudManager, ManyToOneRelationFieldOptions } from \"../helpers/field-crud-managers/ManyToOneRelationFieldCrudManager\";\nimport { MediaFieldCrudManager, SolidMediaType } from \"../helpers/field-crud-managers/MediaFieldCrudManager\";\nimport { NoOpsFieldCrudManager } from \"../helpers/field-crud-managers/NoOpsFieldCrudManager\";\nimport { OneToManyRelationFieldCrudManager, OneToManyRelationFieldOptions } from \"../helpers/field-crud-managers/OneToManyRelationFieldCrudManager\";\nimport { PasswordFieldCrudManager } from \"../helpers/field-crud-managers/PasswordFieldCrudManager\";\nimport { RichTextFieldCrudManager } from \"../helpers/field-crud-managers/RichTextFieldCrudManager\";\nimport { SelectionDynamicFieldCrudManager } from \"../helpers/field-crud-managers/SelectionDynamicFieldCrudManager\";\nimport { SelectionStaticFieldCrudManager } from \"../helpers/field-crud-managers/SelectionStaticFieldCrudManager\";\nimport { ShortTextFieldCrudManager } from \"../helpers/field-crud-managers/ShortTextFieldCrudManager\";\nimport { UUIDFieldCrudManager } from \"../helpers/field-crud-managers/UUIDFieldCrudManager\";\nimport { FieldCrudManager, MediaWithFullUrl } from \"../interfaces\";\nimport { CrudHelperService, FilterCombinator, UserIdFields } from \"./crud-helper.service\";\nimport { HashingService } from \"./hashing.service\";\nimport { SolidRegistry } from \"src/helpers/solid-registry\";\nimport { getMediaStorageProvider } from \"./mediaStorageProviders\";\nimport { ModelMetadataService } from \"./model-metadata.service\";\nimport { RequestContextService } from \"./request-context.service\";\nimport { BasicGroupFilterDto } from \"src/dtos/basic-group-filters.dto\";\n\n\nexport class CRUDService<T extends CommonEntity> { // Add two generic value i.e Person,CreatePersonDto, so we get the proper types in our service\n\n private _modelMetadataService: ModelMetadataService;\n private _crudHelperService: CrudHelperService;\n private _discoveryService: DiscoveryService;\n private _settingService: SettingService;\n\n constructor(\n readonly entityManager: EntityManager,\n readonly repo: SolidBaseRepository<T>,\n readonly modelName: string,\n readonly moduleName: string,\n readonly moduleRef: ModuleRef,\n readonly defaultDatasourceEntityManager?: EntityManager\n ) { }\n\n protected get modelMetadataService(): ModelMetadataService {\n return this._modelMetadataService ??= this.moduleRef.get(ModelMetadataService, { strict: false });\n }\n\n protected get crudHelperService(): CrudHelperService {\n return this._crudHelperService ??= this.moduleRef.get(CrudHelperService, { strict: false });\n }\n\n protected get discoveryService(): DiscoveryService {\n return this._discoveryService ??= this.moduleRef.get(DiscoveryService, { strict: false });\n }\n\n protected get settingService(): SettingService {\n return this._settingService ??= this.moduleRef.get(SettingService, { strict: false });\n }\n\n private async tryCreateAsExtensionUser(createDto: any): Promise<T | null> {\n if (this.repo.metadata?.parentEntityMetadata?.target !== User) return null;\n const registry = this.moduleRef.get(SolidRegistry, { strict: false });\n if (!registry?.getExtensionUserCreationProvider()) {\n throw new InternalServerErrorException(\n `No ExtensionUserCreationProvider registered. Register one to create ${this.repo.metadata.name} entities.`,\n );\n }\n const { AuthenticationService } = await import('./authentication.service');\n const authService = this.moduleRef.get(AuthenticationService, { strict: false });\n return authService.signUp(createDto) as unknown as T;\n }\n\n async create(createDto: any, files: Express.Multer.File[] = [], solidRequestContext: any = {}): Promise<T> {\n const asExtensionUser = await this.tryCreateAsExtensionUser(createDto);\n if (asExtensionUser !== null) return asExtensionUser;\n\n // This class will be extended by the generated service class i.e PersonService\n // The data required to identify the model and module name will be passed from the generate CrudService subclass\n //TODO: Algorithm to create the entity\n // 1. Fire a query and load all the fields in the provided model name for a particular module\n // FIXME This can be optimized to take in module name i.e (handle scenario wherein same model exists in multiple modules)\n let hasMediaFields = false;\n\n const model = await this.loadModel();\n // Check wheather user has create permission for model\n if (solidRequestContext.activeUser) {\n const hasPermission = this.crudHelperService.hasCreatePermissionOnModel(solidRequestContext.activeUser, model.singularName);\n if (!hasPermission) {\n throw new BadRequestException(ERROR_MESSAGES.FORBIDDEN);\n }\n }\n // const inverseRelationFields = await this.loadInverseRelationFields();\n const fieldsToProcess = [...model.fields];\n\n // 2. Loop through the fields with a switch statement\n // 3. Handle the fields based on field type\n for (const field of fieldsToProcess) {\n const transformed = await this.validateAndTransformDto(field, createDto, files, hasMediaFields);\n createDto = transformed.dto;\n hasMediaFields = transformed.hasMediaFields;\n };\n try {\n // 5. Save the entity\n // For media, we need to use a storage provider and save the media, then save the associated uri against the entity or media table\n const entity = this.repo.create(createDto);\n const savedEntity = await this.repo.save(entity) as unknown as T;\n\n // 6. Save the media\n if (hasMediaFields) {\n await this.saveMedia(model, files, savedEntity);\n }\n return savedEntity;\n } catch (error) {\n if (error instanceof QueryFailedError && error.message.includes('duplicate key value violates unique constraint')) {\n throw new BadRequestException(ERROR_MESSAGES.DUPLICATE_ENTRY);\n }\n throw error;\n }\n }\n\n private async loadModel() {\n return await this.modelMetadataService.findOneBySingularName(this.modelName, {\n fields: {\n model: {\n userKeyField: true\n },\n mediaStorageProvider: true,\n },\n module: true,\n });\n }\n\n private async validateAndTransformDto(field: FieldMetadata, dto: any, files: Express.Multer.File[], hasMediaFields: boolean, isPartialUpdate: boolean = false, isUpdate: boolean = false, entityId?: number) {\n const fieldManager: FieldCrudManager = await this.fieldCrudManager(field, this.entityManager, isPartialUpdate, isUpdate, entityId);\n const validationErrors = fieldManager.validate(dto, files);\n const errors = (validationErrors instanceof Promise) ? await validationErrors : validationErrors;\n if (errors.length > 0) {\n throw new BadRequestException(`Validation errors in ${field.name} is invalid i.e ${errors.map(e => e.error).join(', ')}`); //FIXME: Better to return a validation error object\n }\n const dtoOrPromise = fieldManager.transformForCreate(dto);\n dto = (dtoOrPromise instanceof Promise) ? await dtoOrPromise : dtoOrPromise;\n hasMediaFields = hasMediaFields || field.type === 'mediaSingle' || field.type === 'mediaMultiple';\n return { dto, hasMediaFields };\n }\n\n private async saveMedia(model: ModelMetadata, files: Express.Multer.File[], savedEntity: T): Promise<void> {\n // Get all the media fields in the dto\n const mediaFields = model.fields.filter(field => field.type === 'mediaSingle' || field.type === 'mediaMultiple');\n\n // Depending upon media storage provider configured, get the appropriate storage provider\n // Using Promise.all to save all media fields in parallel\n await Promise.all(mediaFields.map(async (mediaField) => {\n const media = files.filter(multerFile => multerFile.fieldname === mediaField.name);\n\n // If media is present, then save the media\n if (media.length > 0) {\n const storageProviderMetadata = mediaField.mediaStorageProvider;\n\n // Use the storage provider metadata to get the appropriate storage provider implementation\n const storageProviderType = storageProviderMetadata.type as MediaStorageProviderType;\n\n // Get the storage provider implementation\n const storageProvider = await getMediaStorageProvider(this.moduleRef, storageProviderType);\n\n await storageProvider.store(media, savedEntity, mediaField);\n }\n }));\n }\n\n //TODO: Will the updates be partial i.e PATCH or full i.e PUT\n async update(id: number, updateDto: any, files: Express.Multer.File[] = [], isPartialUpdate: boolean = false, solidRequestContext: any = {}, isUpdate: boolean = false): Promise<T> {\n if (!id) {\n throw new Error(ERROR_MESSAGES.ID_REQUIRED_FOR_UPDATE);\n }\n isUpdate = true;\n const model = await this.loadModel();\n // Check wheather user has update permission for model\n if (solidRequestContext.activeUser) {\n const hasPermission = this.crudHelperService.hasUpdatePermissionOnModel(solidRequestContext.activeUser, model.singularName);\n if (!hasPermission) {\n throw new BadRequestException(ERROR_MESSAGES.FORBIDDEN);\n }\n }\n const entity = await this.repo.findOne({\n where: {\n id: id,\n } as unknown as FindOptionsWhere<T>,\n });\n if (!entity) {\n throw new Error(`Entity [${this.moduleName}.${this.modelName}] with id ${id} not found`);\n }\n\n if (model.draftPublishWorkflow === true && entity.publishedAt) {\n throw new BadRequestException(`Cannot update a published record for model ${this.modelName}. Unpublish it first.`\n );\n }\n\n // // In some instances for legacy tables sometimes id is mapped as a bigint. \n // // in these cases the update method ends up attempting to insert records due to some type orm type mismatch issue.\n // const idFieldMetadata = model.fields.find(f => f.name === 'id');\n // updateDto.id = idFieldMetadata?.type === 'bigint' ? BigInt(id) : id;\n\n // This class will be extended by the generated service class i.e PersonService\n // The data required to identify the model and module name will be passed from the generate CrudService subclass\n //TODO: Algorithm to create the entity\n // 1. Fire a query and load all the fields in the provided model name for a particular module\n // FIXME This can be optimized to take in module name i.e (handle scenario wherein same model exists in multiple modules)\n let hasMediaFields = false;\n\n const fieldsToProcess = [...model.fields];\n\n // 2. Loop through the fields with a switch statement\n // 3. Handle the fields based on field type\n for (const field of fieldsToProcess) {\n const transformed = await this.validateAndTransformDto(field, updateDto, files, hasMediaFields, isPartialUpdate, isUpdate, id);\n updateDto = transformed.dto;\n hasMediaFields = transformed.hasMediaFields;\n }\n\n // 5. Save the entity\n // For media, we need to use a storage provider and save the media, then save the associated uri against the entity or media table\n const mergedEntity = this.repo.merge(entity, updateDto);\n const savedEntity = await this.repo.save(mergedEntity) as T;\n\n //FIXME: Skip the many-to-many, and instead fire differential updates and avoid loading the entire association graph for the ids\n\n // 6. Save the media\n if (hasMediaFields) {\n await this.saveMedia(model, files, savedEntity);\n }\n return savedEntity;\n }\n\n //TODO: Will the updates be partial i.e PATCH or full i.e PUT\n async delete(id: number, solidRequestContext: any = {}) {\n if (!id) {\n throw new Error(ERROR_MESSAGES.ID_REQUIRED_FOR_DELETE);\n }\n const loadedmodel = await this.loadModel();\n // Check wheather user has update permission for model\n if (solidRequestContext.activeUser) {\n const hasPermission = this.crudHelperService.hasDeletePermissionOnModel(solidRequestContext.activeUser, loadedmodel.singularName);\n if (!hasPermission) {\n throw new BadRequestException(ERROR_MESSAGES.FORBIDDEN);\n }\n }\n\n const model = await this.modelMetadataService.findOneBySingularName(this.modelName, {\n fields: {\n model: true,\n mediaStorageProvider: true,\n },\n module: true,\n });\n const entity = await this.repo.findOne({\n where: {\n id: id,\n } as unknown as FindOptionsWhere<T>,\n }\n );\n if (!entity) {\n throw new Error(`Entity [${this.moduleName}.${this.modelName}] with id ${id} not found`);\n }\n\n if (model.draftPublishWorkflow === true && entity.publishedAt) {\n throw new BadRequestException(`Cannot update a published record for model ${this.modelName}, Unpublish it first.`);\n }\n\n // If the model has internationalisation enabled, delete children with defaultEntityLocaleId === this entity's id\n if (model.internationalisation) {\n // Find all child entities where defaultEntityLocaleId === this entity's id\n const childEntities = await this.repo.find({\n where: { defaultEntityLocaleId: id } as any\n });\n\n if (childEntities.length > 0) {\n if (model.enableSoftDelete === true) {\n await this.repo.softRemove(childEntities);\n } else {\n await this.repo.remove(childEntities);\n }\n }\n }\n\n if (model.enableSoftDelete === true) {\n await this.repo.softRemove(entity);\n return this.repo.save(entity);\n } else {\n return this.repo.remove(entity);\n }\n }\n\n private async fieldCrudManager(fieldMetadata: FieldMetadata, entityManager: EntityManager, isPartialUpdate: boolean = false, isUpdate: boolean = false, entityId?: number) {\n const commonOptions = { required: fieldMetadata.required && !isPartialUpdate, fieldName: fieldMetadata.name, isUpdate };\n switch (fieldMetadata.type) {\n case SolidFieldType.shortText: {\n const options = { ...commonOptions, length: fieldMetadata.max, regexPattern: fieldMetadata.regexPattern };\n return new ShortTextFieldCrudManager(options);\n }\n case SolidFieldType.longtext: {\n const options = { ...commonOptions, regexPattern: fieldMetadata.regexPattern };\n return new LongTextFieldCrudManager(options);\n }\n case SolidFieldType.boolean: {\n const options = { ...commonOptions };\n return new BooleanFieldCrudManager(options);\n }\n case SolidFieldType.richText: {\n const options = { ...commonOptions, regexPattern: fieldMetadata.regexPattern };\n return new RichTextFieldCrudManager(options);\n }\n case SolidFieldType.json: {\n const options = { ...commonOptions };\n return new JsonFieldCrudManager(options);\n }\n case SolidFieldType.int: {\n const options = { ...commonOptions, min: fieldMetadata.min, max: fieldMetadata.max };\n return new IntFieldCrudManager(options);\n }\n case SolidFieldType.decimal: {\n const options = { ...commonOptions, min: fieldMetadata.min, max: fieldMetadata.max };\n return new DecimalFieldCrudManager(options);\n }\n case SolidFieldType.bigint: {\n const options = { ...commonOptions, min: fieldMetadata.min, max: fieldMetadata.max };\n return new BigIntFieldCrudManager(options);\n }\n case SolidFieldType.email: {\n const options = { ...commonOptions, max: fieldMetadata.max ?? MAX_EMAIL_LENGTH, regexPattern: fieldMetadata.regexPattern };\n return new EmailFieldCrudManager(options);\n }\n case SolidFieldType.date:\n case SolidFieldType.datetime: {\n const options = { ...commonOptions };\n return new DateFieldCrudManager(options);\n }\n case SolidFieldType.password: {\n const options = { ...commonOptions, min: fieldMetadata.min, max: fieldMetadata.max, regexPattern: fieldMetadata.regexPattern, hashingService: this.moduleRef.get(HashingService, { strict: false }) };\n return new PasswordFieldCrudManager(options);\n }\n case SolidFieldType.mediaSingle:\n case SolidFieldType.mediaMultiple: {\n // update will need to delete the existing media and save the new media \n // case 'mediaSingle':\n // Use the EntityController to extract uploaded content & pass to the entity service.\n // If embedded media, then the media uri will saved in the entity table,\n // else the uri will be saved in the media table\n // Plan the media table schema e.g id, uri, storageProvider, entity_id, entity_name, createdAt, updatedAt\n // break;\n // case 'mediaMultiple':\n // Use the EntityController to extract uploaded content & pass to the entity service.\n // If embedded media, then the media uri will saved in the entity table, else the uri will be saved in the media table\n // Plan the media table schema e.g id, uri, storageProvider, entity_id, entity_name, createdAt, updatedAt\n const options = {\n ...commonOptions,\n mediaMaxSizeKb: fieldMetadata.mediaMaxSizeKb,\n mediaTypes: fieldMetadata.mediaTypes,\n type: fieldMetadata.type as unknown as SolidMediaType\n };\n return new MediaFieldCrudManager(options);\n }\n case SolidFieldType.relation: {\n // Identify if the field is for the inverse side or not\n if (fieldMetadata.relationType === RelationType.manyToOne) {\n const relationCoModelUserKeyFieldName = await this.getUserKeyFieldNameForModel(fieldMetadata.relationCoModelSingularName);\n const manyToOneOptions: ManyToOneRelationFieldOptions = {\n ...commonOptions,\n relationCoModelSingularName: fieldMetadata.relationCoModelSingularName,\n // modelUserKeyFieldName: fieldMetadata.model.userKeyField?.name,\n modelSingularName: fieldMetadata.model.singularName,\n relationCoModelUserKeyFieldName: relationCoModelUserKeyFieldName,\n entityManager,\n }\n return new ManyToOneRelationFieldCrudManager(manyToOneOptions);\n }\n else if (fieldMetadata.relationType === RelationType.oneToMany) {\n const oneToManyOptions: OneToManyRelationFieldOptions = {\n ...commonOptions,\n relationCoModelSingularName: fieldMetadata.relationCoModelSingularName,\n modelSingularName: fieldMetadata.model.singularName,\n entityManager,\n inverseFieldName: fieldMetadata.relationCoModelFieldName,\n inverseRelationCoModelFieldName: fieldMetadata.name,\n entityId,\n }\n return new OneToManyRelationFieldCrudManager(oneToManyOptions);\n }\n else if (fieldMetadata.relationType === RelationType.manyTomany) {\n if (fieldMetadata.isRelationManyToManyOwner) {\n const manyToManyOptions: ManyToManyRelationFieldOptions = {\n ...commonOptions,\n relationCoModelSingularName: fieldMetadata.relationCoModelSingularName,\n modelSingularName: fieldMetadata.model.singularName,\n isInverseSide: false,\n entityManager,\n fieldName: fieldMetadata.name,\n entityId,\n }\n return new ManyToManyRelationFieldCrudManager(manyToManyOptions);\n }\n else {\n const inverseManyToManyOptions: ManyToManyRelationFieldOptions = {\n ...commonOptions,\n relationCoModelSingularName: fieldMetadata.relationCoModelSingularName,\n modelSingularName: fieldMetadata.model.singularName,\n isInverseSide: true,\n entityManager,\n fieldName: fieldMetadata.relationCoModelFieldName,\n relationCoModelFieldName: fieldMetadata.name,\n entityId,\n }\n return new ManyToManyRelationFieldCrudManager(inverseManyToManyOptions);\n }\n }\n else throw new Error(ERROR_MESSAGES.RELATION_TYPE_NOT_SUPPORTED);\n // return (fieldMetadata.relationType === 'many-to-one') ? new ManyToOneRelationFieldCrudManager(fieldMetadata, entityManager) : new ManyToManyRelationFieldCrudManager(fieldMetadata, entityManager); //FIXME many-to-many pending\n // ManyToOne -> fieldId. The value is saved as is. No transformation is required\n // OneToMany -> fieldIds. Get the value of the oneToMany field side. No transformation is required (While saving special provision to be made)\n // ManyToMany\n // break;\n }\n case SolidFieldType.selectionStatic: {\n\n // Validation against the selectionStatic values. No transformation is required\n // If the value is not in the selectionStatic values, then throw\n // Also validate against the selectionType\n const options = { ...commonOptions, selectionStaticValues: fieldMetadata.selectionStaticValues, selectionValueType: fieldMetadata.selectionValueType as SelectionValueType, isMultiSelect: fieldMetadata.isMultiSelect };\n return new SelectionStaticFieldCrudManager(options);\n }\n case SolidFieldType.selectionDynamic: {// [HOLD]\n // Default implementation using list of values.\n // ISelectionProvider interface to be implemented for dynamic selection\n // dataSource: string; // The name of the selection provider\n // filterSchema : json // This is a custom json object that every data source will handle accordingly. We could validate the query against the selection provider\n // values : string[]; // The values returned by the selection provider\n const options = { ...commonOptions, selectionDynamicProvider: fieldMetadata.selectionDynamicProvider, selectionDynamicProviderCtxt: JSON.parse(fieldMetadata.selectionDynamicProviderCtxt), selectionValueType: fieldMetadata.selectionValueType as SelectionValueType, discoveryService: this.discoveryService, isMultiSelect: fieldMetadata.isMultiSelect };\n return new SelectionDynamicFieldCrudManager(options);\n }\n case SolidFieldType.uuid: {\n const options = { ...commonOptions };\n // If no value is provided, then generate a uuid. Add to the dto\n return new UUIDFieldCrudManager(options);\n }\n case SolidFieldType.computed: {\n\n // The value will be computed by the computed provider\n // Invoke the appropriate computed provider, get the value and add to the dto\n const options = { ...commonOptions, computedFieldProvider: fieldMetadata.computedFieldValueProvider, computedFieldValueProviderCtxt: fieldMetadata.computedFieldValueProviderCtxt, computedFieldValueType: fieldMetadata.computedFieldValueType as ComputedFieldValueType, discoveryService: this.discoveryService, skipComputation: this.isSkipComputation(isPartialUpdate, fieldMetadata) };\n return new ComputedFieldCrudManager(options);\n }\n default:\n return new NoOpsFieldCrudManager();\n }\n }\n\n private isSkipComputation(isPartialUpdate: boolean, computedFieldMetadata: FieldMetadata) {\n if (isPartialUpdate) return true; // If it is a partial update, then skip computation\n if (computedFieldMetadata.computedFieldTriggerConfig && computedFieldMetadata.computedFieldTriggerConfig.length > 0) {\n return true; // computedFieldTriggerConfig is a new field introduced as part of the IEntityComputedFieldProvider new interface, so this computation will be skiipped in crud service & will be called in the subscriber instead\n }\n return false; // If it is not a partial update, then do not skip computation\n }\n\n async find(basicFilterDto: BasicFilterDto, solidRequestContext: any = {}) {\n const alias = 'entity';\n // Extract the required keys from the input query\n let { limit, offset, populateMedia, populateGroup, groupFilter } = basicFilterDto;\n const populateUserIdFields = this.crudHelperService.extractUserIdFieldsFromPopulate(basicFilterDto.populate);\n\n const { singularName, internationalisation, draftPublishWorkflow } = await this.loadModel();\n // Check wheather user has update permission for model\n if (solidRequestContext.activeUser) {\n const hasPermission = this.crudHelperService.hasReadPermissionOnModel(solidRequestContext.activeUser, singularName);\n if (!hasPermission) {\n throw new BadRequestException('Forbidden');\n }\n }\n\n // Set the request filter in the request context service\n const requestContextService = this.moduleRef.get(RequestContextService, { strict: false });\n requestContextService.setRequestFilter(basicFilterDto);\n\n // Create above query on pincode table using query builder\n var qb: SelectQueryBuilder<T> = await this.repo.createSecurityRuleAwareQueryBuilder(alias)\n\n if (basicFilterDto.groupBy) {\n const groupFilterQb = (internationalisation && draftPublishWorkflow)\n ? this.crudHelperService.buildFilterQuery(qb, basicFilterDto, alias, internationalisation, draftPublishWorkflow, this.moduleRef, FilterCombinator.AND, false, false)\n : this.crudHelperService.buildFilterQuery(qb, basicFilterDto, alias, undefined, undefined, undefined, FilterCombinator.AND, false, false);\n\n const groupByFields = this.crudHelperService.normalize(basicFilterDto.groupBy);\n if (!groupByFields.length) {\n throw new BadRequestException(ERROR_MESSAGES.INVALID_GROUP_BY_COUNT);\n }\n\n if (basicFilterDto.populateGroup) {\n const hasRelationGroup = groupByFields.some(field => field.includes('.'));\n if (hasRelationGroup) {\n throw new BadRequestException('populateGroup is not supported when grouping on relation fields. Fetch group metadata first and retrieve records in a separate call.');\n }\n }\n\n const { aliasMap: groupAliasMap, formatMap: groupFormatMap, expressionMap: groupExpressionMap } = this.crudHelperService.applyGroupBySelections(groupFilterQb, groupByFields, alias);\n const aggregateAliasMap = this.crudHelperService.applyAggregates(groupFilterQb, basicFilterDto.aggregates, alias);\n const sortAliasMap = { ...groupAliasMap, ...aggregateAliasMap };\n this.crudHelperService.applyGroupSortingAndPagination(groupFilterQb, basicFilterDto.sort, sortAliasMap, limit, offset);\n\n const groupByResult = await groupFilterQb.getRawMany();\n const totalGroups = await this.crudHelperService.countGroups(groupFilterQb);\n\n const groupByFieldsOrdered = this.crudHelperService.normalize(basicFilterDto.groupBy || []);\n const { groupMeta, groupRecords } = await this.handleGroupFind(groupByResult, groupFilter, populateGroup, alias, populateUserIdFields, populateMedia, basicFilterDto, groupAliasMap, aggregateAliasMap, groupByFieldsOrdered, groupFormatMap, groupExpressionMap);\n\n return {\n meta: {\n \"totalRecords\": totalGroups\n },\n groupMeta,\n groupRecords,\n }\n }\n else {\n qb = (internationalisation && draftPublishWorkflow)\n ? this.crudHelperService.buildFilterQuery(qb, basicFilterDto, alias, internationalisation, draftPublishWorkflow, this.moduleRef)\n : this.crudHelperService.buildFilterQuery(qb, basicFilterDto, alias);\n const { meta, records } = await this.handleNonGroupFind(qb, populateUserIdFields, populateMedia, offset, limit, alias);\n return {\n meta,\n records,\n }\n }\n }\n\n private async handleNonGroupFind(qb: SelectQueryBuilder<T>, populateUserIdFields: UserIdFields[], populateMedia: string[], offset: number, limit: number, alias: string) {\n const [entities, count] = await qb.getManyAndCount();\n\n // Populate the entity with the userId fields\n if (populateUserIdFields && populateUserIdFields.length > 0) {\n await this.handlePopulateUserIdFields(populateUserIdFields, entities);\n }\n\n // Populate the entity with the media\n if (populateMedia && populateMedia.length > 0) {\n await this.handlePopulateMedia(populateMedia, entities);\n }\n\n return this.wrapFindResponse(offset, limit, count, entities);\n }\n\n private async handleGroupFind(\n groupByResult: any[],\n groupFilter: BasicGroupFilterDto | undefined,\n populateGroup: boolean,\n alias: string,\n populateUserIdFields: UserIdFields[],\n populateMedia: string[],\n baseFilterDto: BasicFilterDto,\n groupAliasMap: Record<string, string>,\n aggregateAliasMap: Record<string, string>,\n groupByFieldsOrdered: string[],\n groupFormatMap: Record<string, string | undefined>,\n groupExpressionMap: Record<string, string>\n ) {\n const groupMeta = [];\n const groupRecords = [];\n const aggregateAliasSet = new Set(Object.values(aggregateAliasMap));\n // For each group, get the records and the count\n for (const group of groupByResult) {\n if (populateGroup) {\n let groupByQb: SelectQueryBuilder<T> = await this.repo.createSecurityRuleAwareQueryBuilder(alias);\n const groupFilterDto: BasicFilterDto = {\n ...baseFilterDto,\n ...groupFilter,\n groupBy: undefined,\n aggregates: undefined,\n // Only use explicit groupFilter.sort for record ordering; group-level sorts can contain\n // group expressions (e.g. createdAt:day) that are invalid on record queries.\n sort: groupFilter?.sort,\n };\n groupByQb = this.crudHelperService.buildFilterQuery(groupByQb, groupFilterDto, alias);\n groupByQb = this.crudHelperService.buildGroupByRecordsQuery(groupByQb, group, alias, groupAliasMap, aggregateAliasMap, groupExpressionMap);\n const [entities, count] = await groupByQb.getManyAndCount();\n\n // Populate the entity with the userId fields\n if (populateUserIdFields && populateUserIdFields.length > 0) {\n await this.handlePopulateUserIdFields(populateUserIdFields, entities);\n }\n\n // Populate the entity with the media\n if (populateMedia && populateMedia.length > 0) {\n await this.handlePopulateMedia(populateMedia, entities);\n }\n const groupData = this.wrapFindResponse(groupFilter?.offset, groupFilter?.limit, count, entities);\n groupRecords.push(this.crudHelperService.createGroupRecords(group, aggregateAliasSet, groupData, groupByFieldsOrdered, groupAliasMap, groupFormatMap));\n }\n groupMeta.push(this.crudHelperService.createGroupMeta(group, aggregateAliasSet, groupByFieldsOrdered, groupAliasMap, groupFormatMap));\n }\n return { groupMeta, groupRecords };\n }\n\n private wrapFindResponse(offset: number | undefined, limit: number | undefined, count: number, entities: T[]) {\n const safeLimit = limit ?? count ?? 0;\n const safeOffset = offset ?? 0;\n const currentPage = safeLimit ? Math.floor(safeOffset / safeLimit) + 1 : 1;\n const totalPages = safeLimit ? Math.ceil(count / safeLimit) : 1;\n\n const nextPage = safeLimit && currentPage < totalPages ? currentPage + 1 : null;\n const prevPage = safeLimit && currentPage > 1 ? currentPage - 1 : null;\n\n const r = {\n meta: {\n totalRecords: count,\n currentPage: currentPage,\n nextPage: nextPage,\n prevPage: prevPage,\n totalPages: totalPages,\n perPage: safeLimit ? +safeLimit : 0,\n },\n records: entities\n };\n return r;\n }\n\n // entities is an array of T\n // T can contain createdBy and updatedBy fields\n // We need to populate the createdBy and updatedBy fields with the User entity\n private async handlePopulateUserIdFields(userIdFields: UserIdFields[], entities: T[]) {\n const userRepository = this.entityManager.getRepository(User);\n for (const entity of entities) {\n for (const userFieldPath of userIdFields) {\n const userId = entity[userFieldPath as keyof T] as unknown as number;\n if (userId) {\n const user = await userRepository.findOne({\n where: { id: userId },\n });\n // @ts-ignore\n entity[userFieldPath] = user;\n }\n }\n }\n }\n\n private async handlePopulateMedia(populateMedia: string[], entities: T[]) {\n const model = await this.getDatasourceDefaultEntityManager().getRepository(ModelMetadata).findOne({\n where: {\n singularName: this.modelName,\n },\n relations: ['fields', 'fields.mediaStorageProvider', 'fields.model', 'module'],\n });\n\n // Will iterate through every entity & all populateMedia & call getMediaDetails for each field\n for (const entity of entities) {\n for (const mediaFieldPath of populateMedia) {\n await this.populateMediaObject(mediaFieldPath, model, entity);\n }\n }\n return entities;\n }\n\n // Adds the media with full URL to the entity / nested entity\n private async populateMediaObject(mediaFieldPath: string, model: ModelMetadata, entity: T) {\n if (mediaFieldPath.includes('.')) { // mediaFieldPath is a nested field\n const pathParts = mediaFieldPath.split('.');\n const mediaFieldMetadata = await this.getFieldMetadataRecursively(pathParts, model.fields);\n if (!mediaFieldMetadata) {\n throw new BadRequestException(`Media field ${mediaFieldPath} not found in model ${this.modelName}`);\n }\n\n // We can assume that the media field entity model is already populated as part of the entity data\n const mediaFieldEntities = this.getMediaFieldEntities(entity, pathParts);\n if (!mediaFieldEntities || mediaFieldEntities.length === 0) {\n return;//no need to populate data if relation not exists\n }\n // Populate the media field entities with the full URL\n for (const mediaFieldEntity of mediaFieldEntities) {\n const mediaWithFullUrl = await this.getMediaWithFullUrl(mediaFieldEntity, mediaFieldMetadata);\n this.appendMediaKey(mediaWithFullUrl, mediaFieldEntity, mediaFieldMetadata.name);\n // mediaFieldEntity['_media'][mediaFieldPath] = mediaWithFullUrl\n }\n }\n else {\n // mediaFieldPath is a single field\n const mediaFieldMetadata = model.fields.find(field => field.name === mediaFieldPath);\n if (!mediaFieldMetadata) {\n throw new BadRequestException(`Media field ${mediaFieldPath} not found in model ${this.modelName}`);\n }\n const mediaWithFullUrl = await this.getMediaWithFullUrl(entity, mediaFieldMetadata);\n this.appendMediaKey(mediaWithFullUrl, entity, mediaFieldPath);\n // entity['_media'][mediaFieldPath] = mediaWithFullUrl;\n }\n }\n\n // // Add the media with full URL to the entity\n private appendMediaKey(mediaWithFullUrl: MediaWithFullUrl[], entity: T, mediaFieldPath: string) {\n // if _media key already exists, append the new media to the existing array\n if (entity['_media']) {\n entity['_media'][mediaFieldPath] = mediaWithFullUrl;\n }\n else {\n entity['_media'] = {\n [mediaFieldPath]: mediaWithFullUrl\n };\n }\n }\n\n private getMediaFieldEntities(entity: T, mediaPathParts: string[]): T[] {\n let entityPart = entity;\n for (let i = 0; i < mediaPathParts.length - 1; i++) {\n const pathPart = mediaPathParts[i];\n if (entity[pathPart]) {\n entityPart = entity[pathPart];\n } else {\n throw new BadRequestException(`Media field ${pathPart} not found in entity ${JSON.stringify(entity)}`);\n }\n }\n return isArray(entityPart) ? entityPart : [entityPart];\n }\n\n async getMediaWithFullUrl(mediaEntity: any, mediaFieldMetadata: FieldMetadata): Promise<MediaWithFullUrl[]> {\n const storageProviderMetadata = mediaFieldMetadata.mediaStorageProvider;\n const storageProviderType = storageProviderMetadata.type as MediaStorageProviderType;\n const storageProvider = await getMediaStorageProvider(this.moduleRef, storageProviderType);\n const mediaDetails = await storageProvider.retrieve(mediaEntity, mediaFieldMetadata);\n return mediaDetails as MediaWithFullUrl[];\n }\n\n async findOne(id: number, query: any = {}, solidRequestContext: any = {}) {\n const { populate = [], fields = [], populateMedia = [] } = query;\n\n // const normalizedFields = this.crudHelperService.normalize(fields);\n const normalizedPopulate = this.crudHelperService.normalize(populate);\n const normalizedPopulateMedia = this.crudHelperService.normalize(populateMedia);\n\n // if normalizedPopulateMedia, has any nested media paths, then add then to populate excluding the last part\n const additionalPopulate = this.crudHelperService.additionalRelationsRequiredForMediaPopulation(normalizedPopulateMedia);\n // Add the additional populate relations to the normalizedPopulate, if they are not already present\n normalizedPopulate.push(...additionalPopulate.filter((relation) => !normalizedPopulate.includes(relation)));\n\n const model = await this.loadModel();\n // Check wheather user has update permission for model\n if (solidRequestContext.activeUser) {\n const hasPermission = this.crudHelperService.hasReadPermissionOnModel(solidRequestContext.activeUser, model.singularName);\n if (!hasPermission) {\n throw new BadRequestException(ERROR_MESSAGES.FORBIDDEN);\n }\n }\n\n let entity = await this.repo.findOne({\n where: {\n id: id,\n } as unknown as FindOptionsWhere<T>,\n relations: normalizedPopulate,\n select: fields,\n });\n if (!entity) {\n throw new NotFoundException(`Entity [${this.moduleName}.${this.modelName}] with id ${id} not found`);\n }\n // Populate the entity with the media\n if (normalizedPopulateMedia.length > 0) {\n const populatedEntities = await this.handlePopulateMedia(normalizedPopulateMedia, [entity]);\n entity = populatedEntities[0] as Awaited<T>;\n }\n return entity;\n }\n\n async createMany(createDtos: any[], solidRequestContext: any = {}): Promise<T[]> {\n const loadedmodel = await this.loadModel();\n\n // Check wheather user has create permission for model\n if (solidRequestContext.activeUser) {\n const hasPermission = this.crudHelperService.hasCreatePermissionOnModel(solidRequestContext.activeUser, loadedmodel.singularName);\n if (!hasPermission) {\n throw new BadRequestException(ERROR_MESSAGES.FORBIDDEN);\n }\n }\n\n // Fetch model metadata once\n const model = await this.modelMetadataService.findOneBySingularName(this.modelName, {\n fields: {\n model: true,\n mediaStorageProvider: true,\n },\n module: true,\n });\n\n const entitiesForSave: T[] = [];\n for (const createDto of createDtos) {\n // Validate and transform each createDto sequentially\n let transformedDto = createDto;\n for (const field of model.fields) {\n const fieldManager: FieldCrudManager = await this.fieldCrudManager(field, this.entityManager);\n const validationErrors = await fieldManager.validate(createDto, []); // TODO, This is set, because we are not supporting files for insertMany currently\n if (validationErrors.length > 0) {\n throw new BadRequestException(`Validation errors in ${field.name} are invalid: ${validationErrors.map(e => e.error).join(', ')}`);\n }\n transformedDto = await fieldManager.transformForCreate(createDto);\n }\n const entity = this.repo.create(transformedDto);\n entitiesForSave.push(entity as unknown as T);\n }\n // Save all entities in a single batch\n const savedEntities = await this.repo.save(entitiesForSave) as T[];\n return savedEntities;\n }\n\n async insertMany(createDtos: any[], filesArray: Express.Multer.File[][] = [], solidRequestContext: any = {}): Promise<T[]> {\n const savedEntities = await this.createMany(createDtos, solidRequestContext);\n return savedEntities;\n }\n\n async deleteMany(ids: number[], solidRequestContext: any = {}): Promise<any> {\n\n if (!ids || ids.length === 0) {\n throw new Error(ERROR_MESSAGES.DELETE_IDS_REQUIRED);\n }\n\n const loadedmodel = await this.loadModel();\n // Check wheather user has update permission for model\n if (solidRequestContext.activeUser) {\n const hasPermission = this.crudHelperService.hasDeletePermissionOnModel(solidRequestContext.activeUser, loadedmodel.singularName);\n if (!hasPermission) {\n throw new BadRequestException(ERROR_MESSAGES.FORBIDDEN);\n }\n }\n const model = await this.modelMetadataService.findOneBySingularName(this.modelName, {\n fields: {\n model: true,\n mediaStorageProvider: true,\n },\n module: true,\n });\n\n\n\n const removedEntities = [];\n for (let i = 0; i < ids.length; i++) {\n const id = ids[i]\n const entity = await this.repo.findOne({\n where: {\n id: id,\n } as unknown as FindOptionsWhere<T>,\n });\n\n removedEntities.push(entity);\n }\n\n\n // entity-level flag\n const isDraftPublishEnabled = model?.draftPublishWorkflow === true;\n\n let publishedEntitiesExists: T[] = [];\n\n if (isDraftPublishEnabled) {\n publishedEntitiesExists = removedEntities.filter(\n (x) => !!x?.publishedAt\n );\n }\n\n if (publishedEntitiesExists.length > 0) {\n const publishedEntitiesExistsID = publishedEntitiesExists.map(x => x.id);\n\n throw new BadRequestException(\n `Cannot delete published record(s) for model ${this.modelName} with Ids ${publishedEntitiesExistsID.join(', ')}. Unpublish them first.`\n );\n }\n\n if (model.enableSoftDelete === true) {\n await this.repo.softRemove(removedEntities);\n return this.repo.save(removedEntities);\n } else {\n return this.repo.remove(removedEntities);\n }\n // return removedEntities\n }\n\n async recover(id: number, solidRequestContext: any = {}) {\n try {\n const loadedmodel = await this.loadModel();\n // Check wheather user has update permission for model\n if (solidRequestContext.activeUser) {\n const hasPermission = this.crudHelperService.hasRecoverPermissionOnModel(solidRequestContext.activeUser, loadedmodel.singularName);\n if (!hasPermission) {\n throw new BadRequestException(ERROR_MESSAGES.FORBIDDEN);\n }\n }\n\n const softDeletedRows = await this.repo.findOne({\n where: {\n id, deletedAt: Not(IsNull())\n } as unknown as FindOptionsWhere<T>,\n withDeleted: true,\n });\n\n if (!softDeletedRows) {\n throw new Error(ERROR_MESSAGES.NO_SOFT_DELETED_RECORD_FOUND);\n }\n\n await this.repo.update(id, {\n deletedAt: null, deletedTracker: \"not-deleted\"\n } as unknown as QueryDeepPartialEntity<T>\n );\n\n return { message: SUCCESS_MESSAGES.RECORD_RECOVERED, data: softDeletedRows };\n } catch (error) {\n if (error instanceof QueryFailedError) {\n if ((error as any).code === '23505') {\n throw new Error(ERROR_MESSAGES.CONFLICTING_RECORD_ON_UNARCHIVE);\n }\n }\n\n throw new Error(error);\n }\n }\n\n async recoverMany(ids: number[], solidRequestContext: any = {}) {\n try {\n const loadedmodel = await this.loadModel();\n // Check wheather user has update permission for model\n if (solidRequestContext.activeUser) {\n const hasPermission = this.crudHelperService.hasRecoverPermissionOnModel(solidRequestContext.activeUser, loadedmodel.singularName);\n if (!hasPermission) {\n throw new BadRequestException(ERROR_MESSAGES.FORBIDDEN);\n }\n }\n\n if (!ids || ids.length === 0) {\n throw new Error(ERROR_MESSAGES.DELETE_IDS_REQUIRED);\n }\n\n // Find soft-deleted records matching the given IDs\n const softDeletedRows = await this.repo.find({\n where: {\n id: In(ids),\n deletedAt: Not(IsNull()),\n } as unknown as FindOptionsWhere<T>,\n withDeleted: true,\n });\n\n if (softDeletedRows.length === 0) {\n throw new Error(ERROR_MESSAGES.NO_SOFT_DELETED_RECORDS_FOUND);\n }\n\n // Recover the specific records by setting deletedAt to null\n await this.repo.update(\n { id: In(ids) } as unknown as FindOptionsWhere<T>,\n { deletedAt: null, deletedTracker: \"not-deleted\" } as unknown as QueryDeepPartialEntity<T>\n );\n\n return { message: SUCCESS_MESSAGES.SELECTED_RECORDS_RECOVERED, recoveredIds: ids };\n } catch (error) {\n if (error instanceof QueryFailedError) {\n if ((error as any).code === \"23505\") {\n throw new Error(ERROR_MESSAGES.CONFLICTING_RECORD_ON_UNARCHIVE);\n }\n }\n\n throw new Error(error);\n }\n }\n\n\n async getFieldMetadataRecursively(pathParts: string[], fields: FieldMetadata[]) {\n if (!pathParts || pathParts.length === 0) {\n throw new BadRequestException(ERROR_MESSAGES.EMPTY_PATH_PARTS);\n }\n\n const [currentPart, ...remainingParts] = pathParts;\n const field = fields.find(field => field.name === currentPart);\n\n if (!field) {\n throw new BadRequestException(`Field ${currentPart} not found in model ${this.modelName}`);\n }\n\n // Base case: last part, return the field\n if (remainingParts.length === 0) {\n return field;\n }\n\n if (!field.relationCoModelSingularName) {\n throw new BadRequestException(`Field ${field.name} does not define a relationCoModelSingularName`);\n }\n\n const relationCoModel = await this.getDatasourceDefaultEntityManager().getRepository(ModelMetadata).findOne({\n where: { singularName: field.relationCoModelSingularName },\n relations: ['fields', 'fields.mediaStorageProvider', 'fields.model'],\n });\n\n if (!relationCoModel) {\n throw new BadRequestException(`Model ${field.relationCoModelSingularName} not found`);\n }\n\n return this.getFieldMetadataRecursively(remainingParts, relationCoModel.fields);\n }\n\n async getUserKeyFieldNameForModel(modelSingularName: string): Promise<string> {\n const model = await this.modelMetadataService.findOneBySingularName(modelSingularName, ['userKeyField']);\n if (!model) {\n throw new BadRequestException(`Model ${modelSingularName} not found`);\n }\n return model.userKeyField?.name || '';\n }\n\n /* Publish a record - sets publishedAt timestamp */\n async publishRecord(id: number, solidRequestContext: any = {}): Promise<T> {\n\n const model = await this.loadModel();\n\n // Check if publish workflow is enabled for this model\n if (!model.draftPublishWorkflow) {\n throw new BadRequestException(\n `Publish workflow is not enabled for ${this.modelName}`\n );\n }\n\n // Check user permissions\n if (solidRequestContext.activeUser) {\n const hasPermission = this.crudHelperService.hasPublishPermissionOnModel(\n solidRequestContext.activeUser,\n model.singularName\n );\n if (!hasPermission) {\n throw new BadRequestException(ERROR_MESSAGES.FORBIDDEN);\n }\n }\n\n // Find the entity\n const entity = await this.repo.findOne({ where: { id } as any });\n if (!entity) {\n throw new NotFoundException(`${this.modelName} with id ${id} not found`);\n }\n\n // Check if already published\n if (entity.publishedAt) {\n throw new BadRequestException(\n `${this.modelName} with id ${id} is already published`\n );\n }\n\n // Update publish status\n const updatedEntity = await this.repo.save({ ...entity, publishedAt: new Date() });\n\n return updatedEntity\n }\n\n /* Unpublish a record - clears publishedAt timestamp */\n async unpublishRecord(id: number, solidRequestContext: any = {}): Promise<T> {\n\n const model = await this.loadModel();\n\n // Check if publish workflow is enabled for this model\n if (!model.draftPublishWorkflow) {\n throw new BadRequestException(\n `Publish workflow is not enabled for ${this.modelName}`\n );\n }\n\n // Check user permissions\n if (solidRequestContext.activeUser) {\n const hasPermission = this.crudHelperService.hasUnpublishPermissionOnModel(\n solidRequestContext.activeUser,\n model.singularName\n );\n if (!hasPermission) {\n throw new BadRequestException(ERROR_MESSAGES.FORBIDDEN);\n }\n }\n\n // Find the entity\n const entity = await this.repo.findOne({ where: { id } as any });\n if (!entity) {\n throw new NotFoundException(`${this.modelName} with id ${id} not found`);\n }\n\n // Check if already unpublished\n if (!entity.publishedAt) {\n throw new BadRequestException(\n `${this.modelName} with id ${id} is already unpublished`\n );\n }\n\n // Update unpublish status\n const updatedEntity = await this.repo.save({ ...entity, publishedAt: null });\n\n return updatedEntity\n }\n\n private getDatasourceDefaultEntityManager() {\n return this.defaultDatasourceEntityManager ?? this.entityManager;\n }\n}\n"]}
1
+ {"version":3,"file":"crud.service.js","sourceRoot":"","sources":["../../src/services/crud.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { BadRequestException, InternalServerErrorException, NotFoundException } from \"@nestjs/common\";\nimport { DiscoveryService, ModuleRef } from \"@nestjs/core\";\nimport { isArray } from \"class-validator\";\nimport { CommonEntity } from \"../entities/common.entity\";\nimport { User } from \"../entities/user.entity\";\nimport { SolidBaseRepository } from \"../repository/solid-base.repository\";\nimport { SettingService } from \"./setting.service\";\nimport { ERROR_MESSAGES } from \"src/constants/error-messages\";\nimport { SUCCESS_MESSAGES } from \"src/constants/success-messages\";\nimport { EntityManager, FindOptionsWhere, In, IsNull, Not, QueryFailedError, SelectQueryBuilder } from \"typeorm\";\nimport { QueryDeepPartialEntity } from \"typeorm/query-builder/QueryPartialEntity\";\nimport { BasicFilterDto } from \"../dtos/basic-filters.dto\";\nimport { ComputedFieldValueType, RelationType, SelectionValueType, SolidFieldType } from \"../dtos/create-field-metadata.dto\";\nimport { MediaStorageProviderType } from \"../dtos/create-media-storage-provider-metadata.dto\";\nimport { FieldMetadata } from \"../entities/field-metadata.entity\";\nimport { ModelMetadata } from \"../entities/model-metadata.entity\";\nimport { BigIntFieldCrudManager } from \"../helpers/field-crud-managers/BigIntFieldCrudManager\";\nimport { BooleanFieldCrudManager } from \"../helpers/field-crud-managers/BooleanFieldCrudManager\";\nimport { ComputedFieldCrudManager } from \"../helpers/field-crud-managers/ComputedFieldCrudManager\";\nimport { DateFieldCrudManager } from \"../helpers/field-crud-managers/DateFieldCrudManager\";\nimport { DecimalFieldCrudManager } from \"../helpers/field-crud-managers/DecimalFieldCrudManager\";\nimport { EmailFieldCrudManager, MAX_EMAIL_LENGTH } from \"../helpers/field-crud-managers/EmailFieldCrudManager\";\nimport { IntFieldCrudManager } from \"../helpers/field-crud-managers/IntFieldCrudManager\";\nimport { JsonFieldCrudManager } from \"../helpers/field-crud-managers/JsonFieldCrudManager\";\nimport { LongTextFieldCrudManager } from \"../helpers/field-crud-managers/LongTextFieldCrudManager\";\nimport { ManyToManyRelationFieldCrudManager, ManyToManyRelationFieldOptions } from \"../helpers/field-crud-managers/ManyToManyRelationFieldCrudManager\";\nimport { ManyToOneRelationFieldCrudManager, ManyToOneRelationFieldOptions } from \"../helpers/field-crud-managers/ManyToOneRelationFieldCrudManager\";\nimport { MediaFieldCrudManager, SolidMediaType } from \"../helpers/field-crud-managers/MediaFieldCrudManager\";\nimport { NoOpsFieldCrudManager } from \"../helpers/field-crud-managers/NoOpsFieldCrudManager\";\nimport { OneToManyRelationFieldCrudManager, OneToManyRelationFieldOptions } from \"../helpers/field-crud-managers/OneToManyRelationFieldCrudManager\";\nimport { PasswordFieldCrudManager } from \"../helpers/field-crud-managers/PasswordFieldCrudManager\";\nimport { RichTextFieldCrudManager } from \"../helpers/field-crud-managers/RichTextFieldCrudManager\";\nimport { SelectionDynamicFieldCrudManager } from \"../helpers/field-crud-managers/SelectionDynamicFieldCrudManager\";\nimport { SelectionStaticFieldCrudManager } from \"../helpers/field-crud-managers/SelectionStaticFieldCrudManager\";\nimport { ShortTextFieldCrudManager } from \"../helpers/field-crud-managers/ShortTextFieldCrudManager\";\nimport { UUIDFieldCrudManager } from \"../helpers/field-crud-managers/UUIDFieldCrudManager\";\nimport { FieldCrudManager, MediaWithFullUrl } from \"../interfaces\";\nimport { CrudHelperService, FilterCombinator, UserIdFields } from \"./crud-helper.service\";\nimport { HashingService } from \"./hashing.service\";\nimport { SolidRegistry } from \"src/helpers/solid-registry\";\nimport { getMediaStorageProvider } from \"./mediaStorageProviders\";\nimport { ModelMetadataService } from \"./model-metadata.service\";\nimport { RequestContextService } from \"./request-context.service\";\nimport { BasicGroupFilterDto } from \"src/dtos/basic-group-filters.dto\";\n\n\nexport class CRUDService<T extends CommonEntity> { // Add two generic value i.e Person,CreatePersonDto, so we get the proper types in our service\n\n private _modelMetadataService: ModelMetadataService;\n private _crudHelperService: CrudHelperService;\n private _discoveryService: DiscoveryService;\n private _settingService: SettingService;\n\n constructor(\n readonly entityManager: EntityManager,\n readonly repo: SolidBaseRepository<T>,\n readonly modelName: string,\n readonly moduleName: string,\n readonly moduleRef: ModuleRef,\n readonly defaultDatasourceEntityManager?: EntityManager\n ) { }\n\n protected get modelMetadataService(): ModelMetadataService {\n return this._modelMetadataService ??= this.moduleRef.get(ModelMetadataService, { strict: false });\n }\n\n protected get crudHelperService(): CrudHelperService {\n return this._crudHelperService ??= this.moduleRef.get(CrudHelperService, { strict: false });\n }\n\n protected get discoveryService(): DiscoveryService {\n return this._discoveryService ??= this.moduleRef.get(DiscoveryService, { strict: false });\n }\n\n protected get settingService(): SettingService {\n return this._settingService ??= this.moduleRef.get(SettingService, { strict: false });\n }\n\n private async tryCreateAsExtensionUser(createDto: any): Promise<T | null> {\n if (this.repo.metadata?.parentEntityMetadata?.target !== User) return null;\n const registry = this.moduleRef.get(SolidRegistry, { strict: false });\n if (!registry?.getExtensionUserCreationProvider()) {\n throw new InternalServerErrorException(\n `No ExtensionUserCreationProvider registered. Register one to create ${this.repo.metadata.name} entities.`,\n );\n }\n const { AuthenticationService } = await import('./authentication.service');\n const authService = this.moduleRef.get(AuthenticationService, { strict: false });\n return authService.signUp(createDto) as unknown as T;\n }\n\n async create(createDto: any, files: Express.Multer.File[] = [], solidRequestContext: any = {}): Promise<T> {\n const asExtensionUser = await this.tryCreateAsExtensionUser(createDto);\n if (asExtensionUser !== null) return asExtensionUser;\n\n // This class will be extended by the generated service class i.e PersonService\n // The data required to identify the model and module name will be passed from the generate CrudService subclass\n //TODO: Algorithm to create the entity\n // 1. Fire a query and load all the fields in the provided model name for a particular module\n // FIXME This can be optimized to take in module name i.e (handle scenario wherein same model exists in multiple modules)\n let hasMediaFields = false;\n\n const model = await this.loadModel();\n // Check wheather user has create permission for model\n if (solidRequestContext.activeUser) {\n const hasPermission = this.crudHelperService.hasCreatePermissionOnModel(solidRequestContext.activeUser, model.singularName);\n if (!hasPermission) {\n throw new BadRequestException(ERROR_MESSAGES.FORBIDDEN);\n }\n }\n // const inverseRelationFields = await this.loadInverseRelationFields();\n const fieldsToProcess = [...model.fields];\n\n // 2. Loop through the fields with a switch statement\n // 3. Handle the fields based on field type\n for (const field of fieldsToProcess) {\n const transformed = await this.validateAndTransformDto(field, createDto, files, hasMediaFields);\n createDto = transformed.dto;\n hasMediaFields = transformed.hasMediaFields;\n };\n try {\n // 5. Save the entity\n // For media, we need to use a storage provider and save the media, then save the associated uri against the entity or media table\n const entity = this.repo.create(createDto);\n const savedEntity = await this.repo.save(entity) as unknown as T;\n\n // 6. Save the media\n if (hasMediaFields) {\n await this.saveMedia(model, files, savedEntity);\n }\n return savedEntity;\n } catch (error: any) {\n if (error instanceof QueryFailedError && error.message.includes('duplicate key value violates unique constraint')) {\n throw new BadRequestException(ERROR_MESSAGES.DUPLICATE_ENTRY);\n }\n throw error;\n }\n }\n\n private async loadModel() {\n return await this.modelMetadataService.findOneBySingularName(this.modelName, {\n fields: {\n model: {\n userKeyField: true\n },\n mediaStorageProvider: true,\n },\n module: true,\n });\n }\n\n private async validateAndTransformDto(field: FieldMetadata, dto: any, files: Express.Multer.File[], hasMediaFields: boolean, isPartialUpdate: boolean = false, isUpdate: boolean = false, entityId?: number) {\n const fieldManager: FieldCrudManager = await this.fieldCrudManager(field, this.entityManager, isPartialUpdate, isUpdate, entityId);\n const validationErrors = fieldManager.validate(dto, files);\n const errors = (validationErrors instanceof Promise) ? await validationErrors : validationErrors;\n if (errors.length > 0) {\n throw new BadRequestException(`Validation errors in ${field.name} is invalid i.e ${errors.map(e => e.error).join(', ')}`); //FIXME: Better to return a validation error object\n }\n const dtoOrPromise = fieldManager.transformForCreate(dto);\n dto = (dtoOrPromise instanceof Promise) ? await dtoOrPromise : dtoOrPromise;\n hasMediaFields = hasMediaFields || field.type === 'mediaSingle' || field.type === 'mediaMultiple';\n return { dto, hasMediaFields };\n }\n\n private async saveMedia(model: ModelMetadata, files: Express.Multer.File[], savedEntity: T): Promise<void> {\n // Get all the media fields in the dto\n const mediaFields = model.fields.filter(field => field.type === 'mediaSingle' || field.type === 'mediaMultiple');\n\n // Depending upon media storage provider configured, get the appropriate storage provider\n // Using Promise.all to save all media fields in parallel\n await Promise.all(mediaFields.map(async (mediaField) => {\n const media = files.filter(multerFile => multerFile.fieldname === mediaField.name);\n\n // If media is present, then save the media\n if (media.length > 0) {\n const storageProviderMetadata = mediaField.mediaStorageProvider;\n\n // Use the storage provider metadata to get the appropriate storage provider implementation\n const storageProviderType = storageProviderMetadata.type as MediaStorageProviderType;\n\n // Get the storage provider implementation\n const storageProvider = await getMediaStorageProvider(this.moduleRef, storageProviderType);\n\n await storageProvider.store(media, savedEntity, mediaField);\n }\n }));\n }\n\n //TODO: Will the updates be partial i.e PATCH or full i.e PUT\n async update(id: number, updateDto: any, files: Express.Multer.File[] = [], isPartialUpdate: boolean = false, solidRequestContext: any = {}, isUpdate: boolean = false): Promise<T> {\n if (!id) {\n throw new Error(ERROR_MESSAGES.ID_REQUIRED_FOR_UPDATE);\n }\n isUpdate = true;\n const model = await this.loadModel();\n // Check wheather user has update permission for model\n if (solidRequestContext.activeUser) {\n const hasPermission = this.crudHelperService.hasUpdatePermissionOnModel(solidRequestContext.activeUser, model.singularName);\n if (!hasPermission) {\n throw new BadRequestException(ERROR_MESSAGES.FORBIDDEN);\n }\n }\n const entity = await this.repo.findOne({\n where: {\n id: id,\n } as unknown as FindOptionsWhere<T>,\n });\n if (!entity) {\n throw new Error(`Entity [${this.moduleName}.${this.modelName}] with id ${id} not found`);\n }\n\n if (model.draftPublishWorkflow === true && entity.publishedAt) {\n throw new BadRequestException(`Cannot update a published record for model ${this.modelName}. Unpublish it first.`\n );\n }\n\n // // In some instances for legacy tables sometimes id is mapped as a bigint. \n // // in these cases the update method ends up attempting to insert records due to some type orm type mismatch issue.\n // const idFieldMetadata = model.fields.find(f => f.name === 'id');\n // updateDto.id = idFieldMetadata?.type === 'bigint' ? BigInt(id) : id;\n\n // This class will be extended by the generated service class i.e PersonService\n // The data required to identify the model and module name will be passed from the generate CrudService subclass\n //TODO: Algorithm to create the entity\n // 1. Fire a query and load all the fields in the provided model name for a particular module\n // FIXME This can be optimized to take in module name i.e (handle scenario wherein same model exists in multiple modules)\n let hasMediaFields = false;\n\n const fieldsToProcess = [...model.fields];\n\n // 2. Loop through the fields with a switch statement\n // 3. Handle the fields based on field type\n for (const field of fieldsToProcess) {\n const transformed = await this.validateAndTransformDto(field, updateDto, files, hasMediaFields, isPartialUpdate, isUpdate, id);\n updateDto = transformed.dto;\n hasMediaFields = transformed.hasMediaFields;\n }\n\n // 5. Save the entity\n // For media, we need to use a storage provider and save the media, then save the associated uri against the entity or media table\n const mergedEntity = this.repo.merge(entity, updateDto);\n const savedEntity = await this.repo.save(mergedEntity) as T;\n\n //FIXME: Skip the many-to-many, and instead fire differential updates and avoid loading the entire association graph for the ids\n\n // 6. Save the media\n if (hasMediaFields) {\n await this.saveMedia(model, files, savedEntity);\n }\n return savedEntity;\n }\n\n //TODO: Will the updates be partial i.e PATCH or full i.e PUT\n async delete(id: number, solidRequestContext: any = {}) {\n if (!id) {\n throw new Error(ERROR_MESSAGES.ID_REQUIRED_FOR_DELETE);\n }\n const loadedmodel = await this.loadModel();\n // Check wheather user has update permission for model\n if (solidRequestContext.activeUser) {\n const hasPermission = this.crudHelperService.hasDeletePermissionOnModel(solidRequestContext.activeUser, loadedmodel.singularName);\n if (!hasPermission) {\n throw new BadRequestException(ERROR_MESSAGES.FORBIDDEN);\n }\n }\n\n const model = await this.modelMetadataService.findOneBySingularName(this.modelName, {\n fields: {\n model: true,\n mediaStorageProvider: true,\n },\n module: true,\n });\n const entity = await this.repo.findOne({\n where: {\n id: id,\n } as unknown as FindOptionsWhere<T>,\n }\n );\n if (!entity) {\n throw new Error(`Entity [${this.moduleName}.${this.modelName}] with id ${id} not found`);\n }\n\n if (model.draftPublishWorkflow === true && entity.publishedAt) {\n throw new BadRequestException(`Cannot update a published record for model ${this.modelName}, Unpublish it first.`);\n }\n\n // If the model has internationalisation enabled, delete children with defaultEntityLocaleId === this entity's id\n if (model.internationalisation) {\n // Find all child entities where defaultEntityLocaleId === this entity's id\n const childEntities = await this.repo.find({\n where: { defaultEntityLocaleId: id } as any\n });\n\n if (childEntities.length > 0) {\n if (model.enableSoftDelete === true) {\n await this.repo.softRemove(childEntities);\n } else {\n await this.repo.remove(childEntities);\n }\n }\n }\n\n if (model.enableSoftDelete === true) {\n await this.repo.softRemove(entity);\n return this.repo.save(entity);\n } else {\n return this.repo.remove(entity);\n }\n }\n\n private async fieldCrudManager(fieldMetadata: FieldMetadata, entityManager: EntityManager, isPartialUpdate: boolean = false, isUpdate: boolean = false, entityId?: number) {\n const commonOptions = { required: fieldMetadata.required && !isPartialUpdate, fieldName: fieldMetadata.name, isUpdate };\n switch (fieldMetadata.type) {\n case SolidFieldType.shortText: {\n const options = { ...commonOptions, length: fieldMetadata.max, regexPattern: fieldMetadata.regexPattern };\n return new ShortTextFieldCrudManager(options);\n }\n case SolidFieldType.longtext: {\n const options = { ...commonOptions, regexPattern: fieldMetadata.regexPattern };\n return new LongTextFieldCrudManager(options);\n }\n case SolidFieldType.boolean: {\n const options = { ...commonOptions };\n return new BooleanFieldCrudManager(options);\n }\n case SolidFieldType.richText: {\n const options = { ...commonOptions, regexPattern: fieldMetadata.regexPattern };\n return new RichTextFieldCrudManager(options);\n }\n case SolidFieldType.json: {\n const options = { ...commonOptions };\n return new JsonFieldCrudManager(options);\n }\n case SolidFieldType.int: {\n const options = { ...commonOptions, min: fieldMetadata.min, max: fieldMetadata.max };\n return new IntFieldCrudManager(options);\n }\n case SolidFieldType.decimal: {\n const options = { ...commonOptions, min: fieldMetadata.min, max: fieldMetadata.max };\n return new DecimalFieldCrudManager(options);\n }\n case SolidFieldType.bigint: {\n const options = { ...commonOptions, min: fieldMetadata.min, max: fieldMetadata.max };\n return new BigIntFieldCrudManager(options);\n }\n case SolidFieldType.email: {\n const options = { ...commonOptions, max: fieldMetadata.max ?? MAX_EMAIL_LENGTH, regexPattern: fieldMetadata.regexPattern };\n return new EmailFieldCrudManager(options);\n }\n case SolidFieldType.date:\n case SolidFieldType.datetime: {\n const options = { ...commonOptions };\n return new DateFieldCrudManager(options);\n }\n case SolidFieldType.password: {\n const options = { ...commonOptions, min: fieldMetadata.min, max: fieldMetadata.max, regexPattern: fieldMetadata.regexPattern, hashingService: this.moduleRef.get(HashingService, { strict: false }) };\n return new PasswordFieldCrudManager(options);\n }\n case SolidFieldType.mediaSingle:\n case SolidFieldType.mediaMultiple: {\n // update will need to delete the existing media and save the new media \n // case 'mediaSingle':\n // Use the EntityController to extract uploaded content & pass to the entity service.\n // If embedded media, then the media uri will saved in the entity table,\n // else the uri will be saved in the media table\n // Plan the media table schema e.g id, uri, storageProvider, entity_id, entity_name, createdAt, updatedAt\n // break;\n // case 'mediaMultiple':\n // Use the EntityController to extract uploaded content & pass to the entity service.\n // If embedded media, then the media uri will saved in the entity table, else the uri will be saved in the media table\n // Plan the media table schema e.g id, uri, storageProvider, entity_id, entity_name, createdAt, updatedAt\n const options = {\n ...commonOptions,\n mediaMaxSizeKb: fieldMetadata.mediaMaxSizeKb,\n mediaTypes: fieldMetadata.mediaTypes,\n type: fieldMetadata.type as unknown as SolidMediaType\n };\n return new MediaFieldCrudManager(options);\n }\n case SolidFieldType.relation: {\n // Identify if the field is for the inverse side or not\n if (fieldMetadata.relationType === RelationType.manyToOne) {\n const relationCoModelUserKeyFieldName = await this.getUserKeyFieldNameForModel(fieldMetadata.relationCoModelSingularName);\n const manyToOneOptions: ManyToOneRelationFieldOptions = {\n ...commonOptions,\n relationCoModelSingularName: fieldMetadata.relationCoModelSingularName,\n // modelUserKeyFieldName: fieldMetadata.model.userKeyField?.name,\n modelSingularName: fieldMetadata.model.singularName,\n relationCoModelUserKeyFieldName: relationCoModelUserKeyFieldName,\n entityManager,\n }\n return new ManyToOneRelationFieldCrudManager(manyToOneOptions);\n }\n else if (fieldMetadata.relationType === RelationType.oneToMany) {\n const oneToManyOptions: OneToManyRelationFieldOptions = {\n ...commonOptions,\n relationCoModelSingularName: fieldMetadata.relationCoModelSingularName,\n modelSingularName: fieldMetadata.model.singularName,\n entityManager,\n inverseFieldName: fieldMetadata.relationCoModelFieldName,\n inverseRelationCoModelFieldName: fieldMetadata.name,\n entityId,\n }\n return new OneToManyRelationFieldCrudManager(oneToManyOptions);\n }\n else if (fieldMetadata.relationType === RelationType.manyTomany) {\n if (fieldMetadata.isRelationManyToManyOwner) {\n const manyToManyOptions: ManyToManyRelationFieldOptions = {\n ...commonOptions,\n relationCoModelSingularName: fieldMetadata.relationCoModelSingularName,\n modelSingularName: fieldMetadata.model.singularName,\n isInverseSide: false,\n entityManager,\n fieldName: fieldMetadata.name,\n entityId,\n }\n return new ManyToManyRelationFieldCrudManager(manyToManyOptions);\n }\n else {\n const inverseManyToManyOptions: ManyToManyRelationFieldOptions = {\n ...commonOptions,\n relationCoModelSingularName: fieldMetadata.relationCoModelSingularName,\n modelSingularName: fieldMetadata.model.singularName,\n isInverseSide: true,\n entityManager,\n fieldName: fieldMetadata.relationCoModelFieldName,\n relationCoModelFieldName: fieldMetadata.name,\n entityId,\n }\n return new ManyToManyRelationFieldCrudManager(inverseManyToManyOptions);\n }\n }\n else throw new Error(ERROR_MESSAGES.RELATION_TYPE_NOT_SUPPORTED);\n // return (fieldMetadata.relationType === 'many-to-one') ? new ManyToOneRelationFieldCrudManager(fieldMetadata, entityManager) : new ManyToManyRelationFieldCrudManager(fieldMetadata, entityManager); //FIXME many-to-many pending\n // ManyToOne -> fieldId. The value is saved as is. No transformation is required\n // OneToMany -> fieldIds. Get the value of the oneToMany field side. No transformation is required (While saving special provision to be made)\n // ManyToMany\n // break;\n }\n case SolidFieldType.selectionStatic: {\n\n // Validation against the selectionStatic values. No transformation is required\n // If the value is not in the selectionStatic values, then throw\n // Also validate against the selectionType\n const options = { ...commonOptions, selectionStaticValues: fieldMetadata.selectionStaticValues, selectionValueType: fieldMetadata.selectionValueType as SelectionValueType, isMultiSelect: fieldMetadata.isMultiSelect };\n return new SelectionStaticFieldCrudManager(options);\n }\n case SolidFieldType.selectionDynamic: {// [HOLD]\n // Default implementation using list of values.\n // ISelectionProvider interface to be implemented for dynamic selection\n // dataSource: string; // The name of the selection provider\n // filterSchema : json // This is a custom json object that every data source will handle accordingly. We could validate the query against the selection provider\n // values : string[]; // The values returned by the selection provider\n const options = { ...commonOptions, selectionDynamicProvider: fieldMetadata.selectionDynamicProvider, selectionDynamicProviderCtxt: JSON.parse(fieldMetadata.selectionDynamicProviderCtxt), selectionValueType: fieldMetadata.selectionValueType as SelectionValueType, discoveryService: this.discoveryService, isMultiSelect: fieldMetadata.isMultiSelect };\n return new SelectionDynamicFieldCrudManager(options);\n }\n case SolidFieldType.uuid: {\n const options = { ...commonOptions };\n // If no value is provided, then generate a uuid. Add to the dto\n return new UUIDFieldCrudManager(options);\n }\n case SolidFieldType.computed: {\n\n // The value will be computed by the computed provider\n // Invoke the appropriate computed provider, get the value and add to the dto\n const options = { ...commonOptions, computedFieldProvider: fieldMetadata.computedFieldValueProvider, computedFieldValueProviderCtxt: fieldMetadata.computedFieldValueProviderCtxt, computedFieldValueType: fieldMetadata.computedFieldValueType as ComputedFieldValueType, discoveryService: this.discoveryService, skipComputation: this.isSkipComputation(isPartialUpdate, fieldMetadata) };\n return new ComputedFieldCrudManager(options);\n }\n default:\n return new NoOpsFieldCrudManager();\n }\n }\n\n private isSkipComputation(isPartialUpdate: boolean, computedFieldMetadata: FieldMetadata) {\n if (isPartialUpdate) return true; // If it is a partial update, then skip computation\n if (computedFieldMetadata.computedFieldTriggerConfig && computedFieldMetadata.computedFieldTriggerConfig.length > 0) {\n return true; // computedFieldTriggerConfig is a new field introduced as part of the IEntityComputedFieldProvider new interface, so this computation will be skiipped in crud service & will be called in the subscriber instead\n }\n return false; // If it is not a partial update, then do not skip computation\n }\n\n async find(basicFilterDto: BasicFilterDto, solidRequestContext: any = {}) {\n const alias = 'entity';\n // Extract the required keys from the input query\n let { limit, offset, populateMedia, populateGroup, groupFilter } = basicFilterDto;\n const populateUserIdFields = this.crudHelperService.extractUserIdFieldsFromPopulate(basicFilterDto.populate);\n\n const { singularName, internationalisation, draftPublishWorkflow } = await this.loadModel();\n // Check wheather user has update permission for model\n if (solidRequestContext.activeUser) {\n const hasPermission = this.crudHelperService.hasReadPermissionOnModel(solidRequestContext.activeUser, singularName);\n if (!hasPermission) {\n throw new BadRequestException('Forbidden');\n }\n }\n\n // Set the request filter in the request context service\n const requestContextService = this.moduleRef.get(RequestContextService, { strict: false });\n requestContextService.setRequestFilter(basicFilterDto);\n\n // Create above query on pincode table using query builder\n var qb: SelectQueryBuilder<T> = await this.repo.createSecurityRuleAwareQueryBuilder(alias)\n\n if (basicFilterDto.groupBy) {\n const groupFilterQb = (internationalisation && draftPublishWorkflow)\n ? this.crudHelperService.buildFilterQuery(qb, basicFilterDto, alias, internationalisation, draftPublishWorkflow, this.moduleRef, FilterCombinator.AND, false, false)\n : this.crudHelperService.buildFilterQuery(qb, basicFilterDto, alias, undefined, undefined, undefined, FilterCombinator.AND, false, false);\n\n const groupByFields = this.crudHelperService.normalize(basicFilterDto.groupBy);\n if (!groupByFields.length) {\n throw new BadRequestException(ERROR_MESSAGES.INVALID_GROUP_BY_COUNT);\n }\n\n if (basicFilterDto.populateGroup) {\n const hasRelationGroup = groupByFields.some(field => field.includes('.'));\n if (hasRelationGroup) {\n throw new BadRequestException('populateGroup is not supported when grouping on relation fields. Fetch group metadata first and retrieve records in a separate call.');\n }\n }\n\n const { aliasMap: groupAliasMap, formatMap: groupFormatMap, expressionMap: groupExpressionMap } = this.crudHelperService.applyGroupBySelections(groupFilterQb, groupByFields, alias);\n const aggregateAliasMap = this.crudHelperService.applyAggregates(groupFilterQb, basicFilterDto.aggregates, alias);\n const sortAliasMap = { ...groupAliasMap, ...aggregateAliasMap };\n this.crudHelperService.applyGroupSortingAndPagination(groupFilterQb, basicFilterDto.sort, sortAliasMap, limit, offset);\n\n const groupByResult = await groupFilterQb.getRawMany();\n const totalGroups = await this.crudHelperService.countGroups(groupFilterQb);\n\n const groupByFieldsOrdered = this.crudHelperService.normalize(basicFilterDto.groupBy || []);\n const { groupMeta, groupRecords } = await this.handleGroupFind(groupByResult, groupFilter, populateGroup, alias, populateUserIdFields, populateMedia, basicFilterDto, groupAliasMap, aggregateAliasMap, groupByFieldsOrdered, groupFormatMap, groupExpressionMap);\n\n return {\n meta: {\n \"totalRecords\": totalGroups\n },\n groupMeta,\n groupRecords,\n }\n }\n else {\n qb = (internationalisation && draftPublishWorkflow)\n ? this.crudHelperService.buildFilterQuery(qb, basicFilterDto, alias, internationalisation, draftPublishWorkflow, this.moduleRef)\n : this.crudHelperService.buildFilterQuery(qb, basicFilterDto, alias);\n const { meta, records } = await this.handleNonGroupFind(qb, populateUserIdFields, populateMedia, offset, limit, alias);\n return {\n meta,\n records,\n }\n }\n }\n\n private async handleNonGroupFind(qb: SelectQueryBuilder<T>, populateUserIdFields: UserIdFields[], populateMedia: string[], offset: number, limit: number, alias: string) {\n const [entities, count] = await qb.getManyAndCount();\n\n // Populate the entity with the userId fields\n if (populateUserIdFields && populateUserIdFields.length > 0) {\n await this.handlePopulateUserIdFields(populateUserIdFields, entities);\n }\n\n // Populate the entity with the media\n if (populateMedia && populateMedia.length > 0) {\n await this.handlePopulateMedia(populateMedia, entities);\n }\n\n return this.wrapFindResponse(offset, limit, count, entities);\n }\n\n private async handleGroupFind(\n groupByResult: any[],\n groupFilter: BasicGroupFilterDto | undefined,\n populateGroup: boolean,\n alias: string,\n populateUserIdFields: UserIdFields[],\n populateMedia: string[],\n baseFilterDto: BasicFilterDto,\n groupAliasMap: Record<string, string>,\n aggregateAliasMap: Record<string, string>,\n groupByFieldsOrdered: string[],\n groupFormatMap: Record<string, string | undefined>,\n groupExpressionMap: Record<string, string>\n ) {\n const groupMeta = [];\n const groupRecords = [];\n const aggregateAliasSet = new Set(Object.values(aggregateAliasMap));\n // For each group, get the records and the count\n for (const group of groupByResult) {\n if (populateGroup) {\n let groupByQb: SelectQueryBuilder<T> = await this.repo.createSecurityRuleAwareQueryBuilder(alias);\n const groupFilterDto: BasicFilterDto = {\n ...baseFilterDto,\n ...groupFilter,\n groupBy: undefined,\n aggregates: undefined,\n // Only use explicit groupFilter.sort for record ordering; group-level sorts can contain\n // group expressions (e.g. createdAt:day) that are invalid on record queries.\n sort: groupFilter?.sort,\n };\n groupByQb = this.crudHelperService.buildFilterQuery(groupByQb, groupFilterDto, alias);\n groupByQb = this.crudHelperService.buildGroupByRecordsQuery(groupByQb, group, alias, groupAliasMap, aggregateAliasMap, groupExpressionMap);\n const [entities, count] = await groupByQb.getManyAndCount();\n\n // Populate the entity with the userId fields\n if (populateUserIdFields && populateUserIdFields.length > 0) {\n await this.handlePopulateUserIdFields(populateUserIdFields, entities);\n }\n\n // Populate the entity with the media\n if (populateMedia && populateMedia.length > 0) {\n await this.handlePopulateMedia(populateMedia, entities);\n }\n const groupData = this.wrapFindResponse(groupFilter?.offset, groupFilter?.limit, count, entities);\n groupRecords.push(this.crudHelperService.createGroupRecords(group, aggregateAliasSet, groupData, groupByFieldsOrdered, groupAliasMap, groupFormatMap));\n }\n groupMeta.push(this.crudHelperService.createGroupMeta(group, aggregateAliasSet, groupByFieldsOrdered, groupAliasMap, groupFormatMap));\n }\n return { groupMeta, groupRecords };\n }\n\n private wrapFindResponse(offset: number | undefined, limit: number | undefined, count: number, entities: T[]) {\n const safeLimit = limit ?? count ?? 0;\n const safeOffset = offset ?? 0;\n const currentPage = safeLimit ? Math.floor(safeOffset / safeLimit) + 1 : 1;\n const totalPages = safeLimit ? Math.ceil(count / safeLimit) : 1;\n\n const nextPage = safeLimit && currentPage < totalPages ? currentPage + 1 : null;\n const prevPage = safeLimit && currentPage > 1 ? currentPage - 1 : null;\n\n const r = {\n meta: {\n totalRecords: count,\n currentPage: currentPage,\n nextPage: nextPage,\n prevPage: prevPage,\n totalPages: totalPages,\n perPage: safeLimit ? +safeLimit : 0,\n },\n records: entities\n };\n return r;\n }\n\n // entities is an array of T\n // T can contain createdBy and updatedBy fields\n // We need to populate the createdBy and updatedBy fields with the User entity\n private async handlePopulateUserIdFields(userIdFields: UserIdFields[], entities: T[]) {\n const userRepository = this.entityManager.getRepository(User);\n for (const entity of entities) {\n for (const userFieldPath of userIdFields) {\n const userId = entity[userFieldPath as keyof T] as unknown as number;\n if (userId) {\n const user = await userRepository.findOne({\n where: { id: userId },\n });\n // @ts-ignore\n entity[userFieldPath] = user;\n }\n }\n }\n }\n\n private async handlePopulateMedia(populateMedia: string[], entities: T[]) {\n const model = await this.getDatasourceDefaultEntityManager().getRepository(ModelMetadata).findOne({\n where: {\n singularName: this.modelName,\n },\n relations: ['fields', 'fields.mediaStorageProvider', 'fields.model', 'module'],\n });\n\n // Will iterate through every entity & all populateMedia & call getMediaDetails for each field\n for (const entity of entities) {\n for (const mediaFieldPath of populateMedia) {\n await this.populateMediaObject(mediaFieldPath, model, entity);\n }\n }\n return entities;\n }\n\n // Adds the media with full URL to the entity / nested entity\n private async populateMediaObject(mediaFieldPath: string, model: ModelMetadata, entity: T) {\n if (mediaFieldPath.includes('.')) { // mediaFieldPath is a nested field\n const pathParts = mediaFieldPath.split('.');\n const mediaFieldMetadata = await this.getFieldMetadataRecursively(pathParts, model.fields);\n if (!mediaFieldMetadata) {\n throw new BadRequestException(`Media field ${mediaFieldPath} not found in model ${this.modelName}`);\n }\n\n // We can assume that the media field entity model is already populated as part of the entity data\n const mediaFieldEntities = this.getMediaFieldEntities(entity, pathParts);\n if (!mediaFieldEntities || mediaFieldEntities.length === 0) {\n return;//no need to populate data if relation not exists\n }\n // Populate the media field entities with the full URL\n for (const mediaFieldEntity of mediaFieldEntities) {\n const mediaWithFullUrl = await this.getMediaWithFullUrl(mediaFieldEntity, mediaFieldMetadata);\n this.appendMediaKey(mediaWithFullUrl, mediaFieldEntity, mediaFieldMetadata.name);\n // mediaFieldEntity['_media'][mediaFieldPath] = mediaWithFullUrl\n }\n }\n else {\n // mediaFieldPath is a single field\n const mediaFieldMetadata = model.fields.find(field => field.name === mediaFieldPath);\n if (!mediaFieldMetadata) {\n throw new BadRequestException(`Media field ${mediaFieldPath} not found in model ${this.modelName}`);\n }\n const mediaWithFullUrl = await this.getMediaWithFullUrl(entity, mediaFieldMetadata);\n this.appendMediaKey(mediaWithFullUrl, entity, mediaFieldPath);\n // entity['_media'][mediaFieldPath] = mediaWithFullUrl;\n }\n }\n\n // // Add the media with full URL to the entity\n private appendMediaKey(mediaWithFullUrl: MediaWithFullUrl[], entity: T, mediaFieldPath: string) {\n // if _media key already exists, append the new media to the existing array\n if (entity['_media']) {\n entity['_media'][mediaFieldPath] = mediaWithFullUrl;\n }\n else {\n entity['_media'] = {\n [mediaFieldPath]: mediaWithFullUrl\n };\n }\n }\n\n private getMediaFieldEntities(entity: T, mediaPathParts: string[]): T[] {\n let entityPart = entity;\n for (let i = 0; i < mediaPathParts.length - 1; i++) {\n const pathPart = mediaPathParts[i];\n if (entity[pathPart]) {\n entityPart = entity[pathPart];\n } else {\n throw new BadRequestException(`Media field ${pathPart} not found in entity ${JSON.stringify(entity)}`);\n }\n }\n return isArray(entityPart) ? entityPart : [entityPart];\n }\n\n async getMediaWithFullUrl(mediaEntity: any, mediaFieldMetadata: FieldMetadata): Promise<MediaWithFullUrl[]> {\n const storageProviderMetadata = mediaFieldMetadata.mediaStorageProvider;\n const storageProviderType = storageProviderMetadata.type as MediaStorageProviderType;\n const storageProvider = await getMediaStorageProvider(this.moduleRef, storageProviderType);\n const mediaDetails = await storageProvider.retrieve(mediaEntity, mediaFieldMetadata);\n return mediaDetails as MediaWithFullUrl[];\n }\n\n async findOne(id: number, query: any = {}, solidRequestContext: any = {}) {\n const { populate = [], fields = [], populateMedia = [] } = query;\n\n // const normalizedFields = this.crudHelperService.normalize(fields);\n const normalizedPopulate = this.crudHelperService.normalize(populate);\n const normalizedPopulateMedia = this.crudHelperService.normalize(populateMedia);\n\n // if normalizedPopulateMedia, has any nested media paths, then add then to populate excluding the last part\n const additionalPopulate = this.crudHelperService.additionalRelationsRequiredForMediaPopulation(normalizedPopulateMedia);\n // Add the additional populate relations to the normalizedPopulate, if they are not already present\n normalizedPopulate.push(...additionalPopulate.filter((relation) => !normalizedPopulate.includes(relation)));\n\n const model = await this.loadModel();\n // Check wheather user has update permission for model\n if (solidRequestContext.activeUser) {\n const hasPermission = this.crudHelperService.hasReadPermissionOnModel(solidRequestContext.activeUser, model.singularName);\n if (!hasPermission) {\n throw new BadRequestException(ERROR_MESSAGES.FORBIDDEN);\n }\n }\n\n let entity = await this.repo.findOne({\n where: {\n id: id,\n } as unknown as FindOptionsWhere<T>,\n relations: normalizedPopulate,\n select: fields,\n });\n if (!entity) {\n throw new NotFoundException(`Entity [${this.moduleName}.${this.modelName}] with id ${id} not found`);\n }\n // Populate the entity with the media\n if (normalizedPopulateMedia.length > 0) {\n const populatedEntities = await this.handlePopulateMedia(normalizedPopulateMedia, [entity]);\n entity = populatedEntities[0] as Awaited<T>;\n }\n return entity;\n }\n\n async createMany(createDtos: any[], solidRequestContext: any = {}): Promise<T[]> {\n const loadedmodel = await this.loadModel();\n\n // Check wheather user has create permission for model\n if (solidRequestContext.activeUser) {\n const hasPermission = this.crudHelperService.hasCreatePermissionOnModel(solidRequestContext.activeUser, loadedmodel.singularName);\n if (!hasPermission) {\n throw new BadRequestException(ERROR_MESSAGES.FORBIDDEN);\n }\n }\n\n // Fetch model metadata once\n const model = await this.modelMetadataService.findOneBySingularName(this.modelName, {\n fields: {\n model: true,\n mediaStorageProvider: true,\n },\n module: true,\n });\n\n const entitiesForSave: T[] = [];\n for (const createDto of createDtos) {\n // Validate and transform each createDto sequentially\n let transformedDto = createDto;\n for (const field of model.fields) {\n const fieldManager: FieldCrudManager = await this.fieldCrudManager(field, this.entityManager);\n const validationErrors = await fieldManager.validate(createDto, []); // TODO, This is set, because we are not supporting files for insertMany currently\n if (validationErrors.length > 0) {\n throw new BadRequestException(`Validation errors in ${field.name} are invalid: ${validationErrors.map(e => e.error).join(', ')}`);\n }\n transformedDto = await fieldManager.transformForCreate(createDto);\n }\n const entity = this.repo.create(transformedDto);\n entitiesForSave.push(entity as unknown as T);\n }\n // Save all entities in a single batch\n const savedEntities = await this.repo.save(entitiesForSave) as T[];\n return savedEntities;\n }\n\n async insertMany(createDtos: any[], filesArray: Express.Multer.File[][] = [], solidRequestContext: any = {}): Promise<T[]> {\n const savedEntities = await this.createMany(createDtos, solidRequestContext);\n return savedEntities;\n }\n\n async deleteMany(ids: number[], solidRequestContext: any = {}): Promise<any> {\n\n if (!ids || ids.length === 0) {\n throw new Error(ERROR_MESSAGES.DELETE_IDS_REQUIRED);\n }\n\n const loadedmodel = await this.loadModel();\n // Check wheather user has update permission for model\n if (solidRequestContext.activeUser) {\n const hasPermission = this.crudHelperService.hasDeletePermissionOnModel(solidRequestContext.activeUser, loadedmodel.singularName);\n if (!hasPermission) {\n throw new BadRequestException(ERROR_MESSAGES.FORBIDDEN);\n }\n }\n const model = await this.modelMetadataService.findOneBySingularName(this.modelName, {\n fields: {\n model: true,\n mediaStorageProvider: true,\n },\n module: true,\n });\n\n\n\n const removedEntities = [];\n for (let i = 0; i < ids.length; i++) {\n const id = ids[i]\n const entity = await this.repo.findOne({\n where: {\n id: id,\n } as unknown as FindOptionsWhere<T>,\n });\n\n removedEntities.push(entity);\n }\n\n\n // entity-level flag\n const isDraftPublishEnabled = model?.draftPublishWorkflow === true;\n\n let publishedEntitiesExists: T[] = [];\n\n if (isDraftPublishEnabled) {\n publishedEntitiesExists = removedEntities.filter(\n (x) => !!x?.publishedAt\n );\n }\n\n if (publishedEntitiesExists.length > 0) {\n const publishedEntitiesExistsID = publishedEntitiesExists.map(x => x.id);\n\n throw new BadRequestException(\n `Cannot delete published record(s) for model ${this.modelName} with Ids ${publishedEntitiesExistsID.join(', ')}. Unpublish them first.`\n );\n }\n\n if (model.enableSoftDelete === true) {\n await this.repo.softRemove(removedEntities);\n return this.repo.save(removedEntities);\n } else {\n return this.repo.remove(removedEntities);\n }\n // return removedEntities\n }\n\n async recover(id: number, solidRequestContext: any = {}) {\n try {\n const loadedmodel = await this.loadModel();\n // Check wheather user has update permission for model\n if (solidRequestContext.activeUser) {\n const hasPermission = this.crudHelperService.hasRecoverPermissionOnModel(solidRequestContext.activeUser, loadedmodel.singularName);\n if (!hasPermission) {\n throw new BadRequestException(ERROR_MESSAGES.FORBIDDEN);\n }\n }\n\n const softDeletedRows = await this.repo.findOne({\n where: {\n id, deletedAt: Not(IsNull())\n } as unknown as FindOptionsWhere<T>,\n withDeleted: true,\n });\n\n if (!softDeletedRows) {\n throw new Error(ERROR_MESSAGES.NO_SOFT_DELETED_RECORD_FOUND);\n }\n\n await this.repo.update(id, {\n deletedAt: null, deletedTracker: \"not-deleted\"\n } as unknown as QueryDeepPartialEntity<T>\n );\n\n return { message: SUCCESS_MESSAGES.RECORD_RECOVERED, data: softDeletedRows };\n } catch (error: any) {\n if (error instanceof QueryFailedError) {\n if ((error as any).code === '23505') {\n throw new Error(ERROR_MESSAGES.CONFLICTING_RECORD_ON_UNARCHIVE);\n }\n }\n\n throw new Error(error);\n }\n }\n\n async recoverMany(ids: number[], solidRequestContext: any = {}) {\n try {\n const loadedmodel = await this.loadModel();\n // Check wheather user has update permission for model\n if (solidRequestContext.activeUser) {\n const hasPermission = this.crudHelperService.hasRecoverPermissionOnModel(solidRequestContext.activeUser, loadedmodel.singularName);\n if (!hasPermission) {\n throw new BadRequestException(ERROR_MESSAGES.FORBIDDEN);\n }\n }\n\n if (!ids || ids.length === 0) {\n throw new Error(ERROR_MESSAGES.DELETE_IDS_REQUIRED);\n }\n\n // Find soft-deleted records matching the given IDs\n const softDeletedRows = await this.repo.find({\n where: {\n id: In(ids),\n deletedAt: Not(IsNull()),\n } as unknown as FindOptionsWhere<T>,\n withDeleted: true,\n });\n\n if (softDeletedRows.length === 0) {\n throw new Error(ERROR_MESSAGES.NO_SOFT_DELETED_RECORDS_FOUND);\n }\n\n // Recover the specific records by setting deletedAt to null\n await this.repo.update(\n { id: In(ids) } as unknown as FindOptionsWhere<T>,\n { deletedAt: null, deletedTracker: \"not-deleted\" } as unknown as QueryDeepPartialEntity<T>\n );\n\n return { message: SUCCESS_MESSAGES.SELECTED_RECORDS_RECOVERED, recoveredIds: ids };\n } catch (error: any) {\n if (error instanceof QueryFailedError) {\n if ((error as any).code === \"23505\") {\n throw new Error(ERROR_MESSAGES.CONFLICTING_RECORD_ON_UNARCHIVE);\n }\n }\n\n throw new Error(error);\n }\n }\n\n\n async getFieldMetadataRecursively(pathParts: string[], fields: FieldMetadata[]) {\n if (!pathParts || pathParts.length === 0) {\n throw new BadRequestException(ERROR_MESSAGES.EMPTY_PATH_PARTS);\n }\n\n const [currentPart, ...remainingParts] = pathParts;\n const field = fields.find(field => field.name === currentPart);\n\n if (!field) {\n throw new BadRequestException(`Field ${currentPart} not found in model ${this.modelName}`);\n }\n\n // Base case: last part, return the field\n if (remainingParts.length === 0) {\n return field;\n }\n\n if (!field.relationCoModelSingularName) {\n throw new BadRequestException(`Field ${field.name} does not define a relationCoModelSingularName`);\n }\n\n const relationCoModel = await this.getDatasourceDefaultEntityManager().getRepository(ModelMetadata).findOne({\n where: { singularName: field.relationCoModelSingularName },\n relations: ['fields', 'fields.mediaStorageProvider', 'fields.model'],\n });\n\n if (!relationCoModel) {\n throw new BadRequestException(`Model ${field.relationCoModelSingularName} not found`);\n }\n\n return this.getFieldMetadataRecursively(remainingParts, relationCoModel.fields);\n }\n\n async getUserKeyFieldNameForModel(modelSingularName: string): Promise<string> {\n const model = await this.modelMetadataService.findOneBySingularName(modelSingularName, ['userKeyField']);\n if (!model) {\n throw new BadRequestException(`Model ${modelSingularName} not found`);\n }\n return model.userKeyField?.name || '';\n }\n\n /* Publish a record - sets publishedAt timestamp */\n async publishRecord(id: number, solidRequestContext: any = {}): Promise<T> {\n\n const model = await this.loadModel();\n\n // Check if publish workflow is enabled for this model\n if (!model.draftPublishWorkflow) {\n throw new BadRequestException(\n `Publish workflow is not enabled for ${this.modelName}`\n );\n }\n\n // Check user permissions\n if (solidRequestContext.activeUser) {\n const hasPermission = this.crudHelperService.hasPublishPermissionOnModel(\n solidRequestContext.activeUser,\n model.singularName\n );\n if (!hasPermission) {\n throw new BadRequestException(ERROR_MESSAGES.FORBIDDEN);\n }\n }\n\n // Find the entity\n const entity = await this.repo.findOne({ where: { id } as any });\n if (!entity) {\n throw new NotFoundException(`${this.modelName} with id ${id} not found`);\n }\n\n // Check if already published\n if (entity.publishedAt) {\n throw new BadRequestException(\n `${this.modelName} with id ${id} is already published`\n );\n }\n\n // Update publish status\n const updatedEntity = await this.repo.save({ ...entity, publishedAt: new Date() });\n\n return updatedEntity\n }\n\n /* Unpublish a record - clears publishedAt timestamp */\n async unpublishRecord(id: number, solidRequestContext: any = {}): Promise<T> {\n\n const model = await this.loadModel();\n\n // Check if publish workflow is enabled for this model\n if (!model.draftPublishWorkflow) {\n throw new BadRequestException(\n `Publish workflow is not enabled for ${this.modelName}`\n );\n }\n\n // Check user permissions\n if (solidRequestContext.activeUser) {\n const hasPermission = this.crudHelperService.hasUnpublishPermissionOnModel(\n solidRequestContext.activeUser,\n model.singularName\n );\n if (!hasPermission) {\n throw new BadRequestException(ERROR_MESSAGES.FORBIDDEN);\n }\n }\n\n // Find the entity\n const entity = await this.repo.findOne({ where: { id } as any });\n if (!entity) {\n throw new NotFoundException(`${this.modelName} with id ${id} not found`);\n }\n\n // Check if already unpublished\n if (!entity.publishedAt) {\n throw new BadRequestException(\n `${this.modelName} with id ${id} is already unpublished`\n );\n }\n\n // Update unpublish status\n const updatedEntity = await this.repo.save({ ...entity, publishedAt: null });\n\n return updatedEntity\n }\n\n private getDatasourceDefaultEntityManager() {\n return this.defaultDatasourceEntityManager ?? this.entityManager;\n }\n}\n"]}
@@ -1 +1 @@
1
- {"version":3,"file":"csv.service.js","sourceRoot":"","sources":["../../src/services/csv.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable, Logger } from '@nestjs/common';\nimport { format, parse } from 'fast-csv';\nimport { ERROR_MESSAGES } from 'src/constants/error-messages';\nimport { PassThrough, Readable } from 'stream';\n\nexport interface CsvReadOptions {\n pageSize?: number; // Number of records per page\n hasHeaderRow?: boolean;\n providedHeaders?: string[]\n};\nconst DEFAULT_PAGE_SIZE = 100; // Default page size if not provided\nexport interface CsvReadResult {\n headers: string[]; // Headers of the CSV file\n data: Record<string, any>[]; // Data records in the current page\n}\n\n@Injectable()\nexport class CsvService {\n private logger = new Logger(CsvService.name);\n public async createCsvStream(\n getDataRecords: (chunkIndex: number, chunkSize: number) => Promise<any[]> = null,\n chunkSize: number = 100,\n headers: string[] = []\n ): Promise<Readable> {\n // Validations\n // If neither headers nor data records function is provided, throw an error\n if (headers.length === 0 && typeof getDataRecords !== 'function') {\n throw new Error(ERROR_MESSAGES.MISSING_HEADERS_OR_FUNCTION);\n }\n\n // If data records function is provided, chunkSize must be greater than 0\n if (getDataRecords && chunkSize <= 0) {\n throw new Error(ERROR_MESSAGES.INVALID_CHUNK_SIZE);\n }\n\n const passThrough = new PassThrough(); // ✅ Create a streaming pipe\n const csvStream = headers.length\n ? format({ headers })\n : format({ headers: true });\n\n csvStream.pipe(passThrough); // ✅ Pipe CSV output to PassThrough stream\n\n try {\n // 🧠 If no data retrieval logic is provided, just write headers and close\n if (typeof getDataRecords !== 'function') {\n\n const dummyRow = headers.reduce((acc, header) => {\n acc[header] = '';\n return acc;\n }, {} as Record<string, string>);\n csvStream.write(dummyRow);\n csvStream.end();\n return passThrough;\n }\n\n // Write the data records in chunks\n let chunkIndex = 0;\n while (true) {\n const records = await getDataRecords(chunkIndex, chunkSize); // ✅ Fetch chunked data\n if (records.length === 0) break; // ✅ Stop if no more records\n\n for (const record of records) {\n csvStream.write(record); // ✅ Write each record to the CSV stream\n }\n\n chunkIndex++; // ✅ Fetch next chunk\n this.logger.debug(`✅ Chunk ${chunkIndex} written to CSV`);\n }\n\n csvStream.end(); // ✅ Ensure CSV stream is finalized\n } catch (error) {\n this.logger.error(`❌ Error writing CSV: ${error.message}`);\n passThrough.destroy(error); // ✅ Properly destroy stream on error\n throw error;\n }\n\n return passThrough; // ✅ Return the streaming response\n }\n\n public async *readCsvInPagesFromStream(\n stream: Readable,\n options?: CsvReadOptions\n ): AsyncGenerator<CsvReadResult> {\n const { pageSize = DEFAULT_PAGE_SIZE, hasHeaderRow = true, providedHeaders = [] } = options || {};\n let headers: string[] = [];\n let page: Record<string, any>[] = [];\n let isFirstRow = true;\n let hasYieldedData = false;\n\n // Create parser\n const parser = parse({ headers: hasHeaderRow, renameHeaders: false, trim: true });\n\n // Pipe the input stream into the parser\n const parsingStream = stream.pipe(parser);\n\n for await (const row of parsingStream) {\n if (isFirstRow && !hasHeaderRow) {\n isFirstRow = false;\n\n if (providedHeaders.length) {\n headers = providedHeaders;\n } else {\n // If no header row and no provided headers, generate index-based headers\n headers = Object.keys(row).length > 0 ? Object.keys(row).map((_, i) => i.toString()) : [];\n }\n }\n\n // If hasHeaderRow = true, fast-csv already assigns keys as headers, so capture once\n if (hasHeaderRow && isFirstRow) {\n headers = Object.keys(row);\n isFirstRow = false;\n }\n\n // When headers are not set yet (edge case), set them now\n if (!headers.length) {\n headers = providedHeaders.length ? providedHeaders : Object.keys(row);\n }\n\n // Map row fields to headers - if keys mismatch, fallback to index-based mapping\n const record: Record<string, any> = {};\n for (let i = 0; i < headers.length; i++) {\n // For safety, access by header name or fallback by index\n const key = headers[i];\n const value = row[key] ?? Object.values(row)[i] ?? null;\n record[key] = value;\n }\n\n // Skip empty rows\n if (Object.values(record).every(v => v === null || v === '')) continue;\n\n page.push(record);\n\n if (page.length === pageSize) {\n yield { headers, data: page };\n hasYieldedData = true;\n page = [];\n }\n }\n\n if (page.length > 0) {\n yield { headers, data: page };\n hasYieldedData = true;\n }\n\n // If only headers present but no data, yield headers with empty data array\n if (!hasYieldedData && headers.length > 0) {\n yield { headers, data: [] };\n }\n }\n\n}\n"]}
1
+ {"version":3,"file":"csv.service.js","sourceRoot":"","sources":["../../src/services/csv.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable, Logger } from '@nestjs/common';\nimport { format, parse } from 'fast-csv';\nimport { ERROR_MESSAGES } from 'src/constants/error-messages';\nimport { PassThrough, Readable } from 'stream';\n\nexport interface CsvReadOptions {\n pageSize?: number; // Number of records per page\n hasHeaderRow?: boolean;\n providedHeaders?: string[]\n};\nconst DEFAULT_PAGE_SIZE = 100; // Default page size if not provided\nexport interface CsvReadResult {\n headers: string[]; // Headers of the CSV file\n data: Record<string, any>[]; // Data records in the current page\n}\n\n@Injectable()\nexport class CsvService {\n private logger = new Logger(CsvService.name);\n public async createCsvStream(\n getDataRecords: (chunkIndex: number, chunkSize: number) => Promise<any[]> = null,\n chunkSize: number = 100,\n headers: string[] = []\n ): Promise<Readable> {\n // Validations\n // If neither headers nor data records function is provided, throw an error\n if (headers.length === 0 && typeof getDataRecords !== 'function') {\n throw new Error(ERROR_MESSAGES.MISSING_HEADERS_OR_FUNCTION);\n }\n\n // If data records function is provided, chunkSize must be greater than 0\n if (getDataRecords && chunkSize <= 0) {\n throw new Error(ERROR_MESSAGES.INVALID_CHUNK_SIZE);\n }\n\n const passThrough = new PassThrough(); // ✅ Create a streaming pipe\n const csvStream = headers.length\n ? format({ headers })\n : format({ headers: true });\n\n csvStream.pipe(passThrough); // ✅ Pipe CSV output to PassThrough stream\n\n try {\n // 🧠 If no data retrieval logic is provided, just write headers and close\n if (typeof getDataRecords !== 'function') {\n\n const dummyRow = headers.reduce((acc, header) => {\n acc[header] = '';\n return acc;\n }, {} as Record<string, string>);\n csvStream.write(dummyRow);\n csvStream.end();\n return passThrough;\n }\n\n // Write the data records in chunks\n let chunkIndex = 0;\n while (true) {\n const records = await getDataRecords(chunkIndex, chunkSize); // ✅ Fetch chunked data\n if (records.length === 0) break; // ✅ Stop if no more records\n\n for (const record of records) {\n csvStream.write(record); // ✅ Write each record to the CSV stream\n }\n\n chunkIndex++; // ✅ Fetch next chunk\n this.logger.debug(`✅ Chunk ${chunkIndex} written to CSV`);\n }\n\n csvStream.end(); // ✅ Ensure CSV stream is finalized\n } catch (error: any) {\n this.logger.error(`❌ Error writing CSV: ${error.message}`);\n passThrough.destroy(error); // ✅ Properly destroy stream on error\n throw error;\n }\n\n return passThrough; // ✅ Return the streaming response\n }\n\n public async *readCsvInPagesFromStream(\n stream: Readable,\n options?: CsvReadOptions\n ): AsyncGenerator<CsvReadResult> {\n const { pageSize = DEFAULT_PAGE_SIZE, hasHeaderRow = true, providedHeaders = [] } = options || {};\n let headers: string[] = [];\n let page: Record<string, any>[] = [];\n let isFirstRow = true;\n let hasYieldedData = false;\n\n // Create parser\n const parser = parse({ headers: hasHeaderRow, renameHeaders: false, trim: true });\n\n // Pipe the input stream into the parser\n const parsingStream = stream.pipe(parser);\n\n for await (const row of parsingStream) {\n if (isFirstRow && !hasHeaderRow) {\n isFirstRow = false;\n\n if (providedHeaders.length) {\n headers = providedHeaders;\n } else {\n // If no header row and no provided headers, generate index-based headers\n headers = Object.keys(row).length > 0 ? Object.keys(row).map((_, i) => i.toString()) : [];\n }\n }\n\n // If hasHeaderRow = true, fast-csv already assigns keys as headers, so capture once\n if (hasHeaderRow && isFirstRow) {\n headers = Object.keys(row);\n isFirstRow = false;\n }\n\n // When headers are not set yet (edge case), set them now\n if (!headers.length) {\n headers = providedHeaders.length ? providedHeaders : Object.keys(row);\n }\n\n // Map row fields to headers - if keys mismatch, fallback to index-based mapping\n const record: Record<string, any> = {};\n for (let i = 0; i < headers.length; i++) {\n // For safety, access by header name or fallback by index\n const key = headers[i];\n const value = row[key] ?? Object.values(row)[i] ?? null;\n record[key] = value;\n }\n\n // Skip empty rows\n if (Object.values(record).every(v => v === null || v === '')) continue;\n\n page.push(record);\n\n if (page.length === pageSize) {\n yield { headers, data: page };\n hasYieldedData = true;\n page = [];\n }\n }\n\n if (page.length > 0) {\n yield { headers, data: page };\n hasYieldedData = true;\n }\n\n // If only headers present but no data, yield headers with empty data array\n if (!hasYieldedData && headers.length > 0) {\n yield { headers, data: [] };\n }\n }\n\n}\n"]}
@@ -1 +1 @@
1
- {"version":3,"file":"dashboard.service.js","sourceRoot":"","sources":["../../src/services/dashboard.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable, Logger, NotFoundException } from '@nestjs/common';\nimport { ModuleRef } from \"@nestjs/core\";\nimport { InjectEntityManager } from '@nestjs/typeorm';\nimport { EntityManager } from 'typeorm';\n\nimport { CRUDService } from 'src/services/crud.service';\n\n\nimport * as fs from 'fs/promises'; // Use the Promise-based version of fs for async/await\nimport { SelectionDynamicSourceType } from 'src/dtos/create-dashboard-variable.dto';\nimport { DashboardVariableSelectionDynamicQueryDto } from 'src/dtos/dashboard-variable-selection-dynamic-query.dto';\nimport { DashboardVariable } from 'src/entities/dashboard-variable.entity';\nimport { ModuleMetadataHelperService } from 'src/helpers/module-metadata-helper.service';\nimport { SolidRegistry } from 'src/helpers/solid-registry';\nimport { DashboardMapper } from 'src/mappers/dashboard-mapper';\nimport { DashboardRepository } from 'src/repository/dashboard.repository';\nimport { Dashboard } from '../entities/dashboard.entity';\nimport { CreateDashboardDto } from 'src/dtos/create-dashboard.dto';\n\n\nexport const SQL_DYNAMIC_PROVIDER_NAME = 'DashboardVariableSQLDynamicProvider';\n@Injectable()\nexport class DashboardService extends CRUDService<Dashboard> {\n private readonly logger = new Logger(this.constructor.name);\n constructor(\n @InjectEntityManager()\n readonly entityManager: EntityManager,\n readonly repo: DashboardRepository, // Assuming you have a DashboardRepository for custom queries\n readonly moduleRef: ModuleRef,\n readonly solidRegistry: SolidRegistry, // Assuming solidRegistry is injected for selection providers\n readonly moduleMetadataHelperService: ModuleMetadataHelperService,\n readonly dashboardMapper: DashboardMapper,\n ) {\n super(entityManager, repo, 'dashboard', 'solid-core', moduleRef);\n }\n\n\n async create(createDto: CreateDashboardDto, files: Express.Multer.File[]) {\n createDto.name = createDto.name.trim().replace(/\\s+/g, '-').toLowerCase();\n return super.create(createDto, files);\n }\n\n async getSelectionDynamicValues(query: DashboardVariableSelectionDynamicQueryDto) {\n // Get the dashboard variable repo\n const dashboardVariable = await this.loadDashboardVariable(query.variableId);\n\n // Get the providerName and context for the dashboard variable\n const [providerName, context] = this.getProviderNameAndContext(dashboardVariable, query);\n\n // Get hold of the provider instance from the SolidRegistry\n const selectionProviderInstance = this.solidRegistry.getDashboardVariableSelectionProviderInstance(providerName);\n if (!selectionProviderInstance) {\n throw new NotFoundException(`Field incorrectly configured. No provider with name ${providerName} registered in backend.`);\n }\n\n // 4. Call the provider's getSelectionDynamicValues method\n return selectionProviderInstance.values(query.query, context);\n }\n\n\n private getProviderNameAndContext(dashboardVariable: DashboardVariable, query: DashboardVariableSelectionDynamicQueryDto): [string, any] {\n const sourceType = dashboardVariable.selectionDynamicSourceType;\n\n // Get the appropriate provide name based on the source type\n let providerName: string;\n const context = { limit: query.limit, offset: query.offset };\n switch (sourceType) {\n case SelectionDynamicSourceType.SQL:\n providerName = SQL_DYNAMIC_PROVIDER_NAME;\n context['sql'] = dashboardVariable.selectionDynamicSQL;\n break;\n case SelectionDynamicSourceType.PROVIDER:\n providerName = dashboardVariable.selectionDynamicProviderName;\n break;\n default:\n throw new Error(`Unsupported selection dynamic source type: ${sourceType}`);\n }\n return [providerName, context];\n }\n\n private async loadDashboardVariable(variableId: number) {\n const dashboardVariableRepo = this.entityManager.getRepository(DashboardVariable);\n\n // Load the dashboard record using the field\n const dashboardVariable = await dashboardVariableRepo.findOne({\n where: {\n id: variableId,\n },\n });\n return dashboardVariable;\n }\n\n async saveDashboardToConfig(entity: Dashboard) {\n if (!entity) {\n this.logger.debug('No entity found in the DashboardSubscriber saveDashboardToConfig method');\n return;\n }\n\n // Validate dashboard details\n const dashboard = entity as Dashboard;\n const moduleMetadata = entity.module;\n if (!moduleMetadata) {\n throw new Error(`Module metadata not found for dashboard id ${entity.id}`);\n }\n\n // Get config file details\n const { filePath, metaData } = await this.getConfigFileDetails(moduleMetadata.name);\n if (!filePath || !metaData) {\n throw new Error(`Configuration details not found for module: ${moduleMetadata.name}`);\n }\n\n // Write the dashboard to the config file\n await this.writeToConfig(metaData, dashboard, filePath);\n }\n\n private async getConfigFileDetails(moduleName: string): Promise<{ filePath: string; metaData: any }> {\n const filePath = await this.moduleMetadataHelperService.getModuleMetadataFilePath(moduleName);\n try {\n await fs.access(filePath);\n } catch (error) {\n throw new Error(`Configuration file not found for module: ${moduleName}`);\n }\n const metaData = await this.moduleMetadataHelperService.getModuleMetadataConfiguration(filePath);\n return { filePath, metaData };\n }\n\n private async writeToConfig(metaData: any, dashboard: Dashboard, filePath: string) {\n if (metaData.dashboards && Array.isArray(metaData.dashboards)) {\n const dashboardIndex = metaData.dashboards?.findIndex((dashboardFromFile: { name: string; }) => dashboardFromFile.name === dashboard.name);\n const dto = await this.dashboardMapper.toDto(dashboard);\n if (dashboardIndex !== -1) {\n metaData.dashboards[dashboardIndex] = dto;\n }\n else {\n metaData.dashboards.push(dto);\n }\n }\n else {\n const dashboards = [];\n const dto = await this.dashboardMapper.toDto(dashboard);\n dashboards.push(dto);\n metaData.dashboards = dashboards;\n }\n // Write the updated object back to the file\n const updatedContent = JSON.stringify(metaData, null, 2);\n await fs.writeFile(filePath, updatedContent);\n }\n}"]}
1
+ {"version":3,"file":"dashboard.service.js","sourceRoot":"","sources":["../../src/services/dashboard.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable, Logger, NotFoundException } from '@nestjs/common';\nimport { ModuleRef } from \"@nestjs/core\";\nimport { InjectEntityManager } from '@nestjs/typeorm';\nimport { EntityManager } from 'typeorm';\n\nimport { CRUDService } from 'src/services/crud.service';\n\n\nimport * as fs from 'fs/promises'; // Use the Promise-based version of fs for async/await\nimport { SelectionDynamicSourceType } from 'src/dtos/create-dashboard-variable.dto';\nimport { DashboardVariableSelectionDynamicQueryDto } from 'src/dtos/dashboard-variable-selection-dynamic-query.dto';\nimport { DashboardVariable } from 'src/entities/dashboard-variable.entity';\nimport { ModuleMetadataHelperService } from 'src/helpers/module-metadata-helper.service';\nimport { SolidRegistry } from 'src/helpers/solid-registry';\nimport { DashboardMapper } from 'src/mappers/dashboard-mapper';\nimport { DashboardRepository } from 'src/repository/dashboard.repository';\nimport { Dashboard } from '../entities/dashboard.entity';\nimport { CreateDashboardDto } from 'src/dtos/create-dashboard.dto';\n\n\nexport const SQL_DYNAMIC_PROVIDER_NAME = 'DashboardVariableSQLDynamicProvider';\n@Injectable()\nexport class DashboardService extends CRUDService<Dashboard> {\n private readonly logger = new Logger(this.constructor.name);\n constructor(\n @InjectEntityManager()\n readonly entityManager: EntityManager,\n readonly repo: DashboardRepository, // Assuming you have a DashboardRepository for custom queries\n readonly moduleRef: ModuleRef,\n readonly solidRegistry: SolidRegistry, // Assuming solidRegistry is injected for selection providers\n readonly moduleMetadataHelperService: ModuleMetadataHelperService,\n readonly dashboardMapper: DashboardMapper,\n ) {\n super(entityManager, repo, 'dashboard', 'solid-core', moduleRef);\n }\n\n\n async create(createDto: CreateDashboardDto, files: Express.Multer.File[]) {\n createDto.name = createDto.name.trim().replace(/\\s+/g, '-').toLowerCase();\n return super.create(createDto, files);\n }\n\n async getSelectionDynamicValues(query: DashboardVariableSelectionDynamicQueryDto) {\n // Get the dashboard variable repo\n const dashboardVariable = await this.loadDashboardVariable(query.variableId);\n\n // Get the providerName and context for the dashboard variable\n const [providerName, context] = this.getProviderNameAndContext(dashboardVariable, query);\n\n // Get hold of the provider instance from the SolidRegistry\n const selectionProviderInstance = this.solidRegistry.getDashboardVariableSelectionProviderInstance(providerName);\n if (!selectionProviderInstance) {\n throw new NotFoundException(`Field incorrectly configured. No provider with name ${providerName} registered in backend.`);\n }\n\n // 4. Call the provider's getSelectionDynamicValues method\n return selectionProviderInstance.values(query.query, context);\n }\n\n\n private getProviderNameAndContext(dashboardVariable: DashboardVariable, query: DashboardVariableSelectionDynamicQueryDto): [string, any] {\n const sourceType = dashboardVariable.selectionDynamicSourceType;\n\n // Get the appropriate provide name based on the source type\n let providerName: string;\n const context = { limit: query.limit, offset: query.offset };\n switch (sourceType) {\n case SelectionDynamicSourceType.SQL:\n providerName = SQL_DYNAMIC_PROVIDER_NAME;\n context['sql'] = dashboardVariable.selectionDynamicSQL;\n break;\n case SelectionDynamicSourceType.PROVIDER:\n providerName = dashboardVariable.selectionDynamicProviderName;\n break;\n default:\n throw new Error(`Unsupported selection dynamic source type: ${sourceType}`);\n }\n return [providerName, context];\n }\n\n private async loadDashboardVariable(variableId: number) {\n const dashboardVariableRepo = this.entityManager.getRepository(DashboardVariable);\n\n // Load the dashboard record using the field\n const dashboardVariable = await dashboardVariableRepo.findOne({\n where: {\n id: variableId,\n },\n });\n return dashboardVariable;\n }\n\n async saveDashboardToConfig(entity: Dashboard) {\n if (!entity) {\n this.logger.debug('No entity found in the DashboardSubscriber saveDashboardToConfig method');\n return;\n }\n\n // Validate dashboard details\n const dashboard = entity as Dashboard;\n const moduleMetadata = entity.module;\n if (!moduleMetadata) {\n throw new Error(`Module metadata not found for dashboard id ${entity.id}`);\n }\n\n // Get config file details\n const { filePath, metaData } = await this.getConfigFileDetails(moduleMetadata.name);\n if (!filePath || !metaData) {\n throw new Error(`Configuration details not found for module: ${moduleMetadata.name}`);\n }\n\n // Write the dashboard to the config file\n await this.writeToConfig(metaData, dashboard, filePath);\n }\n\n private async getConfigFileDetails(moduleName: string): Promise<{ filePath: string; metaData: any }> {\n const filePath = await this.moduleMetadataHelperService.getModuleMetadataFilePath(moduleName);\n try {\n await fs.access(filePath);\n } catch (error: any) {\n throw new Error(`Configuration file not found for module: ${moduleName}`);\n }\n const metaData = await this.moduleMetadataHelperService.getModuleMetadataConfiguration(filePath);\n return { filePath, metaData };\n }\n\n private async writeToConfig(metaData: any, dashboard: Dashboard, filePath: string) {\n if (metaData.dashboards && Array.isArray(metaData.dashboards)) {\n const dashboardIndex = metaData.dashboards?.findIndex((dashboardFromFile: { name: string; }) => dashboardFromFile.name === dashboard.name);\n const dto = await this.dashboardMapper.toDto(dashboard);\n if (dashboardIndex !== -1) {\n metaData.dashboards[dashboardIndex] = dto;\n }\n else {\n metaData.dashboards.push(dto);\n }\n }\n else {\n const dashboards = [];\n const dto = await this.dashboardMapper.toDto(dashboard);\n dashboards.push(dto);\n metaData.dashboards = dashboards;\n }\n // Write the updated object back to the file\n const updatedContent = JSON.stringify(metaData, null, 2);\n await fs.writeFile(filePath, updatedContent);\n }\n}"]}
@@ -1 +1 @@
1
- {"version":3,"file":"database-bootstrap.service.js","sourceRoot":"","sources":["../../../src/services/database/database-bootstrap.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable, Logger, OnModuleInit } from '@nestjs/common';\nimport { DataSource } from 'typeorm';\nimport { readdir, readFile } from 'fs/promises';\nimport * as path from 'path';\nimport { InjectDataSource } from '@nestjs/typeorm';\n\n@Injectable()\nexport class DatabaseBootstrapService implements OnModuleInit {\n private readonly logger = new Logger(DatabaseBootstrapService.name);\n\n constructor(\n @InjectDataSource()\n private readonly dataSource: DataSource,\n ) { }\n\n async onModuleInit() {\n if (!this.dataSource.isInitialized) {\n this.logger.warn(`[${this.dataSource.name}] DataSource not initialized. Skipping SQL bootstrap.`);\n return;\n }\n\n this.logger.debug(`[${this.dataSource.name}] Bootstrapping stored procedures...`);\n\n await this.applyAllSqlFiles();\n\n this.logger.debug(`[${this.dataSource.name}] SQL bootstrap completed`);\n }\n\n private resolveSqlDirectory(): string {\n const datasourceName = this.dataSource.name || 'default';\n const dbType = this.dataSource.options.type;\n\n const sqlFilePath = path.resolve(__dirname, `../../../sql/${datasourceName}/${dbType}`);\n\n return sqlFilePath\n }\n\n private async applyAllSqlFiles() {\n const sqlDir = this.resolveSqlDirectory();\n\n this.logger.debug(`[${this.dataSource.name}] SQL directory: ${sqlDir}`);\n\n let files: string[];\n try {\n files = await readdir(sqlDir);\n } catch {\n this.logger.warn(\n `[${this.dataSource.name}] No SQL directory found. Skipping.`,\n );\n return;\n }\n\n const sqlFiles = files\n .filter(file => file.endsWith('.sql'))\n .sort();\n\n if (!sqlFiles.length) {\n this.logger.warn(\n `[${this.dataSource.name}] No SQL files found`,\n );\n return;\n }\n\n for (const file of sqlFiles) {\n await this.applySqlFileSafely(\n path.join(sqlDir, file),\n file,\n );\n }\n }\n\n private async applySqlFileSafely(\n filePath: string,\n fileName: string,\n ) {\n this.logger.debug(`[${this.dataSource.name}] Applying ${fileName}`);\n\n try {\n const sql = await readFile(filePath, 'utf8');\n await this.dataSource.query(sql);\n\n this.logger.debug(`[${this.dataSource.name}] Applied ${fileName}`);\n } catch (error) {\n // DO NOT THROW — continue with next file\n this.logger.error(\n `[${this.dataSource.name}] Failed ${fileName}`,\n error instanceof Error ? error.stack : String(error),\n );\n }\n }\n}\n"]}
1
+ {"version":3,"file":"database-bootstrap.service.js","sourceRoot":"","sources":["../../../src/services/database/database-bootstrap.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable, Logger, OnModuleInit } from '@nestjs/common';\nimport { DataSource } from 'typeorm';\nimport { readdir, readFile } from 'fs/promises';\nimport * as path from 'path';\nimport { InjectDataSource } from '@nestjs/typeorm';\n\n@Injectable()\nexport class DatabaseBootstrapService implements OnModuleInit {\n private readonly logger = new Logger(DatabaseBootstrapService.name);\n\n constructor(\n @InjectDataSource()\n private readonly dataSource: DataSource,\n ) { }\n\n async onModuleInit() {\n if (!this.dataSource.isInitialized) {\n this.logger.warn(`[${this.dataSource.name}] DataSource not initialized. Skipping SQL bootstrap.`);\n return;\n }\n\n this.logger.debug(`[${this.dataSource.name}] Bootstrapping stored procedures...`);\n\n await this.applyAllSqlFiles();\n\n this.logger.debug(`[${this.dataSource.name}] SQL bootstrap completed`);\n }\n\n private resolveSqlDirectory(): string {\n const datasourceName = this.dataSource.name || 'default';\n const dbType = this.dataSource.options.type;\n\n const sqlFilePath = path.resolve(__dirname, `../../../sql/${datasourceName}/${dbType}`);\n\n return sqlFilePath\n }\n\n private async applyAllSqlFiles() {\n const sqlDir = this.resolveSqlDirectory();\n\n this.logger.debug(`[${this.dataSource.name}] SQL directory: ${sqlDir}`);\n\n let files: string[];\n try {\n files = await readdir(sqlDir);\n } catch {\n this.logger.warn(\n `[${this.dataSource.name}] No SQL directory found. Skipping.`,\n );\n return;\n }\n\n const sqlFiles = files\n .filter(file => file.endsWith('.sql'))\n .sort();\n\n if (!sqlFiles.length) {\n this.logger.warn(\n `[${this.dataSource.name}] No SQL files found`,\n );\n return;\n }\n\n for (const file of sqlFiles) {\n await this.applySqlFileSafely(\n path.join(sqlDir, file),\n file,\n );\n }\n }\n\n private async applySqlFileSafely(\n filePath: string,\n fileName: string,\n ) {\n this.logger.debug(`[${this.dataSource.name}] Applying ${fileName}`);\n\n try {\n const sql = await readFile(filePath, 'utf8');\n await this.dataSource.query(sql);\n\n this.logger.debug(`[${this.dataSource.name}] Applied ${fileName}`);\n } catch (error: any) {\n // DO NOT THROW — continue with next file\n this.logger.error(\n `[${this.dataSource.name}] Failed ${fileName}`,\n error instanceof Error ? error.stack : String(error),\n );\n }\n }\n}\n"]}