@solidstarters/solid-core 1.2.200 → 1.2.202
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/commands/fixtures/fixtures-setup.command.d.ts +15 -0
- package/dist/commands/fixtures/fixtures-setup.command.d.ts.map +1 -0
- package/dist/commands/fixtures/fixtures-setup.command.js +58 -0
- package/dist/commands/fixtures/fixtures-setup.command.js.map +1 -0
- package/dist/commands/fixtures/fixtures-tear-down.command.d.ts +16 -0
- package/dist/commands/fixtures/fixtures-tear-down.command.d.ts.map +1 -0
- package/dist/commands/fixtures/fixtures-tear-down.command.js +59 -0
- package/dist/commands/fixtures/fixtures-tear-down.command.js.map +1 -0
- package/dist/commands/refresh-model.command.d.ts.map +1 -1
- package/dist/commands/refresh-model.command.js +4 -0
- package/dist/commands/refresh-model.command.js.map +1 -1
- package/dist/config/cache.options.d.ts +1 -1
- package/dist/config/cache.options.d.ts.map +1 -1
- package/dist/config/cache.options.js +2 -2
- package/dist/config/cache.options.js.map +1 -1
- package/dist/config/iam.config.d.ts +4 -0
- package/dist/config/iam.config.d.ts.map +1 -1
- package/dist/config/iam.config.js +2 -0
- package/dist/config/iam.config.js.map +1 -1
- package/dist/constants/error-messages.d.ts +2 -0
- package/dist/constants/error-messages.d.ts.map +1 -1
- package/dist/constants/error-messages.js +4 -0
- package/dist/constants/error-messages.js.map +1 -1
- package/dist/controllers/model-metadata.controller.d.ts +25 -0
- package/dist/controllers/model-metadata.controller.d.ts.map +1 -1
- package/dist/controllers/model-metadata.controller.js +23 -0
- package/dist/controllers/model-metadata.controller.js.map +1 -1
- package/dist/controllers/model-sequence.controller.d.ts +43 -0
- package/dist/controllers/model-sequence.controller.d.ts.map +1 -0
- package/dist/controllers/model-sequence.controller.js +179 -0
- package/dist/controllers/model-sequence.controller.js.map +1 -0
- package/dist/controllers/setting.controller.d.ts +2 -2
- package/dist/controllers/setting.controller.d.ts.map +1 -1
- package/dist/controllers/setting.controller.js +36 -42
- package/dist/controllers/setting.controller.js.map +1 -1
- package/dist/decorators/sms-provider.decorator.d.ts +3 -0
- package/dist/decorators/sms-provider.decorator.d.ts.map +1 -0
- package/dist/decorators/sms-provider.decorator.js +11 -0
- package/dist/decorators/sms-provider.decorator.js.map +1 -0
- package/dist/dtos/basic-filters.dto.d.ts +3 -1
- package/dist/dtos/basic-filters.dto.d.ts.map +1 -1
- package/dist/dtos/basic-filters.dto.js +8 -2
- package/dist/dtos/basic-filters.dto.js.map +1 -1
- package/dist/dtos/basic-group-filters.dto.d.ts +6 -0
- package/dist/dtos/basic-group-filters.dto.d.ts.map +1 -0
- package/dist/dtos/basic-group-filters.dto.js +46 -0
- package/dist/dtos/basic-group-filters.dto.js.map +1 -0
- package/dist/dtos/create-field-metadata.dto.js +2 -2
- package/dist/dtos/create-field-metadata.dto.js.map +1 -1
- package/dist/dtos/create-model-sequence.dto.d.ts +14 -0
- package/dist/dtos/create-model-sequence.dto.d.ts.map +1 -0
- package/dist/dtos/create-model-sequence.dto.js +90 -0
- package/dist/dtos/create-model-sequence.dto.js.map +1 -0
- package/dist/dtos/create-role-metadata.dto.d.ts.map +1 -1
- package/dist/dtos/create-role-metadata.dto.js +1 -0
- package/dist/dtos/create-role-metadata.dto.js.map +1 -1
- package/dist/dtos/get-mcp-url.dto.d.ts +5 -0
- package/dist/dtos/get-mcp-url.dto.d.ts.map +1 -0
- package/dist/dtos/get-mcp-url.dto.js +31 -0
- package/dist/dtos/get-mcp-url.dto.js.map +1 -0
- package/dist/dtos/navigation.dto.d.ts +6 -0
- package/dist/dtos/navigation.dto.d.ts.map +1 -0
- package/dist/dtos/navigation.dto.js +33 -0
- package/dist/dtos/navigation.dto.js.map +1 -0
- package/dist/dtos/resolve-s3-url.dto.d.ts +5 -5
- package/dist/dtos/resolve-s3-url.dto.d.ts.map +1 -1
- package/dist/dtos/resolve-s3-url.dto.js +7 -7
- package/dist/dtos/resolve-s3-url.dto.js.map +1 -1
- package/dist/dtos/sign-in.dto.js +3 -3
- package/dist/dtos/sign-in.dto.js.map +1 -1
- package/dist/dtos/update-model-sequence.dto.d.ts +15 -0
- package/dist/dtos/update-model-sequence.dto.d.ts.map +1 -0
- package/dist/dtos/update-model-sequence.dto.js +94 -0
- package/dist/dtos/update-model-sequence.dto.js.map +1 -0
- package/dist/entities/common.entity.d.ts.map +1 -1
- package/dist/entities/common.entity.js +6 -4
- package/dist/entities/common.entity.js.map +1 -1
- package/dist/entities/field-metadata.entity.d.ts.map +1 -1
- package/dist/entities/field-metadata.entity.js +2 -1
- package/dist/entities/field-metadata.entity.js.map +1 -1
- package/dist/entities/legacy-common.entity.d.ts.map +1 -1
- package/dist/entities/legacy-common.entity.js +6 -4
- package/dist/entities/legacy-common.entity.js.map +1 -1
- package/dist/entities/model-metadata.entity.d.ts.map +1 -1
- package/dist/entities/model-metadata.entity.js +5 -1
- package/dist/entities/model-metadata.entity.js.map +1 -1
- package/dist/entities/model-sequence.entity.d.ts +15 -0
- package/dist/entities/model-sequence.entity.d.ts.map +1 -0
- package/dist/entities/model-sequence.entity.js +67 -0
- package/dist/entities/model-sequence.entity.js.map +1 -0
- package/dist/factories/mail.factory.d.ts.map +1 -1
- package/dist/factories/mail.factory.js.map +1 -1
- package/dist/factories/sms.factory.d.ts +14 -0
- package/dist/factories/sms.factory.d.ts.map +1 -0
- package/dist/factories/sms.factory.js +53 -0
- package/dist/factories/sms.factory.js.map +1 -0
- package/dist/helpers/date.helper.d.ts.map +1 -1
- package/dist/helpers/date.helper.js +13 -4
- package/dist/helpers/date.helper.js.map +1 -1
- package/dist/helpers/field-crud-managers/BigIntFieldCrudManager.d.ts.map +1 -1
- package/dist/helpers/field-crud-managers/BigIntFieldCrudManager.js +13 -2
- package/dist/helpers/field-crud-managers/BigIntFieldCrudManager.js.map +1 -1
- package/dist/helpers/field-crud-managers/ManyToManyRelationFieldCrudManager.d.ts +0 -1
- package/dist/helpers/field-crud-managers/ManyToManyRelationFieldCrudManager.d.ts.map +1 -1
- package/dist/helpers/field-crud-managers/ManyToManyRelationFieldCrudManager.js +4 -9
- package/dist/helpers/field-crud-managers/ManyToManyRelationFieldCrudManager.js.map +1 -1
- package/dist/helpers/field-crud-managers/ManyToOneRelationFieldCrudManager.d.ts +0 -1
- package/dist/helpers/field-crud-managers/ManyToOneRelationFieldCrudManager.d.ts.map +1 -1
- package/dist/helpers/field-crud-managers/ManyToOneRelationFieldCrudManager.js +7 -8
- package/dist/helpers/field-crud-managers/ManyToOneRelationFieldCrudManager.js.map +1 -1
- package/dist/helpers/field-crud-managers/OneToManyRelationFieldCrudManager.d.ts +0 -1
- package/dist/helpers/field-crud-managers/OneToManyRelationFieldCrudManager.d.ts.map +1 -1
- package/dist/helpers/field-crud-managers/OneToManyRelationFieldCrudManager.js +4 -9
- package/dist/helpers/field-crud-managers/OneToManyRelationFieldCrudManager.js.map +1 -1
- package/dist/helpers/model-metadata-helper.service.d.ts.map +1 -1
- package/dist/helpers/model-metadata-helper.service.js +6 -2
- package/dist/helpers/model-metadata-helper.service.js.map +1 -1
- package/dist/helpers/module-metadata-helper.service.d.ts +1 -0
- package/dist/helpers/module-metadata-helper.service.d.ts.map +1 -1
- package/dist/helpers/module-metadata-helper.service.js +9 -0
- package/dist/helpers/module-metadata-helper.service.js.map +1 -1
- package/dist/helpers/module.helper.d.ts +1 -0
- package/dist/helpers/module.helper.d.ts.map +1 -1
- package/dist/helpers/module.helper.js +29 -3
- package/dist/helpers/module.helper.js.map +1 -1
- package/dist/helpers/solid-registry.d.ts +14 -0
- package/dist/helpers/solid-registry.d.ts.map +1 -1
- package/dist/helpers/solid-registry.js +7 -0
- package/dist/helpers/solid-registry.js.map +1 -1
- package/dist/index.d.ts +12 -7
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +13 -8
- package/dist/index.js.map +1 -1
- package/dist/jobs/computed-field-evaluation-subscriber.service.d.ts +1 -0
- package/dist/jobs/computed-field-evaluation-subscriber.service.d.ts.map +1 -1
- package/dist/jobs/computed-field-evaluation-subscriber.service.js +16 -4
- package/dist/jobs/computed-field-evaluation-subscriber.service.js.map +1 -1
- package/dist/jobs/database/{sms-publisher-database.service.d.ts → msg91-sms-publisher-database.service.d.ts} +2 -2
- package/dist/jobs/database/msg91-sms-publisher-database.service.d.ts.map +1 -0
- package/dist/jobs/database/{sms-publisher-database.service.js → msg91-sms-publisher-database.service.js} +8 -8
- package/dist/jobs/database/msg91-sms-publisher-database.service.js.map +1 -0
- package/dist/jobs/database/{sms-queue-database-options.d.ts → msg91-sms-queue-database-options.d.ts} +1 -1
- package/dist/jobs/database/msg91-sms-queue-database-options.d.ts.map +1 -0
- package/dist/jobs/database/{sms-queue-database-options.js → msg91-sms-queue-database-options.js} +1 -1
- package/dist/jobs/database/msg91-sms-queue-database-options.js.map +1 -0
- package/dist/jobs/database/{sms-subscriber-database.service.d.ts → msg91-sms-subscriber-database.service.d.ts} +5 -5
- package/dist/jobs/database/msg91-sms-subscriber-database.service.d.ts.map +1 -0
- package/dist/jobs/database/{sms-subscriber-database.service.js → msg91-sms-subscriber-database.service.js} +14 -12
- package/dist/jobs/database/msg91-sms-subscriber-database.service.js.map +1 -0
- package/dist/jobs/database/otp-subscriber-database.service.d.ts +4 -4
- package/dist/jobs/database/otp-subscriber-database.service.d.ts.map +1 -1
- package/dist/jobs/database/otp-subscriber-database.service.js +6 -4
- package/dist/jobs/database/otp-subscriber-database.service.js.map +1 -1
- package/dist/jobs/database/twilio-sms-subscriber-database.service.d.ts +3 -3
- package/dist/jobs/database/twilio-sms-subscriber-database.service.d.ts.map +1 -1
- package/dist/jobs/database/twilio-sms-subscriber-database.service.js +6 -4
- package/dist/jobs/database/twilio-sms-subscriber-database.service.js.map +1 -1
- package/dist/jobs/{sms-publisher.service.d.ts → msg91-otp-publisher.service.d.ts} +2 -2
- package/dist/jobs/msg91-otp-publisher.service.d.ts.map +1 -0
- package/dist/jobs/{sms-publisher.service.js → msg91-otp-publisher.service.js} +8 -8
- package/dist/jobs/msg91-otp-publisher.service.js.map +1 -0
- package/dist/jobs/{sms-queue-options.d.ts → msg91-otp-queue-options.d.ts} +1 -1
- package/dist/jobs/msg91-otp-queue-options.d.ts.map +1 -0
- package/dist/jobs/{otp-queue-options.js → msg91-otp-queue-options.js} +1 -1
- package/dist/jobs/msg91-otp-queue-options.js.map +1 -0
- package/dist/jobs/{sms-subscriber.service.d.ts → msg91-otp-subscriber.service.d.ts} +6 -6
- package/dist/jobs/msg91-otp-subscriber.service.d.ts.map +1 -0
- package/dist/jobs/{otp-subscriber.service.js → msg91-otp-subscriber.service.js} +14 -12
- package/dist/jobs/msg91-otp-subscriber.service.js.map +1 -0
- package/dist/jobs/{otp-publisher.service.d.ts → msg91-sms-publisher.service.d.ts} +2 -2
- package/dist/jobs/msg91-sms-publisher.service.d.ts.map +1 -0
- package/dist/jobs/{otp-publisher.service.js → msg91-sms-publisher.service.js} +8 -8
- package/dist/jobs/msg91-sms-publisher.service.js.map +1 -0
- package/dist/jobs/{otp-queue-options.d.ts → msg91-sms-queue-options.d.ts} +1 -1
- package/dist/jobs/msg91-sms-queue-options.d.ts.map +1 -0
- package/dist/jobs/{sms-queue-options.js → msg91-sms-queue-options.js} +1 -1
- package/dist/jobs/msg91-sms-queue-options.js.map +1 -0
- package/dist/jobs/{otp-subscriber.service.d.ts → msg91-sms-subscriber.service.d.ts} +7 -7
- package/dist/jobs/msg91-sms-subscriber.service.d.ts.map +1 -0
- package/dist/jobs/{sms-subscriber.service.js → msg91-sms-subscriber.service.js} +14 -12
- package/dist/jobs/msg91-sms-subscriber.service.js.map +1 -0
- package/dist/jobs/twilio-sms-subscriber.service.d.ts +3 -3
- package/dist/jobs/twilio-sms-subscriber.service.d.ts.map +1 -1
- package/dist/jobs/twilio-sms-subscriber.service.js +6 -4
- package/dist/jobs/twilio-sms-subscriber.service.js.map +1 -1
- package/dist/repository/media.repository.d.ts.map +1 -1
- package/dist/repository/media.repository.js +4 -0
- package/dist/repository/media.repository.js.map +1 -1
- package/dist/repository/model-sequence.repository.d.ts +14 -0
- package/dist/repository/model-sequence.repository.d.ts.map +1 -0
- package/dist/repository/model-sequence.repository.js +103 -0
- package/dist/repository/model-sequence.repository.js.map +1 -0
- package/dist/seeders/module-metadata-seeder.service.d.ts +7 -12
- package/dist/seeders/module-metadata-seeder.service.d.ts.map +1 -1
- package/dist/seeders/module-metadata-seeder.service.js +87 -27
- package/dist/seeders/module-metadata-seeder.service.js.map +1 -1
- package/dist/seeders/seed-data/solid-core-metadata.json +373 -52
- package/dist/seeders/system-fields-seeder.service.d.ts +1 -0
- package/dist/seeders/system-fields-seeder.service.d.ts.map +1 -1
- package/dist/seeders/system-fields-seeder.service.js +11 -2
- package/dist/seeders/system-fields-seeder.service.js.map +1 -1
- package/dist/seeders/user-seeder.service.d.ts.map +1 -1
- package/dist/seeders/user-seeder.service.js +5 -4
- package/dist/seeders/user-seeder.service.js.map +1 -1
- package/dist/services/action-metadata.service.d.ts.map +1 -1
- package/dist/services/action-metadata.service.js +1 -0
- package/dist/services/action-metadata.service.js.map +1 -1
- package/dist/services/ai-interaction.service.d.ts.map +1 -1
- package/dist/services/ai-interaction.service.js +1 -0
- package/dist/services/ai-interaction.service.js.map +1 -1
- package/dist/services/authentication.service.d.ts +6 -3
- package/dist/services/authentication.service.d.ts.map +1 -1
- package/dist/services/authentication.service.js +70 -27
- package/dist/services/authentication.service.js.map +1 -1
- package/dist/services/chatter-message-details.service.d.ts.map +1 -1
- package/dist/services/chatter-message-details.service.js +1 -0
- package/dist/services/chatter-message-details.service.js.map +1 -1
- package/dist/services/chatter-message.service.d.ts.map +1 -1
- package/dist/services/chatter-message.service.js +7 -3
- package/dist/services/chatter-message.service.js.map +1 -1
- package/dist/services/computed-fields/entity/alpha-num-external-id-computed-field-provider.js +7 -5
- package/dist/services/computed-fields/entity/alpha-num-external-id-computed-field-provider.js.map +1 -1
- package/dist/services/computed-fields/entity/sequence-num-computed-field-provider.d.ts +15 -0
- package/dist/services/computed-fields/entity/sequence-num-computed-field-provider.d.ts.map +1 -0
- package/dist/services/computed-fields/entity/sequence-num-computed-field-provider.js +72 -0
- package/dist/services/computed-fields/entity/sequence-num-computed-field-provider.js.map +1 -0
- package/dist/services/crud-helper.service.d.ts +23 -6
- package/dist/services/crud-helper.service.d.ts.map +1 -1
- package/dist/services/crud-helper.service.js +257 -45
- package/dist/services/crud-helper.service.js.map +1 -1
- package/dist/services/crud.service.d.ts +4 -3
- package/dist/services/crud.service.d.ts.map +1 -1
- package/dist/services/crud.service.js +53 -24
- package/dist/services/crud.service.js.map +1 -1
- package/dist/services/database/database-bootstrap.service.d.ts +12 -0
- package/dist/services/database/database-bootstrap.service.d.ts.map +1 -0
- package/dist/services/database/database-bootstrap.service.js +115 -0
- package/dist/services/database/database-bootstrap.service.js.map +1 -0
- package/dist/services/email-template.service.d.ts +7 -7
- package/dist/services/email-template.service.d.ts.map +1 -1
- package/dist/services/email-template.service.js +8 -7
- package/dist/services/email-template.service.js.map +1 -1
- package/dist/services/excel.service.d.ts +11 -0
- package/dist/services/excel.service.d.ts.map +1 -1
- package/dist/services/excel.service.js +104 -0
- package/dist/services/excel.service.js.map +1 -1
- package/dist/services/field-metadata.service.d.ts +4 -1
- package/dist/services/field-metadata.service.d.ts.map +1 -1
- package/dist/services/field-metadata.service.js +35 -30
- package/dist/services/field-metadata.service.js.map +1 -1
- package/dist/services/file.service.d.ts +1 -0
- package/dist/services/file.service.d.ts.map +1 -1
- package/dist/services/file.service.js +9 -0
- package/dist/services/file.service.js.map +1 -1
- package/dist/services/fixtures.service.d.ts +13 -0
- package/dist/services/fixtures.service.d.ts.map +1 -0
- package/dist/services/fixtures.service.js +95 -0
- package/dist/services/fixtures.service.js.map +1 -0
- package/dist/services/genai/ingest-metadata.service.d.ts.map +1 -1
- package/dist/services/genai/ingest-metadata.service.js +1 -1
- package/dist/services/genai/ingest-metadata.service.js.map +1 -1
- package/dist/services/import-transaction-error-log.service.d.ts.map +1 -1
- package/dist/services/import-transaction-error-log.service.js +1 -0
- package/dist/services/import-transaction-error-log.service.js.map +1 -1
- package/dist/services/import-transaction.service.d.ts.map +1 -1
- package/dist/services/import-transaction.service.js +7 -1
- package/dist/services/import-transaction.service.js.map +1 -1
- package/dist/services/list-of-values.service.d.ts +2 -2
- package/dist/services/list-of-values.service.d.ts.map +1 -1
- package/dist/services/list-of-values.service.js +2 -1
- package/dist/services/list-of-values.service.js.map +1 -1
- package/dist/services/locale.service.d.ts.map +1 -1
- package/dist/services/locale.service.js +1 -0
- package/dist/services/locale.service.js.map +1 -1
- package/dist/services/mail/smtp-email.service.js +0 -1
- package/dist/services/mail/smtp-email.service.js.map +1 -1
- package/dist/services/media.service.d.ts +3 -3
- package/dist/services/media.service.d.ts.map +1 -1
- package/dist/services/media.service.js +6 -4
- package/dist/services/media.service.js.map +1 -1
- package/dist/services/mediaStorageProviders/file-s3-storage-provider.d.ts.map +1 -1
- package/dist/services/mediaStorageProviders/file-s3-storage-provider.js +17 -6
- package/dist/services/mediaStorageProviders/file-s3-storage-provider.js.map +1 -1
- package/dist/services/mediaStorageProviders/file-storage-provider.d.ts.map +1 -1
- package/dist/services/mediaStorageProviders/file-storage-provider.js +0 -13
- package/dist/services/mediaStorageProviders/file-storage-provider.js.map +1 -1
- package/dist/services/menu-item-metadata.service.d.ts.map +1 -1
- package/dist/services/menu-item-metadata.service.js +4 -0
- package/dist/services/menu-item-metadata.service.js.map +1 -1
- package/dist/services/model-metadata.service.d.ts +28 -1
- package/dist/services/model-metadata.service.d.ts.map +1 -1
- package/dist/services/model-metadata.service.js +111 -44
- package/dist/services/model-metadata.service.js.map +1 -1
- package/dist/services/model-sequence.service.d.ts +23 -0
- package/dist/services/model-sequence.service.d.ts.map +1 -0
- package/dist/services/model-sequence.service.js +55 -0
- package/dist/services/model-sequence.service.js.map +1 -0
- package/dist/services/module-metadata.service.d.ts +1 -0
- package/dist/services/module-metadata.service.d.ts.map +1 -1
- package/dist/services/module-metadata.service.js +35 -1
- package/dist/services/module-metadata.service.js.map +1 -1
- package/dist/services/permission-metadata.service.d.ts +5 -5
- package/dist/services/permission-metadata.service.d.ts.map +1 -1
- package/dist/services/permission-metadata.service.js +6 -5
- package/dist/services/permission-metadata.service.js.map +1 -1
- package/dist/services/queues/database-subscriber.service.d.ts.map +1 -1
- package/dist/services/queues/database-subscriber.service.js +2 -1
- package/dist/services/queues/database-subscriber.service.js.map +1 -1
- package/dist/services/queues/rabbitmq-subscriber.service.d.ts.map +1 -1
- package/dist/services/queues/rabbitmq-subscriber.service.js +2 -2
- package/dist/services/queues/rabbitmq-subscriber.service.js.map +1 -1
- package/dist/services/role-metadata.service.d.ts.map +1 -1
- package/dist/services/role-metadata.service.js +1 -0
- package/dist/services/role-metadata.service.js.map +1 -1
- package/dist/services/scheduled-job.service.d.ts +6 -6
- package/dist/services/scheduled-job.service.d.ts.map +1 -1
- package/dist/services/scheduled-job.service.js +8 -8
- package/dist/services/scheduled-job.service.js.map +1 -1
- package/dist/services/scheduled-jobs/scheduler.service.d.ts.map +1 -1
- package/dist/services/scheduled-jobs/scheduler.service.js +4 -0
- package/dist/services/scheduled-jobs/scheduler.service.js.map +1 -1
- package/dist/services/security-rule.service.d.ts.map +1 -1
- package/dist/services/security-rule.service.js +1 -0
- package/dist/services/security-rule.service.js.map +1 -1
- package/dist/services/selection-providers/list-of-models-selection-provider.service.d.ts.map +1 -1
- package/dist/services/selection-providers/list-of-models-selection-provider.service.js +4 -0
- package/dist/services/selection-providers/list-of-models-selection-provider.service.js.map +1 -1
- package/dist/services/setting.service.d.ts +7 -5
- package/dist/services/setting.service.d.ts.map +1 -1
- package/dist/services/setting.service.js +28 -48
- package/dist/services/setting.service.js.map +1 -1
- package/dist/services/sms/Msg91BaseSMSService.js +6 -6
- package/dist/services/sms/Msg91BaseSMSService.js.map +1 -1
- package/dist/services/sms/Msg91OTPService.d.ts.map +1 -1
- package/dist/services/sms/Msg91OTPService.js +3 -1
- package/dist/services/sms/Msg91OTPService.js.map +1 -1
- package/dist/services/sms/Msg91SMSService.d.ts.map +1 -1
- package/dist/services/sms/Msg91SMSService.js +3 -1
- package/dist/services/sms/Msg91SMSService.js.map +1 -1
- package/dist/services/sms/TwilioSMSService.d.ts.map +1 -1
- package/dist/services/sms/TwilioSMSService.js +2 -0
- package/dist/services/sms/TwilioSMSService.js.map +1 -1
- package/dist/services/sms-template.service.d.ts +7 -7
- package/dist/services/sms-template.service.d.ts.map +1 -1
- package/dist/services/sms-template.service.js +8 -7
- package/dist/services/sms-template.service.js.map +1 -1
- package/dist/services/solid-introspect.service.d.ts +5 -13
- package/dist/services/solid-introspect.service.d.ts.map +1 -1
- package/dist/services/solid-introspect.service.js +18 -22
- package/dist/services/solid-introspect.service.js.map +1 -1
- package/dist/services/solid-ts-morph.service.js +2 -2
- package/dist/services/solid-ts-morph.service.js.map +1 -1
- package/dist/services/user-activity-history.service.d.ts.map +1 -1
- package/dist/services/user-activity-history.service.js +1 -0
- package/dist/services/user-activity-history.service.js.map +1 -1
- package/dist/services/user-view-metadata.service.d.ts.map +1 -1
- package/dist/services/user-view-metadata.service.js +3 -2
- package/dist/services/user-view-metadata.service.js.map +1 -1
- package/dist/services/user.service.d.ts.map +1 -1
- package/dist/services/user.service.js +1 -0
- package/dist/services/user.service.js.map +1 -1
- package/dist/services/view-metadata.service.d.ts +1 -1
- package/dist/services/view-metadata.service.d.ts.map +1 -1
- package/dist/services/view-metadata.service.js +3 -1
- package/dist/services/view-metadata.service.js.map +1 -1
- package/dist/solid-core-cli-db.module.d.ts.map +1 -1
- package/dist/solid-core-cli-db.module.js +5 -2
- package/dist/solid-core-cli-db.module.js.map +1 -1
- package/dist/solid-core-cli.module.js +1 -1
- package/dist/solid-core-cli.module.js.map +1 -1
- package/dist/solid-core.module.d.ts.map +1 -1
- package/dist/solid-core.module.js +40 -13
- package/dist/solid-core.module.js.map +1 -1
- package/dist/subscribers/audit.subscriber.d.ts.map +1 -1
- package/dist/subscribers/audit.subscriber.js +5 -1
- package/dist/subscribers/audit.subscriber.js.map +1 -1
- package/dist/subscribers/computed-entity-field.subscriber.d.ts +4 -2
- package/dist/subscribers/computed-entity-field.subscriber.d.ts.map +1 -1
- package/dist/subscribers/computed-entity-field.subscriber.js +53 -12
- package/dist/subscribers/computed-entity-field.subscriber.js.map +1 -1
- package/dist/subscribers/scheduled-job.subscriber.d.ts.map +1 -1
- package/dist/subscribers/scheduled-job.subscriber.js +1 -1
- package/dist/subscribers/scheduled-job.subscriber.js.map +1 -1
- package/dist/transformers/typeorm/local-date-time-transformer.d.ts +5 -0
- package/dist/transformers/typeorm/local-date-time-transformer.d.ts.map +1 -0
- package/dist/transformers/typeorm/local-date-time-transformer.js +48 -0
- package/dist/transformers/typeorm/local-date-time-transformer.js.map +1 -0
- package/dist/tsconfig.tsbuildinfo +1 -1
- package/docs/grouping-enhancements.md +89 -0
- package/package.json +1 -1
- package/src/commands/fixtures/fixtures-setup.command.ts +44 -0
- package/src/commands/fixtures/fixtures-tear-down.command.ts +45 -0
- package/src/commands/refresh-model.command.ts +3 -1
- package/src/config/cache.options.ts +6 -3
- package/src/config/iam.config.ts +2 -1
- package/src/constants/error-messages.ts +7 -1
- package/src/controllers/model-metadata.controller.ts +21 -1
- package/src/controllers/model-sequence.controller.ts +93 -0
- package/src/controllers/setting.controller.ts +62 -54
- package/src/decorators/sms-provider.decorator.ts +7 -0
- package/src/dtos/basic-filters.dto.ts +6 -1
- package/src/dtos/basic-group-filters.dto.ts +23 -0
- package/src/dtos/create-field-metadata.dto.ts +1 -1
- package/src/dtos/create-model-sequence.dto.ts +51 -0
- package/src/dtos/create-role-metadata.dto.ts +16 -3
- package/src/dtos/get-mcp-url.dto.ts +13 -0
- package/src/dtos/navigation.dto.ts +14 -0
- package/src/dtos/resolve-s3-url.dto.ts +9 -11
- package/src/dtos/sign-in.dto.ts +3 -3
- package/src/dtos/update-model-sequence.dto.ts +53 -0
- package/src/entities/common.entity.ts +8 -8
- package/src/entities/field-metadata.entity.ts +1 -1
- package/src/entities/legacy-common.entity.ts +8 -6
- package/src/entities/model-metadata.entity.ts +1 -1
- package/src/entities/model-sequence.entity.ts +32 -0
- package/src/factories/mail.factory.ts +0 -1
- package/src/factories/sms.factory.ts +43 -0
- package/src/helpers/date.helper.ts +38 -9
- package/src/helpers/field-crud-managers/BigIntFieldCrudManager.ts +18 -5
- package/src/helpers/field-crud-managers/ManyToManyRelationFieldCrudManager.ts +9 -9
- package/src/helpers/field-crud-managers/ManyToOneRelationFieldCrudManager.ts +16 -8
- package/src/helpers/field-crud-managers/OneToManyRelationFieldCrudManager.ts +9 -9
- package/src/helpers/model-metadata-helper.service.ts +6 -4
- package/src/helpers/module-metadata-helper.service.ts +18 -1
- package/src/helpers/module.helper.ts +40 -5
- package/src/helpers/solid-registry.ts +23 -0
- package/src/index.ts +12 -7
- package/src/jobs/computed-field-evaluation-subscriber.service.ts +15 -4
- package/src/jobs/database/{sms-publisher-database.service.ts → msg91-sms-publisher-database.service.ts} +2 -2
- package/src/jobs/database/{sms-subscriber-database.service.ts → msg91-sms-subscriber-database.service.ts} +9 -4
- package/src/jobs/database/otp-subscriber-database.service.ts +8 -2
- package/src/jobs/database/twilio-sms-subscriber-database.service.ts +5 -2
- package/src/jobs/{otp-publisher.service.ts → msg91-otp-publisher.service.ts} +2 -2
- package/src/jobs/{otp-subscriber.service.ts → msg91-otp-subscriber.service.ts} +10 -4
- package/src/jobs/{sms-publisher.service.ts → msg91-sms-publisher.service.ts} +2 -2
- package/src/jobs/{sms-subscriber.service.ts → msg91-sms-subscriber.service.ts} +9 -4
- package/src/jobs/twilio-sms-subscriber.service.ts +6 -2
- package/src/repository/media.repository.ts +3 -2
- package/src/repository/model-sequence.repository.ts +97 -0
- package/src/seeders/module-metadata-seeder.service.ts +133 -34
- package/src/seeders/seed-data/email-templates/email-on-signup.handlebars.html +155 -0
- package/src/seeders/seed-data/sms-templates/text-on-signup.handlebars.txt +10 -0
- package/src/seeders/seed-data/solid-core-metadata.json +374 -53
- package/src/seeders/system-fields-seeder.service.ts +6 -2
- package/src/seeders/user-seeder.service.ts +5 -4
- package/src/services/action-metadata.service.ts +3 -2
- package/src/services/ai-interaction.service.ts +2 -1
- package/src/services/authentication.service.ts +119 -24
- package/src/services/chatter-message-details.service.ts +2 -1
- package/src/services/chatter-message.service.ts +10 -4
- package/src/services/computed-fields/entity/alpha-num-external-id-computed-field-provider.ts +9 -9
- package/src/services/computed-fields/entity/sequence-num-computed-field-provider.ts +86 -0
- package/src/services/crud-helper.service.ts +287 -49
- package/src/services/crud.service.ts +95 -45
- package/src/services/database/database-bootstrap.service.ts +91 -0
- package/src/services/email-template.service.ts +11 -13
- package/src/services/excel.service.ts +152 -3
- package/src/services/field-metadata.service.ts +102 -55
- package/src/services/file.service.ts +9 -0
- package/src/services/fixtures.service.ts +108 -0
- package/src/services/genai/ingest-metadata.service.ts +4 -3
- package/src/services/import-transaction-error-log.service.ts +2 -1
- package/src/services/import-transaction.service.ts +8 -4
- package/src/services/list-of-values.service.ts +4 -4
- package/src/services/locale.service.ts +2 -1
- package/src/services/mail/smtp-email.service.ts +1 -1
- package/src/services/media.service.ts +10 -11
- package/src/services/mediaStorageProviders/file-s3-storage-provider.ts +22 -7
- package/src/services/mediaStorageProviders/file-storage-provider.ts +18 -13
- package/src/services/menu-item-metadata.service.ts +6 -2
- package/src/services/model-metadata.service.ts +201 -44
- package/src/services/model-sequence.service.ts +33 -0
- package/src/services/module-metadata.service.ts +49 -2
- package/src/services/permission-metadata.service.ts +8 -9
- package/src/services/queues/database-subscriber.service.ts +3 -1
- package/src/services/queues/rabbitmq-subscriber.service.ts +4 -2
- package/src/services/role-metadata.service.ts +1 -0
- package/src/services/scheduled-job.service.ts +9 -9
- package/src/services/scheduled-jobs/scheduler.service.ts +5 -0
- package/src/services/security-rule.service.ts +1 -0
- package/src/services/selection-providers/list-of-models-selection-provider.service.ts +5 -2
- package/src/services/setting.service.ts +42 -55
- package/src/services/sms/Msg91BaseSMSService.ts +6 -6
- package/src/services/sms/Msg91OTPService.ts +3 -2
- package/src/services/sms/Msg91SMSService.ts +3 -1
- package/src/services/sms/TwilioSMSService.ts +3 -3
- package/src/services/sms-template.service.ts +11 -13
- package/src/services/solid-introspect.service.ts +28 -19
- package/src/services/solid-ts-morph.service.ts +2 -2
- package/src/services/user-activity-history.service.ts +3 -2
- package/src/services/user-view-metadata.service.ts +4 -3
- package/src/services/user.service.ts +2 -1
- package/src/services/view-metadata.service.ts +5 -4
- package/src/solid-core-cli-db.module.ts +5 -4
- package/src/solid-core-cli.module.ts +2 -2
- package/src/solid-core.module.ts +42 -13
- package/src/subscribers/audit.subscriber.ts +3 -2
- package/src/subscribers/computed-entity-field.subscriber.ts +60 -17
- package/src/subscribers/scheduled-job.subscriber.ts +9 -2
- package/src/transformers/typeorm/local-date-time-transformer.ts +55 -0
- package/dist/jobs/database/sms-publisher-database.service.d.ts.map +0 -1
- package/dist/jobs/database/sms-publisher-database.service.js.map +0 -1
- package/dist/jobs/database/sms-queue-database-options.d.ts.map +0 -1
- package/dist/jobs/database/sms-queue-database-options.js.map +0 -1
- package/dist/jobs/database/sms-subscriber-database.service.d.ts.map +0 -1
- package/dist/jobs/database/sms-subscriber-database.service.js.map +0 -1
- package/dist/jobs/otp-publisher.service.d.ts.map +0 -1
- package/dist/jobs/otp-publisher.service.js.map +0 -1
- package/dist/jobs/otp-queue-options.d.ts.map +0 -1
- package/dist/jobs/otp-queue-options.js.map +0 -1
- package/dist/jobs/otp-subscriber.service.d.ts.map +0 -1
- package/dist/jobs/otp-subscriber.service.js.map +0 -1
- package/dist/jobs/sms-publisher.service.d.ts.map +0 -1
- package/dist/jobs/sms-publisher.service.js.map +0 -1
- package/dist/jobs/sms-queue-options.d.ts.map +0 -1
- package/dist/jobs/sms-queue-options.js.map +0 -1
- package/dist/jobs/sms-subscriber.service.d.ts.map +0 -1
- package/dist/jobs/sms-subscriber.service.js.map +0 -1
- /package/sql/{mssql → default/mssql}/proc_CleanupModelMetadata.sql +0 -0
- /package/sql/{mssql → default/mssql}/proc_CleanupModuleMetadata.sql +0 -0
- /package/sql/{mssql/scratchpad.sql → default/mssql/scratchpad.sql.txt} +0 -0
- /package/sql/{postgres → default/postgres}/proc_CleanupModelMetadata.sql +0 -0
- /package/sql/{postgres → default/postgres}/proc_CleanupModuleMetadata.sql +0 -0
- /package/sql/{postgres/scratchpad.sql → default/postgres/scratchpad.sql.txt} +0 -0
- /package/src/jobs/database/{sms-queue-database-options.ts → msg91-sms-queue-database-options.ts} +0 -0
- /package/src/jobs/{otp-queue-options.ts → msg91-otp-queue-options.ts} +0 -0
- /package/src/jobs/{sms-queue-options.ts → msg91-sms-queue-options.ts} +0 -0
|
@@ -0,0 +1,51 @@
|
|
|
1
|
+
import { ApiProperty } from '@nestjs/swagger';
|
|
2
|
+
import { IsInt } from 'class-validator';
|
|
3
|
+
import { IsOptional } from 'class-validator';
|
|
4
|
+
import { IsString, IsNotEmpty } from 'class-validator';
|
|
5
|
+
|
|
6
|
+
export class CreateModelSequenceDto {
|
|
7
|
+
@IsOptional()
|
|
8
|
+
@IsInt()
|
|
9
|
+
@ApiProperty()
|
|
10
|
+
moduleId: number;
|
|
11
|
+
@IsString()
|
|
12
|
+
@IsOptional()
|
|
13
|
+
@ApiProperty()
|
|
14
|
+
moduleUserKey: string;
|
|
15
|
+
@IsOptional()
|
|
16
|
+
@IsInt()
|
|
17
|
+
@ApiProperty()
|
|
18
|
+
modelId: number;
|
|
19
|
+
@IsString()
|
|
20
|
+
@IsOptional()
|
|
21
|
+
@ApiProperty()
|
|
22
|
+
modelUserKey: string;
|
|
23
|
+
@IsOptional()
|
|
24
|
+
@IsInt()
|
|
25
|
+
@ApiProperty()
|
|
26
|
+
fieldId: number;
|
|
27
|
+
@IsString()
|
|
28
|
+
@IsOptional()
|
|
29
|
+
@ApiProperty()
|
|
30
|
+
fieldUserKey: string;
|
|
31
|
+
@IsNotEmpty()
|
|
32
|
+
@IsString()
|
|
33
|
+
@ApiProperty()
|
|
34
|
+
sequenceName: string;
|
|
35
|
+
@IsOptional()
|
|
36
|
+
@IsInt()
|
|
37
|
+
@ApiProperty()
|
|
38
|
+
currentValue: number;
|
|
39
|
+
@IsOptional()
|
|
40
|
+
@IsString()
|
|
41
|
+
@ApiProperty()
|
|
42
|
+
prefix: string;
|
|
43
|
+
@IsOptional()
|
|
44
|
+
@IsInt()
|
|
45
|
+
@ApiProperty()
|
|
46
|
+
padding: number;
|
|
47
|
+
@IsOptional()
|
|
48
|
+
@IsString()
|
|
49
|
+
@ApiProperty()
|
|
50
|
+
separator: string;
|
|
51
|
+
}
|
|
@@ -54,23 +54,29 @@ export class CreateRoleMetadataDto {
|
|
|
54
54
|
@ApiProperty()
|
|
55
55
|
menuItemsCommand: string;
|
|
56
56
|
}
|
|
57
|
+
|
|
57
58
|
export const ADMIN_ROLE_NAME = 'Admin';
|
|
59
|
+
|
|
58
60
|
export const INTERNAL_ROLE_NAME = 'Internal User';
|
|
61
|
+
|
|
59
62
|
export const PUBLIC_ROLE_NAME = 'Public';
|
|
63
|
+
|
|
60
64
|
export const INTERNAL_ROLE_PERMISSIONS = [
|
|
61
65
|
// User permissions
|
|
62
66
|
'UserController.findMany', //Why do we need this?
|
|
63
67
|
'UserController.checkIfPermissionExists',
|
|
64
68
|
'UserController.findOne',
|
|
69
|
+
|
|
65
70
|
// Menu permissions
|
|
66
71
|
'MenuItemMetadataController.findMany',
|
|
67
72
|
'MenuItemMetadataController.findUserMenus',
|
|
68
73
|
'MenuItemMetadataController.findOne',
|
|
74
|
+
|
|
69
75
|
// View metadata permissions
|
|
70
76
|
'ViewMetadataController.getLayout',
|
|
71
77
|
'ViewMetadataController.findMany',
|
|
72
78
|
'ViewMetadataController.findOne',
|
|
73
|
-
|
|
79
|
+
|
|
74
80
|
// Action metadata permissions
|
|
75
81
|
'ActionMetadataController.findMany',
|
|
76
82
|
'ActionMetadataController.findOne',
|
|
@@ -79,14 +85,17 @@ export const INTERNAL_ROLE_PERMISSIONS = [
|
|
|
79
85
|
'UserViewMetadataController.upsert',
|
|
80
86
|
'UserViewMetadataController.findMany',
|
|
81
87
|
'UserViewMetadataController.findOne',
|
|
88
|
+
|
|
82
89
|
// IAM permissions
|
|
83
90
|
'AuthenticationController.changePassword',
|
|
84
91
|
'AuthenticationController.logout',
|
|
85
92
|
'AuthenticationController.me',
|
|
93
|
+
|
|
86
94
|
// Field Metadata permissions
|
|
87
95
|
'FieldMetadataController.getSelectionDynamicValues',
|
|
88
96
|
'FieldMetadataController.getSelectionDynamicValue',
|
|
89
97
|
'FieldMetadataController.findFieldDefaultMetaData',
|
|
98
|
+
|
|
90
99
|
// Saved Filters permissions
|
|
91
100
|
'SavedFiltersController.delete',
|
|
92
101
|
'SavedFiltersController.deleteMany',
|
|
@@ -98,12 +107,14 @@ export const INTERNAL_ROLE_PERMISSIONS = [
|
|
|
98
107
|
'SavedFiltersController.update',
|
|
99
108
|
'SavedFiltersController.insertMany',
|
|
100
109
|
'SavedFiltersController.create',
|
|
110
|
+
|
|
101
111
|
// Other permissions can be added here as required.
|
|
102
112
|
// Chatter permissions
|
|
103
113
|
'ChatterMessageController.create',
|
|
104
114
|
'ChatterMessageController.getChatterMessages',
|
|
105
115
|
'ChatterMessageController.postMessage',
|
|
106
|
-
|
|
116
|
+
'ChatterMessageController.findMany',
|
|
117
|
+
|
|
107
118
|
// Import
|
|
108
119
|
'ImportTransactionController.getImportTemplate',
|
|
109
120
|
'ImportTransactionController.getImportInstructions',
|
|
@@ -111,11 +122,13 @@ export const INTERNAL_ROLE_PERMISSIONS = [
|
|
|
111
122
|
'ImportTransactionController.startImportSync',
|
|
112
123
|
'ImportTransactionController.startImportAsync',
|
|
113
124
|
'ImportTransactionController.exportFailedImportedImports',
|
|
125
|
+
|
|
114
126
|
// Export permissions
|
|
115
127
|
'ExportTemplateController.startExportSync',
|
|
116
128
|
'ExportTemplateController.startExportAsync',
|
|
129
|
+
|
|
117
130
|
// List of values
|
|
118
131
|
'ListOfValuesController.findMany',
|
|
119
132
|
'ListOfValuesController.findOne',
|
|
120
133
|
// Media // [Not required], since media is always populated as part of a model
|
|
121
|
-
]
|
|
134
|
+
]
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import { Type } from "class-transformer";
|
|
2
|
+
import { IsNumber, IsOptional, IsString } from "class-validator";
|
|
3
|
+
import { BasicFilterDto } from "./basic-filters.dto";
|
|
4
|
+
|
|
5
|
+
export class NavigationDto extends BasicFilterDto {
|
|
6
|
+
|
|
7
|
+
@IsString()
|
|
8
|
+
modelName: string;
|
|
9
|
+
|
|
10
|
+
@Type(() => Number)
|
|
11
|
+
@IsNumber()
|
|
12
|
+
@IsOptional()
|
|
13
|
+
recordId: number;
|
|
14
|
+
}
|
|
@@ -7,24 +7,22 @@ export class ResolveS3UrlDto {
|
|
|
7
7
|
@IsNotEmpty()
|
|
8
8
|
fieldName: string;
|
|
9
9
|
|
|
10
|
-
@IsNotEmpty()
|
|
11
|
-
s3KeyFieldName: string;
|
|
12
10
|
|
|
13
11
|
@IsNotEmpty()
|
|
14
|
-
|
|
12
|
+
fileType?: string;
|
|
15
13
|
|
|
16
14
|
@IsNotEmpty()
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
@IsNotEmpty()
|
|
20
|
-
bucketName: string;
|
|
21
|
-
|
|
22
|
-
@IsNotEmpty()
|
|
23
|
-
isPrivate: string;
|
|
24
|
-
}
|
|
15
|
+
s3Key?: string;
|
|
25
16
|
|
|
17
|
+
@IsOptional()
|
|
18
|
+
bucketName?: string;
|
|
26
19
|
|
|
20
|
+
@IsOptional()
|
|
21
|
+
mediaStorageProviderUserKey?: string;
|
|
27
22
|
|
|
23
|
+
@IsNotEmpty()
|
|
24
|
+
isPrivate?: string;
|
|
25
|
+
}
|
|
28
26
|
|
|
29
27
|
|
|
30
28
|
|
package/src/dtos/sign-in.dto.ts
CHANGED
|
@@ -3,19 +3,19 @@ import { IsEmail, IsNotEmpty, IsOptional, IsString, MinLength } from 'class-vali
|
|
|
3
3
|
|
|
4
4
|
export class SignInDto {
|
|
5
5
|
|
|
6
|
-
@ApiProperty({ default: '
|
|
6
|
+
@ApiProperty({ default: 'sa@solidxai.com' })
|
|
7
7
|
@IsEmail()
|
|
8
8
|
// @IsNotEmpty()
|
|
9
9
|
@IsOptional()
|
|
10
10
|
email: string;
|
|
11
11
|
|
|
12
|
-
@ApiProperty({ default: '
|
|
12
|
+
@ApiProperty({ default: 'sa' })
|
|
13
13
|
@IsString()
|
|
14
14
|
// @IsNotEmpty()
|
|
15
15
|
@IsOptional()
|
|
16
16
|
username: string;
|
|
17
17
|
|
|
18
|
-
@ApiProperty({ default: '
|
|
18
|
+
@ApiProperty({ default: '' })
|
|
19
19
|
@IsOptional()
|
|
20
20
|
password: string;
|
|
21
21
|
}
|
|
@@ -0,0 +1,53 @@
|
|
|
1
|
+
import { IsInt,IsOptional, IsString, IsNotEmpty } from 'class-validator';
|
|
2
|
+
import { ApiProperty } from '@nestjs/swagger';
|
|
3
|
+
|
|
4
|
+
export class UpdateModelSequenceDto {
|
|
5
|
+
@IsOptional()
|
|
6
|
+
@IsInt()
|
|
7
|
+
id: number;
|
|
8
|
+
@IsOptional()
|
|
9
|
+
@IsInt()
|
|
10
|
+
@ApiProperty()
|
|
11
|
+
moduleId: number;
|
|
12
|
+
@IsString()
|
|
13
|
+
@IsOptional()
|
|
14
|
+
@ApiProperty()
|
|
15
|
+
moduleUserKey: string;
|
|
16
|
+
@IsOptional()
|
|
17
|
+
@IsInt()
|
|
18
|
+
@ApiProperty()
|
|
19
|
+
modelId: number;
|
|
20
|
+
@IsString()
|
|
21
|
+
@IsOptional()
|
|
22
|
+
@ApiProperty()
|
|
23
|
+
modelUserKey: string;
|
|
24
|
+
@IsOptional()
|
|
25
|
+
@IsInt()
|
|
26
|
+
@ApiProperty()
|
|
27
|
+
fieldId: number;
|
|
28
|
+
@IsString()
|
|
29
|
+
@IsOptional()
|
|
30
|
+
@ApiProperty()
|
|
31
|
+
fieldUserKey: string;
|
|
32
|
+
@IsNotEmpty()
|
|
33
|
+
@IsOptional()
|
|
34
|
+
@IsString()
|
|
35
|
+
@ApiProperty()
|
|
36
|
+
sequenceName: string;
|
|
37
|
+
@IsOptional()
|
|
38
|
+
@IsInt()
|
|
39
|
+
@ApiProperty()
|
|
40
|
+
currentValue: number;
|
|
41
|
+
@IsOptional()
|
|
42
|
+
@IsString()
|
|
43
|
+
@ApiProperty()
|
|
44
|
+
prefix: string;
|
|
45
|
+
@IsOptional()
|
|
46
|
+
@IsInt()
|
|
47
|
+
@ApiProperty()
|
|
48
|
+
padding: number;
|
|
49
|
+
@IsOptional()
|
|
50
|
+
@IsString()
|
|
51
|
+
@ApiProperty()
|
|
52
|
+
separator: string;
|
|
53
|
+
}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
|
-
import { Column, CreateDateColumn, DeleteDateColumn,
|
|
2
|
-
import
|
|
3
|
-
import {
|
|
1
|
+
import { Column, CreateDateColumn, DeleteDateColumn, Index, PrimaryGeneratedColumn, UpdateDateColumn } from "typeorm";
|
|
2
|
+
import { Exclude, Expose } from "class-transformer";
|
|
3
|
+
import { LocalDateTimeTransformer } from "src/transformers/typeorm/local-date-time-transformer";
|
|
4
4
|
|
|
5
5
|
@Exclude()
|
|
6
6
|
export abstract class CommonEntity {
|
|
@@ -8,20 +8,21 @@ export abstract class CommonEntity {
|
|
|
8
8
|
@PrimaryGeneratedColumn({ type: 'integer' })
|
|
9
9
|
id: number
|
|
10
10
|
|
|
11
|
-
@CreateDateColumn({ name: "created_at" })
|
|
11
|
+
@CreateDateColumn({ name: "created_at", transformer: LocalDateTimeTransformer })
|
|
12
12
|
createdAt: Date;
|
|
13
13
|
|
|
14
|
-
@UpdateDateColumn({ name: "updated_at" })
|
|
14
|
+
@UpdateDateColumn({ name: "updated_at", transformer: LocalDateTimeTransformer })
|
|
15
15
|
updatedAt: Date;
|
|
16
16
|
|
|
17
|
-
@DeleteDateColumn({ name: "deleted_at" })
|
|
17
|
+
@DeleteDateColumn({ name: "deleted_at", transformer: LocalDateTimeTransformer })
|
|
18
|
+
@Index()
|
|
18
19
|
deletedAt: Date;
|
|
19
20
|
|
|
20
21
|
@Column({ name: "deletedTracker", default: "not-deleted" })
|
|
21
22
|
deletedTracker: string;
|
|
22
23
|
|
|
23
24
|
@Expose()
|
|
24
|
-
@Column({ name: 'published_at', default: null, nullable: true })
|
|
25
|
+
@Column({ name: 'published_at', default: null, nullable: true, transformer: LocalDateTimeTransformer })
|
|
25
26
|
publishedAt: Date;
|
|
26
27
|
|
|
27
28
|
@Expose()
|
|
@@ -49,5 +50,4 @@ export abstract class CommonEntity {
|
|
|
49
50
|
@Expose()
|
|
50
51
|
@Column({ name: `updated_by_id`, nullable: true })
|
|
51
52
|
updatedBy: number;
|
|
52
|
-
|
|
53
53
|
}
|
|
@@ -159,7 +159,7 @@ export class FieldMetadata extends CommonEntity {
|
|
|
159
159
|
relationJoinTableName: string;
|
|
160
160
|
|
|
161
161
|
@Column({ name: 'enable_audit_tracking', default: false })
|
|
162
|
-
enableAuditTracking: boolean;
|
|
162
|
+
enableAuditTracking: boolean = false;
|
|
163
163
|
|
|
164
164
|
@Column({ name: "is_multiSelect", default: false })
|
|
165
165
|
isMultiSelect: boolean;
|
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
import { Exclude, Expose, Type } from "class-transformer";
|
|
2
|
-
import { Column, CreateDateColumn, DeleteDateColumn, JoinColumn, ManyToOne, UpdateDateColumn } from "typeorm";
|
|
2
|
+
import { Column, CreateDateColumn, DeleteDateColumn, Index, JoinColumn, ManyToOne, UpdateDateColumn } from "typeorm";
|
|
3
3
|
import type { User } from "./user.entity";
|
|
4
|
+
import { LocalDateTimeTransformer } from "src/transformers/typeorm/local-date-time-transformer";
|
|
4
5
|
|
|
5
6
|
export const LEGACY_TABLE_FIELDS_PREFIX = 'ss';
|
|
6
7
|
|
|
@@ -11,20 +12,21 @@ export abstract class LegacyCommonEntity {
|
|
|
11
12
|
// @Generated("increment")
|
|
12
13
|
// id: number
|
|
13
14
|
|
|
14
|
-
@CreateDateColumn({ name: `${LEGACY_TABLE_FIELDS_PREFIX}_created_at
|
|
15
|
+
@CreateDateColumn({ name: `${LEGACY_TABLE_FIELDS_PREFIX}_created_at`, transformer: LocalDateTimeTransformer })
|
|
15
16
|
createdAt: Date;
|
|
16
17
|
|
|
17
|
-
@UpdateDateColumn({ name: `${LEGACY_TABLE_FIELDS_PREFIX}_updated_at
|
|
18
|
+
@UpdateDateColumn({ name: `${LEGACY_TABLE_FIELDS_PREFIX}_updated_at`, transformer: LocalDateTimeTransformer })
|
|
18
19
|
updatedAt: Date;
|
|
19
20
|
|
|
20
|
-
@DeleteDateColumn({ name: `${LEGACY_TABLE_FIELDS_PREFIX}_deleted_at
|
|
21
|
+
@DeleteDateColumn({ name: `${LEGACY_TABLE_FIELDS_PREFIX}_deleted_at`, transformer: LocalDateTimeTransformer })
|
|
22
|
+
@Index()
|
|
21
23
|
deletedAt: Date;
|
|
22
24
|
|
|
23
25
|
@Column({ name: `${LEGACY_TABLE_FIELDS_PREFIX}_deleted_tracker`, default: "not-deleted" })
|
|
24
26
|
deletedTracker: string;
|
|
25
27
|
|
|
26
28
|
@Expose()
|
|
27
|
-
@Column({ name: `${LEGACY_TABLE_FIELDS_PREFIX}_published_at`, default: null
|
|
29
|
+
@Column({ name: `${LEGACY_TABLE_FIELDS_PREFIX}_published_at`, default: null, nullable: true, transformer: LocalDateTimeTransformer })
|
|
28
30
|
publishedAt: Date;
|
|
29
31
|
|
|
30
32
|
@Expose()
|
|
@@ -50,7 +52,7 @@ export abstract class LegacyCommonEntity {
|
|
|
50
52
|
@Expose()
|
|
51
53
|
@Column({ name: `${LEGACY_TABLE_FIELDS_PREFIX}_created_by_id`, nullable: true })
|
|
52
54
|
createdBy: number;
|
|
53
|
-
|
|
55
|
+
|
|
54
56
|
@Expose()
|
|
55
57
|
@Column({ name: `${LEGACY_TABLE_FIELDS_PREFIX}_updated_by_id`, nullable: true })
|
|
56
58
|
updatedBy: number;
|
|
@@ -34,7 +34,7 @@ export class ModelMetadata extends CommonEntity {
|
|
|
34
34
|
enableSoftDelete: boolean;
|
|
35
35
|
|
|
36
36
|
@Column({ name: "enable_audit_tracking", default: false })
|
|
37
|
-
enableAuditTracking: boolean;
|
|
37
|
+
enableAuditTracking: boolean = false;
|
|
38
38
|
|
|
39
39
|
@Column({ name: "internationalisation", default: false })
|
|
40
40
|
internationalisation: boolean;
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
import { CommonEntity } from "src/entities/common.entity"
|
|
2
|
+
import { Entity, JoinColumn, ManyToOne, Index, Column } from 'typeorm';
|
|
3
|
+
import { ModuleMetadata } from 'src/entities/module-metadata.entity';
|
|
4
|
+
import { ModelMetadata } from 'src/entities/model-metadata.entity';
|
|
5
|
+
import { FieldMetadata } from 'src/entities/field-metadata.entity'
|
|
6
|
+
|
|
7
|
+
@Entity('ss_model_sequence')
|
|
8
|
+
export class ModelSequence extends CommonEntity {
|
|
9
|
+
@Index()
|
|
10
|
+
@ManyToOne(() => ModuleMetadata, { nullable: false })
|
|
11
|
+
@JoinColumn()
|
|
12
|
+
module: ModuleMetadata;
|
|
13
|
+
@Index()
|
|
14
|
+
@ManyToOne(() => ModelMetadata, { nullable: false })
|
|
15
|
+
@JoinColumn()
|
|
16
|
+
model: ModelMetadata;
|
|
17
|
+
@Index()
|
|
18
|
+
@ManyToOne(() => FieldMetadata, { nullable: false })
|
|
19
|
+
@JoinColumn()
|
|
20
|
+
field: FieldMetadata;
|
|
21
|
+
@Index({ unique: true })
|
|
22
|
+
@Column({ type: "varchar" })
|
|
23
|
+
sequenceName: string;
|
|
24
|
+
@Column({ type: "integer", default: 1 })
|
|
25
|
+
currentValue: number;
|
|
26
|
+
@Column({ type: "varchar", nullable: true })
|
|
27
|
+
prefix: string;
|
|
28
|
+
@Column({ type: "integer", default: 5 })
|
|
29
|
+
padding: number;
|
|
30
|
+
@Column({ type: "varchar", default: "" })
|
|
31
|
+
separator: string;
|
|
32
|
+
}
|
|
@@ -20,7 +20,6 @@ export class MailFactory {
|
|
|
20
20
|
private readonly commonConfiguration: ConfigType<typeof commonConfig>,
|
|
21
21
|
) { }
|
|
22
22
|
|
|
23
|
-
|
|
24
23
|
getMailService(): IMail {
|
|
25
24
|
const mailServiceName = this.commonConfiguration.emailProvider;
|
|
26
25
|
const mailProviders = this.solidRegistry.getMailProviders();
|
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
import { Inject, Injectable, Logger } from "@nestjs/common";
|
|
2
|
+
import { ConfigType } from "@nestjs/config";
|
|
3
|
+
import { ModuleRef } from "@nestjs/core";
|
|
4
|
+
import commonConfig from "src/config/common.config";
|
|
5
|
+
import { SolidRegistry } from "src/helpers/solid-registry";
|
|
6
|
+
import { ISMS } from "src/interfaces";
|
|
7
|
+
|
|
8
|
+
function norm(s?: string) {
|
|
9
|
+
return s?.trim().toLowerCase();
|
|
10
|
+
}
|
|
11
|
+
|
|
12
|
+
// This factory will be use to return a mail service instance, using the configured environment variables
|
|
13
|
+
@Injectable()
|
|
14
|
+
export class SmsFactory {
|
|
15
|
+
private readonly logger = new Logger(this.constructor.name);
|
|
16
|
+
|
|
17
|
+
constructor(
|
|
18
|
+
private readonly moduleRef: ModuleRef,
|
|
19
|
+
private readonly solidRegistry: SolidRegistry,
|
|
20
|
+
@Inject(commonConfig.KEY)
|
|
21
|
+
private readonly commonConfiguration: ConfigType<typeof commonConfig>,
|
|
22
|
+
) { }
|
|
23
|
+
|
|
24
|
+
getSmsService(name: string = null): ISMS {
|
|
25
|
+
// This is the default provider
|
|
26
|
+
const smsServiceName = name || this.commonConfiguration.smsProvider;
|
|
27
|
+
if (!smsServiceName) {
|
|
28
|
+
throw new Error("Unable to resolve sms provider")
|
|
29
|
+
}
|
|
30
|
+
const smsProviders = this.solidRegistry.getSmsProviders();
|
|
31
|
+
|
|
32
|
+
// Return the instance which matches the smsServicename
|
|
33
|
+
if (!smsProviders.length) {
|
|
34
|
+
// throw new Error("No mail providers are registered.");
|
|
35
|
+
this.logger.error("No sms providers are registered.");
|
|
36
|
+
}
|
|
37
|
+
|
|
38
|
+
const smsServiceProvider = smsProviders.find(provider => provider.name === smsServiceName);
|
|
39
|
+
|
|
40
|
+
return smsServiceProvider.instance as ISMS;
|
|
41
|
+
}
|
|
42
|
+
|
|
43
|
+
}
|
|
@@ -1,34 +1,63 @@
|
|
|
1
1
|
import dayjs from 'dayjs';
|
|
2
2
|
import customParseFormat from 'dayjs/plugin/customParseFormat';
|
|
3
|
+
|
|
3
4
|
dayjs.extend(customParseFormat);
|
|
4
5
|
|
|
5
6
|
export function parseFlexibleDate(value: any): Date | null {
|
|
6
7
|
if (!value) return null;
|
|
8
|
+
|
|
9
|
+
// Already a valid Date (ExcelJS often gives this)
|
|
7
10
|
if (value instanceof Date && !isNaN(value.getTime())) {
|
|
8
11
|
return value;
|
|
9
12
|
}
|
|
13
|
+
|
|
14
|
+
// Excel serial number
|
|
10
15
|
if (typeof value === 'number') {
|
|
11
16
|
const excelEpoch = new Date(Date.UTC(1899, 11, 30));
|
|
12
17
|
const d = new Date(excelEpoch.getTime() + value * 86400000);
|
|
13
18
|
return isNaN(d.getTime()) ? null : d;
|
|
14
19
|
}
|
|
15
|
-
|
|
20
|
+
|
|
21
|
+
let str = value.toString().trim();
|
|
22
|
+
|
|
23
|
+
// STRIP "(British Summer Time)" or any "(...)" suffix
|
|
24
|
+
str = str.replace(/\s*\(.*\)$/, '');
|
|
25
|
+
|
|
16
26
|
const formats = [
|
|
27
|
+
// strict business formats
|
|
17
28
|
'DD-MM-YYYY',
|
|
29
|
+
|
|
30
|
+
// common alternates
|
|
18
31
|
'YYYY-MM-DD',
|
|
19
32
|
'DD/MM/YYYY',
|
|
20
33
|
'MM/DD/YYYY',
|
|
21
34
|
'D-M-YYYY',
|
|
22
35
|
'YYYY/MM/DD',
|
|
36
|
+
|
|
37
|
+
// JS Date.toString() (without timezone name)
|
|
38
|
+
// (handle single-digit day + different offset shapes)
|
|
39
|
+
'ddd MMM D YYYY HH:mm:ss [GMT]ZZ', // GMT+0100
|
|
40
|
+
'ddd MMM DD YYYY HH:mm:ss [GMT]ZZ',
|
|
41
|
+
'ddd MMM D YYYY HH:mm:ss [GMT]Z', // GMT+01:00
|
|
42
|
+
'ddd MMM DD YYYY HH:mm:ss [GMT]Z',
|
|
43
|
+
|
|
44
|
+
// ISO variants
|
|
23
45
|
'YYYY-MM-DD HH:mm:ss',
|
|
24
|
-
'YYYY-MM-DDTHH:mm:ss',
|
|
25
|
-
'YYYY-MM-DDTHH:mm:ss.SSS',
|
|
26
|
-
'YYYY-MM-DDTHH:mm:ssZ',
|
|
46
|
+
'YYYY-MM-DDTHH:mm:ss',
|
|
47
|
+
'YYYY-MM-DDTHH:mm:ss.SSS',
|
|
48
|
+
'YYYY-MM-DDTHH:mm:ssZ',
|
|
27
49
|
];
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
50
|
+
|
|
51
|
+
const parsed = dayjs(str, formats, true); // strict
|
|
52
|
+
if (parsed.isValid()) {
|
|
53
|
+
return parsed.toDate();
|
|
54
|
+
}
|
|
55
|
+
|
|
56
|
+
// Fallback: native Date can parse this JS format very reliably
|
|
57
|
+
const native = new Date(str);
|
|
58
|
+
if (!isNaN(native.getTime())) {
|
|
59
|
+
return native;
|
|
31
60
|
}
|
|
32
|
-
return parsed.toDate();
|
|
33
|
-
}
|
|
34
61
|
|
|
62
|
+
return null;
|
|
63
|
+
}
|
|
@@ -14,13 +14,22 @@ export class BigIntFieldCrudManager implements FieldCrudManager {
|
|
|
14
14
|
}
|
|
15
15
|
|
|
16
16
|
validate(createDto: any): ValidationError[] {
|
|
17
|
-
|
|
17
|
+
let fieldValue: any = createDto[this.options.fieldName];
|
|
18
|
+
if (fieldValue !== undefined && fieldValue !== null) {
|
|
19
|
+
try {
|
|
20
|
+
if (typeof fieldValue === 'string' || typeof fieldValue === 'number') {
|
|
21
|
+
fieldValue = BigInt(fieldValue);
|
|
22
|
+
}
|
|
23
|
+
} catch (err) {
|
|
24
|
+
return [{ field: this.options.fieldName, error: 'Invalid numeric value' }];
|
|
25
|
+
}
|
|
26
|
+
}
|
|
18
27
|
return this.applyValidations(fieldValue);
|
|
19
28
|
}
|
|
20
29
|
|
|
21
30
|
private applyValidations(fieldValue: any): ValidationError[] {
|
|
22
31
|
const errors: ValidationError[] = [];
|
|
23
|
-
this.isApplyRequiredValidation() && isEmpty(fieldValue) ? errors.push({ field: this.options.fieldName, error: `Field: ${this.options.fieldName} is required` }): "no errors";
|
|
32
|
+
this.isApplyRequiredValidation() && isEmpty(fieldValue) ? errors.push({ field: this.options.fieldName, error: `Field: ${this.options.fieldName} is required` }) : "no errors";
|
|
24
33
|
if (isNotEmpty(fieldValue)) {
|
|
25
34
|
errors.push(...this.applyFormatValidations(fieldValue));
|
|
26
35
|
}
|
|
@@ -29,7 +38,7 @@ export class BigIntFieldCrudManager implements FieldCrudManager {
|
|
|
29
38
|
|
|
30
39
|
private applyFormatValidations(fieldValue: any): ValidationError[] {
|
|
31
40
|
const errors: ValidationError[] = [];
|
|
32
|
-
!this.isBigInt(fieldValue) ? errors.push({ field: this.options.fieldName, error: 'Field is not a bigint' }): "no errors";
|
|
41
|
+
!this.isBigInt(fieldValue) ? errors.push({ field: this.options.fieldName, error: 'Field is not a bigint' }) : "no errors";
|
|
33
42
|
this.isApplyMinValidation() && !min(fieldValue, this.options.min) ? errors.push({ field: this.options.fieldName, error: 'Field value is lesser than minimum required' }) : "no errors"; //FIXME min length to be handled
|
|
34
43
|
this.isApplyMaxValidation() && !max(fieldValue, this.options.max) ? errors.push({ field: this.options.fieldName, error: 'Field value is greater than maximum required' }) : "no errors";
|
|
35
44
|
return errors;
|
|
@@ -43,13 +52,17 @@ export class BigIntFieldCrudManager implements FieldCrudManager {
|
|
|
43
52
|
private isApplyMinValidation(): boolean {
|
|
44
53
|
return this.options.min > 0;
|
|
45
54
|
}
|
|
55
|
+
|
|
46
56
|
private isApplyMaxValidation(): boolean {
|
|
47
57
|
return this.options.max > 0;
|
|
48
58
|
}
|
|
59
|
+
|
|
49
60
|
private isApplyRequiredValidation(): boolean {
|
|
50
61
|
return this.options.required;
|
|
51
62
|
}
|
|
63
|
+
|
|
52
64
|
private isBigInt(value: any): boolean {
|
|
53
|
-
|
|
54
|
-
|
|
65
|
+
const valueType = typeof value;
|
|
66
|
+
return valueType === 'bigint' || (valueType === 'number' && Number.isFinite(value));
|
|
67
|
+
}
|
|
55
68
|
}
|
|
@@ -68,11 +68,11 @@ export class ManyToManyRelationFieldCrudManager implements FieldCrudManager {
|
|
|
68
68
|
}
|
|
69
69
|
|
|
70
70
|
async transformForCreate(dto: any): Promise<any> {
|
|
71
|
-
const
|
|
72
|
-
const currentEntityRepository = this.options.entityManager.getRepository(
|
|
71
|
+
const currentEntityName = classify(this.options.modelSingularName);
|
|
72
|
+
const currentEntityRepository = this.options.entityManager.getRepository(currentEntityName);
|
|
73
73
|
|
|
74
|
-
const
|
|
75
|
-
const relatedEntityRepository = this.options.entityManager.getRepository(
|
|
74
|
+
const relatedEntityName = classify(this.options.relationCoModelSingularName);
|
|
75
|
+
const relatedEntityRepository = this.options.entityManager.getRepository(relatedEntityName)
|
|
76
76
|
|
|
77
77
|
dto[this.valueFieldName] = await this.transformByCommand(dto, relatedEntityRepository, currentEntityRepository);
|
|
78
78
|
return dto;
|
|
@@ -192,9 +192,9 @@ export class ManyToManyRelationFieldCrudManager implements FieldCrudManager {
|
|
|
192
192
|
|
|
193
193
|
// TODO: We have moved this to SolidRegistry service, refactor to use that service.
|
|
194
194
|
// Returns the entity target class from the entity name
|
|
195
|
-
private getEntityTarget(entityName: string): any { //TODO Can be refactored to use this function from crud helper service
|
|
196
|
-
|
|
197
|
-
|
|
198
|
-
|
|
199
|
-
}
|
|
195
|
+
// private getEntityTarget(entityName: string): any { //TODO Can be refactored to use this function from crud helper service
|
|
196
|
+
// const entityMetadatas = this.options.entityManager.connection.entityMetadatas;
|
|
197
|
+
// const entityMetadata = entityMetadatas.find(em => em.name === entityName);
|
|
198
|
+
// return entityMetadata.target;
|
|
199
|
+
// }
|
|
200
200
|
}
|