@aerokit/sdk 12.44.0
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/LICENSE +277 -0
- package/README.md +170 -0
- package/dist/cjs/bpm/deployer.js +57 -0
- package/dist/cjs/bpm/index.js +35 -0
- package/dist/cjs/bpm/process.js +636 -0
- package/dist/cjs/bpm/tasks.js +973 -0
- package/dist/cjs/bpm/values.js +82 -0
- package/dist/cjs/cache/cache.js +64 -0
- package/dist/cjs/cache/index.js +26 -0
- package/dist/cjs/cms/cmis.js +689 -0
- package/dist/cjs/cms/index.js +26 -0
- package/dist/cjs/component/decorators.js +126 -0
- package/dist/cjs/component/index.js +36 -0
- package/dist/cjs/core/configurations.js +110 -0
- package/dist/cjs/core/context.js +47 -0
- package/dist/cjs/core/env.js +45 -0
- package/dist/cjs/core/globals.js +54 -0
- package/dist/cjs/core/index.js +35 -0
- package/dist/cjs/db/dao.js +795 -0
- package/dist/cjs/db/database.js +904 -0
- package/dist/cjs/db/decorators.js +167 -0
- package/dist/cjs/db/index.js +72 -0
- package/dist/cjs/db/insert.js +51 -0
- package/dist/cjs/db/orm.js +245 -0
- package/dist/cjs/db/ormstatements.js +243 -0
- package/dist/cjs/db/procedure.js +112 -0
- package/dist/cjs/db/query.js +57 -0
- package/dist/cjs/db/repository.js +148 -0
- package/dist/cjs/db/sequence.js +59 -0
- package/dist/cjs/db/sql.js +516 -0
- package/dist/cjs/db/store.js +172 -0
- package/dist/cjs/db/translator.js +100 -0
- package/dist/cjs/db/update.js +43 -0
- package/dist/cjs/etcd/client.js +174 -0
- package/dist/cjs/etcd/index.js +26 -0
- package/dist/cjs/extensions/decorators.js +40 -0
- package/dist/cjs/extensions/extensions.js +108 -0
- package/dist/cjs/extensions/index.js +39 -0
- package/dist/cjs/git/client.js +277 -0
- package/dist/cjs/git/index.js +26 -0
- package/dist/cjs/http/client-async.js +224 -0
- package/dist/cjs/http/client.js +145 -0
- package/dist/cjs/http/decorators.js +76 -0
- package/dist/cjs/http/errors/ForbiddenError.js +41 -0
- package/dist/cjs/http/errors/ValidationError.js +41 -0
- package/dist/cjs/http/errors.js +26 -0
- package/dist/cjs/http/index.js +59 -0
- package/dist/cjs/http/request.js +281 -0
- package/dist/cjs/http/response.js +452 -0
- package/dist/cjs/http/rs/resource-common.js +32 -0
- package/dist/cjs/http/rs/resource-http-controller.js +306 -0
- package/dist/cjs/http/rs/resource-mappings.js +130 -0
- package/dist/cjs/http/rs/resource-method.js +218 -0
- package/dist/cjs/http/rs/resource.js +232 -0
- package/dist/cjs/http/rs.js +31 -0
- package/dist/cjs/http/session.js +124 -0
- package/dist/cjs/http/upload.js +144 -0
- package/dist/cjs/http/utils.js +106 -0
- package/dist/cjs/index.js +1 -0
- package/dist/cjs/indexing/index.js +29 -0
- package/dist/cjs/indexing/searcher.js +70 -0
- package/dist/cjs/indexing/writer.js +45 -0
- package/dist/cjs/integrations/index.js +26 -0
- package/dist/cjs/integrations/integrations.js +55 -0
- package/dist/cjs/io/bytes.js +101 -0
- package/dist/cjs/io/files.js +344 -0
- package/dist/cjs/io/image.js +43 -0
- package/dist/cjs/io/index.js +38 -0
- package/dist/cjs/io/streams.js +243 -0
- package/dist/cjs/io/zip.js +251 -0
- package/dist/cjs/job/decorators.js +40 -0
- package/dist/cjs/job/index.js +39 -0
- package/dist/cjs/job/scheduler.js +347 -0
- package/dist/cjs/junit/index.js +18 -0
- package/dist/cjs/junit/junit.js +67 -0
- package/dist/cjs/kafka/consumer.js +70 -0
- package/dist/cjs/kafka/index.js +29 -0
- package/dist/cjs/kafka/producer.js +70 -0
- package/dist/cjs/log/index.js +26 -0
- package/dist/cjs/log/logging.js +174 -0
- package/dist/cjs/mail/client.js +153 -0
- package/dist/cjs/mail/index.js +26 -0
- package/dist/cjs/messaging/consumer.js +83 -0
- package/dist/cjs/messaging/decorators.js +40 -0
- package/dist/cjs/messaging/index.js +42 -0
- package/dist/cjs/messaging/producer.js +81 -0
- package/dist/cjs/mongodb/client.js +627 -0
- package/dist/cjs/mongodb/dao.js +390 -0
- package/dist/cjs/mongodb/index.js +36 -0
- package/dist/cjs/net/decorators.js +40 -0
- package/dist/cjs/net/index.js +42 -0
- package/dist/cjs/net/soap.js +228 -0
- package/dist/cjs/net/websockets.js +151 -0
- package/dist/cjs/net/wrappers/onClose.js +2 -0
- package/dist/cjs/net/wrappers/onError.js +2 -0
- package/dist/cjs/net/wrappers/onMessage.js +2 -0
- package/dist/cjs/net/wrappers/onOpen.js +2 -0
- package/dist/cjs/pdf/index.js +26 -0
- package/dist/cjs/pdf/pdf.js +160 -0
- package/dist/cjs/platform/command.js +47 -0
- package/dist/cjs/platform/engines.js +70 -0
- package/dist/cjs/platform/index.js +47 -0
- package/dist/cjs/platform/lifecycle.js +49 -0
- package/dist/cjs/platform/os.js +51 -0
- package/dist/cjs/platform/problems.js +127 -0
- package/dist/cjs/platform/registry.js +319 -0
- package/dist/cjs/platform/repository.js +498 -0
- package/dist/cjs/platform/workspace.js +574 -0
- package/dist/cjs/qldb/index.js +26 -0
- package/dist/cjs/qldb/qldb.js +24 -0
- package/dist/cjs/rabbitmq/consumer.js +50 -0
- package/dist/cjs/rabbitmq/index.js +29 -0
- package/dist/cjs/rabbitmq/producer.js +38 -0
- package/dist/cjs/redis/client.js +190 -0
- package/dist/cjs/redis/index.js +26 -0
- package/dist/cjs/security/decorators.js +48 -0
- package/dist/cjs/security/index.js +40 -0
- package/dist/cjs/security/oauth.js +75 -0
- package/dist/cjs/security/user.js +88 -0
- package/dist/cjs/template/engines.js +139 -0
- package/dist/cjs/template/index.js +26 -0
- package/dist/cjs/utils/alphanumeric.js +107 -0
- package/dist/cjs/utils/base64.js +104 -0
- package/dist/cjs/utils/converter.js +78 -0
- package/dist/cjs/utils/digest.js +167 -0
- package/dist/cjs/utils/escape.js +160 -0
- package/dist/cjs/utils/hex.js +104 -0
- package/dist/cjs/utils/index.js +68 -0
- package/dist/cjs/utils/jsonpath.js +489 -0
- package/dist/cjs/utils/qrcode.js +41 -0
- package/dist/cjs/utils/url.js +82 -0
- package/dist/cjs/utils/utf8.js +61 -0
- package/dist/cjs/utils/uuid.js +48 -0
- package/dist/cjs/utils/xml.js +57 -0
- package/dist/dts/bpm/deployer.d.ts +29 -0
- package/dist/dts/bpm/index.d.ts +8 -0
- package/dist/dts/bpm/process.d.ts +433 -0
- package/dist/dts/bpm/tasks.d.ts +2022 -0
- package/dist/dts/bpm/values.d.ts +38 -0
- package/dist/dts/cache/cache.d.ts +30 -0
- package/dist/dts/cache/index.d.ts +2 -0
- package/dist/dts/cms/cmis.d.ts +413 -0
- package/dist/dts/cms/index.d.ts +2 -0
- package/dist/dts/component/decorators.d.ts +52 -0
- package/dist/dts/component/index.d.ts +2 -0
- package/dist/dts/core/configurations.d.ts +65 -0
- package/dist/dts/core/context.d.ts +19 -0
- package/dist/dts/core/env.d.ts +23 -0
- package/dist/dts/core/globals.d.ts +30 -0
- package/dist/dts/core/index.d.ts +8 -0
- package/dist/dts/db/dao.d.ts +8 -0
- package/dist/dts/db/database.d.ts +507 -0
- package/dist/dts/db/decorators.d.ts +89 -0
- package/dist/dts/db/index.d.ts +25 -0
- package/dist/dts/db/insert.d.ts +32 -0
- package/dist/dts/db/orm.d.ts +44 -0
- package/dist/dts/db/ormstatements.d.ts +4 -0
- package/dist/dts/db/procedure.d.ts +25 -0
- package/dist/dts/db/query.d.ts +48 -0
- package/dist/dts/db/repository.d.ts +64 -0
- package/dist/dts/db/sequence.d.ts +34 -0
- package/dist/dts/db/sql.d.ts +267 -0
- package/dist/dts/db/store.d.ts +138 -0
- package/dist/dts/db/translator.d.ts +26 -0
- package/dist/dts/db/update.d.ts +21 -0
- package/dist/dts/etcd/client.d.ts +92 -0
- package/dist/dts/etcd/index.d.ts +2 -0
- package/dist/dts/extensions/decorators.d.ts +11 -0
- package/dist/dts/extensions/extensions.d.ts +41 -0
- package/dist/dts/extensions/index.d.ts +4 -0
- package/dist/dts/git/client.d.ts +478 -0
- package/dist/dts/git/index.d.ts +2 -0
- package/dist/dts/http/client-async.d.ts +158 -0
- package/dist/dts/http/client.d.ts +180 -0
- package/dist/dts/http/decorators.d.ts +11 -0
- package/dist/dts/http/errors/ForbiddenError.d.ts +20 -0
- package/dist/dts/http/errors/ValidationError.d.ts +20 -0
- package/dist/dts/http/errors.d.ts +2 -0
- package/dist/dts/http/index.d.ts +16 -0
- package/dist/dts/http/request.d.ts +158 -0
- package/dist/dts/http/response.d.ts +281 -0
- package/dist/dts/http/rs/resource-common.d.ts +11 -0
- package/dist/dts/http/rs/resource-http-controller.d.ts +43 -0
- package/dist/dts/http/rs/resource-mappings.d.ts +70 -0
- package/dist/dts/http/rs/resource-method.d.ts +206 -0
- package/dist/dts/http/rs/resource.d.ts +126 -0
- package/dist/dts/http/rs.d.ts +4 -0
- package/dist/dts/http/session.d.ts +81 -0
- package/dist/dts/http/upload.d.ts +100 -0
- package/dist/dts/http/utils.d.ts +54 -0
- package/dist/dts/index.d.ts +0 -0
- package/dist/dts/indexing/index.d.ts +4 -0
- package/dist/dts/indexing/searcher.d.ts +47 -0
- package/dist/dts/indexing/writer.d.ts +22 -0
- package/dist/dts/integrations/index.d.ts +2 -0
- package/dist/dts/integrations/integrations.d.ts +118 -0
- package/dist/dts/io/bytes.d.ts +56 -0
- package/dist/dts/io/files.d.ts +261 -0
- package/dist/dts/io/image.d.ts +22 -0
- package/dist/dts/io/index.d.ts +10 -0
- package/dist/dts/io/streams.d.ts +172 -0
- package/dist/dts/io/zip.d.ts +178 -0
- package/dist/dts/job/decorators.d.ts +11 -0
- package/dist/dts/job/index.d.ts +4 -0
- package/dist/dts/job/scheduler.d.ts +250 -0
- package/dist/dts/junit/index.d.ts +1 -0
- package/dist/dts/junit/junit.d.ts +50 -0
- package/dist/dts/kafka/consumer.d.ts +48 -0
- package/dist/dts/kafka/index.d.ts +4 -0
- package/dist/dts/kafka/producer.d.ts +50 -0
- package/dist/dts/log/index.d.ts +2 -0
- package/dist/dts/log/logging.d.ts +102 -0
- package/dist/dts/mail/client.d.ts +90 -0
- package/dist/dts/mail/index.d.ts +2 -0
- package/dist/dts/messaging/consumer.d.ts +61 -0
- package/dist/dts/messaging/decorators.d.ts +11 -0
- package/dist/dts/messaging/index.d.ts +6 -0
- package/dist/dts/messaging/producer.d.ts +59 -0
- package/dist/dts/mongodb/client.d.ts +367 -0
- package/dist/dts/mongodb/dao.d.ts +24 -0
- package/dist/dts/mongodb/index.d.ts +2 -0
- package/dist/dts/net/decorators.d.ts +11 -0
- package/dist/dts/net/index.d.ts +6 -0
- package/dist/dts/net/soap.d.ts +115 -0
- package/dist/dts/net/websockets.d.ts +100 -0
- package/dist/dts/net/wrappers/onClose.d.ts +0 -0
- package/dist/dts/net/wrappers/onError.d.ts +0 -0
- package/dist/dts/net/wrappers/onMessage.d.ts +0 -0
- package/dist/dts/net/wrappers/onOpen.d.ts +0 -0
- package/dist/dts/pdf/index.d.ts +2 -0
- package/dist/dts/pdf/pdf.d.ts +72 -0
- package/dist/dts/platform/command.d.ts +41 -0
- package/dist/dts/platform/engines.d.ts +35 -0
- package/dist/dts/platform/index.d.ts +16 -0
- package/dist/dts/platform/lifecycle.d.ts +22 -0
- package/dist/dts/platform/os.d.ts +23 -0
- package/dist/dts/platform/problems.d.ts +114 -0
- package/dist/dts/platform/registry.d.ts +227 -0
- package/dist/dts/platform/repository.d.ts +354 -0
- package/dist/dts/platform/workspace.d.ts +421 -0
- package/dist/dts/qldb/index.d.ts +2 -0
- package/dist/dts/qldb/qldb.d.ts +1 -0
- package/dist/dts/rabbitmq/consumer.d.ts +25 -0
- package/dist/dts/rabbitmq/index.d.ts +4 -0
- package/dist/dts/rabbitmq/producer.d.ts +15 -0
- package/dist/dts/redis/client.d.ts +134 -0
- package/dist/dts/redis/index.d.ts +2 -0
- package/dist/dts/security/decorators.d.ts +4 -0
- package/dist/dts/security/index.d.ts +5 -0
- package/dist/dts/security/oauth.d.ts +39 -0
- package/dist/dts/security/user.d.ts +51 -0
- package/dist/dts/template/engines.d.ts +98 -0
- package/dist/dts/template/index.d.ts +2 -0
- package/dist/dts/utils/alphanumeric.d.ts +39 -0
- package/dist/dts/utils/base64.d.ts +48 -0
- package/dist/dts/utils/converter.d.ts +44 -0
- package/dist/dts/utils/digest.d.ts +50 -0
- package/dist/dts/utils/escape.d.ts +110 -0
- package/dist/dts/utils/hex.d.ts +48 -0
- package/dist/dts/utils/index.d.ts +23 -0
- package/dist/dts/utils/jsonpath.d.ts +22 -0
- package/dist/dts/utils/qrcode.d.ts +16 -0
- package/dist/dts/utils/url.d.ts +50 -0
- package/dist/dts/utils/utf8.d.ts +33 -0
- package/dist/dts/utils/uuid.d.ts +21 -0
- package/dist/dts/utils/xml.d.ts +22 -0
- package/dist/esm/bpm/deployer.mjs +38 -0
- package/dist/esm/bpm/index.mjs +15 -0
- package/dist/esm/bpm/process.mjs +617 -0
- package/dist/esm/bpm/tasks.mjs +954 -0
- package/dist/esm/bpm/values.mjs +63 -0
- package/dist/esm/cache/cache.mjs +45 -0
- package/dist/esm/cache/index.mjs +6 -0
- package/dist/esm/cms/cmis.mjs +660 -0
- package/dist/esm/cms/index.mjs +6 -0
- package/dist/esm/component/decorators.mjs +107 -0
- package/dist/esm/component/index.mjs +6 -0
- package/dist/esm/core/configurations.mjs +91 -0
- package/dist/esm/core/context.mjs +28 -0
- package/dist/esm/core/env.mjs +26 -0
- package/dist/esm/core/globals.mjs +35 -0
- package/dist/esm/core/index.mjs +15 -0
- package/dist/esm/db/dao.mjs +775 -0
- package/dist/esm/db/database.mjs +885 -0
- package/dist/esm/db/decorators.mjs +148 -0
- package/dist/esm/db/index.mjs +42 -0
- package/dist/esm/db/insert.mjs +32 -0
- package/dist/esm/db/orm.mjs +225 -0
- package/dist/esm/db/ormstatements.mjs +223 -0
- package/dist/esm/db/procedure.mjs +93 -0
- package/dist/esm/db/query.mjs +38 -0
- package/dist/esm/db/repository.mjs +129 -0
- package/dist/esm/db/sequence.mjs +40 -0
- package/dist/esm/db/sql.mjs +497 -0
- package/dist/esm/db/store.mjs +153 -0
- package/dist/esm/db/translator.mjs +81 -0
- package/dist/esm/db/update.mjs +24 -0
- package/dist/esm/etcd/client.mjs +155 -0
- package/dist/esm/etcd/index.mjs +6 -0
- package/dist/esm/extensions/decorators.mjs +21 -0
- package/dist/esm/extensions/extensions.mjs +89 -0
- package/dist/esm/extensions/index.mjs +9 -0
- package/dist/esm/git/client.mjs +258 -0
- package/dist/esm/git/index.mjs +6 -0
- package/dist/esm/http/client-async.mjs +205 -0
- package/dist/esm/http/client.mjs +126 -0
- package/dist/esm/http/decorators.mjs +47 -0
- package/dist/esm/http/errors/ForbiddenError.mjs +22 -0
- package/dist/esm/http/errors/ValidationError.mjs +22 -0
- package/dist/esm/http/errors.mjs +7 -0
- package/dist/esm/http/index.mjs +29 -0
- package/dist/esm/http/request.mjs +262 -0
- package/dist/esm/http/response.mjs +433 -0
- package/dist/esm/http/rs/resource-common.mjs +13 -0
- package/dist/esm/http/rs/resource-http-controller.mjs +287 -0
- package/dist/esm/http/rs/resource-mappings.mjs +111 -0
- package/dist/esm/http/rs/resource-method.mjs +199 -0
- package/dist/esm/http/rs/resource.mjs +213 -0
- package/dist/esm/http/rs.mjs +12 -0
- package/dist/esm/http/session.mjs +105 -0
- package/dist/esm/http/upload.mjs +125 -0
- package/dist/esm/http/utils.mjs +87 -0
- package/dist/esm/index.mjs +1 -0
- package/dist/esm/indexing/index.mjs +9 -0
- package/dist/esm/indexing/searcher.mjs +51 -0
- package/dist/esm/indexing/writer.mjs +26 -0
- package/dist/esm/integrations/index.mjs +6 -0
- package/dist/esm/integrations/integrations.mjs +36 -0
- package/dist/esm/io/bytes.mjs +82 -0
- package/dist/esm/io/files.mjs +325 -0
- package/dist/esm/io/image.mjs +24 -0
- package/dist/esm/io/index.mjs +18 -0
- package/dist/esm/io/streams.mjs +224 -0
- package/dist/esm/io/zip.mjs +232 -0
- package/dist/esm/job/decorators.mjs +21 -0
- package/dist/esm/job/index.mjs +9 -0
- package/dist/esm/job/scheduler.mjs +328 -0
- package/dist/esm/junit/index.mjs +2 -0
- package/dist/esm/junit/junit.mjs +48 -0
- package/dist/esm/kafka/consumer.mjs +51 -0
- package/dist/esm/kafka/index.mjs +9 -0
- package/dist/esm/kafka/producer.mjs +51 -0
- package/dist/esm/log/index.mjs +6 -0
- package/dist/esm/log/logging.mjs +155 -0
- package/dist/esm/mail/client.mjs +134 -0
- package/dist/esm/mail/index.mjs +6 -0
- package/dist/esm/messaging/consumer.mjs +64 -0
- package/dist/esm/messaging/decorators.mjs +21 -0
- package/dist/esm/messaging/index.mjs +12 -0
- package/dist/esm/messaging/producer.mjs +62 -0
- package/dist/esm/mongodb/client.mjs +608 -0
- package/dist/esm/mongodb/dao.mjs +360 -0
- package/dist/esm/mongodb/index.mjs +7 -0
- package/dist/esm/net/decorators.mjs +21 -0
- package/dist/esm/net/index.mjs +12 -0
- package/dist/esm/net/soap.mjs +209 -0
- package/dist/esm/net/websockets.mjs +132 -0
- package/dist/esm/net/wrappers/onClose.mjs +2 -0
- package/dist/esm/net/wrappers/onError.mjs +2 -0
- package/dist/esm/net/wrappers/onMessage.mjs +2 -0
- package/dist/esm/net/wrappers/onOpen.mjs +2 -0
- package/dist/esm/pdf/index.mjs +6 -0
- package/dist/esm/pdf/pdf.mjs +141 -0
- package/dist/esm/platform/command.mjs +28 -0
- package/dist/esm/platform/engines.mjs +51 -0
- package/dist/esm/platform/index.mjs +27 -0
- package/dist/esm/platform/lifecycle.mjs +30 -0
- package/dist/esm/platform/os.mjs +32 -0
- package/dist/esm/platform/problems.mjs +108 -0
- package/dist/esm/platform/registry.mjs +300 -0
- package/dist/esm/platform/repository.mjs +479 -0
- package/dist/esm/platform/workspace.mjs +555 -0
- package/dist/esm/qldb/index.mjs +6 -0
- package/dist/esm/qldb/qldb.mjs +5 -0
- package/dist/esm/rabbitmq/consumer.mjs +31 -0
- package/dist/esm/rabbitmq/index.mjs +9 -0
- package/dist/esm/rabbitmq/producer.mjs +19 -0
- package/dist/esm/redis/client.mjs +171 -0
- package/dist/esm/redis/index.mjs +6 -0
- package/dist/esm/security/decorators.mjs +29 -0
- package/dist/esm/security/index.mjs +10 -0
- package/dist/esm/security/oauth.mjs +56 -0
- package/dist/esm/security/user.mjs +69 -0
- package/dist/esm/template/engines.mjs +120 -0
- package/dist/esm/template/index.mjs +6 -0
- package/dist/esm/utils/alphanumeric.mjs +88 -0
- package/dist/esm/utils/base64.mjs +85 -0
- package/dist/esm/utils/converter.mjs +59 -0
- package/dist/esm/utils/digest.mjs +148 -0
- package/dist/esm/utils/escape.mjs +141 -0
- package/dist/esm/utils/hex.mjs +85 -0
- package/dist/esm/utils/index.mjs +38 -0
- package/dist/esm/utils/jsonpath.mjs +470 -0
- package/dist/esm/utils/qrcode.mjs +22 -0
- package/dist/esm/utils/url.mjs +63 -0
- package/dist/esm/utils/utf8.mjs +42 -0
- package/dist/esm/utils/uuid.mjs +29 -0
- package/dist/esm/utils/xml.mjs +38 -0
- package/package.json +58 -0
|
@@ -0,0 +1,795 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __defProp = Object.defineProperty;
|
|
3
|
+
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
4
|
+
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
5
|
+
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
6
|
+
var __export = (target, all) => {
|
|
7
|
+
for (var name in all)
|
|
8
|
+
__defProp(target, name, { get: all[name], enumerable: true });
|
|
9
|
+
};
|
|
10
|
+
var __copyProps = (to, from, except, desc) => {
|
|
11
|
+
if (from && typeof from === "object" || typeof from === "function") {
|
|
12
|
+
for (let key of __getOwnPropNames(from))
|
|
13
|
+
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
14
|
+
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
15
|
+
}
|
|
16
|
+
return to;
|
|
17
|
+
};
|
|
18
|
+
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
19
|
+
var dao_exports = {};
|
|
20
|
+
__export(dao_exports, {
|
|
21
|
+
DAO: () => DAO,
|
|
22
|
+
create: () => create,
|
|
23
|
+
dao: () => dao
|
|
24
|
+
});
|
|
25
|
+
module.exports = __toCommonJS(dao_exports);
|
|
26
|
+
var import_orm = require("./orm");
|
|
27
|
+
var import_ormstatements = require("./ormstatements");
|
|
28
|
+
var import_sequence = require("./sequence");
|
|
29
|
+
var import_database = require("./database");
|
|
30
|
+
var import_db = require("@aerokit/sdk/db");
|
|
31
|
+
var import_update = require("./update");
|
|
32
|
+
var import_insert = require("./insert");
|
|
33
|
+
var import_log = require("@aerokit/sdk/log");
|
|
34
|
+
var import_core = require("@aerokit/sdk/core");
|
|
35
|
+
function DAO(orm, logCtxName, dataSourceName) {
|
|
36
|
+
if (orm === void 0)
|
|
37
|
+
throw Error("Illegal argument: orm[" + orm + "]");
|
|
38
|
+
this.orm = (0, import_orm.get)(orm);
|
|
39
|
+
this.sequenceName = this.orm.table + "_" + this.orm.getPrimaryKey().name.toUpperCase();
|
|
40
|
+
this.dropIdGenerator = function() {
|
|
41
|
+
return import_sequence.Sequence.drop(this.sequenceName, dataSourceName);
|
|
42
|
+
};
|
|
43
|
+
this.generateId = function() {
|
|
44
|
+
return import_sequence.Sequence.nextval(this.sequenceName, this.orm.table, dataSourceName);
|
|
45
|
+
};
|
|
46
|
+
const conn = import_database.Database.getConnection(dataSourceName);
|
|
47
|
+
try {
|
|
48
|
+
this.ormstatements = (0, import_ormstatements.create)(this.orm, conn);
|
|
49
|
+
} finally {
|
|
50
|
+
conn.close();
|
|
51
|
+
}
|
|
52
|
+
let loggerName = logCtxName;
|
|
53
|
+
if (!loggerName) {
|
|
54
|
+
loggerName = "db.dao";
|
|
55
|
+
if (this.orm.table)
|
|
56
|
+
loggerName = "db.dao." + this.orm.table.toLowerCase();
|
|
57
|
+
}
|
|
58
|
+
this.$log = import_log.Logging.getLogger(loggerName);
|
|
59
|
+
this.execute = function(sqlBuilder, parameterBindings) {
|
|
60
|
+
const sql = sqlBuilder.build();
|
|
61
|
+
if (sql === void 0 || sql.length < 1)
|
|
62
|
+
throw Error("Illegal argument: sql from statement builder is invalid[" + sql + "]");
|
|
63
|
+
this.$log.trace("Executing SQL Statement: {}", sql);
|
|
64
|
+
const parameters = sqlBuilder.parameters && sqlBuilder.parameters();
|
|
65
|
+
const _parameterBindings = [];
|
|
66
|
+
if (parameterBindings?.$filter && parameters && parameters.length > 0) {
|
|
67
|
+
if (parameterBindings.$filter.equals) {
|
|
68
|
+
const propertiesKeys = Object.keys(parameterBindings.$filter.equals);
|
|
69
|
+
const addedPropertiesKeys = [];
|
|
70
|
+
parameters.forEach((e) => {
|
|
71
|
+
if (propertiesKeys.includes(e.name) && !addedPropertiesKeys.includes(e.name)) {
|
|
72
|
+
const value = parameterBindings.$filter.equals[e.name];
|
|
73
|
+
if (Array.isArray(value)) {
|
|
74
|
+
value.forEach((v) => {
|
|
75
|
+
_parameterBindings.push({
|
|
76
|
+
type: e.type,
|
|
77
|
+
value: parseValue(e.type, v)
|
|
78
|
+
});
|
|
79
|
+
});
|
|
80
|
+
} else {
|
|
81
|
+
_parameterBindings.push({
|
|
82
|
+
type: e.type,
|
|
83
|
+
value: parseValue(e.type, value)
|
|
84
|
+
});
|
|
85
|
+
}
|
|
86
|
+
addedPropertiesKeys.push(e.name);
|
|
87
|
+
}
|
|
88
|
+
});
|
|
89
|
+
}
|
|
90
|
+
if (parameterBindings.$filter.notEquals) {
|
|
91
|
+
const propertiesKeys = Object.keys(parameterBindings.$filter.notEquals);
|
|
92
|
+
const addedPropertiesKeys = [];
|
|
93
|
+
parameters.forEach((e) => {
|
|
94
|
+
if (propertiesKeys.includes(e.name) && !addedPropertiesKeys.includes(e.name)) {
|
|
95
|
+
const value = parameterBindings.$filter.notEquals[e.name];
|
|
96
|
+
if (Array.isArray(value)) {
|
|
97
|
+
value.forEach((v) => {
|
|
98
|
+
_parameterBindings.push({
|
|
99
|
+
type: e.type,
|
|
100
|
+
value: parseValue(e.type, v)
|
|
101
|
+
});
|
|
102
|
+
});
|
|
103
|
+
} else {
|
|
104
|
+
_parameterBindings.push({
|
|
105
|
+
type: e.type,
|
|
106
|
+
value: parseValue(e.type, value)
|
|
107
|
+
});
|
|
108
|
+
}
|
|
109
|
+
addedPropertiesKeys.push(e.name);
|
|
110
|
+
}
|
|
111
|
+
});
|
|
112
|
+
}
|
|
113
|
+
if (parameterBindings.$filter.contains) {
|
|
114
|
+
const propertiesKeys = Object.keys(parameterBindings.$filter.contains);
|
|
115
|
+
const addedPropertiesKeys = [];
|
|
116
|
+
parameters.forEach((e) => {
|
|
117
|
+
if (propertiesKeys.includes(e.name) && !addedPropertiesKeys.includes(e.name)) {
|
|
118
|
+
_parameterBindings.push({
|
|
119
|
+
type: e.type,
|
|
120
|
+
value: `%${parameterBindings.$filter.contains[e.name]}%`
|
|
121
|
+
});
|
|
122
|
+
addedPropertiesKeys.push(e.name);
|
|
123
|
+
}
|
|
124
|
+
});
|
|
125
|
+
}
|
|
126
|
+
if (parameterBindings.$filter.greaterThan) {
|
|
127
|
+
const propertiesKeys = Object.keys(parameterBindings.$filter.greaterThan);
|
|
128
|
+
const addedPropertiesKeys = [];
|
|
129
|
+
parameters.forEach((e) => {
|
|
130
|
+
if (propertiesKeys.includes(e.name) && !addedPropertiesKeys.includes(e.name)) {
|
|
131
|
+
_parameterBindings.push({
|
|
132
|
+
type: e.type,
|
|
133
|
+
value: parseValue(e.type, parameterBindings.$filter.greaterThan[e.name])
|
|
134
|
+
});
|
|
135
|
+
addedPropertiesKeys.push(e.name);
|
|
136
|
+
}
|
|
137
|
+
});
|
|
138
|
+
}
|
|
139
|
+
if (parameterBindings.$filter.lessThan) {
|
|
140
|
+
const propertiesKeys = Object.keys(parameterBindings.$filter.lessThan);
|
|
141
|
+
const addedPropertiesKeys = [];
|
|
142
|
+
parameters.forEach((e) => {
|
|
143
|
+
if (propertiesKeys.includes(e.name) && !addedPropertiesKeys.includes(e.name)) {
|
|
144
|
+
_parameterBindings.push({
|
|
145
|
+
type: e.type,
|
|
146
|
+
value: parseValue(e.type, parameterBindings.$filter.lessThan[e.name])
|
|
147
|
+
});
|
|
148
|
+
addedPropertiesKeys.push(e.name);
|
|
149
|
+
}
|
|
150
|
+
});
|
|
151
|
+
}
|
|
152
|
+
if (parameterBindings.$filter.greaterThanOrEqual) {
|
|
153
|
+
const propertiesKeys = Object.keys(parameterBindings.$filter.greaterThanOrEqual);
|
|
154
|
+
const addedPropertiesKeys = [];
|
|
155
|
+
parameters.forEach((e) => {
|
|
156
|
+
if (propertiesKeys.includes(e.name) && !addedPropertiesKeys.includes(e.name)) {
|
|
157
|
+
_parameterBindings.push({
|
|
158
|
+
type: e.type,
|
|
159
|
+
value: parseValue(e.type, parameterBindings.$filter.greaterThanOrEqual[e.name])
|
|
160
|
+
});
|
|
161
|
+
addedPropertiesKeys.push(e.name);
|
|
162
|
+
}
|
|
163
|
+
});
|
|
164
|
+
}
|
|
165
|
+
if (parameterBindings.$filter.lessThanOrEqual) {
|
|
166
|
+
const propertiesKeys = Object.keys(parameterBindings.$filter.lessThanOrEqual);
|
|
167
|
+
const addedPropertiesKeys = [];
|
|
168
|
+
parameters.forEach((e) => {
|
|
169
|
+
if (propertiesKeys.includes(e.name) && !addedPropertiesKeys.includes(e.name)) {
|
|
170
|
+
_parameterBindings.push({
|
|
171
|
+
type: e.type,
|
|
172
|
+
value: parseValue(e.type, parameterBindings.$filter.lessThanOrEqual[e.name])
|
|
173
|
+
});
|
|
174
|
+
addedPropertiesKeys.push(e.name);
|
|
175
|
+
}
|
|
176
|
+
});
|
|
177
|
+
}
|
|
178
|
+
}
|
|
179
|
+
if (parameters && parameters.length > 0) {
|
|
180
|
+
for (var i = 0; i < parameters.length; i++) {
|
|
181
|
+
var val;
|
|
182
|
+
if (parameterBindings) {
|
|
183
|
+
if (Array.isArray(parameterBindings)) {
|
|
184
|
+
val = parameterBindings[i];
|
|
185
|
+
} else {
|
|
186
|
+
val = parameterBindings[parameters[i].name];
|
|
187
|
+
}
|
|
188
|
+
}
|
|
189
|
+
if ((val === null || val === void 0) && sql.toLowerCase().startsWith("select")) {
|
|
190
|
+
continue;
|
|
191
|
+
}
|
|
192
|
+
const index = i + 1;
|
|
193
|
+
this.$log.trace("Binding to parameter[{}]: {}", index, val);
|
|
194
|
+
_parameterBindings.push({
|
|
195
|
+
"type": parameters[i].type,
|
|
196
|
+
"value": parseValue(parameters[i].type, val)
|
|
197
|
+
});
|
|
198
|
+
}
|
|
199
|
+
}
|
|
200
|
+
let result;
|
|
201
|
+
if (sql.toLowerCase().startsWith("select")) {
|
|
202
|
+
result = import_db.Query.execute(sql, _parameterBindings, dataSourceName);
|
|
203
|
+
} else if (sql.toLowerCase().startsWith("insert")) {
|
|
204
|
+
result = import_insert.Insert.execute(sql, _parameterBindings, dataSourceName);
|
|
205
|
+
} else {
|
|
206
|
+
result = import_update.Update.execute(sql, _parameterBindings, dataSourceName);
|
|
207
|
+
}
|
|
208
|
+
return result !== null ? result : [];
|
|
209
|
+
};
|
|
210
|
+
function parseValue(type, value) {
|
|
211
|
+
switch (type.toUpperCase()) {
|
|
212
|
+
case "INTEGER":
|
|
213
|
+
return parseInt(value);
|
|
214
|
+
case "DOUBLE":
|
|
215
|
+
case "FLOAT":
|
|
216
|
+
return parseFloat(value);
|
|
217
|
+
case "BOOLEAN":
|
|
218
|
+
return value ? "true" : "false";
|
|
219
|
+
default:
|
|
220
|
+
return value;
|
|
221
|
+
}
|
|
222
|
+
}
|
|
223
|
+
}
|
|
224
|
+
;
|
|
225
|
+
DAO.prototype.notify = function(event) {
|
|
226
|
+
const func = this[event];
|
|
227
|
+
if (!this[event])
|
|
228
|
+
return;
|
|
229
|
+
if (typeof func !== "function")
|
|
230
|
+
throw Error("Illegal argument. Not a function: " + func);
|
|
231
|
+
const args = [].slice.call(arguments);
|
|
232
|
+
func.apply(this, args.slice(1));
|
|
233
|
+
};
|
|
234
|
+
DAO.prototype.createSQLEntity = function(entity) {
|
|
235
|
+
let i;
|
|
236
|
+
const persistentItem = {};
|
|
237
|
+
const mandatories = this.orm.getMandatoryProperties();
|
|
238
|
+
for (i = 0; i < mandatories.length; i++) {
|
|
239
|
+
if (mandatories[i].dbValue) {
|
|
240
|
+
persistentItem[mandatories[i].name] = mandatories[i].dbValue.apply(this, [entity[mandatories[i].name], entity]);
|
|
241
|
+
} else {
|
|
242
|
+
persistentItem[mandatories[i].name] = entity[mandatories[i].name];
|
|
243
|
+
}
|
|
244
|
+
}
|
|
245
|
+
const optionals = this.orm.getOptionalProperties();
|
|
246
|
+
for (i = 0; i < optionals.length; i++) {
|
|
247
|
+
if (optionals[i].dbValue !== void 0) {
|
|
248
|
+
persistentItem[optionals[i].name] = optionals[i].dbValue.apply(this, [entity[optionals[i].name], entity]);
|
|
249
|
+
} else {
|
|
250
|
+
persistentItem[optionals[i].name] = entity[optionals[i].name] === void 0 ? null : entity[optionals[i].name];
|
|
251
|
+
}
|
|
252
|
+
}
|
|
253
|
+
return persistentItem;
|
|
254
|
+
};
|
|
255
|
+
DAO.prototype.createEntity = function(resultSetEntry, entityPropertyNames) {
|
|
256
|
+
const entity = {};
|
|
257
|
+
let properties = this.orm.properties;
|
|
258
|
+
if (entityPropertyNames && entityPropertyNames.length > 0) {
|
|
259
|
+
properties = properties.filter(function(prop) {
|
|
260
|
+
return entityPropertyNames.indexOf(prop.name) > -1;
|
|
261
|
+
});
|
|
262
|
+
}
|
|
263
|
+
for (let i = 0; i < properties.length; i++) {
|
|
264
|
+
const prop = properties[i];
|
|
265
|
+
entity[prop.name] = resultSetEntry[prop.columnName];
|
|
266
|
+
if (prop.value) {
|
|
267
|
+
entity[prop.name] = prop.value(entity[prop.name]);
|
|
268
|
+
}
|
|
269
|
+
}
|
|
270
|
+
Object.keys(entity).forEach(function(propertyName) {
|
|
271
|
+
if (entity[propertyName] === null)
|
|
272
|
+
entity[propertyName] = void 0;
|
|
273
|
+
});
|
|
274
|
+
let entitySegment = "";
|
|
275
|
+
if (entity[this.orm.getPrimaryKey().name]) {
|
|
276
|
+
entitySegment = "[" + entity[this.orm.getPrimaryKey().name] + "]";
|
|
277
|
+
}
|
|
278
|
+
return entity;
|
|
279
|
+
};
|
|
280
|
+
DAO.prototype.validateEntity = function(entity, skip) {
|
|
281
|
+
if (entity === void 0 || entity === null) {
|
|
282
|
+
throw new Error("Illegal argument: entity is " + entity);
|
|
283
|
+
}
|
|
284
|
+
if (skip) {
|
|
285
|
+
if (skip.constructor !== Array) {
|
|
286
|
+
skip = [skip];
|
|
287
|
+
}
|
|
288
|
+
for (var j = 0; j < skip.length; j++) {
|
|
289
|
+
skip[j];
|
|
290
|
+
}
|
|
291
|
+
}
|
|
292
|
+
const mandatories = this.orm.getMandatoryProperties();
|
|
293
|
+
for (let i = 0; i < mandatories.length; i++) {
|
|
294
|
+
const propName = mandatories[i].name;
|
|
295
|
+
if (skip && skip.indexOf(propName) > -1 || mandatories[i].type.toUpperCase() === "BOOLEAN")
|
|
296
|
+
continue;
|
|
297
|
+
const propValue = entity[propName];
|
|
298
|
+
if (propValue === void 0 || propValue === null) {
|
|
299
|
+
throw new Error("Illegal " + propName + " attribute value in " + this.orm.table + " entity: " + propValue);
|
|
300
|
+
}
|
|
301
|
+
}
|
|
302
|
+
};
|
|
303
|
+
DAO.prototype.insert = function(_entity) {
|
|
304
|
+
const ids = [];
|
|
305
|
+
let entities = _entity;
|
|
306
|
+
if (_entity.constructor !== Array) {
|
|
307
|
+
entities = [_entity];
|
|
308
|
+
}
|
|
309
|
+
this.$log.trace("Inserting {} {}", this.orm.table, entities.length === 1 ? "entity" : "entities");
|
|
310
|
+
for (let i = 0; i < entities.length; i++) {
|
|
311
|
+
let entity = entities[i];
|
|
312
|
+
entity = entities[i];
|
|
313
|
+
this.validateEntity(entity, [this.orm.getPrimaryKey().name]);
|
|
314
|
+
const uniques = this.orm.getUniqueProperties();
|
|
315
|
+
for (let _i = 0; _i < uniques.length; _i++) {
|
|
316
|
+
const prop = uniques[_i];
|
|
317
|
+
const st = this.ormstatements.dialect.select(prop.column).from(this.orm.table).where(prop.column + "=?", [prop]);
|
|
318
|
+
const params = {};
|
|
319
|
+
params[prop.name] = entity[prop.name];
|
|
320
|
+
const rs = this.execute(st, params);
|
|
321
|
+
if (rs.length > 0)
|
|
322
|
+
throw Error("Unique constraint violation for " + prop.name + "[" + entity[prop.name] + "]");
|
|
323
|
+
}
|
|
324
|
+
const dbEntity = this.createSQLEntity(entity);
|
|
325
|
+
try {
|
|
326
|
+
const parametericStatement = this.ormstatements.insert.apply(this.ormstatements);
|
|
327
|
+
if (this.orm.isAutoIncrementPrimaryKey()) {
|
|
328
|
+
const id = this.generateId();
|
|
329
|
+
dbEntity[this.orm.getPrimaryKey().name] = id;
|
|
330
|
+
}
|
|
331
|
+
const updatedRecordCount = this.execute(parametericStatement, dbEntity);
|
|
332
|
+
if (!this.orm.isAutoIncrementPrimaryKey() && isNotEmptyArray(updatedRecordCount)) {
|
|
333
|
+
const id = updatedRecordCount[0];
|
|
334
|
+
dbEntity[this.orm.getPrimaryKey().name] = id;
|
|
335
|
+
}
|
|
336
|
+
this.notify("afterInsert", dbEntity);
|
|
337
|
+
this.notify("beforeInsertAssociationSets", dbEntity);
|
|
338
|
+
if ((updatedRecordCount > 0 || isNotEmptyArray(updatedRecordCount)) && this.orm.associations && Object.keys(this.orm.associations).length) {
|
|
339
|
+
this.$log.trace("Inserting association sets for {}[{}]", this.orm.table, dbEntity[this.orm.getPrimaryKey().name]);
|
|
340
|
+
for (const idx in Object.keys(this.orm.associations)) {
|
|
341
|
+
const association = this.orm.associations[idx];
|
|
342
|
+
const associationName = association["name"];
|
|
343
|
+
if ([this.orm.ASSOCIATION_TYPES["MANY-TO-MANY"], this.orm.ASSOCIATION_TYPES["MANY-TO-ONE"]].indexOf(association.type) < 0) {
|
|
344
|
+
if (entity[associationName] && entity[associationName].length > 0) {
|
|
345
|
+
const associationDaoFactoryFunc = association.targetDao || this;
|
|
346
|
+
if (associationDaoFactoryFunc.constructor !== Function)
|
|
347
|
+
throw Error("Invalid ORM: Association " + associationName + " dao property is expected to be function. Instead, it is: " + typeof associationDaoFactoryFunc);
|
|
348
|
+
const associationDAO = associationDaoFactoryFunc.apply(this);
|
|
349
|
+
this.notify("beforeInsertAssociationSet", entity[associationName], entity);
|
|
350
|
+
this.$log.trace("Inserting {} inline entities into association set {}", entity[associationName].length, associationName);
|
|
351
|
+
for (let j = 0; j < entity[associationName].length; j++) {
|
|
352
|
+
const associatedEntity = entity[associationName][j];
|
|
353
|
+
const associatedEntityJoinKey = association.joinKey;
|
|
354
|
+
const key = association.key || this.orm.getPrimaryKey().name;
|
|
355
|
+
associatedEntity[associatedEntityJoinKey] = entity[key];
|
|
356
|
+
this.notify("beforeInsertAssociationSetEntity", entity[associationName], dbEntity);
|
|
357
|
+
associationDAO.insert.apply(associationDAO, [associatedEntity]);
|
|
358
|
+
}
|
|
359
|
+
this.$log.trace("Inserting {} inline entities into association set {} finsihed", entity[associationName].length, associationName);
|
|
360
|
+
this.notify("afterInsertAssociationSet", entity[associationName], dbEntity);
|
|
361
|
+
}
|
|
362
|
+
}
|
|
363
|
+
}
|
|
364
|
+
}
|
|
365
|
+
if (updatedRecordCount > 0 || isNotEmptyArray(updatedRecordCount)) {
|
|
366
|
+
ids.push(dbEntity[this.orm.getPrimaryKey().name]);
|
|
367
|
+
this.$log.trace("{}[] entity inserted", this.orm.table, dbEntity[this.orm.getPrimaryKey().name]);
|
|
368
|
+
} else {
|
|
369
|
+
this.$log.trace("No changes incurred in {}", this.orm.table);
|
|
370
|
+
}
|
|
371
|
+
} catch (e) {
|
|
372
|
+
this.$log.error("Inserting {} {} failed", this.orm.table, entities.length === 1 ? "entity" : "entities", e);
|
|
373
|
+
this.$log.trace("Rolling back changes after failed {}[{}] insert. ", this.orm.table, dbEntity[this.orm.getPrimaryKey().name]);
|
|
374
|
+
if (dbEntity[this.orm.getPrimaryKey().name]) {
|
|
375
|
+
try {
|
|
376
|
+
this.remove(dbEntity[this.orm.getPrimaryKey().name]);
|
|
377
|
+
} catch (err) {
|
|
378
|
+
this.$log.error("Could not rollback changes after failed {}[{}] insert. ", this.orm.table, dbEntity[this.orm.getPrimaryKey().name], err);
|
|
379
|
+
}
|
|
380
|
+
}
|
|
381
|
+
throw e;
|
|
382
|
+
}
|
|
383
|
+
}
|
|
384
|
+
if (_entity.constructor !== Array)
|
|
385
|
+
return ids[0];
|
|
386
|
+
else
|
|
387
|
+
return ids;
|
|
388
|
+
};
|
|
389
|
+
function isNotEmptyArray(array) {
|
|
390
|
+
return Array.isArray(array) && array.length > 0;
|
|
391
|
+
}
|
|
392
|
+
DAO.prototype.update = function(entity) {
|
|
393
|
+
this.$log.trace("Updating {}[{}] entity", this.orm.table, entity !== void 0 ? entity[this.orm.getPrimaryKey().name] : entity);
|
|
394
|
+
if (entity === void 0 || entity === null) {
|
|
395
|
+
throw new Error("Illegal argument: entity is " + entity);
|
|
396
|
+
}
|
|
397
|
+
const ignoredProperties = this.orm.getMandatoryProperties().filter(function(property) {
|
|
398
|
+
return property.allowedOps && property.allowedOps.indexOf("update") < 0;
|
|
399
|
+
}).map(function(property) {
|
|
400
|
+
return property.name;
|
|
401
|
+
});
|
|
402
|
+
this.validateEntity(entity, ignoredProperties);
|
|
403
|
+
const parametericStatement = this.ormstatements.update.apply(this.ormstatements, [entity]);
|
|
404
|
+
const dbEntity = this.createSQLEntity(entity);
|
|
405
|
+
try {
|
|
406
|
+
this.notify("beforeUpdateEntity", dbEntity);
|
|
407
|
+
const updatedRecordsCount = this.execute(parametericStatement, dbEntity);
|
|
408
|
+
if (updatedRecordsCount > 0)
|
|
409
|
+
this.$log.trace("{}[{}] entity updated", this.orm.table, dbEntity[this.orm.getPrimaryKey().name]);
|
|
410
|
+
else
|
|
411
|
+
this.$log.trace("No changes incurred in {}", this.orm.table);
|
|
412
|
+
return this;
|
|
413
|
+
} catch (e) {
|
|
414
|
+
this.$log.error("Updating {}[{}] failed", this.orm.table, entity !== void 0 ? entity[this.orm.getPrimaryKey().name] : entity, e);
|
|
415
|
+
throw e;
|
|
416
|
+
}
|
|
417
|
+
};
|
|
418
|
+
DAO.prototype.remove = function() {
|
|
419
|
+
let ids = [];
|
|
420
|
+
if (arguments.length === 0) {
|
|
421
|
+
ids = this.list({
|
|
422
|
+
"$select": [this.orm.getPrimaryKey().name]
|
|
423
|
+
}).map(function(ent) {
|
|
424
|
+
return ent[this.orm.getPrimaryKey().name];
|
|
425
|
+
}.bind(this));
|
|
426
|
+
} else {
|
|
427
|
+
if (arguments[0].constructor !== Array) {
|
|
428
|
+
ids = [arguments[0]];
|
|
429
|
+
} else {
|
|
430
|
+
ids = arguments[0];
|
|
431
|
+
}
|
|
432
|
+
}
|
|
433
|
+
this.$log.trace("Deleting " + this.orm.table + (ids !== void 0 && ids.length === 1 ? "[" + ids[0] + "] entity" : ids.length + " entities"));
|
|
434
|
+
for (let i = 0; i < ids.length; i++) {
|
|
435
|
+
let id = ids[i];
|
|
436
|
+
if (this.orm.getPrimaryKey().type.toUpperCase() !== "VARCHAR")
|
|
437
|
+
id = parseInt(id, 10);
|
|
438
|
+
if (ids.length > 1)
|
|
439
|
+
this.$log.trace("Deleting {}[{}] entity", this.orm.table, id);
|
|
440
|
+
if (id === void 0 || id === null) {
|
|
441
|
+
throw new Error("Illegal argument for id parameter:" + id);
|
|
442
|
+
}
|
|
443
|
+
try {
|
|
444
|
+
this.notify("beforeRemoveEntity", id);
|
|
445
|
+
if (this.orm.associations) {
|
|
446
|
+
for (const idx in Object.keys(this.orm.associations)) {
|
|
447
|
+
const association = this.orm.associations[idx];
|
|
448
|
+
const associationName = association["name"];
|
|
449
|
+
if ([this.orm.ASSOCIATION_TYPES["MANY-TO-MANY"], this.orm.ASSOCIATION_TYPES["MANY-TO-ONE"]].indexOf(association.type) < 0) {
|
|
450
|
+
this.$log.trace("Inspecting {}[{}}] entity's dependency '{}' for entities to delete.", this.orm.table, id, associationName);
|
|
451
|
+
const associationDAO = association.targetDao ? association.targetDao() : this;
|
|
452
|
+
const settings = {};
|
|
453
|
+
let joinId = id;
|
|
454
|
+
if (association.key !== void 0) {
|
|
455
|
+
var ctxEntity = this.find(id);
|
|
456
|
+
joinId = ctxEntity[association.key];
|
|
457
|
+
}
|
|
458
|
+
settings[association.joinKey] = joinId;
|
|
459
|
+
let associatedEntities;
|
|
460
|
+
associatedEntities = associationDAO.list(settings);
|
|
461
|
+
if (associatedEntities && associatedEntities.length > 0) {
|
|
462
|
+
this.$log.trace("Deleting {}[{}] entity's {} dependent {}", this.orm.table, id, associatedEntities.length, associationName);
|
|
463
|
+
this.notify("beforeRemoveAssociationSet", associatedEntities, id);
|
|
464
|
+
for (let j = 0; j < associatedEntities.length; j++) {
|
|
465
|
+
const associatedEntity = associatedEntities[j];
|
|
466
|
+
this.notify("beforeRemoveAssociationSetEntity", associatedEntity, associatedEntities, id);
|
|
467
|
+
associationDAO.remove.apply(associationDAO, [associatedEntity[associationDAO.orm.getPrimaryKey().name]]);
|
|
468
|
+
}
|
|
469
|
+
this.$log.trace("{}[{}] entity's {} dependent {} {} deleted.", this.orm.table, id, associatedEntities.length, associationName, associatedEntities.length > 1 ? "entities" : "entity");
|
|
470
|
+
}
|
|
471
|
+
}
|
|
472
|
+
}
|
|
473
|
+
}
|
|
474
|
+
const parametericStatement = this.ormstatements["delete"].apply(this.ormstatements, [this.orm.getPrimaryKey().name]);
|
|
475
|
+
let params = {};
|
|
476
|
+
params[this.orm.getPrimaryKey().name] = id;
|
|
477
|
+
const updatedRecordsCount = this.execute(parametericStatement, params);
|
|
478
|
+
if (updatedRecordsCount > 0)
|
|
479
|
+
this.$log.trace("{}[{}] entity deleted", this.orm.table, id);
|
|
480
|
+
else
|
|
481
|
+
this.$log.trace("No changes incurred in {}", this.orm.table);
|
|
482
|
+
} catch (e) {
|
|
483
|
+
this.$log.error("Deleting {}[{}] entity failed", this.orm.table, id, e);
|
|
484
|
+
throw e;
|
|
485
|
+
}
|
|
486
|
+
}
|
|
487
|
+
};
|
|
488
|
+
DAO.prototype.expand = function(expansionPath, context) {
|
|
489
|
+
let i;
|
|
490
|
+
let settings;
|
|
491
|
+
let key;
|
|
492
|
+
let joinId;
|
|
493
|
+
this.$log.trace("Expanding for association path {} and context entity {}", expansionPath, (typeof arguments[1] !== "object" ? "id " : "") + JSON.stringify(arguments[1]));
|
|
494
|
+
if (!expansionPath || !expansionPath.length) {
|
|
495
|
+
throw new Error("Illegal argument: expansionPath[" + expansionPath + "]");
|
|
496
|
+
}
|
|
497
|
+
if (!context) {
|
|
498
|
+
throw new Error("Illegal argument: context[" + context + "]");
|
|
499
|
+
}
|
|
500
|
+
const associationName = expansionPath.splice ? expansionPath.splice(0, 1)[0] : expansionPath;
|
|
501
|
+
const association = this.orm.getAssociation(associationName);
|
|
502
|
+
if (!associationName || !association)
|
|
503
|
+
throw new Error("Illegal argument: Unknown association for this DAO [" + associationName + "]");
|
|
504
|
+
const joinKey = association.joinKey;
|
|
505
|
+
let contextEntity;
|
|
506
|
+
if (context[this.orm.getPrimaryKey().name] !== void 0) {
|
|
507
|
+
contextEntity = context;
|
|
508
|
+
} else {
|
|
509
|
+
contextEntity = this.find(context);
|
|
510
|
+
}
|
|
511
|
+
if (!contextEntity) {
|
|
512
|
+
throw Error("No record found for context entity [" + context + "]");
|
|
513
|
+
}
|
|
514
|
+
const associationTargetDAO = association.targetDao ? association.targetDao.apply(this) : this;
|
|
515
|
+
if (!associationTargetDAO)
|
|
516
|
+
throw Error("No target association DAO instance available for association " + associationName);
|
|
517
|
+
let expansion;
|
|
518
|
+
let associationEntities = [];
|
|
519
|
+
if (association.type === this.orm.ASSOCIATION_TYPES["ONE-TO-ONE"] || association.type === this.orm.ASSOCIATION_TYPES["MANY-TO-ONE"]) {
|
|
520
|
+
joinId = contextEntity[joinKey];
|
|
521
|
+
this.$log.trace("Expanding association type {} on {}[{}]", association.type, joinKey, joinId);
|
|
522
|
+
if (!association.key || association.key === associationTargetDAO.orm.getPrimaryKey().name)
|
|
523
|
+
expansion = associationTargetDAO.find.apply(associationTargetDAO, [joinId]);
|
|
524
|
+
else {
|
|
525
|
+
let listSettings = {};
|
|
526
|
+
listSettings["$filter"] = association.key;
|
|
527
|
+
listSettings[association.key] = joinId;
|
|
528
|
+
expansion = associationTargetDAO.list.apply(associationTargetDAO, [listSettings])[0];
|
|
529
|
+
}
|
|
530
|
+
if (expansionPath.length > 0) {
|
|
531
|
+
this.expand(expansionPath, expansion);
|
|
532
|
+
}
|
|
533
|
+
} else if (association.type === this.orm.ASSOCIATION_TYPES["ONE-TO-MANY"]) {
|
|
534
|
+
settings = {};
|
|
535
|
+
if (association.defaults)
|
|
536
|
+
settings = association.defaults;
|
|
537
|
+
key = association.key || this.orm.getPrimaryKey().name;
|
|
538
|
+
joinId = contextEntity[key];
|
|
539
|
+
this.$log.trace("Expanding association type {} on {}[{}]", association.type, joinKey, joinId);
|
|
540
|
+
settings[joinKey] = joinId;
|
|
541
|
+
associationEntities = associationEntities.concat(associationTargetDAO.list.apply(associationTargetDAO, [settings]));
|
|
542
|
+
if (expansionPath.length > 0) {
|
|
543
|
+
for (i = 0; i < associationEntities.length; i++) {
|
|
544
|
+
this.expand(expansionPath, associationEntities[i]);
|
|
545
|
+
}
|
|
546
|
+
} else {
|
|
547
|
+
expansion = associationEntities;
|
|
548
|
+
}
|
|
549
|
+
} else if (association.type === this.orm.ASSOCIATION_TYPES["MANY-TO-MANY"]) {
|
|
550
|
+
const joinDAO = association.joinDao();
|
|
551
|
+
if (!joinDAO)
|
|
552
|
+
throw Error("No join DAO instance available for association " + associationName);
|
|
553
|
+
if (!joinDAO.listJoins)
|
|
554
|
+
throw Error("No listJoins function in join DAO instance available for association " + associationName);
|
|
555
|
+
settings = {};
|
|
556
|
+
key = association.key || this.orm.getPrimaryKey().name;
|
|
557
|
+
joinId = contextEntity[key];
|
|
558
|
+
settings[association.joinKey] = joinId;
|
|
559
|
+
associationEntities = associationEntities.concat(joinDAO.listJoins.apply(joinDAO, [settings, { "sourceDao": this, "joinDao": joinDAO, "targetDao": associationTargetDAO }]));
|
|
560
|
+
if (expansionPath.length > 0) {
|
|
561
|
+
for (i = 0; i < associationEntities.length; i++) {
|
|
562
|
+
this.expand(expansionPath, associationEntities[i]);
|
|
563
|
+
}
|
|
564
|
+
} else {
|
|
565
|
+
expansion = associationEntities;
|
|
566
|
+
}
|
|
567
|
+
}
|
|
568
|
+
return expansion;
|
|
569
|
+
};
|
|
570
|
+
DAO.prototype.find = function(id, expand, select) {
|
|
571
|
+
if (typeof arguments[0] === "object") {
|
|
572
|
+
id = arguments[0].id;
|
|
573
|
+
expand = arguments[0].$expand || arguments[0].expand;
|
|
574
|
+
select = arguments[0].$select || arguments[0].select;
|
|
575
|
+
}
|
|
576
|
+
this.$log.trace("Finding {}[{}] entity with list parameters expand[{}], select[{}]", this.orm.table, id, expand, select);
|
|
577
|
+
if (id === void 0 || id === null) {
|
|
578
|
+
throw new Error("Illegal argument for id parameter:" + id);
|
|
579
|
+
}
|
|
580
|
+
try {
|
|
581
|
+
let entity;
|
|
582
|
+
if (select !== void 0) {
|
|
583
|
+
if (select.constructor !== Array) {
|
|
584
|
+
if (select.constructor === String) {
|
|
585
|
+
select = select.split(",").map(function(sel) {
|
|
586
|
+
if (sel.constructor !== String)
|
|
587
|
+
throw Error("Illegal argument: select array components are expected ot be strings but found " + typeof sel);
|
|
588
|
+
return sel.trim();
|
|
589
|
+
});
|
|
590
|
+
} else {
|
|
591
|
+
throw Error("Illegal argument: select is expected to be string or array of strings but was " + typeof select);
|
|
592
|
+
}
|
|
593
|
+
}
|
|
594
|
+
}
|
|
595
|
+
if (select !== void 0 && expand !== void 0) {
|
|
596
|
+
select.push(this.orm.getPrimaryKey().name);
|
|
597
|
+
}
|
|
598
|
+
let findQbParams = {
|
|
599
|
+
select
|
|
600
|
+
};
|
|
601
|
+
const parametericStatement = this.ormstatements.find.apply(this.ormstatements, [findQbParams]);
|
|
602
|
+
let params = {};
|
|
603
|
+
if (this.orm.getPrimaryKey().type.toUpperCase() !== "VARCHAR")
|
|
604
|
+
id = parseInt(id, 10);
|
|
605
|
+
params[this.orm.getPrimaryKey().name] = id;
|
|
606
|
+
const resultSet = this.execute(parametericStatement, params);
|
|
607
|
+
if (resultSet[0]) {
|
|
608
|
+
entity = this.createEntity(resultSet[0], select);
|
|
609
|
+
if (entity) {
|
|
610
|
+
this.$log.trace("{}[{}] entity found", this.orm.table, id);
|
|
611
|
+
this.notify("afterFound", entity);
|
|
612
|
+
if (expand !== void 0) {
|
|
613
|
+
if (expand.constructor !== Array) {
|
|
614
|
+
if (expand.constructor === String) {
|
|
615
|
+
expand = String(expand);
|
|
616
|
+
expand = expand.split(",").map(function(exp) {
|
|
617
|
+
if (exp.constructor !== String)
|
|
618
|
+
throw Error("Illegal argument: expand array components are expected ot be strings but found " + typeof exp);
|
|
619
|
+
return exp.trim();
|
|
620
|
+
});
|
|
621
|
+
} else {
|
|
622
|
+
throw Error("Illegal argument: expand is expected to be string or array of strings but was " + typeof expand);
|
|
623
|
+
}
|
|
624
|
+
}
|
|
625
|
+
var associationNames = this.orm.getAssociationNames();
|
|
626
|
+
for (var idx in associationNames) {
|
|
627
|
+
var associationName = associationNames[idx];
|
|
628
|
+
if (expand.indexOf(associationName) > -1) {
|
|
629
|
+
entity[associationName] = this.expand([associationName], entity);
|
|
630
|
+
}
|
|
631
|
+
}
|
|
632
|
+
}
|
|
633
|
+
} else {
|
|
634
|
+
this.$log.trace("{}[{}] entity not found", this.orm.table, id);
|
|
635
|
+
}
|
|
636
|
+
}
|
|
637
|
+
return entity;
|
|
638
|
+
} catch (e) {
|
|
639
|
+
this.$log.error("Finding {}[{}] entity failed.", this.orm.table, id, e);
|
|
640
|
+
throw e;
|
|
641
|
+
}
|
|
642
|
+
};
|
|
643
|
+
DAO.prototype.count = function(settings) {
|
|
644
|
+
settings = settings || {};
|
|
645
|
+
const parametericStatement = this.ormstatements.count.apply(this.ormstatements, [settings]);
|
|
646
|
+
this.$log.trace("Counting " + this.orm.table + " entities");
|
|
647
|
+
let count = 0;
|
|
648
|
+
try {
|
|
649
|
+
const rs = this.execute(parametericStatement, settings);
|
|
650
|
+
if (rs.length > 0) {
|
|
651
|
+
const key = Object.keys(rs[0])[0];
|
|
652
|
+
count = parseInt(rs[0][key], 10);
|
|
653
|
+
}
|
|
654
|
+
} catch (e) {
|
|
655
|
+
this.$log.error("Counting {} entities failed", this.orm.table, e);
|
|
656
|
+
e.errContext = parametericStatement.toString();
|
|
657
|
+
throw e;
|
|
658
|
+
}
|
|
659
|
+
this.$log.trace("{} {} entities counted", String(count), this.orm.table);
|
|
660
|
+
return count;
|
|
661
|
+
};
|
|
662
|
+
DAO.prototype.list = function(settings) {
|
|
663
|
+
let key;
|
|
664
|
+
settings = settings || {};
|
|
665
|
+
const expand = settings.$expand || settings.expand;
|
|
666
|
+
if (expand !== void 0) {
|
|
667
|
+
if (expand.constructor !== Array) {
|
|
668
|
+
if (expand.constructor === String) {
|
|
669
|
+
if (expand.indexOf(",") > -1) {
|
|
670
|
+
settings.$expand = expand.split(",").map(function(exp) {
|
|
671
|
+
if (exp.constructor !== String)
|
|
672
|
+
throw Error("Illegal argument: expand array components are expected ot be strings but found " + typeof exp);
|
|
673
|
+
return exp.trim();
|
|
674
|
+
});
|
|
675
|
+
} else {
|
|
676
|
+
settings.$expand = [expand];
|
|
677
|
+
}
|
|
678
|
+
} else {
|
|
679
|
+
throw Error("Illegal argument: expand is expected to be string or array of strings but was " + typeof expand);
|
|
680
|
+
}
|
|
681
|
+
}
|
|
682
|
+
}
|
|
683
|
+
const select = settings.$select || settings.select;
|
|
684
|
+
if (select !== void 0) {
|
|
685
|
+
if (select.constructor !== Array) {
|
|
686
|
+
if (select.constructor === String) {
|
|
687
|
+
if (select.indexOf(",") > -1) {
|
|
688
|
+
settings.$select = select.split(",").map(function(exp) {
|
|
689
|
+
if (exp.constructor !== String)
|
|
690
|
+
throw Error("Illegal argument: select array components are expected ot be strings but found " + typeof exp);
|
|
691
|
+
return exp.trim();
|
|
692
|
+
});
|
|
693
|
+
} else {
|
|
694
|
+
settings.$select = [select];
|
|
695
|
+
}
|
|
696
|
+
} else {
|
|
697
|
+
throw Error("Illegal argument: select is expected to be string or array of strings but was " + typeof expand);
|
|
698
|
+
}
|
|
699
|
+
}
|
|
700
|
+
}
|
|
701
|
+
const listArgs = [];
|
|
702
|
+
for (key in settings) {
|
|
703
|
+
listArgs.push(" " + key + "[" + settings[key] + "]");
|
|
704
|
+
}
|
|
705
|
+
this.$log.trace("Listing {} entity collection with list operators: {}", this.orm.table, listArgs.join(","));
|
|
706
|
+
if (settings.$select !== void 0 && expand !== void 0) {
|
|
707
|
+
settings.$select.push(this.orm.getPrimaryKey().name);
|
|
708
|
+
}
|
|
709
|
+
var parametericStatement = this.ormstatements.list.apply(this.ormstatements, [settings]);
|
|
710
|
+
try {
|
|
711
|
+
let entities = [];
|
|
712
|
+
const resultSet = this.execute(parametericStatement, settings);
|
|
713
|
+
resultSet.forEach(function(rsEntry) {
|
|
714
|
+
var entity = this.createEntity(rsEntry, settings.$select);
|
|
715
|
+
if (expand) {
|
|
716
|
+
var associationNames = this.orm.getAssociationNames();
|
|
717
|
+
for (var idx = 0; idx < associationNames.length; idx++) {
|
|
718
|
+
var associationName = associationNames[idx];
|
|
719
|
+
if (expand.indexOf(associationName) > -1) {
|
|
720
|
+
entity[associationName] = this.expand([associationName], entity);
|
|
721
|
+
}
|
|
722
|
+
}
|
|
723
|
+
}
|
|
724
|
+
this.notify("afterFound", entity, settings);
|
|
725
|
+
entities.push(entity);
|
|
726
|
+
}.bind(this));
|
|
727
|
+
this.$log.trace("{} {} entities found", entities.length, this.orm.table);
|
|
728
|
+
return entities;
|
|
729
|
+
} catch (e) {
|
|
730
|
+
this.$log.error("Listing {} entities failed.", this.orm.table, e);
|
|
731
|
+
throw e;
|
|
732
|
+
}
|
|
733
|
+
};
|
|
734
|
+
DAO.prototype.existsTable = function() {
|
|
735
|
+
this.$log.trace("Check exists table " + this.orm.table);
|
|
736
|
+
try {
|
|
737
|
+
const parametericStatement = this.ormstatements.count.apply(this.ormstatements);
|
|
738
|
+
const rs = this.execute(parametericStatement);
|
|
739
|
+
return rs.length > 0;
|
|
740
|
+
} catch (e) {
|
|
741
|
+
return false;
|
|
742
|
+
}
|
|
743
|
+
};
|
|
744
|
+
DAO.prototype.createTable = function() {
|
|
745
|
+
this.$log.trace("Creating table {}", this.orm.table);
|
|
746
|
+
const parametericStatement = this.ormstatements.createTable.apply(this.ormstatements);
|
|
747
|
+
try {
|
|
748
|
+
this.execute(parametericStatement);
|
|
749
|
+
this.$log.trace("{} table created", this.orm.table);
|
|
750
|
+
return this;
|
|
751
|
+
} catch (e) {
|
|
752
|
+
this.$log.error("Create table {} failed", this.orm.table, e);
|
|
753
|
+
throw e;
|
|
754
|
+
}
|
|
755
|
+
};
|
|
756
|
+
DAO.prototype.dropTable = function(dropIdSequence) {
|
|
757
|
+
this.$log.trace("Dropping table {}.", this.orm.table);
|
|
758
|
+
const parametericStatement = this.ormstatements.dropTable.apply(this.ormstatements);
|
|
759
|
+
try {
|
|
760
|
+
this.execute(parametericStatement);
|
|
761
|
+
this.$log.trace("Table {} dropped.", this.orm.table);
|
|
762
|
+
} catch (e) {
|
|
763
|
+
this.$log.error("Dropping table {} failed.", this.orm.table, e);
|
|
764
|
+
throw e;
|
|
765
|
+
}
|
|
766
|
+
if (dropIdSequence) {
|
|
767
|
+
this.$log.trace("Dropping table {} sequence {}.", this.orm.table, this.sequenceName);
|
|
768
|
+
try {
|
|
769
|
+
this.dropIdGenerator();
|
|
770
|
+
this.$log.trace("Table {} sequence {} dropped.", this.orm.table, this.sequenceName);
|
|
771
|
+
} catch (e) {
|
|
772
|
+
this.$log.error("Dropping table {} sequence {} failed.", this.orm.table, this.sequenceName, e);
|
|
773
|
+
throw e;
|
|
774
|
+
}
|
|
775
|
+
}
|
|
776
|
+
return this;
|
|
777
|
+
};
|
|
778
|
+
function create(oDefinition, logCtxName, dataSourceName) {
|
|
779
|
+
let orm;
|
|
780
|
+
orm = oDefinition;
|
|
781
|
+
if (!dataSourceName || dataSourceName === null) {
|
|
782
|
+
dataSourceName = import_core.configurations.get("DIRIGIBLE_DATABASE_DATASOURCE_NAME_DEFAULT", "DefaultDB");
|
|
783
|
+
}
|
|
784
|
+
let productName = import_core.globals.get(dataSourceName);
|
|
785
|
+
if (!productName) {
|
|
786
|
+
productName = import_database.Database.getProductName(dataSourceName);
|
|
787
|
+
import_core.globals.set(dataSourceName, productName);
|
|
788
|
+
}
|
|
789
|
+
return new DAO(orm, logCtxName, dataSourceName);
|
|
790
|
+
}
|
|
791
|
+
;
|
|
792
|
+
function dao(oDefinition, logCtxName, dataSourceName) {
|
|
793
|
+
return create(oDefinition, logCtxName, dataSourceName);
|
|
794
|
+
}
|
|
795
|
+
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../src/db/dao.ts"],
  "sourcesContent": ["\"use strict\";\n\nimport { ORMDefinition, get as getORM } from \"./orm\";\nimport { create as createORMStatements } from \"./ormstatements\";\nimport { Sequence } from \"./sequence\";\nimport { Database } from \"./database\";\nimport { Query } from \"@aerokit/sdk/db\";\nimport { Update } from \"./update\";\nimport { Insert } from \"./insert\";\nimport { Logging } from \"@aerokit/sdk/log\";\nimport { configurations, globals } from \"@aerokit/sdk/core\";\n\n\nexport function DAO(orm: ORMDefinition, logCtxName?: string, dataSourceName?: string) {\n\tif (orm === undefined)\n\t\tthrow Error('Illegal argument: orm[' + orm + ']');\n\n\tthis.orm = getORM(orm);\n\tthis.sequenceName = this.orm.table + '_' + this.orm.getPrimaryKey().name.toUpperCase();\n\tthis.dropIdGenerator = function () {\n\t\treturn Sequence.drop(this.sequenceName, dataSourceName);\n\t};\n\tthis.generateId = function () {\n\t\treturn Sequence.nextval(this.sequenceName, this.orm.table, dataSourceName);\n\t};\n\n\tconst conn = Database.getConnection(dataSourceName);\n\ttry {\n\t\tthis.ormstatements = createORMStatements(this.orm, conn);\n\t} finally {\n\t\tconn.close();\n\t}\n\n\t// setup loggerName\n\tlet loggerName = logCtxName;\n\tif (!loggerName) {\n\t\tloggerName = 'db.dao';\n\t\tif (this.orm.table)\n\t\t\tloggerName = 'db.dao.' + (this.orm.table.toLowerCase());\n\t}\n\tthis.$log = Logging.getLogger(loggerName);\n\n\tthis.execute = function (sqlBuilder, parameterBindings) {\n\t\tconst sql = sqlBuilder.build();\n\t\tif (sql === undefined || sql.length < 1)\n\t\t\tthrow Error(\"Illegal argument: sql from statement builder is invalid[\" + sql + \"]\");\n\t\tthis.$log.trace('Executing SQL Statement: {}', sql);\n\n\t\tconst parameters = sqlBuilder.parameters && sqlBuilder.parameters();\n\t\tconst _parameterBindings = [];\n\t\tif (parameterBindings?.$filter && parameters && parameters.length > 0) {\n\t\t\tif (parameterBindings.$filter.equals) {\n\t\t\t\tconst propertiesKeys = Object.keys(parameterBindings.$filter.equals);\n\t\t\t\tconst addedPropertiesKeys = [];\n\t\t\t\tparameters.forEach(e => {\n\t\t\t\t\tif (propertiesKeys.includes(e.name) && !addedPropertiesKeys.includes(e.name)) {\n\t\t\t\t\t\tconst value = parameterBindings.$filter.equals[e.name];\n\t\t\t\t\t\tif (Array.isArray(value)) {\n\t\t\t\t\t\t\tvalue.forEach(v => {\n\t\t\t\t\t\t\t\t_parameterBindings.push({\n\t\t\t\t\t\t\t\t\ttype: e.type,\n\t\t\t\t\t\t\t\t\tvalue: parseValue(e.type, v)\n\t\t\t\t\t\t\t\t});\n\t\t\t\t\t\t\t});\n\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\t_parameterBindings.push({\n\t\t\t\t\t\t\t\ttype: e.type,\n\t\t\t\t\t\t\t\tvalue: parseValue(e.type, value)\n\t\t\t\t\t\t\t});\n\t\t\t\t\t\t}\n\t\t\t\t\t\taddedPropertiesKeys.push(e.name);\n\t\t\t\t\t}\n\t\t\t\t});\n\t\t\t}\n\t\t\tif (parameterBindings.$filter.notEquals) {\n\t\t\t\tconst propertiesKeys = Object.keys(parameterBindings.$filter.notEquals);\n\t\t\t\tconst addedPropertiesKeys = [];\n\t\t\t\tparameters.forEach(e => {\n\t\t\t\t\tif (propertiesKeys.includes(e.name) && !addedPropertiesKeys.includes(e.name)) {\n\t\t\t\t\t\tconst value = parameterBindings.$filter.notEquals[e.name];\n\t\t\t\t\t\tif (Array.isArray(value)) {\n\t\t\t\t\t\t\tvalue.forEach(v => {\n\t\t\t\t\t\t\t\t_parameterBindings.push({\n\t\t\t\t\t\t\t\t\ttype: e.type,\n\t\t\t\t\t\t\t\t\tvalue: parseValue(e.type, v)\n\t\t\t\t\t\t\t\t});\n\t\t\t\t\t\t\t});\n\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\t_parameterBindings.push({\n\t\t\t\t\t\t\t\ttype: e.type,\n\t\t\t\t\t\t\t\tvalue: parseValue(e.type, value)\n\t\t\t\t\t\t\t});\n\t\t\t\t\t\t}\n\t\t\t\t\t\taddedPropertiesKeys.push(e.name);\n\t\t\t\t\t}\n\t\t\t\t});\n\t\t\t}\n\t\t\tif (parameterBindings.$filter.contains) {\n\t\t\t\tconst propertiesKeys = Object.keys(parameterBindings.$filter.contains);\n\t\t\t\tconst addedPropertiesKeys = [];\n\t\t\t\tparameters.forEach(e => {\n\t\t\t\t\tif (propertiesKeys.includes(e.name) && !addedPropertiesKeys.includes(e.name)) {\n\t\t\t\t\t\t_parameterBindings.push({\n\t\t\t\t\t\t\ttype: e.type,\n\t\t\t\t\t\t\tvalue: `%${parameterBindings.$filter.contains[e.name]}%`\n\t\t\t\t\t\t});\n\t\t\t\t\t\taddedPropertiesKeys.push(e.name);\n\t\t\t\t\t}\n\t\t\t\t});\n\t\t\t}\n\t\t\tif (parameterBindings.$filter.greaterThan) {\n\t\t\t\tconst propertiesKeys = Object.keys(parameterBindings.$filter.greaterThan);\n\t\t\t\tconst addedPropertiesKeys = [];\n\t\t\t\tparameters.forEach(e => {\n\t\t\t\t\tif (propertiesKeys.includes(e.name) && !addedPropertiesKeys.includes(e.name)) {\n\t\t\t\t\t\t_parameterBindings.push({\n\t\t\t\t\t\t\ttype: e.type,\n\t\t\t\t\t\t\tvalue: parseValue(e.type, parameterBindings.$filter.greaterThan[e.name])\n\t\t\t\t\t\t});\n\t\t\t\t\t\taddedPropertiesKeys.push(e.name);\n\t\t\t\t\t}\n\t\t\t\t});\n\t\t\t}\n\t\t\tif (parameterBindings.$filter.lessThan) {\n\t\t\t\tconst propertiesKeys = Object.keys(parameterBindings.$filter.lessThan);\n\t\t\t\tconst addedPropertiesKeys = [];\n\t\t\t\tparameters.forEach(e => {\n\t\t\t\t\tif (propertiesKeys.includes(e.name) && !addedPropertiesKeys.includes(e.name)) {\n\t\t\t\t\t\t_parameterBindings.push({\n\t\t\t\t\t\t\ttype: e.type,\n\t\t\t\t\t\t\tvalue: parseValue(e.type, parameterBindings.$filter.lessThan[e.name])\n\t\t\t\t\t\t});\n\t\t\t\t\t\taddedPropertiesKeys.push(e.name);\n\t\t\t\t\t}\n\t\t\t\t});\n\t\t\t}\n\t\t\tif (parameterBindings.$filter.greaterThanOrEqual) {\n\t\t\t\tconst propertiesKeys = Object.keys(parameterBindings.$filter.greaterThanOrEqual);\n\t\t\t\tconst addedPropertiesKeys = [];\n\t\t\t\tparameters.forEach(e => {\n\t\t\t\t\tif (propertiesKeys.includes(e.name) && !addedPropertiesKeys.includes(e.name)) {\n\t\t\t\t\t\t_parameterBindings.push({\n\t\t\t\t\t\t\ttype: e.type,\n\t\t\t\t\t\t\tvalue: parseValue(e.type, parameterBindings.$filter.greaterThanOrEqual[e.name])\n\t\t\t\t\t\t});\n\t\t\t\t\t\taddedPropertiesKeys.push(e.name);\n\t\t\t\t\t}\n\t\t\t\t});\n\t\t\t}\n\t\t\tif (parameterBindings.$filter.lessThanOrEqual) {\n\t\t\t\tconst propertiesKeys = Object.keys(parameterBindings.$filter.lessThanOrEqual);\n\t\t\t\tconst addedPropertiesKeys = [];\n\t\t\t\tparameters.forEach(e => {\n\t\t\t\t\tif (propertiesKeys.includes(e.name) && !addedPropertiesKeys.includes(e.name)) {\n\t\t\t\t\t\t_parameterBindings.push({\n\t\t\t\t\t\t\ttype: e.type,\n\t\t\t\t\t\t\tvalue: parseValue(e.type, parameterBindings.$filter.lessThanOrEqual[e.name])\n\t\t\t\t\t\t});\n\t\t\t\t\t\taddedPropertiesKeys.push(e.name);\n\t\t\t\t\t}\n\t\t\t\t});\n\t\t\t}\n\t\t}\n\n\t\t// Left for backward compatibility -> it seems that the find() method uses it, might be removed once refactored\n\t\tif (parameters && parameters.length > 0) {\n\t\t\tfor (var i = 0; i < parameters.length; i++) {\n\t\t\t\tvar val;\n\t\t\t\tif (parameterBindings) {\n\t\t\t\t\tif (Array.isArray(parameterBindings)) {\n\t\t\t\t\t\tval = parameterBindings[i];\n\t\t\t\t\t} else {\n\t\t\t\t\t\tval = parameterBindings[parameters[i].name];\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t\tif ((val === null || val === undefined) && sql.toLowerCase().startsWith('select')) {\n\t\t\t\t\tcontinue;\n\t\t\t\t}\n\t\t\t\tconst index = i + 1;\n\t\t\t\tthis.$log.trace('Binding to parameter[{}]: {}', index, val);\n\t\t\t\t_parameterBindings.push({\n\t\t\t\t\t\"type\": parameters[i].type,\n\t\t\t\t\t\"value\": parseValue(parameters[i].type, val)\n\t\t\t\t});\n\t\t\t}\n\t\t}\n\n\t\tlet result;\n\n\t\tif (sql.toLowerCase().startsWith('select')) {\n\t\t\tresult = Query.execute(sql, _parameterBindings, dataSourceName);\n\t\t} else if (sql.toLowerCase().startsWith('insert')) {\n\t\t\tresult = Insert.execute(sql, _parameterBindings, dataSourceName);\n\t\t} else {\n\t\t\tresult = Update.execute(sql, _parameterBindings, dataSourceName);\n\t\t}\n\n\t\treturn result !== null ? result : [];\n\t};\n\n\tfunction parseValue(type, value) {\n\t\tswitch (type.toUpperCase()) {\n\t\t\tcase 'INTEGER':\n\t\t\t\treturn parseInt(value);\n\t\t\tcase 'DOUBLE':\n\t\t\tcase 'FLOAT':\n\t\t\t\treturn parseFloat(value);\n\t\t\tcase 'BOOLEAN':\n\t\t\t\treturn value ? 'true' : 'false';\n\t\t\tdefault:\n\t\t\t\treturn value;\n\t\t}\n\t}\n};\n\nDAO.prototype.notify = function (event) {\n\tconst func = this[event];\n\tif (!this[event])\n\t\treturn;\n\tif (typeof func !== 'function')\n\t\tthrow Error('Illegal argument. Not a function: ' + func);\n\tconst args = [].slice.call(arguments);\n\tfunc.apply(this, args.slice(1));\n};\n\n/**\n * Prepare a JSON object for insert into DB\n */\nDAO.prototype.createSQLEntity = function (entity) {\n\tlet i;\n\tconst persistentItem = {};\n\tconst mandatories = this.orm.getMandatoryProperties();\n\tfor (i = 0; i < mandatories.length; i++) {\n\t\tif (mandatories[i].dbValue) {\n\t\t\tpersistentItem[mandatories[i].name] = mandatories[i].dbValue.apply(this, [entity[mandatories[i].name], entity]);\n\t\t} else {\n\t\t\tpersistentItem[mandatories[i].name] = entity[mandatories[i].name];\n\t\t}\n\t}\n\tconst optionals = this.orm.getOptionalProperties();\n\tfor (i = 0; i < optionals.length; i++) {\n\t\tif (optionals[i].dbValue !== undefined) {\n\t\t\tpersistentItem[optionals[i].name] = optionals[i].dbValue.apply(this, [entity[optionals[i].name], entity]);\n\t\t} else {\n\t\t\tpersistentItem[optionals[i].name] = entity[optionals[i].name] === undefined ? null : entity[optionals[i].name];\n\t\t}\n\t}\n\treturn persistentItem;\n};\n\n/**\n * Create entity as JSON object from ResultSet current Row\n */\nDAO.prototype.createEntity = function (resultSetEntry, entityPropertyNames) {\n\tconst entity = {};\n\tlet properties = this.orm.properties;\n\tif (entityPropertyNames && entityPropertyNames.length > 0) {\n\t\tproperties = properties.filter(function (prop) {\n\t\t\treturn entityPropertyNames.indexOf(prop.name) > -1;\n\t\t});\n\t}\n\tfor (let i = 0; i < properties.length; i++) {\n\t\tconst prop = properties[i];\n\t\tentity[prop.name] = resultSetEntry[prop.columnName];\n\t\tif (prop.value) {\n\t\t\tentity[prop.name] = prop.value(entity[prop.name]);\n\t\t}\n\t}\n\tObject.keys(entity).forEach(function (propertyName) {\n\t\tif (entity[propertyName] === null)\n\t\t\tentity[propertyName] = undefined;\n\t});\n\n\tlet entitySegment = \"\";\n\tif (entity[this.orm.getPrimaryKey().name]) {\n\t\tentitySegment = \"[\" + entity[this.orm.getPrimaryKey().name] + \"]\";\n\t}\n\t// this.$log.trace(\"Transformation from {} DB JSON object finished\", (this.orm.table + entitySegment));\n\treturn entity;\n};\n\nDAO.prototype.validateEntity = function (entity, skip) {\n\tif (entity === undefined || entity === null) {\n\t\tthrow new Error('Illegal argument: entity is ' + entity);\n\t}\n\tif (skip) {\n\t\tif (skip.constructor !== Array) {\n\t\t\tskip = [skip];\n\t\t}\n\t\tfor (var j = 0; j < skip.length; j++) {\n\t\t\tskip[j];\n\t\t}\n\t}\n\tconst mandatories = this.orm.getMandatoryProperties();\n\tfor (let i = 0; i < mandatories.length; i++) {\n\t\tconst propName = mandatories[i].name;\n\t\tif ((skip && skip.indexOf(propName) > -1) || mandatories[i].type.toUpperCase() === 'BOOLEAN')\n\t\t\tcontinue;\n\t\tconst propValue = entity[propName];\n\t\tif (propValue === undefined || propValue === null) {\n\t\t\tthrow new Error('Illegal ' + propName + ' attribute value in ' + this.orm.table + ' entity: ' + propValue);\n\t\t}\n\t}\n};\n\nDAO.prototype.insert = function (_entity) {\n\n\tconst ids = [];\n\tlet entities = _entity;\n\tif (_entity.constructor !== Array) {\n\t\tentities = [_entity];\n\t}\n\n\tthis.$log.trace('Inserting {} {}', this.orm.table, (entities.length === 1 ? 'entity' : 'entities'));\n\n\tfor (let i = 0; i < entities.length; i++) {\n\t\tlet entity = entities[i];\n\t\tentity = entities[i];\n\n\t\tthis.validateEntity(entity, [this.orm.getPrimaryKey().name]);\n\n\t\t//check for unique constraint violations\n\t\tconst uniques = this.orm.getUniqueProperties();\n\t\tfor (let _i = 0; _i < uniques.length; _i++) {\n\t\t\tconst prop = uniques[_i];\n\t\t\tconst st = this.ormstatements.dialect\n\t\t\t\t.select(prop.column)\n\t\t\t\t.from(this.orm.table)\n\t\t\t\t.where(prop.column + '=?', [prop]);\n\t\t\tconst params = {};\n\t\t\tparams[prop.name] = entity[prop.name];\n\t\t\tconst rs = this.execute(st, params);\n\t\t\tif (rs.length > 0)\n\t\t\t\tthrow Error('Unique constraint violation for ' + prop.name + '[' + entity[prop.name] + ']');\n\t\t}\n\n\t\tconst dbEntity = this.createSQLEntity(entity);\n\n\t\ttry {\n\t\t\tconst parametericStatement = this.ormstatements.insert.apply(this.ormstatements);\n\n\t\t\tif (this.orm.isAutoIncrementPrimaryKey()) {\n\t\t\t\tconst id = this.generateId();\n\t\t\t\tdbEntity[this.orm.getPrimaryKey().name] = id;\n\t\t\t}\n\n\t\t\tconst updatedRecordCount = this.execute(parametericStatement, dbEntity);\n\n\t\t\tif (!this.orm.isAutoIncrementPrimaryKey() && isNotEmptyArray(updatedRecordCount)) {\n\t\t\t\tconst id = updatedRecordCount[0];\n\t\t\t\tdbEntity[this.orm.getPrimaryKey().name] = id;\n\t\t\t}\n\n\t\t\tthis.notify('afterInsert', dbEntity);\n\t\t\tthis.notify('beforeInsertAssociationSets', dbEntity);\n\t\t\tif ((updatedRecordCount > 0 || isNotEmptyArray(updatedRecordCount)) && this.orm.associations && Object.keys(this.orm.associations).length) {\n\t\t\t\t//Insert dependencies if any are provided inline with this entity\n\t\t\t\tthis.$log.trace('Inserting association sets for {}[{}]', this.orm.table, dbEntity[this.orm.getPrimaryKey().name]);\n\t\t\t\tfor (const idx in Object.keys(this.orm.associations)) {\n\t\t\t\t\tconst association = this.orm.associations[idx];\n\t\t\t\t\tconst associationName = association['name'];\n\t\t\t\t\tif ([this.orm.ASSOCIATION_TYPES['MANY-TO-MANY'], this.orm.ASSOCIATION_TYPES['MANY-TO-ONE']].indexOf(association.type) < 0) {\n\t\t\t\t\t\tif (entity[associationName] && entity[associationName].length > 0) {\n\t\t\t\t\t\t\tconst associationDaoFactoryFunc = association.targetDao || this;\n\t\t\t\t\t\t\tif (associationDaoFactoryFunc.constructor !== Function)\n\t\t\t\t\t\t\t\tthrow Error('Invalid ORM: Association ' + associationName + ' dao property is expected to be function. Instead, it is: ' + (typeof associationDaoFactoryFunc))\n\t\t\t\t\t\t\tconst associationDAO = associationDaoFactoryFunc.apply(this);\n\t\t\t\t\t\t\tthis.notify('beforeInsertAssociationSet', entity[associationName], entity);\n\t\t\t\t\t\t\tthis.$log.trace('Inserting {} inline entities into association set {}', entity[associationName].length, associationName);\n\t\t\t\t\t\t\tfor (let j = 0; j < entity[associationName].length; j++) {\n\t\t\t\t\t\t\t\tconst associatedEntity = entity[associationName][j];\n\t\t\t\t\t\t\t\tconst associatedEntityJoinKey = association.joinKey;\n\t\t\t\t\t\t\t\tconst key = association.key || this.orm.getPrimaryKey().name;\n\t\t\t\t\t\t\t\tassociatedEntity[associatedEntityJoinKey] = entity[key];\n\t\t\t\t\t\t\t\tthis.notify('beforeInsertAssociationSetEntity', entity[associationName], dbEntity);\n\n\t\t\t\t\t\t\t\tassociationDAO.insert.apply(associationDAO, [associatedEntity]);\n\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\tthis.$log.trace('Inserting {} inline entities into association set {} finsihed', entity[associationName].length, associationName);\n\t\t\t\t\t\t\tthis.notify('afterInsertAssociationSet', entity[associationName], dbEntity);\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tif (updatedRecordCount > 0 || isNotEmptyArray(updatedRecordCount)) {\n\t\t\t\tids.push(dbEntity[this.orm.getPrimaryKey().name]);\n\t\t\t\tthis.$log.trace('{}[] entity inserted', this.orm.table, dbEntity[this.orm.getPrimaryKey().name]);\n\t\t\t} else {\n\t\t\t\tthis.$log.trace('No changes incurred in {}', this.orm.table);\n\t\t\t}\n\n\n\t\t} catch (e) {\n\t\t\tthis.$log.error(\"Inserting {} {} failed\", this.orm.table, (entities.length === 1 ? 'entity' : 'entities'), e);\n\t\t\tthis.$log.trace('Rolling back changes after failed {}[{}] insert. ', this.orm.table, dbEntity[this.orm.getPrimaryKey().name]);\n\t\t\tif (dbEntity[this.orm.getPrimaryKey().name]) {\n\t\t\t\ttry {\n\t\t\t\t\tthis.remove(dbEntity[this.orm.getPrimaryKey().name]);\n\t\t\t\t} catch (err) {\n\t\t\t\t\tthis.$log.error('Could not rollback changes after failed {}[{}] insert. ', this.orm.table, dbEntity[this.orm.getPrimaryKey().name], err);\n\t\t\t\t}\n\t\t\t}\n\t\t\tthrow e;\n\t\t}\n\t}\n\n\tif (_entity.constructor !== Array)\n\t\treturn ids[0];\n\telse\n\t\treturn ids;\n};\n\nfunction isNotEmptyArray(array) {\n\treturn Array.isArray(array) && array.length > 0;\n}\n\n/**\n * Update entity from a JSON object. Returns the id of the updated entity.\n */\nDAO.prototype.update = function (entity) {\n\n\tthis.$log.trace('Updating {}[{}] entity', this.orm.table, entity !== undefined ? entity[this.orm.getPrimaryKey().name] : entity);\n\n\tif (entity === undefined || entity === null) {\n\t\tthrow new Error('Illegal argument: entity is ' + entity);\n\t}\n\n\tconst ignoredProperties = this.orm.getMandatoryProperties()\n\t\t.filter(function (property) {\n\t\t\treturn property.allowedOps && property.allowedOps.indexOf('update') < 0;\n\t\t})\n\t\t.map(function (property) {\n\t\t\treturn property.name;\n\t\t});\n\tthis.validateEntity(entity, ignoredProperties);\n\n\tconst parametericStatement = this.ormstatements.update.apply(this.ormstatements, [entity]);\n\n\tconst dbEntity = this.createSQLEntity(entity);\n\n\ttry {\n\t\tthis.notify('beforeUpdateEntity', dbEntity);\n\t\tconst updatedRecordsCount = this.execute(parametericStatement, dbEntity);\n\t\tif (updatedRecordsCount > 0)\n\t\t\tthis.$log.trace('{}[{}] entity updated', this.orm.table, dbEntity[this.orm.getPrimaryKey().name]);\n\t\telse\n\t\t\tthis.$log.trace('No changes incurred in {}', this.orm.table);\n\n\t\treturn this;\n\n\t} catch (e) {\n\t\tthis.$log.error('Updating {}[{}] failed', this.orm.table, entity !== undefined ? entity[this.orm.getPrimaryKey().name] : entity, e);\n\t\tthrow e;\n\t}\n};\n\n/**\n * Delete entity by id, or array of ids, or delete all (if not argument is provided)\n */\nDAO.prototype.remove = function () {\n\n\tlet ids = [];\n\tif (arguments.length === 0) {\n\t\tids = this.list({\n\t\t\t\"$select\": [this.orm.getPrimaryKey().name]\n\t\t}).map(function (ent) {\n\t\t\treturn ent[this.orm.getPrimaryKey().name];\n\t\t}.bind(this));\n\t} else {\n\t\tif (arguments[0].constructor !== Array) {\n\t\t\tids = [arguments[0]];\n\t\t} else {\n\t\t\tids = arguments[0];\n\t\t}\n\t}\n\n\tthis.$log.trace('Deleting ' + this.orm.table + ((ids !== undefined && ids.length === 1) ? '[' + ids[0] + '] entity' : ids.length + ' entities'));\n\n\tfor (let i = 0; i < ids.length; i++) {\n\n\t\tlet id = ids[i];\n\t\t//prevent implicit type convertion\n\t\tif (this.orm.getPrimaryKey().type.toUpperCase() !== 'VARCHAR')\n\t\t\tid = parseInt(id, 10);\n\n\t\tif (ids.length > 1)\n\t\t\tthis.$log.trace('Deleting {}[{}] entity', this.orm.table, id);\n\n\t\tif (id === undefined || id === null) {\n\t\t\tthrow new Error('Illegal argument for id parameter:' + id);\n\t\t}\n\n\t\ttry {\n\n\t\t\tthis.notify('beforeRemoveEntity', id);\n\n\t\t\t//first we attempt to remove depndents if any\n\t\t\tif (this.orm.associations) {\n\t\t\t\t//Remove associated dependencies\n\t\t\t\tfor (const idx in Object.keys(this.orm.associations)) {\n\t\t\t\t\tconst association = this.orm.associations[idx];\n\t\t\t\t\tconst associationName = association['name'];\n\t\t\t\t\tif ([this.orm.ASSOCIATION_TYPES['MANY-TO-MANY'], this.orm.ASSOCIATION_TYPES['MANY-TO-ONE']].indexOf(association.type) < 0) {\n\t\t\t\t\t\tthis.$log.trace(\"Inspecting {}[{}}] entity's dependency '{}' for entities to delete.\", this.orm.table, id, associationName);\n\t\t\t\t\t\tconst associationDAO = association.targetDao ? association.targetDao() : this;\n\t\t\t\t\t\tconst settings = {};\n\t\t\t\t\t\tlet joinId = id;\n\t\t\t\t\t\t//check if we are joining on field, other than pk\n\t\t\t\t\t\tif (association.key !== undefined) {\n\t\t\t\t\t\t\tvar ctxEntity = this.find(id);\n\t\t\t\t\t\t\tjoinId = ctxEntity[association.key];\n\t\t\t\t\t\t}\n\t\t\t\t\t\tsettings[association.joinKey] = joinId;\n\t\t\t\t\t\tlet associatedEntities;\n\t\t\t\t\t\t//associatedEntities = this.expand(associationName, id);\n\t\t\t\t\t\tassociatedEntities = associationDAO.list(settings);\n\t\t\t\t\t\tif (associatedEntities && associatedEntities.length > 0) {\n\t\t\t\t\t\t\tthis.$log.trace(\"Deleting {}[{}] entity's {} dependent {}\", this.orm.table, id, associatedEntities.length, associationName);\n\t\t\t\t\t\t\tthis.notify('beforeRemoveAssociationSet', associatedEntities, id);\n\t\t\t\t\t\t\tfor (let j = 0; j < associatedEntities.length; j++) {\n\t\t\t\t\t\t\t\tconst associatedEntity = associatedEntities[j];\n\t\t\t\t\t\t\t\tthis.notify('beforeRemoveAssociationSetEntity', associatedEntity, associatedEntities, id);\n\n\t\t\t\t\t\t\t\tassociationDAO.remove.apply(associationDAO, [associatedEntity[associationDAO.orm.getPrimaryKey().name]]);\n\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\tthis.$log.trace(\"{}[{}] entity's {} dependent {} {} deleted.\", this.orm.table, id, associatedEntities.length, associationName, associatedEntities.length > 1 ? 'entities' : 'entity');\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t\t//Delete by primary key value\n\t\t\tconst parametericStatement = this.ormstatements[\"delete\"].apply(this.ormstatements, [this.orm.getPrimaryKey().name]);\n\t\t\tlet params = {};\n\t\t\tparams[this.orm.getPrimaryKey().name] = id;\n\n\t\t\tconst updatedRecordsCount = this.execute(parametericStatement, params);\n\n\t\t\tif (updatedRecordsCount > 0)\n\t\t\t\tthis.$log.trace('{}[{}] entity deleted', this.orm.table, id);\n\t\t\telse\n\t\t\t\tthis.$log.trace('No changes incurred in {}', this.orm.table);\n\n\t\t} catch (e) {\n\t\t\tthis.$log.error('Deleting {}[{}] entity failed',this.orm.table, id, e);\n\t\t\tthrow e;\n\t\t}\n\n\t}\n\n};\n\nDAO.prototype.expand = function (expansionPath, context) {\n\tlet i;\n\tlet settings;\n\tlet key;\n\tlet joinId;\n\tthis.$log.trace('Expanding for association path {} and context entity {}', expansionPath, (typeof arguments[1] !== 'object' ? 'id ' : '') + JSON.stringify(arguments[1]));\n\tif (!expansionPath || !expansionPath.length) {\n\t\tthrow new Error('Illegal argument: expansionPath[' + expansionPath + ']');\n\t}\n\tif (!context) {\n\t\tthrow new Error('Illegal argument: context[' + context + ']');\n\t}\n\tconst associationName = expansionPath.splice ? expansionPath.splice(0, 1)[0] : expansionPath;\n\tconst association = this.orm.getAssociation(associationName);\n\tif (!associationName || !association)\n\t\tthrow new Error('Illegal argument: Unknown association for this DAO [' + associationName + ']');\n\tconst joinKey = association.joinKey;\n\n\tlet contextEntity;\n\tif (context[this.orm.getPrimaryKey().name] !== undefined) {\n\t\tcontextEntity = context;\n\t} else {\n\t\tcontextEntity = this.find(context);\n\t}\n\n\tif (!contextEntity) {\n\t\tthrow Error('No record found for context entity [' + context + ']');\n\t}\n\n\tconst associationTargetDAO = association.targetDao ? association.targetDao.apply(this) : this;\n\tif (!associationTargetDAO)\n\t\tthrow Error('No target association DAO instance available for association ' + associationName);\n\n\tlet expansion;\n\tlet associationEntities = [];\n\n\tif (association.type === this.orm.ASSOCIATION_TYPES['ONE-TO-ONE'] || association.type === this.orm.ASSOCIATION_TYPES['MANY-TO-ONE']) {\n\t\tjoinId = contextEntity[joinKey];\n\t\tthis.$log.trace('Expanding association type {} on {}[{}]', association.type, joinKey, joinId);\n\t\tif (!association.key || association.key === associationTargetDAO.orm.getPrimaryKey().name)\n\t\t\texpansion = associationTargetDAO.find.apply(associationTargetDAO, [joinId]);\n\t\telse {\n\t\t\tlet listSettings = {};\n\t\t\tlistSettings[\"$filter\"] = association.key;\n\t\t\tlistSettings[association.key] = joinId;\n\t\t\texpansion = associationTargetDAO.list.apply(associationTargetDAO, [listSettings])[0];\n\t\t}\n\n\t\tif (expansionPath.length > 0) {\n\t\t\tthis.expand(expansionPath, expansion);\n\t\t}\n\t} else if (association.type === this.orm.ASSOCIATION_TYPES['ONE-TO-MANY']) {\n\t\tsettings = {};\n\t\tif (association.defaults)\n\t\t\tsettings = association.defaults;\n\t\tkey = association.key || this.orm.getPrimaryKey().name;\n\t\tjoinId = contextEntity[key];\n\t\tthis.$log.trace('Expanding association type {} on {}[{}]', association.type, joinKey, joinId);\n\t\tsettings[joinKey] = joinId;\n\t\tassociationEntities = associationEntities.concat(associationTargetDAO.list.apply(associationTargetDAO, [settings]));\n\n\t\tif (expansionPath.length > 0) {\n\t\t\tfor (i = 0; i < associationEntities.length; i++) {\n\t\t\t\tthis.expand(expansionPath, associationEntities[i]);\n\t\t\t}\n\t\t} else {\n\t\t\texpansion = associationEntities;\n\t\t}\n\t} else if (association.type === this.orm.ASSOCIATION_TYPES['MANY-TO-MANY']) {\n\t\tconst joinDAO = association.joinDao();\n\t\tif (!joinDAO)\n\t\t\tthrow Error('No join DAO instance available for association ' + associationName);\n\t\tif (!joinDAO.listJoins)\n\t\t\tthrow Error('No listJoins function in join DAO instance available for association ' + associationName);\n\t\tsettings = {};\n\t\tkey = association.key || this.orm.getPrimaryKey().name;\n\t\tjoinId = contextEntity[key];\n\t\tsettings[association.joinKey] = joinId;\n\t\tassociationEntities = associationEntities.concat(joinDAO.listJoins.apply(joinDAO, [settings, { \"sourceDao\": this, \"joinDao\": joinDAO, \"targetDao\": associationTargetDAO }]));\n\t\tif (expansionPath.length > 0) {\n\t\t\tfor (i = 0; i < associationEntities.length; i++) {\n\t\t\t\tthis.expand(expansionPath, associationEntities[i]);\n\t\t\t}\n\t\t} else {\n\t\t\texpansion = associationEntities;\n\t\t}\n\t}\n\treturn expansion;\n};\n\n/**\n * Reads a single entity by id, parsed into JSON object.\n * If requested as expanded the returned entity will comprise associated (dependent) entities too. \n * Expand can be a string tha tis a valid association name defined in this dao orm or an array of such names.\n */\nDAO.prototype.find = function (id, expand, select) {\n\tif (typeof arguments[0] === 'object') {\n\t\tid = arguments[0].id;\n\t\texpand = arguments[0].$expand || arguments[0].expand;\n\t\tselect = arguments[0].$select || arguments[0].select;\n\t}\n\n\tthis.$log.trace('Finding {}[{}] entity with list parameters expand[{}], select[{}]', this.orm.table, id, expand, select);\n\n\tif (id === undefined || id === null) {\n\t\tthrow new Error('Illegal argument for id parameter:' + id);\n\t}\n\n\ttry {\n\t\tlet entity;\n\t\tif (select !== undefined) {\n\t\t\tif (select.constructor !== Array) {\n\t\t\t\tif (select.constructor === String) {\n\t\t\t\t\tselect = select.split(',').map(function (sel) {\n\t\t\t\t\t\tif (sel.constructor !== String)\n\t\t\t\t\t\t\tthrow Error('Illegal argument: select array components are expected ot be strings but found ' + (typeof sel));\n\t\t\t\t\t\treturn sel.trim();\n\t\t\t\t\t});\n\t\t\t\t} else {\n\t\t\t\t\tthrow Error('Illegal argument: select is expected to be string or array of strings but was ' + (typeof select));\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t\t//ensure that joinkeys for required expands are available and not filtered by select\n\t\tif (select !== undefined && expand !== undefined) {\n\t\t\tselect.push(this.orm.getPrimaryKey().name);\n\t\t\t//TODO: checks\n\t\t\t/*for(var i in expand){\n\t\t\t\tvar association = this.orm.associations[expand[i]];\n\t\t\t\tif(association && select.indexOf(association.joinKey)<1){\n\t\t\t\t\tselect.push(association.joinKey);\n\t\t\t\t}\n\t\t\t}*/\n\t\t}\n\t\tlet findQbParams = {\n\t\t\tselect: select\n\t\t};\n\t\tconst parametericStatement = this.ormstatements.find.apply(this.ormstatements, [findQbParams]);\n\t\tlet params = {};\n\n\t\t//prevent implicit type convertion\n\t\tif (this.orm.getPrimaryKey().type.toUpperCase() !== 'VARCHAR')\n\t\t\tid = parseInt(id, 10);\n\n\t\tparams[this.orm.getPrimaryKey().name] = id;\n\t\tconst resultSet = this.execute(parametericStatement, params);\n\n\t\tif (resultSet[0]) {\n\t\t\tentity = this.createEntity(resultSet[0], select);\n\t\t\tif (entity) {\n\t\t\t\tthis.$log.trace('{}[{}] entity found', this.orm.table, id);\n\t\t\t\tthis.notify('afterFound', entity);\n\t\t\t\tif (expand !== undefined) {\n\t\t\t\t\tif (expand.constructor !== Array) {\n\t\t\t\t\t\tif (expand.constructor === String) {\n\t\t\t\t\t\t\texpand = String(expand);\n\t\t\t\t\t\t\texpand = expand.split(',').map(function (exp) {\n\t\t\t\t\t\t\t\tif (exp.constructor !== String)\n\t\t\t\t\t\t\t\t\tthrow Error('Illegal argument: expand array components are expected ot be strings but found ' + (typeof exp));\n\t\t\t\t\t\t\t\treturn exp.trim();\n\t\t\t\t\t\t\t});\n\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\tthrow Error('Illegal argument: expand is expected to be string or array of strings but was ' + (typeof expand));\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t\tvar associationNames = this.orm.getAssociationNames();\n\t\t\t\t\tfor (var idx in associationNames) {\n\t\t\t\t\t\tvar associationName = associationNames[idx];\n\t\t\t\t\t\tif (expand.indexOf(associationName) > -1) {\n\t\t\t\t\t\t\tentity[associationName] = this.expand([associationName], entity);\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t} else {\n\t\t\t\tthis.$log.trace('{}[{}] entity not found', this.orm.table, id);\n\t\t\t}\n\t\t}\n\t\treturn entity;\n\t} catch (e) {\n\t\tthis.$log.error(\"Finding {}[{}] entity failed.\", this.orm.table, id, e);\n\t\tthrow e;\n\t}\n};\n\nDAO.prototype.count = function (settings?) {\n\tsettings = settings || {};\n\n\tconst parametericStatement = this.ormstatements.count.apply(this.ormstatements, [settings]);\n\tthis.$log.trace('Counting ' + this.orm.table + ' entities');\n\n\tlet count = 0;\n\ttry {\n\t\tconst rs = this.execute(parametericStatement, settings);\n\t\tif (rs.length > 0) {\n\t\t\t//expectaion is that there is a single object in the result set with a single porperty\n\t\t\tconst key = Object.keys(rs[0])[0];\n\t\t\tcount = parseInt(rs[0][key], 10);\n\t\t}\n\t} catch (e) {\n\t\tthis.$log.error('Counting {} entities failed', this.orm.table, e);\n\t\te.errContext = parametericStatement.toString();\n\t\tthrow e;\n\t}\n\n\tthis.$log.trace('{} {} entities counted', String(count), this.orm.table);\n\n\treturn count;\n};\n\n/*\n * list parameters:\n * - $expand\n * - $filter\n * - $select\n * - $sort\n * - $order\n * - $limit\n * - $offset\n */\nDAO.prototype.list = function (settings) {\n\n\tlet key;\n\tsettings = settings || {};\n\n\tconst expand = settings.$expand || settings.expand;\n\tif (expand !== undefined) {\n\t\tif (expand.constructor !== Array) {\n\t\t\tif (expand.constructor === String) {\n\t\t\t\tif (expand.indexOf(',') > -1) {\n\t\t\t\t\tsettings.$expand = expand.split(',').map(function (exp) {\n\t\t\t\t\t\tif (exp.constructor !== String)\n\t\t\t\t\t\t\tthrow Error('Illegal argument: expand array components are expected ot be strings but found ' + (typeof exp));\n\t\t\t\t\t\treturn exp.trim();\n\t\t\t\t\t});\n\t\t\t\t} else {\n\t\t\t\t\tsettings.$expand = [expand];\n\t\t\t\t}\n\t\t\t} else {\n\t\t\t\tthrow Error('Illegal argument: expand is expected to be string or array of strings but was ' + (typeof expand));\n\t\t\t}\n\t\t}\n\t}\n\n\tconst select = settings.$select || settings.select;\n\tif (select !== undefined) {\n\t\tif (select.constructor !== Array) {\n\t\t\tif (select.constructor === String) {\n\t\t\t\tif (select.indexOf(',') > -1) {\n\t\t\t\t\tsettings.$select = select.split(',').map(function (exp) {\n\t\t\t\t\t\tif (exp.constructor !== String)\n\t\t\t\t\t\t\tthrow Error('Illegal argument: select array components are expected ot be strings but found ' + (typeof exp));\n\t\t\t\t\t\treturn exp.trim();\n\t\t\t\t\t});\n\t\t\t\t} else {\n\t\t\t\t\tsettings.$select = [select];\n\t\t\t\t}\n\t\t\t} else {\n\t\t\t\tthrow Error('Illegal argument: select is expected to be string or array of strings but was ' + (typeof expand));\n\t\t\t}\n\t\t}\n\t}\n\n\n\tconst listArgs = [];\n\tfor (key in settings) {\n\t\tlistArgs.push(' ' + key + '[' + settings[key] + ']');\n\t}\n\n\tthis.$log.trace('Listing {} entity collection with list operators: {}', this.orm.table, listArgs.join(','));\n\n\tif (settings.$select !== undefined && expand !== undefined) {\n\t\tsettings.$select.push(this.orm.getPrimaryKey().name);\n\t}\n\n\tvar parametericStatement = this.ormstatements.list.apply(this.ormstatements, [settings]);\n\n\ttry {\n\t\tlet entities = [];\n\n\t\tconst resultSet = this.execute(parametericStatement, settings);\n\n\t\tresultSet.forEach(function (rsEntry) {\n\t\t\tvar entity = this.createEntity(rsEntry, settings.$select);\n\t\t\tif (expand) {\n\t\t\t\tvar associationNames = this.orm.getAssociationNames();\n\t\t\t\tfor (var idx = 0; idx < associationNames.length; idx++) {\n\t\t\t\t\tvar associationName = associationNames[idx];\n\t\t\t\t\tif (expand.indexOf(associationName) > -1) {\n\t\t\t\t\t\tentity[associationName] = this.expand([associationName], entity);\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t\tthis.notify('afterFound', entity, settings);\n\t\t\tentities.push(entity);\n\t\t}.bind(this));\n\n\t\tthis.$log.trace('{} {} entities found', entities.length, this.orm.table);\n\n\t\treturn entities;\n\t} catch (e) {\n\t\tthis.$log.error(\"Listing {} entities failed.\", this.orm.table, e);\n\t\tthrow e;\n\t}\n};\n\nDAO.prototype.existsTable = function () {\n\tthis.$log.trace('Check exists table ' + this.orm.table);\n\ttry {\n\t\tconst parametericStatement = this.ormstatements.count.apply(this.ormstatements);\n\t\tconst rs = this.execute(parametericStatement);\n\t\treturn rs.length > 0;\n\t} catch (e) {\n\t\treturn false;\n\t}\n};\n\nDAO.prototype.createTable = function () {\n\tthis.$log.trace('Creating table {}', this.orm.table);\n\tconst parametericStatement = this.ormstatements.createTable.apply(this.ormstatements);\n\ttry {\n\t\tthis.execute(parametericStatement);\n\t\tthis.$log.trace('{} table created', this.orm.table);\n\t\treturn this;\n\t} catch (e) {\n\t\tthis.$log.error(\"Create table {} failed\", this.orm.table, e);\n\t\tthrow e;\n\t}\n};\n\nDAO.prototype.dropTable = function (dropIdSequence) {\n\tthis.$log.trace('Dropping table {}.', this.orm.table);\n\tconst parametericStatement = this.ormstatements.dropTable.apply(this.ormstatements);\n\ttry {\n\t\tthis.execute(parametericStatement);\n\t\tthis.$log.trace('Table {} dropped.', this.orm.table);\n\t} catch (e) {\n\t\tthis.$log.error(\"Dropping table {} failed.\", this.orm.table, e);\n\t\tthrow e;\n\t}\n\n\tif (dropIdSequence) {\n\t\tthis.$log.trace('Dropping table {} sequence {}.', this.orm.table, this.sequenceName);\n\t\ttry {\n\t\t\tthis.dropIdGenerator();\n\t\t\tthis.$log.trace('Table {} sequence {} dropped.', this.orm.table, this.sequenceName);\n\t\t} catch (e) {\n\t\t\tthis.$log.error(\"Dropping table {} sequence {} failed.\", this.orm.table, this.sequenceName, e);\n\t\t\tthrow e;\n\t\t}\n\t}\n\n\treturn this;\n};\n\n\n/**\n * oDefinition can be table definition or standard orm definition object. Or it can be a valid path to\n * a .table file, or any other text file contianing a standard dao orm definition.\n */\nexport function create(oDefinition, logCtxName?: string, dataSourceName?: string) {\n\tlet orm;\n\torm = oDefinition;\n\n\tif (!dataSourceName || dataSourceName === null) {\n\t\tdataSourceName = configurations.get(\"DIRIGIBLE_DATABASE_DATASOURCE_NAME_DEFAULT\", \"DefaultDB\");\n\t}\n\n\tlet productName = globals.get(dataSourceName);\n\tif (!productName) {\n\t\tproductName = Database.getProductName(dataSourceName);\n\t\tglobals.set(dataSourceName, productName);\n\t}\n\n\t//\t}\n\treturn new DAO(orm, logCtxName, dataSourceName);\n};\n\nexport function dao(oDefinition, logCtxName?: string, dataSourceName?: string) {\n\treturn create(oDefinition, logCtxName, dataSourceName)\n}\n"],
  "mappings": "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",
  "names": ["getORM", "createORMStatements"]
}

|