@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,223 @@
|
|
|
1
|
+
import { Logging } from "@aerokit/sdk/log";
|
|
2
|
+
import { SQLBuilder } from "./sql";
|
|
3
|
+
function ORMStatements(orm, dialect) {
|
|
4
|
+
this.$log = Logging.getLogger("db.dao.ormstatements");
|
|
5
|
+
this.orm = orm;
|
|
6
|
+
this.orm.tableName = this.orm.table;
|
|
7
|
+
this.orm.properties.forEach(function(property) {
|
|
8
|
+
property.columnName = property.column;
|
|
9
|
+
});
|
|
10
|
+
this.dialect = dialect || SQLBuilder.getDialect();
|
|
11
|
+
}
|
|
12
|
+
;
|
|
13
|
+
ORMStatements.prototype.constructor = ORMStatements;
|
|
14
|
+
ORMStatements.prototype.createTable = function() {
|
|
15
|
+
const builder = this.dialect.create().table(this.orm.table);
|
|
16
|
+
this.orm.properties.forEach(function(property) {
|
|
17
|
+
const column = this.orm.toColumn(property);
|
|
18
|
+
if (property.type.toUpperCase() === "VARCHAR") {
|
|
19
|
+
if (property.length === void 0)
|
|
20
|
+
property.length = 255;
|
|
21
|
+
builder.columnVarchar(column.name, property.length, column.primaryKey === "true", column.nullable === "true", property.unique);
|
|
22
|
+
} else if (property.type.toUpperCase() === "CHAR") {
|
|
23
|
+
if (property.length === void 0)
|
|
24
|
+
property.length = 1;
|
|
25
|
+
property.length = parseInt(property.length, 10);
|
|
26
|
+
builder.columnChar(column.name, property.length, column.primaryKey === "true", column.nullable === "true", property.unique);
|
|
27
|
+
} else {
|
|
28
|
+
builder.column(column.name, column.type, column.primaryKey === "true", column.nullable === "true", property.unique);
|
|
29
|
+
}
|
|
30
|
+
}.bind(this));
|
|
31
|
+
return builder;
|
|
32
|
+
};
|
|
33
|
+
ORMStatements.prototype.dropTable = function() {
|
|
34
|
+
return this.dialect.drop().table(this.orm.table);
|
|
35
|
+
};
|
|
36
|
+
ORMStatements.prototype.insert = function() {
|
|
37
|
+
const builder = this.dialect.insert().into(this.orm.table);
|
|
38
|
+
this.orm.properties.forEach(function(property) {
|
|
39
|
+
builder.column(property.column).value("?", property);
|
|
40
|
+
});
|
|
41
|
+
return builder;
|
|
42
|
+
};
|
|
43
|
+
ORMStatements.prototype.update = function(entity) {
|
|
44
|
+
if (!entity)
|
|
45
|
+
throw Error("Illegal argument: entity[" + entity + "]");
|
|
46
|
+
const builder = this.dialect.update().table(this.orm.table);
|
|
47
|
+
this.orm.properties.filter(function(property) {
|
|
48
|
+
return Object.keys(entity).indexOf(property.name) > -1 && (!property.allowedOps || property.allowedOps.indexOf("update") > -1);
|
|
49
|
+
}).forEach(function(property) {
|
|
50
|
+
if (!property.id)
|
|
51
|
+
builder.set(property.column, "?", property);
|
|
52
|
+
});
|
|
53
|
+
const pkProperty = this.orm.getPrimaryKey();
|
|
54
|
+
builder.where(pkProperty.column + "=?", [pkProperty]);
|
|
55
|
+
return builder;
|
|
56
|
+
};
|
|
57
|
+
ORMStatements.prototype["delete"] = ORMStatements.prototype.remove = function() {
|
|
58
|
+
const builder = this.dialect.delete().from(this.orm.table);
|
|
59
|
+
if (arguments[0] !== void 0) {
|
|
60
|
+
let filterFieldNames = arguments[0];
|
|
61
|
+
if (filterFieldNames.constructor !== Array)
|
|
62
|
+
filterFieldNames = [filterFieldNames];
|
|
63
|
+
for (let i = 0; i < filterFieldNames.length; i++) {
|
|
64
|
+
const property = this.orm.getProperty(filterFieldNames[i]);
|
|
65
|
+
if (!property)
|
|
66
|
+
throw Error("Unknown property name: " + filterFieldNames[i] + " in $filter");
|
|
67
|
+
builder.where(property.column + "=?", [property]);
|
|
68
|
+
}
|
|
69
|
+
}
|
|
70
|
+
return builder;
|
|
71
|
+
};
|
|
72
|
+
ORMStatements.prototype.find = function(params) {
|
|
73
|
+
let builder = this.dialect.select();
|
|
74
|
+
if (params !== void 0 && params.select !== void 0) {
|
|
75
|
+
const selectedFields = params.select.constructor === Array ? params.select : [params.select];
|
|
76
|
+
for (let i = 0; i < selectedFields.length; i++) {
|
|
77
|
+
const property = this.orm.getProperty(selectedFields[i]);
|
|
78
|
+
if (!property)
|
|
79
|
+
throw Error("Unknown field name [" + selectedFields[i] + "] in $select");
|
|
80
|
+
builder = builder.column(property.column);
|
|
81
|
+
}
|
|
82
|
+
}
|
|
83
|
+
builder = builder.from(this.orm.table).where(this.orm.getPrimaryKey().column + "=?", [this.orm.getPrimaryKey()]);
|
|
84
|
+
return builder;
|
|
85
|
+
};
|
|
86
|
+
ORMStatements.prototype.count = function(settings) {
|
|
87
|
+
const builder = this.dialect.select().column("COUNT(*)").from(this.orm.table);
|
|
88
|
+
addFilter(this.orm, builder, settings);
|
|
89
|
+
return builder;
|
|
90
|
+
};
|
|
91
|
+
ORMStatements.prototype.list = function(settings) {
|
|
92
|
+
let i;
|
|
93
|
+
settings = settings || {};
|
|
94
|
+
const sort = settings.$sort || settings.sort;
|
|
95
|
+
const order = settings.$order || settings.order;
|
|
96
|
+
const selectedFields = settings.$select || settings.select;
|
|
97
|
+
const builder = this.dialect.select().from(this.orm.table);
|
|
98
|
+
if (selectedFields) {
|
|
99
|
+
for (i = 0; i < selectedFields.length; i++) {
|
|
100
|
+
const property = this.orm.getProperty(selectedFields[i]);
|
|
101
|
+
if (!property)
|
|
102
|
+
throw Error("Unknown field name [" + selectedFields[i] + "] in $select");
|
|
103
|
+
builder.column(property.column);
|
|
104
|
+
}
|
|
105
|
+
}
|
|
106
|
+
addFilter(this.orm, builder, settings);
|
|
107
|
+
const propertyDefinitions = this.orm.properties.filter(function(property) {
|
|
108
|
+
for (var settingName in settings) {
|
|
109
|
+
if (settingName === property.name)
|
|
110
|
+
return true;
|
|
111
|
+
}
|
|
112
|
+
return false;
|
|
113
|
+
});
|
|
114
|
+
if (propertyDefinitions.length > 0) {
|
|
115
|
+
for (i = 0; i < propertyDefinitions.length; i++) {
|
|
116
|
+
const def = propertyDefinitions[i];
|
|
117
|
+
if (settings?.$filter && settings.$filter?.indexOf(def.name) > -1) {
|
|
118
|
+
builder.where(def.column + " LIKE ?", [def]);
|
|
119
|
+
} else {
|
|
120
|
+
const val = settings[def.name];
|
|
121
|
+
if (val === null || val === void 0) {
|
|
122
|
+
builder.where(def.column + " IS NULL", [def]);
|
|
123
|
+
} else {
|
|
124
|
+
if (val.indexOf && val.indexOf(">") > -1) {
|
|
125
|
+
builder.where(def.column + " > ?", [def]);
|
|
126
|
+
} else if (val.indexOf && val.indexOf("<") > -1) {
|
|
127
|
+
builder.where(def.column + " < ?", [def]);
|
|
128
|
+
} else {
|
|
129
|
+
builder.where(def.column + "=?", [def]);
|
|
130
|
+
}
|
|
131
|
+
}
|
|
132
|
+
}
|
|
133
|
+
}
|
|
134
|
+
}
|
|
135
|
+
if (sort !== void 0) {
|
|
136
|
+
var _sort = sort.split(",");
|
|
137
|
+
for (i = 0; i < _sort.length; i++) {
|
|
138
|
+
let _order = true;
|
|
139
|
+
if (order !== void 0) {
|
|
140
|
+
if (["asc", "desc"].indexOf(String(order).toLowerCase()) > -1) {
|
|
141
|
+
_order = order.toLowerCase() === "desc" ? false : true;
|
|
142
|
+
}
|
|
143
|
+
}
|
|
144
|
+
if (this.orm.getProperty(_sort[i])) {
|
|
145
|
+
builder.order(this.orm.getProperty(_sort[i]).column, _order);
|
|
146
|
+
} else {
|
|
147
|
+
console.error("Column: " + _sort[i] + " not present in " + JSON.stringify(this.orm));
|
|
148
|
+
}
|
|
149
|
+
}
|
|
150
|
+
}
|
|
151
|
+
addLimit(builder, settings);
|
|
152
|
+
addOffset(builder, settings);
|
|
153
|
+
return builder;
|
|
154
|
+
};
|
|
155
|
+
function addFilter(orm, builder, settings) {
|
|
156
|
+
if (settings?.$filter) {
|
|
157
|
+
const equalsPropertiesKeys = Object.keys(settings.$filter.equals ?? []);
|
|
158
|
+
const notEqualsPropertiesKeys = Object.keys(settings.$filter.notEquals ?? []);
|
|
159
|
+
const containsPropertiesKeys = Object.keys(settings.$filter.contains ?? []);
|
|
160
|
+
const greaterThanPropertiesKeys = Object.keys(settings.$filter.greaterThan ?? []);
|
|
161
|
+
const lessThanPropertiesKeys = Object.keys(settings.$filter.lessThan ?? []);
|
|
162
|
+
const greaterThanOrEqualPropertiesKeys = Object.keys(settings.$filter.greaterThanOrEqual ?? []);
|
|
163
|
+
const lessThanOrEqualPropertiesKeys = Object.keys(settings.$filter.lessThanOrEqual ?? []);
|
|
164
|
+
const equalsProperties = orm.properties.filter((e) => equalsPropertiesKeys.includes(e.name));
|
|
165
|
+
const notEqualsProperties = orm.properties.filter((e) => notEqualsPropertiesKeys.includes(e.name));
|
|
166
|
+
const containsProperties = orm.properties.filter((e) => containsPropertiesKeys.includes(e.name));
|
|
167
|
+
const greaterThanProperties = orm.properties.filter((e) => greaterThanPropertiesKeys.includes(e.name));
|
|
168
|
+
const lessThanProperties = orm.properties.filter((e) => lessThanPropertiesKeys.includes(e.name));
|
|
169
|
+
const greaterThanOrEqualProperties = orm.properties.filter((e) => greaterThanOrEqualPropertiesKeys.includes(e.name));
|
|
170
|
+
const lessThanOrEqualProperties = orm.properties.filter((e) => lessThanOrEqualPropertiesKeys.includes(e.name));
|
|
171
|
+
equalsProperties.forEach((e) => {
|
|
172
|
+
const value = settings.$filter.equals[e.name];
|
|
173
|
+
if (value === null || value === void 0) {
|
|
174
|
+
builder.where(e.column + " IS NULL", [e]);
|
|
175
|
+
} else if (Array.isArray(value)) {
|
|
176
|
+
builder.where(`${e.column} IN (${value.map((v) => "?").join(", ")})`, [e]);
|
|
177
|
+
} else {
|
|
178
|
+
builder.where(`${e.column} = ?`, [e]);
|
|
179
|
+
}
|
|
180
|
+
});
|
|
181
|
+
notEqualsProperties.forEach((e) => {
|
|
182
|
+
const value = settings.$filter.notEquals[e.name];
|
|
183
|
+
if (value === null || value === void 0) {
|
|
184
|
+
builder.where(e.column + " IS NOT NULL", [e]);
|
|
185
|
+
} else if (Array.isArray(value)) {
|
|
186
|
+
builder.where(`${e.column} NOT IN (${value.map((v) => "?").join(", ")})`, [e]);
|
|
187
|
+
} else {
|
|
188
|
+
builder.where(`${e.column} != ?`, [e]);
|
|
189
|
+
}
|
|
190
|
+
});
|
|
191
|
+
containsProperties.forEach((e) => builder.where(`${e.column} LIKE ?`, [e]));
|
|
192
|
+
greaterThanProperties.forEach((e) => builder.where(`${e.column} > ?`, [e]));
|
|
193
|
+
lessThanProperties.forEach((e) => builder.where(`${e.column} < ?`, [e]));
|
|
194
|
+
greaterThanOrEqualProperties.forEach((e) => builder.where(`${e.column} >= ?`, [e]));
|
|
195
|
+
lessThanOrEqualProperties.forEach((e) => builder.where(`${e.column} <= ?`, [e]));
|
|
196
|
+
}
|
|
197
|
+
}
|
|
198
|
+
function addLimit(builder, settings) {
|
|
199
|
+
const limit = settings.$limit ?? settings.limit;
|
|
200
|
+
if (limit !== void 0) {
|
|
201
|
+
builder.limit(parseInt(limit, 10));
|
|
202
|
+
}
|
|
203
|
+
}
|
|
204
|
+
function addOffset(builder, settings) {
|
|
205
|
+
const offset = settings.$offset ?? settings.offset;
|
|
206
|
+
if (offset !== void 0) {
|
|
207
|
+
builder.offset(parseInt(offset, 10));
|
|
208
|
+
}
|
|
209
|
+
}
|
|
210
|
+
function create(orm, connection) {
|
|
211
|
+
let dialect;
|
|
212
|
+
if (connection) {
|
|
213
|
+
dialect = SQLBuilder.getDialect(connection);
|
|
214
|
+
}
|
|
215
|
+
const stmnts = new ORMStatements(orm, dialect);
|
|
216
|
+
return stmnts;
|
|
217
|
+
}
|
|
218
|
+
;
|
|
219
|
+
export {
|
|
220
|
+
ORMStatements,
|
|
221
|
+
create
|
|
222
|
+
};
|
|
223
|
+
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../src/db/ormstatements.ts"],
  "sourcesContent": ["\"use strict\";\n\nimport { Logging } from \"@aerokit/sdk/log\";\nimport { CreateTableBuilder, DeleteBuilder, DropTableBuilder, InsertBuilder, SelectBuilder, SQLBuilder, UpdateBuilder } from \"./sql\";\nimport { Connection } from \"./database\";\n\nexport function ORMStatements(orm, dialect: SQLBuilder) {\n\tthis.$log = Logging.getLogger('db.dao.ormstatements');\n\tthis.orm = orm;\n\tthis.orm.tableName = this.orm.table;\n\tthis.orm.properties.forEach(function (property) {\n\t\tproperty.columnName = property.column;\n\t});\n\tthis.dialect = dialect || SQLBuilder.getDialect();\n};\nORMStatements.prototype.constructor = ORMStatements;\n\nORMStatements.prototype.createTable = function (): CreateTableBuilder {\n\tconst builder = this.dialect.create().table(this.orm.table);\n\n\tthis.orm.properties.forEach(function (property) {\n\t\tconst column = this.orm.toColumn(property);\n\t\tif (property.type.toUpperCase() === 'VARCHAR') {\n\t\t\tif (property.length === undefined)\n\t\t\t\tproperty.length = 255;\n\t\t\tbuilder.columnVarchar(column.name, property.length, column.primaryKey === 'true', column.nullable === 'true', property.unique);\n\t\t} else if (property.type.toUpperCase() === 'CHAR') {\n\t\t\tif (property.length === undefined)\n\t\t\t\tproperty.length = 1;\n\t\t\tproperty.length = parseInt(property.length, 10);\n\t\t\tbuilder.columnChar(column.name, property.length, column.primaryKey === 'true', column.nullable === 'true', property.unique);\n\t\t} else {\n\t\t\tbuilder.column(column.name, column.type, column.primaryKey === 'true', column.nullable === 'true', property.unique);\n\t\t}\n\t}.bind(this));\n\n\treturn builder;\n};\n\nORMStatements.prototype.dropTable = function (): DropTableBuilder {\n\treturn this.dialect.drop().table(this.orm.table);\n};\n\nORMStatements.prototype.insert = function (): InsertBuilder {\n\tconst builder = this.dialect.insert().into(this.orm.table);\n\tthis.orm.properties.forEach(function (property) {\n\t\tbuilder.column(property.column).value('?', property);\n\t});\n\treturn builder;\n};\n\nORMStatements.prototype.update = function (entity): UpdateBuilder {\n\tif (!entity)\n\t\tthrow Error('Illegal argument: entity[' + entity + ']');\n\n\tconst builder = this.dialect.update().table(this.orm.table);\n\tthis.orm.properties.filter(function (property) {\n\t\treturn Object.keys(entity).indexOf(property.name) > -1 && (!property.allowedOps || property.allowedOps.indexOf('update') > -1);\n\t}).forEach(function (property) {\n\t\tif (!property.id)\n\t\t\tbuilder.set(property.column, '?', property);\n\t});\n\tconst pkProperty = this.orm.getPrimaryKey();\n\tbuilder.where(pkProperty.column + '=?', [pkProperty]);\n\treturn builder;\n};\n\nORMStatements.prototype[\"delete\"] = ORMStatements.prototype.remove = function (): DeleteBuilder {\n\tconst builder = this.dialect.delete().from(this.orm.table);\n\tif (arguments[0] !== undefined) {\n\t\tlet filterFieldNames = arguments[0];\n\t\tif (filterFieldNames.constructor !== Array)\n\t\t\tfilterFieldNames = [filterFieldNames];\n\t\tfor (let i = 0; i < filterFieldNames.length; i++) {\n\t\t\tconst property = this.orm.getProperty(filterFieldNames[i]);\n\t\t\tif (!property)\n\t\t\t\tthrow Error('Unknown property name: ' + filterFieldNames[i] + \" in $filter\");\n\t\t\tbuilder.where(property.column + \"=?\", [property]);\n\t\t}\n\t}\n\treturn builder;\n};\n\nORMStatements.prototype.find = function (params): SelectBuilder {\n\tlet builder = this.dialect.select();\n\tif (params !== undefined && params.select !== undefined) {\n\t\tconst selectedFields = params.select.constructor === Array ? params.select : [params.select];\n\t\tfor (let i = 0; i < selectedFields.length; i++) {\n\t\t\tconst property = this.orm.getProperty(selectedFields[i]);\n\t\t\tif (!property)\n\t\t\t\tthrow Error('Unknown field name [' + selectedFields[i] + '] in $select');\n\t\t\tbuilder = builder.column(property.column);\n\t\t}\n\t}\n\tbuilder = builder.from(this.orm.table)\n\t\t.where(this.orm.getPrimaryKey().column + \"=?\", [this.orm.getPrimaryKey()]);\n\treturn builder;\n};\n\nORMStatements.prototype.count = function (settings): SelectBuilder {\n\tconst builder = this.dialect.select().column('COUNT(*)').from(this.orm.table);\n\taddFilter(this.orm, builder, settings);\n\treturn builder;\n};\n\nORMStatements.prototype.list = function (settings): SelectBuilder {\n\tlet i;\n\tsettings = settings || {};\n\tconst sort = settings.$sort || settings.sort;\n\tconst order = settings.$order || settings.order;\n\tconst selectedFields = settings.$select || settings.select;\n\n\tconst builder = this.dialect.select().from(this.orm.table);\n\n\t//add selected fields if any\n\tif (selectedFields) {\n\t\tfor (i = 0; i < selectedFields.length; i++) {\n\t\t\tconst property = this.orm.getProperty(selectedFields[i]);\n\t\t\tif (!property)\n\t\t\t\tthrow Error('Unknown field name [' + selectedFields[i] + '] in $select');\n\t\t\tbuilder.column(property.column);\n\t\t}\n\t}\n\n\t//add where clause for any fields\n\taddFilter(this.orm, builder, settings);\n\n\t// TODO: The following code might not be needed anymore\n\tconst propertyDefinitions = this.orm.properties.filter(function (property) {\n\t\tfor (var settingName in settings) {\n\t\t\tif (settingName === property.name)\n\t\t\t\treturn true;\n\t\t}\n\t\treturn false;\n\t});\n\tif (propertyDefinitions.length > 0) {\n\t\tfor (i = 0; i < propertyDefinitions.length; i++) {\n\t\t\tconst def = propertyDefinitions[i];\n\t\t\tif (settings?.$filter && settings.$filter?.indexOf(def.name) > -1) {\n\t\t\t\tbuilder.where(def.column + ' LIKE ?', [def]);\n\t\t\t} else {\n\t\t\t\tconst val = settings[def.name];\n\t\t\t\tif (val === null || val === undefined) {\n\t\t\t\t\tbuilder.where(def.column + ' IS NULL', [def]);\n\t\t\t\t} else {\n\t\t\t\t\tif (val.indexOf && val.indexOf('>') > -1) {\n\t\t\t\t\t\tbuilder.where(def.column + ' > ?', [def]);\n\t\t\t\t\t} else if (val.indexOf && val.indexOf('<') > -1) {\n\t\t\t\t\t\tbuilder.where(def.column + ' < ?', [def]);\n\t\t\t\t\t} else {\n\t\t\t\t\t\tbuilder.where(def.column + '=?', [def]);\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n\n\tif (sort !== undefined) {\n\t\tvar _sort = sort.split(',');\n\t\tfor (i = 0; i < _sort.length; i++) {\n\t\t\tlet _order = true;//ASC\n\t\t\t//TODO: change to be able to order per sort property\n\t\t\tif (order !== undefined) {\n\t\t\t\tif (['asc', 'desc'].indexOf(String(order).toLowerCase()) > -1) {\n\t\t\t\t\t_order = order.toLowerCase() === 'desc' ? false : true;\n\t\t\t\t}\n\t\t\t}\n\t\t\tif (this.orm.getProperty(_sort[i])) {\n\t\t\t\tbuilder.order(this.orm.getProperty(_sort[i]).column, _order);\n\t\t\t} else {\n\t\t\t\tconsole.error('Column: ' + _sort[i] + ' not present in ' + JSON.stringify(this.orm));\n\t\t\t}\n\n\t\t}\n\t}\n\taddLimit(builder, settings);\n\taddOffset(builder, settings);\n\treturn builder;\n};\n\nfunction addFilter(orm, builder, settings) {\n\t//add where clause for any fields\n\tif (settings?.$filter) {\n\t\tconst equalsPropertiesKeys = Object.keys(settings.$filter.equals ?? []);\n\t\tconst notEqualsPropertiesKeys = Object.keys(settings.$filter.notEquals ?? []);\n\t\tconst containsPropertiesKeys = Object.keys(settings.$filter.contains ?? []);\n\t\tconst greaterThanPropertiesKeys = Object.keys(settings.$filter.greaterThan ?? []);\n\t\tconst lessThanPropertiesKeys = Object.keys(settings.$filter.lessThan ?? []);\n\t\tconst greaterThanOrEqualPropertiesKeys = Object.keys(settings.$filter.greaterThanOrEqual ?? []);\n\t\tconst lessThanOrEqualPropertiesKeys = Object.keys(settings.$filter.lessThanOrEqual ?? []);\n\n\t\tconst equalsProperties = orm.properties.filter(e => equalsPropertiesKeys.includes(e.name));\n\t\tconst notEqualsProperties = orm.properties.filter(e => notEqualsPropertiesKeys.includes(e.name));\n\t\tconst containsProperties = orm.properties.filter(e => containsPropertiesKeys.includes(e.name));\n\t\tconst greaterThanProperties = orm.properties.filter(e => greaterThanPropertiesKeys.includes(e.name));\n\t\tconst lessThanProperties = orm.properties.filter(e => lessThanPropertiesKeys.includes(e.name));\n\t\tconst greaterThanOrEqualProperties = orm.properties.filter(e => greaterThanOrEqualPropertiesKeys.includes(e.name));\n\t\tconst lessThanOrEqualProperties = orm.properties.filter(e => lessThanOrEqualPropertiesKeys.includes(e.name));\n\n\t\tequalsProperties.forEach(e => {\n\t\t\tconst value = settings.$filter.equals[e.name];\n\t\t\tif (value === null || value === undefined) {\n\t\t\t\tbuilder.where(e.column + ' IS NULL', [e]);\n\t\t\t} else if (Array.isArray(value)) {\n\t\t\t\tbuilder.where(`${e.column} IN (${value.map(v => '?').join(', ')})`, [e])\n\t\t\t} else {\n\t\t\t\tbuilder.where(`${e.column} = ?`, [e])\n\t\t\t}\n\t\t});\n\t\tnotEqualsProperties.forEach(e => {\n\t\t\tconst value = settings.$filter.notEquals[e.name];\n\t\t\tif (value === null || value === undefined) {\n\t\t\t\tbuilder.where(e.column + ' IS NOT NULL', [e]);\n\t\t\t} else if (Array.isArray(value)) {\n\t\t\t\tbuilder.where(`${e.column} NOT IN (${value.map(v => '?').join(', ')})`, [e])\n\t\t\t} else {\n\t\t\t\tbuilder.where(`${e.column} != ?`, [e])\n\t\t\t}\n\t\t});\n\t\tcontainsProperties.forEach(e => builder.where(`${e.column} LIKE ?`, [e]));\n\t\tgreaterThanProperties.forEach(e => builder.where(`${e.column} > ?`, [e]));\n\t\tlessThanProperties.forEach(e => builder.where(`${e.column} < ?`, [e]));\n\t\tgreaterThanOrEqualProperties.forEach(e => builder.where(`${e.column} >= ?`, [e]));\n\t\tlessThanOrEqualProperties.forEach(e => builder.where(`${e.column} <= ?`, [e]));\n\t}\n}\n\nfunction addLimit(builder, settings) {\n\tconst limit = settings.$limit ?? settings.limit;\n\tif (limit !== undefined) {\n\t\tbuilder.limit(parseInt(limit, 10));\n\t}\n}\n\nfunction addOffset(builder, settings) {\n\tconst offset = settings.$offset ?? settings.offset;\n\tif (offset !== undefined) {\n\t\tbuilder.offset(parseInt(offset, 10));\n\t}\n}\n\nexport function create(orm, connection?: Connection) {\n\tlet dialect;\n\tif (connection) {\n\t\tdialect = SQLBuilder.getDialect(connection);\n\t}\n\n\tconst stmnts = new ORMStatements(orm, dialect);\n\treturn stmnts;\n};\n"],
  "mappings": "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",
  "names": []
}

|
|
@@ -0,0 +1,93 @@
|
|
|
1
|
+
import { Update } from "./update";
|
|
2
|
+
import { Database } from "./database";
|
|
3
|
+
class Procedure {
|
|
4
|
+
/**
|
|
5
|
+
* Executes a DDL/DML statement to create or modify a stored procedure without results.
|
|
6
|
+
* * @param {string} sql The SQL statement (e.g., CREATE PROCEDURE).
|
|
7
|
+
* @param {string} [datasourceName] Optional name of the data source to use.
|
|
8
|
+
*/
|
|
9
|
+
static create(sql, datasourceName) {
|
|
10
|
+
Update.execute(sql, [], datasourceName);
|
|
11
|
+
}
|
|
12
|
+
/**
|
|
13
|
+
* Executes a stored procedure call and returns the result set(s).
|
|
14
|
+
* * @param {string} sql The callable statement (e.g., {CALL my_procedure(?, ?)}).
|
|
15
|
+
* @param {(string | number | ProcedureParameter)[]} [parameters=[]] An array of parameters. Primitives (string/number) are automatically typed. Use ProcedureParameter for explicit types.
|
|
16
|
+
* @param {string} [datasourceName] Optional name of the data source to use.
|
|
17
|
+
* @returns {any[]} An array of JSON objects representing the result set(s).
|
|
18
|
+
*/
|
|
19
|
+
static execute(sql, parameters = [], datasourceName) {
|
|
20
|
+
const result = [];
|
|
21
|
+
let connection = null;
|
|
22
|
+
let callableStatement = null;
|
|
23
|
+
let resultSet = null;
|
|
24
|
+
try {
|
|
25
|
+
let hasMoreResults = false;
|
|
26
|
+
connection = Database.getConnection(datasourceName);
|
|
27
|
+
callableStatement = connection.prepareCall(sql);
|
|
28
|
+
const mappedParameters = parameters.map((parameter) => {
|
|
29
|
+
if (parameter && typeof parameter === "object" && "type" in parameter && "value" in parameter) {
|
|
30
|
+
return parameter;
|
|
31
|
+
}
|
|
32
|
+
let type;
|
|
33
|
+
let value;
|
|
34
|
+
if (typeof parameter === "string") {
|
|
35
|
+
type = "string";
|
|
36
|
+
value = parameter;
|
|
37
|
+
} else if (typeof parameter === "number") {
|
|
38
|
+
type = parameter % 1 === 0 ? "int" : "double";
|
|
39
|
+
value = parameter;
|
|
40
|
+
} else {
|
|
41
|
+
throw new Error(`Procedure Call - Unsupported parameter type [${typeof parameter}]`);
|
|
42
|
+
}
|
|
43
|
+
return { value, type };
|
|
44
|
+
});
|
|
45
|
+
for (let i = 0; i < mappedParameters.length; i++) {
|
|
46
|
+
switch (mappedParameters[i].type) {
|
|
47
|
+
case "string":
|
|
48
|
+
callableStatement.setString(i + 1, mappedParameters[i].value);
|
|
49
|
+
break;
|
|
50
|
+
case "int":
|
|
51
|
+
case "integer":
|
|
52
|
+
case "number":
|
|
53
|
+
callableStatement.setInt(i + 1, mappedParameters[i].value);
|
|
54
|
+
break;
|
|
55
|
+
case "float":
|
|
56
|
+
callableStatement.setFloat(i + 1, mappedParameters[i].value);
|
|
57
|
+
break;
|
|
58
|
+
case "double":
|
|
59
|
+
callableStatement.setDouble(i + 1, mappedParameters[i].value);
|
|
60
|
+
break;
|
|
61
|
+
}
|
|
62
|
+
}
|
|
63
|
+
resultSet = callableStatement.executeQuery();
|
|
64
|
+
do {
|
|
65
|
+
result.push(JSON.parse(resultSet.toJson()));
|
|
66
|
+
hasMoreResults = callableStatement.getMoreResults();
|
|
67
|
+
if (hasMoreResults) {
|
|
68
|
+
resultSet.close();
|
|
69
|
+
resultSet = callableStatement.getResultSet();
|
|
70
|
+
}
|
|
71
|
+
} while (hasMoreResults);
|
|
72
|
+
callableStatement.close();
|
|
73
|
+
} finally {
|
|
74
|
+
if (resultSet != null) {
|
|
75
|
+
resultSet.close();
|
|
76
|
+
}
|
|
77
|
+
if (callableStatement != null) {
|
|
78
|
+
callableStatement.close();
|
|
79
|
+
}
|
|
80
|
+
if (connection != null) {
|
|
81
|
+
connection.close();
|
|
82
|
+
}
|
|
83
|
+
}
|
|
84
|
+
return result;
|
|
85
|
+
}
|
|
86
|
+
}
|
|
87
|
+
if (typeof module !== "undefined") {
|
|
88
|
+
module.exports = Procedure;
|
|
89
|
+
}
|
|
90
|
+
export {
|
|
91
|
+
Procedure
|
|
92
|
+
};
|
|
93
|
+
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../src/db/procedure.ts"],
  "sourcesContent": ["/**\n * API Procedure\n *\n */\nimport { Update } from \"./update\";\nimport { Database } from \"./database\";\n\n/**\n * @interface ProcedureParameter\n * @description Defines a structured parameter for procedure calls, allowing the type \n * to be explicitly defined when the natural JavaScript type mapping is insufficient.\n */\nexport interface ProcedureParameter {\n\ttype: string; // Removed readonly to allow assignment during parameter mapping\n\tvalue: any;   // Removed readonly\n}\n\nexport class Procedure {\n\n    /**\n     * Executes a DDL/DML statement to create or modify a stored procedure without results.\n     * * @param {string} sql The SQL statement (e.g., CREATE PROCEDURE).\n     * @param {string} [datasourceName] Optional name of the data source to use.\n     */\n    public static create(sql: string, datasourceName?: string): void {\n        Update.execute(sql, [], datasourceName);\n    }\n\n    /**\n     * Executes a stored procedure call and returns the result set(s).\n     * * @param {string} sql The callable statement (e.g., {CALL my_procedure(?, ?)}).\n     * @param {(string | number | ProcedureParameter)[]} [parameters=[]] An array of parameters. Primitives (string/number) are automatically typed. Use ProcedureParameter for explicit types.\n     * @param {string} [datasourceName] Optional name of the data source to use.\n     * @returns {any[]} An array of JSON objects representing the result set(s).\n     */\n    public static execute(sql: string, parameters: (string | number | ProcedureParameter)[] = [], datasourceName?: string): any[] {\n        const result = [];\n\n        let connection = null;\n        let callableStatement = null;\n        let resultSet = null;\n\n        try {\n            let hasMoreResults = false;\n\n            connection = Database.getConnection(datasourceName);\n            callableStatement = connection.prepareCall(sql);\n            \n            const mappedParameters: ProcedureParameter[] = parameters.map((parameter) => {\n                \n                // 1. If the parameter is an object and looks like a ProcedureParameter, use it directly.\n                if (parameter && typeof parameter === \"object\" && 'type' in parameter && 'value' in parameter) {\n                    return parameter as ProcedureParameter;\n                }\n\n                // 2. Handle primitive types (string or number) by explicitly narrowing the type.\n                let type: string;\n                let value: string | number;\n\n                if (typeof parameter === \"string\") {\n                    type = \"string\";\n                    value = parameter;\n                } else if (typeof parameter === \"number\") {\n                    // Type is correctly narrowed to 'number' here, resolving the TS2362 error.\n                    type = parameter % 1 === 0 ? \"int\" : \"double\";\n                    value = parameter;\n                } else {\n                    // Throw error if the parameter is not a recognized type.\n                    throw new Error(`Procedure Call - Unsupported parameter type [${typeof parameter}]`);\n                }\n\n                return { value, type };\n            });\n\n            for (let i = 0; i < mappedParameters.length; i++) {\n                switch (mappedParameters[i].type) {\n                    case \"string\":\n                        callableStatement.setString(i + 1, mappedParameters[i].value);\n                        break;\n                    case \"int\":\n                    case \"integer\":\n                    case \"number\":\n                        callableStatement.setInt(i + 1, mappedParameters[i].value);\n                        break;\n                    case \"float\":\n                        callableStatement.setFloat(i + 1, mappedParameters[i].value);\n                        break;\n                    case \"double\":\n                        callableStatement.setDouble(i + 1, mappedParameters[i].value);\n                        break;\n                }\n            }\n            resultSet = callableStatement.executeQuery();\n\n            do {\n                result.push(JSON.parse(resultSet.toJson()));\n                hasMoreResults = callableStatement.getMoreResults();\n                if (hasMoreResults) {\n                    resultSet.close();\n                    resultSet = callableStatement.getResultSet();\n                }\n            } while (hasMoreResults)\n\n            callableStatement.close();\n        } finally {\n            if (resultSet != null) {\n                resultSet.close();\n            }\n            if (callableStatement != null) {\n                callableStatement.close();\n            }\n            if (connection != null) {\n                connection.close();\n            }\n        }\n        return result;\n    }\n}\n\n// @ts-ignore\nif (typeof module !== 'undefined') {\n\t// @ts-ignore\n\tmodule.exports = Procedure;\n}"],
  "mappings": "AAIA,SAAS,cAAc;AACvB,SAAS,gBAAgB;AAYlB,MAAM,UAAU;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOnB,OAAc,OAAO,KAAa,gBAA+B;AAC7D,WAAO,QAAQ,KAAK,CAAC,GAAG,cAAc;AAAA,EAC1C;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EASA,OAAc,QAAQ,KAAa,aAAuD,CAAC,GAAG,gBAAgC;AAC1H,UAAM,SAAS,CAAC;AAEhB,QAAI,aAAa;AACjB,QAAI,oBAAoB;AACxB,QAAI,YAAY;AAEhB,QAAI;AACA,UAAI,iBAAiB;AAErB,mBAAa,SAAS,cAAc,cAAc;AAClD,0BAAoB,WAAW,YAAY,GAAG;AAE9C,YAAM,mBAAyC,WAAW,IAAI,CAAC,cAAc;AAGzE,YAAI,aAAa,OAAO,cAAc,YAAY,UAAU,aAAa,WAAW,WAAW;AAC3F,iBAAO;AAAA,QACX;AAGA,YAAI;AACJ,YAAI;AAEJ,YAAI,OAAO,cAAc,UAAU;AAC/B,iBAAO;AACP,kBAAQ;AAAA,QACZ,WAAW,OAAO,cAAc,UAAU;AAEtC,iBAAO,YAAY,MAAM,IAAI,QAAQ;AACrC,kBAAQ;AAAA,QACZ,OAAO;AAEH,gBAAM,IAAI,MAAM,gDAAgD,OAAO,SAAS,GAAG;AAAA,QACvF;AAEA,eAAO,EAAE,OAAO,KAAK;AAAA,MACzB,CAAC;AAED,eAAS,IAAI,GAAG,IAAI,iBAAiB,QAAQ,KAAK;AAC9C,gBAAQ,iBAAiB,CAAC,EAAE,MAAM;AAAA,UAC9B,KAAK;AACD,8BAAkB,UAAU,IAAI,GAAG,iBAAiB,CAAC,EAAE,KAAK;AAC5D;AAAA,UACJ,KAAK;AAAA,UACL,KAAK;AAAA,UACL,KAAK;AACD,8BAAkB,OAAO,IAAI,GAAG,iBAAiB,CAAC,EAAE,KAAK;AACzD;AAAA,UACJ,KAAK;AACD,8BAAkB,SAAS,IAAI,GAAG,iBAAiB,CAAC,EAAE,KAAK;AAC3D;AAAA,UACJ,KAAK;AACD,8BAAkB,UAAU,IAAI,GAAG,iBAAiB,CAAC,EAAE,KAAK;AAC5D;AAAA,QACR;AAAA,MACJ;AACA,kBAAY,kBAAkB,aAAa;AAE3C,SAAG;AACC,eAAO,KAAK,KAAK,MAAM,UAAU,OAAO,CAAC,CAAC;AAC1C,yBAAiB,kBAAkB,eAAe;AAClD,YAAI,gBAAgB;AAChB,oBAAU,MAAM;AAChB,sBAAY,kBAAkB,aAAa;AAAA,QAC/C;AAAA,MACJ,SAAS;AAET,wBAAkB,MAAM;AAAA,IAC5B,UAAE;AACE,UAAI,aAAa,MAAM;AACnB,kBAAU,MAAM;AAAA,MACpB;AACA,UAAI,qBAAqB,MAAM;AAC3B,0BAAkB,MAAM;AAAA,MAC5B;AACA,UAAI,cAAc,MAAM;AACpB,mBAAW,MAAM;AAAA,MACrB;AAAA,IACJ;AACA,WAAO;AAAA,EACX;AACJ;AAGA,IAAI,OAAO,WAAW,aAAa;AAElC,SAAO,UAAU;AAClB;",
  "names": []
}

|
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
const DatabaseFacade = Java.type("org.eclipse.dirigible.components.api.db.DatabaseFacade");
|
|
2
|
+
class Query {
|
|
3
|
+
/**
|
|
4
|
+
* Executes a standard SQL query with positional parameters ('?').
|
|
5
|
+
*
|
|
6
|
+
* @param sql The SQL query to execute.
|
|
7
|
+
* @param parameters An optional array of values (primitives or QueryParameter objects) to replace '?' placeholders.
|
|
8
|
+
* @param datasourceName The name of the database connection to use (optional).
|
|
9
|
+
* @param resultParameter Optional formatting parameters for the result set (e.g., date format).
|
|
10
|
+
* @returns An array of records representing the query results.
|
|
11
|
+
*/
|
|
12
|
+
static execute(sql, parameters, datasourceName, resultParameter) {
|
|
13
|
+
const paramsJson = parameters ? JSON.stringify(parameters) : void 0;
|
|
14
|
+
const resultParamsJson = resultParameter ? JSON.stringify(resultParameter) : void 0;
|
|
15
|
+
const resultset = DatabaseFacade.query(sql, paramsJson, datasourceName, resultParamsJson);
|
|
16
|
+
return JSON.parse(resultset);
|
|
17
|
+
}
|
|
18
|
+
/**
|
|
19
|
+
* Executes a SQL query with named parameters (e.g., ":name", ":id").
|
|
20
|
+
*
|
|
21
|
+
* @param sql The SQL query to execute.
|
|
22
|
+
* @param parameters An optional array of NamedQueryParameter objects.
|
|
23
|
+
* @param datasourceName The name of the database connection to use (optional).
|
|
24
|
+
* @returns An array of records representing the query results.
|
|
25
|
+
*/
|
|
26
|
+
static executeNamed(sql, parameters, datasourceName) {
|
|
27
|
+
const paramsJson = parameters ? JSON.stringify(parameters) : void 0;
|
|
28
|
+
const resultset = DatabaseFacade.queryNamed(sql, paramsJson, datasourceName);
|
|
29
|
+
return JSON.parse(resultset);
|
|
30
|
+
}
|
|
31
|
+
}
|
|
32
|
+
if (typeof module !== "undefined") {
|
|
33
|
+
module.exports = Query;
|
|
34
|
+
}
|
|
35
|
+
export {
|
|
36
|
+
Query
|
|
37
|
+
};
|
|
38
|
+
//# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vLi4vc3JjL2RiL3F1ZXJ5LnRzIl0sCiAgInNvdXJjZXNDb250ZW50IjogWyIvKipcbiAqIEFQSSBRdWVyeVxuICpcbiAqL1xuXG4vLyBKYXZhLnR5cGUgaW1wb3J0cyBhcmUgbmVjZXNzYXJ5IGZvciBlbnZpcm9ubWVudHMgbGlrZSBEaXJpZ2libGUvUmhpbm9cbmNvbnN0IERhdGFiYXNlRmFjYWRlID0gSmF2YS50eXBlKFwib3JnLmVjbGlwc2UuZGlyaWdpYmxlLmNvbXBvbmVudHMuYXBpLmRiLkRhdGFiYXNlRmFjYWRlXCIpO1xuXG4vKipcbiAqIEludGVyZmFjZSB1c2VkIHRvIHdyYXAgY29tcGxleCBvciBzcGVjaWZpYyB2YWx1ZXMgZm9yIG5vbi1uYW1lZCBxdWVyaWVzLlxuICovXG5leHBvcnQgaW50ZXJmYWNlIFF1ZXJ5UGFyYW1ldGVyIHtcblx0cmVhZG9ubHkgdmFsdWU6IGFueTtcbn1cblxuLyoqXG4gKiBJbnRlcmZhY2UgZGVmaW5pbmcgYSBwYXJhbWV0ZXIgZm9yIGEgbmFtZWQgcXVlcnkgKHVzaW5nIHBsYWNlaG9sZGVycyBsaWtlIDpwYXJhbU5hbWUpLlxuICovXG5leHBvcnQgaW50ZXJmYWNlIE5hbWVkUXVlcnlQYXJhbWV0ZXIge1xuXHRyZWFkb25seSBuYW1lOiBzdHJpbmc7XG5cdHJlYWRvbmx5IHR5cGU6IHN0cmluZztcblx0cmVhZG9ubHkgdmFsdWU6IGFueTtcbn1cblxuLyoqXG4gKiBJbnRlcmZhY2UgdG8gc3BlY2lmeSBmb3JtYXR0aW5nIG9wdGlvbnMgZm9yIHRoZSBxdWVyeSByZXN1bHQgc2V0LlxuICovXG5leHBvcnQgaW50ZXJmYWNlIFJlc3VsdFBhcmFtZXRlciB7XG5cdHJlYWRvbmx5IGRhdGVGb3JtYXQ6IHN0cmluZztcbn1cblxuLyoqXG4gKiBQcm92aWRlcyBzdGF0aWMgbWV0aG9kcyBmb3IgZXhlY3V0aW5nIHBhcmFtZXRlcml6ZWQgU1FMIFNFTEVDVCBzdGF0ZW1lbnRzLlxuICovXG5leHBvcnQgY2xhc3MgUXVlcnkge1xuXG5cdC8qKlxuXHQgKiBFeGVjdXRlcyBhIHN0YW5kYXJkIFNRTCBxdWVyeSB3aXRoIHBvc2l0aW9uYWwgcGFyYW1ldGVycyAoJz8nKS5cblx0ICpcblx0ICogQHBhcmFtIHNxbCBUaGUgU1FMIHF1ZXJ5IHRvIGV4ZWN1dGUuXG5cdCAqIEBwYXJhbSBwYXJhbWV0ZXJzIEFuIG9wdGlvbmFsIGFycmF5IG9mIHZhbHVlcyAocHJpbWl0aXZlcyBvciBRdWVyeVBhcmFtZXRlciBvYmplY3RzKSB0byByZXBsYWNlICc/JyBwbGFjZWhvbGRlcnMuXG5cdCAqIEBwYXJhbSBkYXRhc291cmNlTmFtZSBUaGUgbmFtZSBvZiB0aGUgZGF0YWJhc2UgY29ubmVjdGlvbiB0byB1c2UgKG9wdGlvbmFsKS5cblx0ICogQHBhcmFtIHJlc3VsdFBhcmFtZXRlciBPcHRpb25hbCBmb3JtYXR0aW5nIHBhcmFtZXRlcnMgZm9yIHRoZSByZXN1bHQgc2V0IChlLmcuLCBkYXRlIGZvcm1hdCkuXG5cdCAqIEByZXR1cm5zIEFuIGFycmF5IG9mIHJlY29yZHMgcmVwcmVzZW50aW5nIHRoZSBxdWVyeSByZXN1bHRzLlxuXHQgKi9cblx0cHVibGljIHN0YXRpYyBleGVjdXRlKHNxbDogc3RyaW5nLCBwYXJhbWV0ZXJzPzogKHN0cmluZyB8IG51bWJlciB8IGJvb2xlYW4gfCBEYXRlIHwgUXVlcnlQYXJhbWV0ZXIpW10sIGRhdGFzb3VyY2VOYW1lPzogc3RyaW5nLCAgcmVzdWx0UGFyYW1ldGVyPzogUmVzdWx0UGFyYW1ldGVyKTogYW55W10ge1xuXHRcdC8vIFNlcmlhbGl6ZSBwYXJhbWV0ZXJzIGFuZCByZXN1bHQgcGFyYW1ldGVycyBmb3IgdGhlIEphdmEgZmFjYWRlXG5cdFx0Y29uc3QgcGFyYW1zSnNvbiA9IHBhcmFtZXRlcnMgPyBKU09OLnN0cmluZ2lmeShwYXJhbWV0ZXJzKSA6IHVuZGVmaW5lZDtcblx0XHRjb25zdCByZXN1bHRQYXJhbXNKc29uID0gcmVzdWx0UGFyYW1ldGVyID8gSlNPTi5zdHJpbmdpZnkocmVzdWx0UGFyYW1ldGVyKSA6IHVuZGVmaW5lZDtcblxuXHRcdC8vIFRoZSBEYXRhYmFzZUZhY2FkZSByZXR1cm5zIGEgSlNPTiBzdHJpbmcgcmVwcmVzZW50YXRpb24gb2YgdGhlIHJlc3VsdCBzZXRcblx0XHRjb25zdCByZXN1bHRzZXQgPSBEYXRhYmFzZUZhY2FkZS5xdWVyeShzcWwsIHBhcmFtc0pzb24sIGRhdGFzb3VyY2VOYW1lLCByZXN1bHRQYXJhbXNKc29uKTtcblxuXHRcdC8vIFBhcnNlIHRoZSBKU09OIHN0cmluZyBiYWNrIGludG8gYSBKYXZhU2NyaXB0IGFycmF5IG9mIG9iamVjdHNcblx0XHRyZXR1cm4gSlNPTi5wYXJzZShyZXN1bHRzZXQpO1xuXHR9XG5cdFxuXHQvKipcblx0ICogRXhlY3V0ZXMgYSBTUUwgcXVlcnkgd2l0aCBuYW1lZCBwYXJhbWV0ZXJzIChlLmcuLCBcIjpuYW1lXCIsIFwiOmlkXCIpLlxuXHQgKlxuXHQgKiBAcGFyYW0gc3FsIFRoZSBTUUwgcXVlcnkgdG8gZXhlY3V0ZS5cblx0ICogQHBhcmFtIHBhcmFtZXRlcnMgQW4gb3B0aW9uYWwgYXJyYXkgb2YgTmFtZWRRdWVyeVBhcmFtZXRlciBvYmplY3RzLlxuXHQgKiBAcGFyYW0gZGF0YXNvdXJjZU5hbWUgVGhlIG5hbWUgb2YgdGhlIGRhdGFiYXNlIGNvbm5lY3Rpb24gdG8gdXNlIChvcHRpb25hbCkuXG5cdCAqIEByZXR1cm5zIEFuIGFycmF5IG9mIHJlY29yZHMgcmVwcmVzZW50aW5nIHRoZSBxdWVyeSByZXN1bHRzLlxuXHQgKi9cblx0cHVibGljIHN0YXRpYyBleGVjdXRlTmFtZWQoc3FsOiBzdHJpbmcsIHBhcmFtZXRlcnM/OiBOYW1lZFF1ZXJ5UGFyYW1ldGVyW10sIGRhdGFzb3VyY2VOYW1lPzogc3RyaW5nKTogYW55W10ge1xuXHRcdC8vIFNlcmlhbGl6ZSB0aGUgYXJyYXkgb2YgbmFtZWQgcGFyYW1ldGVycyBmb3IgdGhlIEphdmEgZmFjYWRlXG5cdFx0Y29uc3QgcGFyYW1zSnNvbiA9IHBhcmFtZXRlcnMgPyBKU09OLnN0cmluZ2lmeShwYXJhbWV0ZXJzKSA6IHVuZGVmaW5lZDtcblxuXHRcdC8vIFRoZSBEYXRhYmFzZUZhY2FkZSByZXR1cm5zIGEgSlNPTiBzdHJpbmcgcmVwcmVzZW50YXRpb24gb2YgdGhlIHJlc3VsdCBzZXRcblx0XHRjb25zdCByZXN1bHRzZXQgPSBEYXRhYmFzZUZhY2FkZS5xdWVyeU5hbWVkKHNxbCwgcGFyYW1zSnNvbiwgZGF0YXNvdXJjZU5hbWUpO1xuXG5cdFx0Ly8gUGFyc2UgdGhlIEpTT04gc3RyaW5nIGJhY2sgaW50byBhIEphdmFTY3JpcHQgYXJyYXkgb2Ygb2JqZWN0c1xuXHRcdHJldHVybiBKU09OLnBhcnNlKHJlc3VsdHNldCk7XG5cdH1cbn1cblxuLy8gQHRzLWlnbm9yZVxuaWYgKHR5cGVvZiBtb2R1bGUgIT09ICd1bmRlZmluZWQnKSB7XG5cdC8vIEB0cy1pZ25vcmVcblx0bW9kdWxlLmV4cG9ydHMgPSBRdWVyeTtcbn0iXSwKICAibWFwcGluZ3MiOiAiQUFNQSxNQUFNLGlCQUFpQixLQUFLLEtBQUssd0RBQXdEO0FBNEJsRixNQUFNLE1BQU07QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQSxFQVdsQixPQUFjLFFBQVEsS0FBYSxZQUFvRSxnQkFBMEIsaUJBQTBDO0FBRTFLLFVBQU0sYUFBYSxhQUFhLEtBQUssVUFBVSxVQUFVLElBQUk7QUFDN0QsVUFBTSxtQkFBbUIsa0JBQWtCLEtBQUssVUFBVSxlQUFlLElBQUk7QUFHN0UsVUFBTSxZQUFZLGVBQWUsTUFBTSxLQUFLLFlBQVksZ0JBQWdCLGdCQUFnQjtBQUd4RixXQUFPLEtBQUssTUFBTSxTQUFTO0FBQUEsRUFDNUI7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUEsRUFVQSxPQUFjLGFBQWEsS0FBYSxZQUFvQyxnQkFBZ0M7QUFFM0csVUFBTSxhQUFhLGFBQWEsS0FBSyxVQUFVLFVBQVUsSUFBSTtBQUc3RCxVQUFNLFlBQVksZUFBZSxXQUFXLEtBQUssWUFBWSxjQUFjO0FBRzNFLFdBQU8sS0FBSyxNQUFNLFNBQVM7QUFBQSxFQUM1QjtBQUNEO0FBR0EsSUFBSSxPQUFPLFdBQVcsYUFBYTtBQUVsQyxTQUFPLFVBQVU7QUFDbEI7IiwKICAibmFtZXMiOiBbXQp9Cg==
|
|
@@ -0,0 +1,129 @@
|
|
|
1
|
+
import { store, translator } from "@aerokit/sdk/db";
|
|
2
|
+
class Repository {
|
|
3
|
+
constructor(entityConstructor) {
|
|
4
|
+
this.entityConstructor = entityConstructor;
|
|
5
|
+
if (!this.entityConstructor.$entity_name) {
|
|
6
|
+
this.entityConstructor.$entity_name = store.getEntityName(this.entityConstructor.name);
|
|
7
|
+
this.entityConstructor.$table_name = store.getTableName(this.entityConstructor.name);
|
|
8
|
+
this.entityConstructor.$id_name = store.getIdName(this.entityConstructor.name);
|
|
9
|
+
this.entityConstructor.$id_column = store.getIdColumn(this.entityConstructor.name);
|
|
10
|
+
}
|
|
11
|
+
}
|
|
12
|
+
getEntityName() {
|
|
13
|
+
return this.entityConstructor.$entity_name;
|
|
14
|
+
}
|
|
15
|
+
getTableName() {
|
|
16
|
+
return this.entityConstructor.$table_name;
|
|
17
|
+
}
|
|
18
|
+
getIdName() {
|
|
19
|
+
return this.entityConstructor.$id_name;
|
|
20
|
+
}
|
|
21
|
+
getIdColumn() {
|
|
22
|
+
return this.entityConstructor.$id_column;
|
|
23
|
+
}
|
|
24
|
+
/**
|
|
25
|
+
* Finds all entities matching the given options.
|
|
26
|
+
*/
|
|
27
|
+
findAll(options = {}) {
|
|
28
|
+
const list = store.list(this.getEntityName(), options);
|
|
29
|
+
translator.translateList(list, options.language, this.getTableName());
|
|
30
|
+
return list;
|
|
31
|
+
}
|
|
32
|
+
/**
|
|
33
|
+
* Finds a single entity by its primary key ID.
|
|
34
|
+
*/
|
|
35
|
+
findById(id, options = {}) {
|
|
36
|
+
const entity = store.get(this.getEntityName(), id);
|
|
37
|
+
translator.translateEntity(entity, id, options.language, this.getTableName());
|
|
38
|
+
return entity ?? void 0;
|
|
39
|
+
}
|
|
40
|
+
/**
|
|
41
|
+
* Creates a new entity in the database.
|
|
42
|
+
* @returns The generated ID (string or number).
|
|
43
|
+
*/
|
|
44
|
+
create(entity) {
|
|
45
|
+
const id = store.save(this.getEntityName(), entity);
|
|
46
|
+
this.triggerEvent({
|
|
47
|
+
operation: "create",
|
|
48
|
+
table: this.getTableName(),
|
|
49
|
+
entity,
|
|
50
|
+
key: {
|
|
51
|
+
name: this.getIdName(),
|
|
52
|
+
column: this.getIdColumn(),
|
|
53
|
+
value: id
|
|
54
|
+
}
|
|
55
|
+
});
|
|
56
|
+
return id;
|
|
57
|
+
}
|
|
58
|
+
/**
|
|
59
|
+
* Updates an existing entity.
|
|
60
|
+
* The entity must contain the primary key.
|
|
61
|
+
*/
|
|
62
|
+
update(entity) {
|
|
63
|
+
const idName = this.getIdName();
|
|
64
|
+
const id = entity[idName];
|
|
65
|
+
const previousEntity = this.findById(id);
|
|
66
|
+
store.update(this.getEntityName(), entity);
|
|
67
|
+
this.triggerEvent({
|
|
68
|
+
operation: "update",
|
|
69
|
+
table: this.getTableName(),
|
|
70
|
+
entity,
|
|
71
|
+
previousEntity,
|
|
72
|
+
key: {
|
|
73
|
+
name: idName,
|
|
74
|
+
column: this.getIdColumn(),
|
|
75
|
+
value: id
|
|
76
|
+
}
|
|
77
|
+
});
|
|
78
|
+
}
|
|
79
|
+
/**
|
|
80
|
+
* Creates the entity if the ID is null/undefined, otherwise updates it.
|
|
81
|
+
* If an ID is provided but the entity doesn't exist, it creates it.
|
|
82
|
+
* @returns The entity's ID.
|
|
83
|
+
*/
|
|
84
|
+
upsert(entity) {
|
|
85
|
+
const id = entity[this.getIdName()];
|
|
86
|
+
if (id === null || id === void 0) {
|
|
87
|
+
return store.save(this.getEntityName(), entity);
|
|
88
|
+
}
|
|
89
|
+
const existingEntity = store.get(this.getEntityName(), id);
|
|
90
|
+
if (existingEntity) {
|
|
91
|
+
this.update(entity);
|
|
92
|
+
return id;
|
|
93
|
+
} else {
|
|
94
|
+
return store.save(this.getEntityName(), entity);
|
|
95
|
+
}
|
|
96
|
+
}
|
|
97
|
+
/**
|
|
98
|
+
* Deletes an entity by its primary key ID.
|
|
99
|
+
*/
|
|
100
|
+
deleteById(id) {
|
|
101
|
+
const entity = store.get(this.getEntityName(), id);
|
|
102
|
+
store.remove(this.getEntityName(), id);
|
|
103
|
+
this.triggerEvent({
|
|
104
|
+
operation: "delete",
|
|
105
|
+
table: this.getTableName(),
|
|
106
|
+
entity,
|
|
107
|
+
key: {
|
|
108
|
+
name: this.getIdName(),
|
|
109
|
+
column: this.getIdColumn(),
|
|
110
|
+
value: id
|
|
111
|
+
}
|
|
112
|
+
});
|
|
113
|
+
}
|
|
114
|
+
/**
|
|
115
|
+
* Counts the number of entities matching the given options.
|
|
116
|
+
*/
|
|
117
|
+
count(options) {
|
|
118
|
+
return store.count(this.getEntityName(), options);
|
|
119
|
+
}
|
|
120
|
+
/**
|
|
121
|
+
* Protected method intended for subclass overriding or internal event handling.
|
|
122
|
+
*/
|
|
123
|
+
async triggerEvent(_data) {
|
|
124
|
+
}
|
|
125
|
+
}
|
|
126
|
+
export {
|
|
127
|
+
Repository
|
|
128
|
+
};
|
|
129
|
+
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../src/db/repository.ts"],
  "sourcesContent": ["import { store, translator, EntityConstructor, Options } from \"@aerokit/sdk/db\";\n\n/**\n * Represents the data structure passed to the event trigger method before/after an operation.\n */\nexport interface EntityEvent<T> {\n    readonly operation: 'create' | 'update' | 'delete';\n    readonly table: string;\n    readonly entity: Partial<T>; // Use Partial<T> for create/delete where some fields might be missing\n    readonly key: {\n        name: string;\n        column: string;\n        value: string | number;\n    }\n    readonly previousEntity?: T;\n}\n\n\n// --- Repository Class ---\n\n/**\n * Abstract base class for data access/business logic, wrapping the `store` API.\n * It handles entity metadata lookup, CRUD operations, translation, and event triggering.\n * @template T The entity type (must be an object).\n */\nexport abstract class Repository<T extends Record<string, any>> {\n\n    private entityConstructor: EntityConstructor;\n\n    constructor(entityConstructor: EntityConstructor) {\n        this.entityConstructor = entityConstructor;\n        \n        // Caches entity metadata (name, table, id) onto the constructor function for static access\n\t\tif (!this.entityConstructor.$entity_name) {\n            // Assumes store methods return non-null strings\n\t\t\tthis.entityConstructor.$entity_name = (store as any).getEntityName(this.entityConstructor.name);\n\t\t\tthis.entityConstructor.$table_name = (store as any).getTableName(this.entityConstructor.name);\n\t\t\tthis.entityConstructor.$id_name = (store as any).getIdName(this.entityConstructor.name);\n\t\t\tthis.entityConstructor.$id_column = (store as any).getIdColumn(this.entityConstructor.name);\n\t\t}\n    }\n\n    protected getEntityName(): string {\n        // Use non-null assertion since the constructor guarantees these properties exist\n        return this.entityConstructor.$entity_name!;\n    }\n\n    protected getTableName(): string {\n        return this.entityConstructor.$table_name!;\n    }\n\n    protected getIdName(): string {\n        return this.entityConstructor.$id_name!;\n    }\n\n    protected getIdColumn(): string {\n        return this.entityConstructor.$id_column!;\n    }\n\n    /**\n     * Finds all entities matching the given options.\n     */\n    public findAll(options: Options = {}): T[] {\n        // Assume store.list returns T[] but we explicitly cast it to T[]\n        const list: T[] = (store as any).list(this.getEntityName(), options);\n        (translator as any).translateList(list, options.language, this.getTableName());\n        return list;\n    }\n\n    /**\n     * Finds a single entity by its primary key ID.\n     */\n    public findById(id: number | string, options: Options = {}): T | undefined {\n        // Assume store.get returns T or null/undefined\n        const entity: T | null = (store as any).get(this.getEntityName(), id);\n        (translator as any).translateEntity(entity, id, options.language, this.getTableName());\n        return entity ?? undefined;\n    }\n\n    /**\n     * Creates a new entity in the database.\n     * @returns The generated ID (string or number).\n     */\n    public create(entity: T): string | number {\n        const id = (store as any).save(this.getEntityName(), entity);\n        this.triggerEvent({\n            operation: \"create\",\n            table: this.getTableName(),\n            entity: entity,\n            key: {\n                name: this.getIdName(),\n                column: this.getIdColumn(),\n                value: id\n            }\n        });\n        return id;\n    }\n\n    /**\n     * Updates an existing entity.\n     * The entity must contain the primary key.\n     */\n    public update(entity: T): void {\n        const idName = this.getIdName();\n        const id = entity[idName] as (number | string);\n        \n        // Retrieve the entity state before update for the event payload\n        const previousEntity = this.findById(id);\n\n        (store as any).update(this.getEntityName(), entity);\n        \n        this.triggerEvent({\n            operation: \"update\",\n            table: this.getTableName(),\n            entity: entity,\n            previousEntity: previousEntity,\n            key: {\n                name: idName,\n                column: this.getIdColumn(),\n                value: id\n            }\n        });\n    }\n\n    /**\n     * Creates the entity if the ID is null/undefined, otherwise updates it.\n     * If an ID is provided but the entity doesn't exist, it creates it.\n     * @returns The entity's ID.\n     */\n    public upsert(entity: T): string | number {\n        const id = entity[this.getIdName()];\n        \n        // If no ID is present, save (create)\n        if (id === null || id === undefined) {\n            return (store as any).save(this.getEntityName(), entity);\n        }\n\n        // If ID is present, check existence\n        const existingEntity = (store as any).get(this.getEntityName(), id);\n        \n        if (existingEntity) {\n            this.update(entity);\n            return id;\n        } else {\n            // ID exists, but entity does not -> save (create with provided ID)\n            return (store as any).save(this.getEntityName(), entity);\n        }\n    }\n\n    /**\n     * Deletes an entity by its primary key ID.\n     */\n    public deleteById(id: number | string): void {\n        // Retrieve entity before removal for the event payload\n        const entity = (store as any).get(this.getEntityName(), id);\n        \n        (store as any).remove(this.getEntityName(), id);\n\n        this.triggerEvent({\n            operation: \"delete\",\n            table: this.getTableName(),\n            entity: entity,\n            key: {\n                name: this.getIdName(),\n                column: this.getIdColumn(),\n                value: id\n            }\n        });\n    }\n\n    /**\n     * Counts the number of entities matching the given options.\n     */\n    public count(options?: Options): number {\n        return (store as any).count(this.getEntityName(), options);\n    }\n\n    /**\n     * Protected method intended for subclass overriding or internal event handling.\n     */\n    protected async triggerEvent(_data: EntityEvent<T>): Promise<void> {\n        // Empty body as in the original code\n    }\n}\n"],
  "mappings": "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",
  "names": []
}

|
|
@@ -0,0 +1,40 @@
|
|
|
1
|
+
const DatabaseFacade = Java.type("org.eclipse.dirigible.components.api.db.DatabaseFacade");
|
|
2
|
+
class Sequence {
|
|
3
|
+
/**
|
|
4
|
+
* Retrieves the next available value from a specified sequence.
|
|
5
|
+
*
|
|
6
|
+
* @param sequence The name of the database sequence.
|
|
7
|
+
* @param tableName Optional: The name of the table associated with the sequence (depends on database dialect/facade implementation).
|
|
8
|
+
* @param datasourceName Optional: The name of the database connection to use.
|
|
9
|
+
* @returns The next sequence value as a number.
|
|
10
|
+
*/
|
|
11
|
+
static nextval(sequence, tableName, datasourceName) {
|
|
12
|
+
return DatabaseFacade.nextval(sequence, datasourceName, tableName);
|
|
13
|
+
}
|
|
14
|
+
/**
|
|
15
|
+
* Creates a new database sequence.
|
|
16
|
+
*
|
|
17
|
+
* @param sequence The name of the sequence to create.
|
|
18
|
+
* @param start Optional: The starting value for the sequence (defaults to 1 if not provided).
|
|
19
|
+
* @param datasourceName Optional: The name of the database connection to use.
|
|
20
|
+
*/
|
|
21
|
+
static create(sequence, start, datasourceName) {
|
|
22
|
+
DatabaseFacade.createSequence(sequence, start, datasourceName);
|
|
23
|
+
}
|
|
24
|
+
/**
|
|
25
|
+
* Drops (deletes) an existing database sequence.
|
|
26
|
+
*
|
|
27
|
+
* @param sequence The name of the sequence to drop.
|
|
28
|
+
* @param datasourceName Optional: The name of the database connection to use.
|
|
29
|
+
*/
|
|
30
|
+
static drop(sequence, datasourceName) {
|
|
31
|
+
DatabaseFacade.dropSequence(sequence, datasourceName);
|
|
32
|
+
}
|
|
33
|
+
}
|
|
34
|
+
if (typeof module !== "undefined") {
|
|
35
|
+
module.exports = Sequence;
|
|
36
|
+
}
|
|
37
|
+
export {
|
|
38
|
+
Sequence
|
|
39
|
+
};
|
|
40
|
+
//# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vLi4vc3JjL2RiL3NlcXVlbmNlLnRzIl0sCiAgInNvdXJjZXNDb250ZW50IjogWyIvKipcbiAqIEFQSSBTZXF1ZW5jZVxuICpcbiAqIFByb3ZpZGVzIHN0YXRpYyBtZXRob2RzIGZvciBtYW5hZ2luZyBhbmQgYWNjZXNzaW5nIGRhdGFiYXNlIHNlcXVlbmNlcy5cbiAqL1xuXG4vLyBJbXBvcnQgdGhlIEphdmEgdHlwZSB1c2VkIHRvIGJyaWRnZSB0byB0aGUgdW5kZXJseWluZyBkYXRhYmFzZSBmdW5jdGlvbmFsaXR5LlxuY29uc3QgRGF0YWJhc2VGYWNhZGUgPSBKYXZhLnR5cGUoXCJvcmcuZWNsaXBzZS5kaXJpZ2libGUuY29tcG9uZW50cy5hcGkuZGIuRGF0YWJhc2VGYWNhZGVcIik7XG5cbi8qKlxuICogVXRpbGl0eSBjbGFzcyBmb3IgaW50ZXJhY3Rpbmcgd2l0aCBkYXRhYmFzZSBzZXF1ZW5jZSBvYmplY3RzLlxuICovXG5leHBvcnQgY2xhc3MgU2VxdWVuY2Uge1xuXG5cdC8qKlxuXHQgKiBSZXRyaWV2ZXMgdGhlIG5leHQgYXZhaWxhYmxlIHZhbHVlIGZyb20gYSBzcGVjaWZpZWQgc2VxdWVuY2UuXG5cdCAqXG5cdCAqIEBwYXJhbSBzZXF1ZW5jZSBUaGUgbmFtZSBvZiB0aGUgZGF0YWJhc2Ugc2VxdWVuY2UuXG5cdCAqIEBwYXJhbSB0YWJsZU5hbWUgT3B0aW9uYWw6IFRoZSBuYW1lIG9mIHRoZSB0YWJsZSBhc3NvY2lhdGVkIHdpdGggdGhlIHNlcXVlbmNlIChkZXBlbmRzIG9uIGRhdGFiYXNlIGRpYWxlY3QvZmFjYWRlIGltcGxlbWVudGF0aW9uKS5cblx0ICogQHBhcmFtIGRhdGFzb3VyY2VOYW1lIE9wdGlvbmFsOiBUaGUgbmFtZSBvZiB0aGUgZGF0YWJhc2UgY29ubmVjdGlvbiB0byB1c2UuXG5cdCAqIEByZXR1cm5zIFRoZSBuZXh0IHNlcXVlbmNlIHZhbHVlIGFzIGEgbnVtYmVyLlxuXHQgKi9cblx0cHVibGljIHN0YXRpYyBuZXh0dmFsKHNlcXVlbmNlOiBzdHJpbmcsIHRhYmxlTmFtZT86IHN0cmluZywgZGF0YXNvdXJjZU5hbWU/OiBzdHJpbmcpOiBudW1iZXIge1xuXHRcdC8vIE5vdGU6IFRoZSBvcmlnaW5hbCBKYXZhU2NyaXB0IG9yZGVyIG9mIGFyZ3VtZW50cyBmb3IgRGF0YWJhc2VGYWNhZGUubmV4dHZhbCBpczpcblx0XHQvLyBEYXRhYmFzZUZhY2FkZS5uZXh0dmFsKHNlcXVlbmNlLCBkYXRhc291cmNlTmFtZSwgdGFibGVOYW1lKTtcblx0XHRyZXR1cm4gRGF0YWJhc2VGYWNhZGUubmV4dHZhbChzZXF1ZW5jZSwgZGF0YXNvdXJjZU5hbWUsIHRhYmxlTmFtZSk7XG5cdH1cblxuXHQvKipcblx0ICogQ3JlYXRlcyBhIG5ldyBkYXRhYmFzZSBzZXF1ZW5jZS5cblx0ICpcblx0ICogQHBhcmFtIHNlcXVlbmNlIFRoZSBuYW1lIG9mIHRoZSBzZXF1ZW5jZSB0byBjcmVhdGUuXG5cdCAqIEBwYXJhbSBzdGFydCBPcHRpb25hbDogVGhlIHN0YXJ0aW5nIHZhbHVlIGZvciB0aGUgc2VxdWVuY2UgKGRlZmF1bHRzIHRvIDEgaWYgbm90IHByb3ZpZGVkKS5cblx0ICogQHBhcmFtIGRhdGFzb3VyY2VOYW1lIE9wdGlvbmFsOiBUaGUgbmFtZSBvZiB0aGUgZGF0YWJhc2UgY29ubmVjdGlvbiB0byB1c2UuXG5cdCAqL1xuXHRwdWJsaWMgc3RhdGljIGNyZWF0ZShzZXF1ZW5jZTogc3RyaW5nLCBzdGFydD86IG51bWJlciwgZGF0YXNvdXJjZU5hbWU/OiBzdHJpbmcpOiB2b2lkIHtcblx0XHREYXRhYmFzZUZhY2FkZS5jcmVhdGVTZXF1ZW5jZShzZXF1ZW5jZSwgc3RhcnQsIGRhdGFzb3VyY2VOYW1lKTtcblx0fVxuXG5cdC8qKlxuXHQgKiBEcm9wcyAoZGVsZXRlcykgYW4gZXhpc3RpbmcgZGF0YWJhc2Ugc2VxdWVuY2UuXG5cdCAqXG5cdCAqIEBwYXJhbSBzZXF1ZW5jZSBUaGUgbmFtZSBvZiB0aGUgc2VxdWVuY2UgdG8gZHJvcC5cblx0ICogQHBhcmFtIGRhdGFzb3VyY2VOYW1lIE9wdGlvbmFsOiBUaGUgbmFtZSBvZiB0aGUgZGF0YWJhc2UgY29ubmVjdGlvbiB0byB1c2UuXG5cdCAqL1xuXHRwdWJsaWMgc3RhdGljIGRyb3Aoc2VxdWVuY2U6IHN0cmluZywgZGF0YXNvdXJjZU5hbWU/OiBzdHJpbmcpOiB2b2lkIHtcblx0XHREYXRhYmFzZUZhY2FkZS5kcm9wU2VxdWVuY2Uoc2VxdWVuY2UsIGRhdGFzb3VyY2VOYW1lKTtcblx0fVxufVxuXG4vLyBAdHMtaWdub3JlXG5pZiAodHlwZW9mIG1vZHVsZSAhPT0gJ3VuZGVmaW5lZCcpIHtcblx0Ly8gQHRzLWlnbm9yZVxuXHRtb2R1bGUuZXhwb3J0cyA9IFNlcXVlbmNlO1xufSJdLAogICJtYXBwaW5ncyI6ICJBQU9BLE1BQU0saUJBQWlCLEtBQUssS0FBSyx3REFBd0Q7QUFLbEYsTUFBTSxTQUFTO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBLEVBVXJCLE9BQWMsUUFBUSxVQUFrQixXQUFvQixnQkFBaUM7QUFHNUYsV0FBTyxlQUFlLFFBQVEsVUFBVSxnQkFBZ0IsU0FBUztBQUFBLEVBQ2xFO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQSxFQVNBLE9BQWMsT0FBTyxVQUFrQixPQUFnQixnQkFBK0I7QUFDckYsbUJBQWUsZUFBZSxVQUFVLE9BQU8sY0FBYztBQUFBLEVBQzlEO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUEsRUFRQSxPQUFjLEtBQUssVUFBa0IsZ0JBQStCO0FBQ25FLG1CQUFlLGFBQWEsVUFBVSxjQUFjO0FBQUEsRUFDckQ7QUFDRDtBQUdBLElBQUksT0FBTyxXQUFXLGFBQWE7QUFFbEMsU0FBTyxVQUFVO0FBQ2xCOyIsCiAgIm5hbWVzIjogW10KfQo=
|