@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,199 @@
|
|
|
1
|
+
import { handlerFunction } from "./resource-common";
|
|
2
|
+
class ResourceMethod {
|
|
3
|
+
/**
|
|
4
|
+
* @param oConfiguration Initial configuration object.
|
|
5
|
+
* @param controller The HttpController instance.
|
|
6
|
+
* @param resource The parent Resource instance.
|
|
7
|
+
* @param mappings The parent ResourceMappings instance.
|
|
8
|
+
* @returns {ResourceMethod}
|
|
9
|
+
*/
|
|
10
|
+
constructor(oConfiguration, controller, resource, mappings) {
|
|
11
|
+
this.cfg = oConfiguration || {};
|
|
12
|
+
this._resource = resource;
|
|
13
|
+
this.controller = controller;
|
|
14
|
+
if (mappings) {
|
|
15
|
+
this.resource = mappings.resource.bind(mappings);
|
|
16
|
+
this.resourcePath = this.path = this.resource;
|
|
17
|
+
}
|
|
18
|
+
}
|
|
19
|
+
/**
|
|
20
|
+
* Delegates to the HttpController's execute function to process the request.
|
|
21
|
+
*/
|
|
22
|
+
execute() {
|
|
23
|
+
this.controller?.execute?.(...arguments);
|
|
24
|
+
}
|
|
25
|
+
// --- Delegation to Resource HTTP Methods for Chaining ---
|
|
26
|
+
/**
|
|
27
|
+
* Delegates to the parent Resource's 'get' method.
|
|
28
|
+
*/
|
|
29
|
+
get() {
|
|
30
|
+
return this._resource?.["get"]?.(...arguments);
|
|
31
|
+
}
|
|
32
|
+
/**
|
|
33
|
+
* Delegates to the parent Resource's 'post' method.
|
|
34
|
+
*/
|
|
35
|
+
post() {
|
|
36
|
+
return this._resource?.["post"]?.(...arguments);
|
|
37
|
+
}
|
|
38
|
+
/**
|
|
39
|
+
* Delegates to the parent Resource's 'put' method.
|
|
40
|
+
*/
|
|
41
|
+
put() {
|
|
42
|
+
return this._resource?.["put"]?.(...arguments);
|
|
43
|
+
}
|
|
44
|
+
/**
|
|
45
|
+
* Delegates to the parent Resource's 'delete' method.
|
|
46
|
+
*/
|
|
47
|
+
delete() {
|
|
48
|
+
return this._resource?.["delete"]?.(...arguments);
|
|
49
|
+
}
|
|
50
|
+
/**
|
|
51
|
+
* Delegates to the parent Resource's 'remove' method.
|
|
52
|
+
*/
|
|
53
|
+
remove() {
|
|
54
|
+
return this._resource?.["remove"]?.(...arguments);
|
|
55
|
+
}
|
|
56
|
+
/**
|
|
57
|
+
* Delegates to the parent Resource's 'method' method.
|
|
58
|
+
*/
|
|
59
|
+
method() {
|
|
60
|
+
return this._resource?.["method"]?.(...arguments);
|
|
61
|
+
}
|
|
62
|
+
/**
|
|
63
|
+
* Returns the configuration object for this ResourceMethod instance.
|
|
64
|
+
*
|
|
65
|
+
* @returns The configuration object.
|
|
66
|
+
*/
|
|
67
|
+
configuration() {
|
|
68
|
+
return this.cfg;
|
|
69
|
+
}
|
|
70
|
+
// --- Handler Definition Methods ---
|
|
71
|
+
/**
|
|
72
|
+
* Applies a callback function for the **before** phase of processing a matched resource request.
|
|
73
|
+
*
|
|
74
|
+
* @param fHandler Callback function for the before phase.
|
|
75
|
+
* @returns The ResourceMethod instance for method chaining.
|
|
76
|
+
*/
|
|
77
|
+
before(fHandler) {
|
|
78
|
+
return handlerFunction(this, this.configuration(), "before", fHandler);
|
|
79
|
+
}
|
|
80
|
+
/**
|
|
81
|
+
* Applies a callback function for processing a matched resource request (**serve** phase).
|
|
82
|
+
*
|
|
83
|
+
* @param fHandler Callback function for the serve phase.
|
|
84
|
+
* @returns The ResourceMethod instance for method chaining.
|
|
85
|
+
*/
|
|
86
|
+
serve(fHandler) {
|
|
87
|
+
return handlerFunction(this, this.configuration(), "serve", fHandler);
|
|
88
|
+
}
|
|
89
|
+
/**
|
|
90
|
+
* Applies a callback function for the **catch** errors phase of processing a matched resource request.
|
|
91
|
+
*
|
|
92
|
+
* @param fHandler Callback function for the catch phase.
|
|
93
|
+
* @returns The ResourceMethod instance for method chaining.
|
|
94
|
+
*/
|
|
95
|
+
catch(fHandler) {
|
|
96
|
+
return handlerFunction(this, this.configuration(), "catch", fHandler);
|
|
97
|
+
}
|
|
98
|
+
/**
|
|
99
|
+
* Applies a callback function for the **finally** phase of processing a matched resource request.
|
|
100
|
+
*
|
|
101
|
+
* @param fHandler Callback function for the finally phase.
|
|
102
|
+
* @returns The ResourceMethod instance for method chaining.
|
|
103
|
+
*/
|
|
104
|
+
finally(fHandler) {
|
|
105
|
+
return handlerFunction(this, this.configuration(), "finally", fHandler);
|
|
106
|
+
}
|
|
107
|
+
// --- MIME Type Configuration Methods ---
|
|
108
|
+
/**
|
|
109
|
+
* Defines the content MIME type(s), which this ResourceMethod expects as input (**consumes**).
|
|
110
|
+
*
|
|
111
|
+
* @param mimeTypes Sets the mime types that this ResourceMethod is capable to consume.
|
|
112
|
+
* @returns The ResourceMethod instance for method chaining.
|
|
113
|
+
*/
|
|
114
|
+
consumes(mimeTypes) {
|
|
115
|
+
return this.mimeSetting("consumes", mimeTypes);
|
|
116
|
+
}
|
|
117
|
+
/**
|
|
118
|
+
* Defines the HTTP response payload MIME type(s), which this ResourceMethod request processing function outputs, i.e.
|
|
119
|
+
* those that it 'produces'. At runtime, the Accept request header will be matched for compatibility with this setting
|
|
120
|
+
* to elicit request processing functions.
|
|
121
|
+
* Note that the matching is performed by compatibility, not strict equality, i.e. the MIME type format wildcards are
|
|
122
|
+
* considered too. For example, a request Accept header "*\/json" will match a produces setting "application\/json".
|
|
123
|
+
*
|
|
124
|
+
* @example
|
|
125
|
+
* ```js
|
|
126
|
+
* rs.service()
|
|
127
|
+
* .resource("")
|
|
128
|
+
* .get(function(){})
|
|
129
|
+
* .produces(["application\/json"])
|
|
130
|
+
* .execute();
|
|
131
|
+
* .
|
|
132
|
+
* ```
|
|
133
|
+
*
|
|
134
|
+
* Take care to make sure that the produces constraint correctly describes the response contenty MIME types that the request
|
|
135
|
+
* processing function can produce so that only client request that can accept them land there.
|
|
136
|
+
*
|
|
137
|
+
* A note about method argument multiplicity (string vs array of strings).
|
|
138
|
+
* One of the arguments of the produce method will translate to the response Content-Type property, which is known to be a
|
|
139
|
+
* single value header by [specification](https://tools.ietf.org/html/rfc7231#section-3.1.1.5). There are two reasons why
|
|
140
|
+
* the method accepts array and not a single value only:
|
|
141
|
+
*
|
|
142
|
+
* 1. Normally, when matched, content types are evaluated for semantic compatibility and not strict equality on both sides
|
|
143
|
+
* - client and server. Providing a range of compatible MIME types instead of single value, increases the range of acceptable
|
|
144
|
+
* requests for procesing, while reducing the stricness of the requirements on the client making the request. For example,
|
|
145
|
+
* declaring ["text/json,"application/json"] as produced types makes requests with any of these accept headers (or a combination
|
|
146
|
+
* of them) acceptable for processing: "*\/json", "text/json", "application/json", "*\/*".
|
|
147
|
+
*
|
|
148
|
+
* 2. Although in most cases a handler function will produce payload in single format (media type), it is quite possible to
|
|
149
|
+
* desgin it also as a controller that produces alternative payload in different formats. In these cases you need produces
|
|
150
|
+
* that declares all supported media types so that the request with a relaxed Accept header matching any of them can land
|
|
151
|
+
* in this function. That makes the routing a bit less transparent and dependent on the client, but may prove valuable for
|
|
152
|
+
* certian cases.
|
|
153
|
+
*
|
|
154
|
+
* In any case it is responsibility of the request processing function to set the correct Content-Type header.
|
|
155
|
+
*
|
|
156
|
+
* @param mimeTypes Sets the mime type(s) that this ResourceMethod may produce.
|
|
157
|
+
* @returns The ResourceMethod instance for method chaining.
|
|
158
|
+
*/
|
|
159
|
+
produces(mimeTypes) {
|
|
160
|
+
return this.mimeSetting("produces", mimeTypes);
|
|
161
|
+
}
|
|
162
|
+
/**
|
|
163
|
+
* Commmon function for initializng the 'consumes' and 'produces' arrays in the ResourceMethod instances.
|
|
164
|
+
* Before finalizing the configuration setup the function will remove duplicates with exact match filtering.
|
|
165
|
+
*
|
|
166
|
+
* @param mimeSettingName must be either 'consumes' or 'produces'.
|
|
167
|
+
* @param mimeTypes An array of strings formatted as mime types (type/subtype) or a single string.
|
|
168
|
+
* @returns The ResourceMethod instance to which the function is bound.
|
|
169
|
+
* @private
|
|
170
|
+
*/
|
|
171
|
+
mimeSetting(mimeSettingName, mimeTypes) {
|
|
172
|
+
let arrMimeTypes;
|
|
173
|
+
if (typeof mimeTypes === "string") {
|
|
174
|
+
arrMimeTypes = [mimeTypes];
|
|
175
|
+
} else if (Array.isArray(mimeTypes)) {
|
|
176
|
+
arrMimeTypes = mimeTypes;
|
|
177
|
+
} else {
|
|
178
|
+
throw new Error("Invalid argument: " + mimeSettingName + " mime type argument must be valid MIME type string or array of such strings, but instead is " + typeof mimeTypes);
|
|
179
|
+
}
|
|
180
|
+
arrMimeTypes.forEach((mimeType) => {
|
|
181
|
+
const mt = mimeType.split("/");
|
|
182
|
+
if (mt.length !== 2 || !mt[0] || !mt[1])
|
|
183
|
+
throw new Error("Invalid argument. Not a valid MIME type format type/subtype: " + mimeType);
|
|
184
|
+
});
|
|
185
|
+
if (!this.cfg[mimeSettingName]) {
|
|
186
|
+
this.cfg[mimeSettingName] = [];
|
|
187
|
+
}
|
|
188
|
+
const existingMimes = this.cfg[mimeSettingName];
|
|
189
|
+
const newMimeTypes = arrMimeTypes.filter((mimeType) => {
|
|
190
|
+
return existingMimes.indexOf(mimeType) < 0;
|
|
191
|
+
});
|
|
192
|
+
this.cfg[mimeSettingName] = existingMimes.concat(newMimeTypes);
|
|
193
|
+
return this;
|
|
194
|
+
}
|
|
195
|
+
}
|
|
196
|
+
export {
|
|
197
|
+
ResourceMethod
|
|
198
|
+
};
|
|
199
|
+
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../../src/http/rs/resource-method.ts"],
  "sourcesContent": ["import { handlerFunction } from \"./resource-common\";\n\n/**\n * Interface for the internal configuration object of a ResourceMethod.\n */\ninterface ResourceMethodConfig {\n    consumes?: string[];\n    produces?: string[];\n    before?: Function;\n    serve?: Function; // Could also be named 'handler'\n    catch?: Function;\n    finally?: Function;\n    // Add other relevant configuration properties as they become known\n    [key: string]: any;\n}\n\n/**\n * Constructor function for ResourceMethod instances.\n * This class handles the fluent configuration for a single HTTP method handler (e.g., GET)\n * attached to a Resource.\n * \n * /**\n * Constructor function for ResourceMethod instances.\n * All parameters of the function are optional.\n *\n * Providing oConfiguration will initialize this instance with some initial configuration instead of starting\n * entirely from scratch. Note that the configuration object schema must be compliant with the one produced by\n * the ResourceMethod itself. If this parameter is omited, setup will start from scratch.\n *\n * Provisioning controller, will inject a reference to the execute method of the controller so that it can be\n * fluently invoked in the scope of this ResourceMehtod instance as part of the method chaining flow. The execute\n * function scope is bound to the controller instance for this ResourceMethod.\n *\n * @example\n * ```js\n * rs.service()\n *  .resource('')\n * \t\t.get()\n * \t.execute();\n * ```\n *\n * Provisioning resource, will inject a reference ot the HTTP method functions of the Resource class (get, post,\n * put, delete, remove, method) so that they can be fluently invoked in the scope of this ResourceMethod instance\n * as part of the method chaining flow. The functions are bound to the resource instance for this ResourceMethod.\n *\n * @example\n * ```js\n * rs.service()\n *  .resource('')\n * \t\t.get(function(){})\n * \t\t.post(function(){})\n * \t\t.put(function(){})\n * \t\t.remove(function(){})\n * .execute();\n * ```\n *\n * Provisioning mappings, will inject a reference ot the resource method of the ResourceMappings class so that\n * it can be fluently invoked in the scope of this ResourceMethod instance as part of the method chaining flow.\n * The function is bound to the mappings instance for this ResourceMethod.\n *\n * @example\n * ```js\n * rs.service()\n *  .resource('')\n * \t\t.get(function(){})\n * \t.resource('{id}')\n * \t\t.get(function(){})\n * .execute();\n * ``\n * \n */\nexport class ResourceMethod {\n    cfg: ResourceMethodConfig;\n    _resource: any; // Reference to the parent Resource instance\n    controller: any; // Reference to the HttpController instance\n\n    // Fluent API aliases/delegates bound to ResourceMappings/Resource\n    resource: Function;\n    resourcePath: Function;\n    path: Function;\n\n    /**\n     * @param oConfiguration Initial configuration object.\n     * @param controller The HttpController instance.\n     * @param resource The parent Resource instance.\n     * @param mappings The parent ResourceMappings instance.\n     * @returns {ResourceMethod}\n     */\n    constructor(oConfiguration: any, controller: any, resource: any, mappings: any) {\n        this.cfg = oConfiguration || {};\n        this._resource = resource;\n        this.controller = controller;\n\n        if (mappings) {\n            // Bind the resource/path methods from ResourceMappings for method chaining\n            this.resource = mappings.resource.bind(mappings);\n            this.resourcePath = this.path = this.resource; // aliases\n        }\n    }\n\n    /**\n     * Delegates to the HttpController's execute function to process the request.\n     */\n    execute(): void {\n        // Use optional chaining as controller might not be available in all setups\n        this.controller?.execute?.(...arguments);\n    }\n\n    // --- Delegation to Resource HTTP Methods for Chaining ---\n\n    /**\n     * Delegates to the parent Resource's 'get' method.\n     */\n    get(): any {\n        return this._resource?.[\"get\"]?.(...arguments);\n    }\n\n    /**\n     * Delegates to the parent Resource's 'post' method.\n     */\n    post(): any {\n        return this._resource?.[\"post\"]?.(...arguments);\n    }\n\n    /**\n     * Delegates to the parent Resource's 'put' method.\n     */\n    put(): any {\n        return this._resource?.[\"put\"]?.(...arguments);\n    }\n\n    /**\n     * Delegates to the parent Resource's 'delete' method.\n     */\n    delete(): any {\n        return this._resource?.[\"delete\"]?.(...arguments);\n    }\n\n    /**\n     * Delegates to the parent Resource's 'remove' method.\n     */\n    remove(): any {\n        return this._resource?.[\"remove\"]?.(...arguments);\n    }\n\n    /**\n     * Delegates to the parent Resource's 'method' method.\n     */\n    method(): any {\n        return this._resource?.[\"method\"]?.(...arguments);\n    }\n\n    /**\n     * Returns the configuration object for this ResourceMethod instance.\n     *\n     * @returns The configuration object.\n     */\n    configuration(): ResourceMethodConfig {\n        return this.cfg;\n    };\n\n    // --- Handler Definition Methods ---\n\n    /**\n     * Applies a callback function for the **before** phase of processing a matched resource request.\n     *\n     * @param fHandler Callback function for the before phase.\n     * @returns The ResourceMethod instance for method chaining.\n     */\n    before(fHandler: Function): ResourceMethod {\n        return handlerFunction(this, this.configuration(), 'before', fHandler);\n    };\n\n    /**\n     * Applies a callback function for processing a matched resource request (**serve** phase).\n     *\n     * @param fHandler Callback function for the serve phase.\n     * @returns The ResourceMethod instance for method chaining.\n     */\n    serve(fHandler: Function): ResourceMethod {\n        return handlerFunction(this, this.configuration(), 'serve', fHandler);\n    };\n\n    /**\n     * Applies a callback function for the **catch** errors phase of processing a matched resource request.\n     *\n     * @param fHandler Callback function for the catch phase.\n     * @returns The ResourceMethod instance for method chaining.\n     */\n    catch(fHandler: Function): ResourceMethod {\n        return handlerFunction(this, this.configuration(), 'catch', fHandler);\n    };\n\n    /**\n     * Applies a callback function for the **finally** phase of processing a matched resource request.\n     *\n     * @param fHandler Callback function for the finally phase.\n     * @returns The ResourceMethod instance for method chaining.\n     */\n    finally(fHandler: Function): ResourceMethod {\n        return handlerFunction(this, this.configuration(), 'finally', fHandler);\n    };\n\n    // --- MIME Type Configuration Methods ---\n\n    /**\n     * Defines the content MIME type(s), which this ResourceMethod expects as input (**consumes**).\n     *\n     * @param mimeTypes Sets the mime types that this ResourceMethod is capable to consume.\n     * @returns The ResourceMethod instance for method chaining.\n     */\n    consumes(mimeTypes: string | string[]): ResourceMethod {\n        return this.mimeSetting('consumes', mimeTypes);\n    };\n\n    /**\n\t * Defines the HTTP response payload MIME type(s), which this ResourceMethod request processing function outputs, i.e.\n\t * those that it 'produces'. At runtime, the Accept request header will be matched for compatibility with this setting\n\t * to elicit request processing functions.\n\t * Note that the matching is performed by compatibility, not strict equality, i.e. the MIME type format wildcards are\n\t * considered too. For example, a request Accept header \"*\\/json\" will match a produces setting \"application\\/json\".\n\t * \n     * @example\n     * ```js\n     * rs.service()\n     *\t.resource(\"\")\n     * \t\t.get(function(){})\n     * \t\t\t.produces([\"application\\/json\"])\n     * .execute();\n     * \t.\n     * ```\n     *\n     * Take care to make sure that the produces constraint correctly describes the response contenty MIME types that the request\n     * processing function can produce so that only client request that can accept them land there.\n     *\n     * A note about method argument multiplicity (string vs array of strings).\n     * One of the arguments of the produce method will translate to the response Content-Type property, which is known to be a\n     * single value header by [specification](https://tools.ietf.org/html/rfc7231#section-3.1.1.5). There are two reasons why\n     * the method accepts array and not a single value only:\n     *\n     * 1. Normally, when matched, content types are evaluated for semantic compatibility and not strict equality on both sides\n     *  - client and server. Providing a range of compatible MIME types instead of single value, increases the range of acceptable\n     * requests for procesing, while reducing the stricness of the requirements on the client making the request. For example,\n     * declaring [\"text/json,\"application/json\"] as produced types makes requests with any of these accept headers (or a combination\n     * of them) acceptable for processing: \"*\\/json\", \"text/json\", \"application/json\", \"*\\/*\".\n     *\n     * 2. Although in most cases a handler function will produce payload in single format (media type), it is quite possible to\n     * desgin it also as a controller that produces alternative payload in different formats. In these cases you need produces\n     * that declares all supported media types so that the request with a relaxed Accept header matching any of them can land\n     * in this function. That makes the routing a bit less transparent and dependent on the client, but may prove valuable for\n     * certian cases.\n     *\n     * In any case it is responsibility of the request processing function to set the correct Content-Type header.\n     *\n     * @param mimeTypes Sets the mime type(s) that this ResourceMethod may produce.\n     * @returns The ResourceMethod instance for method chaining.\n     */\n    produces(mimeTypes: string | string[]): ResourceMethod {\n        return this.mimeSetting('produces', mimeTypes);\n    };\n\n    /**\n     * Commmon function for initializng the 'consumes' and 'produces' arrays in the ResourceMethod instances.\n     * Before finalizing the configuration setup the function will remove duplicates with exact match filtering.\n     *\n     * @param mimeSettingName must be either 'consumes' or 'produces'.\n     * @param mimeTypes An array of strings formatted as mime types (type/subtype) or a single string.\n     * @returns The ResourceMethod instance to which the function is bound.\n     * @private\n     */\n    private mimeSetting(mimeSettingName: 'consumes' | 'produces', mimeTypes: string | string[]): ResourceMethod {\n\n        let arrMimeTypes: string[];\n\n        if (typeof mimeTypes === 'string') {\n            arrMimeTypes = [mimeTypes];\n        } else if (Array.isArray(mimeTypes)) {\n            arrMimeTypes = mimeTypes;\n        } else {\n            throw new Error('Invalid argument: ' + mimeSettingName + ' mime type argument must be valid MIME type string or array of such strings, but instead is ' + (typeof mimeTypes));\n        }\n\n        arrMimeTypes.forEach((mimeType) => {\n            const mt = mimeType.split('/');\n            if (mt.length !== 2 || !mt[0] || !mt[1])\n                throw new Error('Invalid argument. Not a valid MIME type format type/subtype: ' + mimeType);\n            // Basic format check is sufficient\n        });\n\n        if (!this.cfg[mimeSettingName]) {\n            this.cfg[mimeSettingName] = [];\n        }\n\n        // Deduplicate entries before concatenation\n        const existingMimes: string[] = this.cfg[mimeSettingName];\n        const newMimeTypes = arrMimeTypes.filter((mimeType) => {\n            return existingMimes.indexOf(mimeType) < 0;\n        });\n\n        this.cfg[mimeSettingName] = existingMimes.concat(newMimeTypes);\n\n        return this;\n    };\n}\n"],
  "mappings": "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",
  "names": []
}

|
|
@@ -0,0 +1,213 @@
|
|
|
1
|
+
import { handlerFunction } from "./resource-common";
|
|
2
|
+
import { ResourceMethod } from "./resource-method";
|
|
3
|
+
function arrayEquals(source, target) {
|
|
4
|
+
if (source === target)
|
|
5
|
+
return true;
|
|
6
|
+
if (!Array.isArray(source) || !Array.isArray(target))
|
|
7
|
+
return false;
|
|
8
|
+
if (source !== void 0 && target === void 0 || source === void 0 && target !== void 0)
|
|
9
|
+
return false;
|
|
10
|
+
if (source.length !== target.length)
|
|
11
|
+
return false;
|
|
12
|
+
for (let i = 0; i < source.length; i++) {
|
|
13
|
+
if (source[i] !== target[i])
|
|
14
|
+
return false;
|
|
15
|
+
}
|
|
16
|
+
return true;
|
|
17
|
+
}
|
|
18
|
+
class Resource {
|
|
19
|
+
/**
|
|
20
|
+
* @param sPath The base URL path for the resource.
|
|
21
|
+
* @param oConfiguration Optional configuration object (map of method handlers).
|
|
22
|
+
* @param controller Optional controller instance containing an execute method.
|
|
23
|
+
* @param mappings Optional object for resource mappings.
|
|
24
|
+
*/
|
|
25
|
+
constructor(sPath, oConfiguration, controller, mappings) {
|
|
26
|
+
this.sPath = sPath;
|
|
27
|
+
this.cfg = oConfiguration || {};
|
|
28
|
+
if (controller) {
|
|
29
|
+
this.controller = controller;
|
|
30
|
+
this.execute = controller.execute.bind(controller);
|
|
31
|
+
}
|
|
32
|
+
if (mappings) {
|
|
33
|
+
this.mappings = mappings;
|
|
34
|
+
}
|
|
35
|
+
}
|
|
36
|
+
/**
|
|
37
|
+
* Sets the URL path for this resource, overriding the one specified upon its construction,
|
|
38
|
+
* if a path string is provided as argument ot the method (i.e. acts as setter),
|
|
39
|
+
* or returns the path set for this resource, if the method is invoked without arguments (i.e. acts as getter).
|
|
40
|
+
*
|
|
41
|
+
* @param sPath The path property to be set for this resource.
|
|
42
|
+
* @returns The resource instance for method chaining (setter mode), or the path set for this resource (getter mode).
|
|
43
|
+
*/
|
|
44
|
+
path(sPath) {
|
|
45
|
+
if (arguments.length === 0)
|
|
46
|
+
return this.sPath;
|
|
47
|
+
this.sPath = sPath;
|
|
48
|
+
return this;
|
|
49
|
+
}
|
|
50
|
+
/**
|
|
51
|
+
* Creates a new HTTP method handling specification.
|
|
52
|
+
*
|
|
53
|
+
* @param sHttpMethod The HTTP method (method) (e.g., "GET").
|
|
54
|
+
* @param oConfiguration The handler specification(s) for this HTTP method. Can be a single object or array.
|
|
55
|
+
* @returns The ResourceMethod instance, or an array of ResourceMethod instances.
|
|
56
|
+
*/
|
|
57
|
+
method(sHttpMethod, oConfiguration) {
|
|
58
|
+
if (sHttpMethod === void 0)
|
|
59
|
+
throw new Error("Illegal sHttpMethod argument: " + sHttpMethod);
|
|
60
|
+
const method = sHttpMethod.toLowerCase();
|
|
61
|
+
if (!this.cfg[method])
|
|
62
|
+
this.cfg[method] = [];
|
|
63
|
+
let arrConfig = oConfiguration || {};
|
|
64
|
+
if (!Array.isArray(arrConfig)) {
|
|
65
|
+
arrConfig = [arrConfig];
|
|
66
|
+
}
|
|
67
|
+
const handlers = [];
|
|
68
|
+
arrConfig.forEach((handlerSpec) => {
|
|
69
|
+
const consumes = handlerSpec.consumes;
|
|
70
|
+
const produces = handlerSpec.produces;
|
|
71
|
+
const _h = this.find(sHttpMethod, consumes, produces);
|
|
72
|
+
if (!_h) {
|
|
73
|
+
this.cfg[method].push(handlerSpec);
|
|
74
|
+
} else {
|
|
75
|
+
const existingSpec = this.cfg[method].find(
|
|
76
|
+
(spec) => arrayEquals(spec.consumes, consumes) && arrayEquals(spec.produces, produces)
|
|
77
|
+
);
|
|
78
|
+
if (existingSpec) {
|
|
79
|
+
for (const propName in handlerSpec) {
|
|
80
|
+
if (Object.prototype.hasOwnProperty.call(handlerSpec, propName)) {
|
|
81
|
+
existingSpec[propName] = handlerSpec[propName];
|
|
82
|
+
}
|
|
83
|
+
}
|
|
84
|
+
}
|
|
85
|
+
}
|
|
86
|
+
const finalHandlerSpec = this.cfg[method].find(
|
|
87
|
+
(spec) => arrayEquals(spec.consumes, consumes) && arrayEquals(spec.produces, produces)
|
|
88
|
+
);
|
|
89
|
+
if (finalHandlerSpec) {
|
|
90
|
+
handlers.push(new ResourceMethod(finalHandlerSpec, this.controller, this, this.mappings));
|
|
91
|
+
}
|
|
92
|
+
});
|
|
93
|
+
return handlers.length > 1 ? handlers : handlers[0];
|
|
94
|
+
}
|
|
95
|
+
/**
|
|
96
|
+
* Internal utility method to handle the logic for HTTP verb shortcut methods (get, post, etc.).
|
|
97
|
+
*
|
|
98
|
+
* @param sMethodName The HTTP method name (e.g., 'get').
|
|
99
|
+
* @param args The arguments passed to the shortcut method.
|
|
100
|
+
* @returns The ResourceMethod instance or an array of instances.
|
|
101
|
+
*/
|
|
102
|
+
buildMethod(sMethodName, ...args) {
|
|
103
|
+
if (args.length > 0) {
|
|
104
|
+
if (typeof args[0] === "function") {
|
|
105
|
+
return this.method(sMethodName).serve(args[0]);
|
|
106
|
+
} else if (typeof args[0] === "object" && args[0] !== null) {
|
|
107
|
+
return this.method(sMethodName, args[0]);
|
|
108
|
+
} else {
|
|
109
|
+
throw new Error(`Invalid argument: Resource.${sMethodName} method first argument must be valid javascript function or configuration object, but instead is ${typeof args[0]} ${args[0]}`);
|
|
110
|
+
}
|
|
111
|
+
} else {
|
|
112
|
+
return this.method(sMethodName);
|
|
113
|
+
}
|
|
114
|
+
}
|
|
115
|
+
get() {
|
|
116
|
+
return this.buildMethod("get", ...arguments);
|
|
117
|
+
}
|
|
118
|
+
post() {
|
|
119
|
+
return this.buildMethod("post", ...arguments);
|
|
120
|
+
}
|
|
121
|
+
put() {
|
|
122
|
+
return this.buildMethod("put", ...arguments);
|
|
123
|
+
}
|
|
124
|
+
delete() {
|
|
125
|
+
return this.buildMethod("delete", ...arguments);
|
|
126
|
+
}
|
|
127
|
+
remove() {
|
|
128
|
+
return this.buildMethod("delete", ...arguments);
|
|
129
|
+
}
|
|
130
|
+
/**
|
|
131
|
+
* Finds a ResourceMethod with the given constraints.
|
|
132
|
+
*
|
|
133
|
+
* @param sVerb The name of the method property of the ResourceMethod in search (e.g., "GET").
|
|
134
|
+
* @param arrConsumesMimeTypeStrings The consumes constraint property of the ResourceMethod in search.
|
|
135
|
+
* @param arrProducesMimeTypeStrings The produces constraint property of the ResourceMethod in search.
|
|
136
|
+
* @returns The found ResourceMethod instance, or undefined if not found.
|
|
137
|
+
*/
|
|
138
|
+
find(sVerb, arrConsumesMimeTypeStrings, arrProducesMimeTypeStrings) {
|
|
139
|
+
let hit;
|
|
140
|
+
const sVerbLower = sVerb.toLowerCase();
|
|
141
|
+
Object.keys(this.cfg).filter((sVerbName) => sVerbName === sVerbLower).forEach((sVerbName) => {
|
|
142
|
+
this.cfg[sVerbName].forEach((verbHandlerSpec) => {
|
|
143
|
+
if (arrayEquals(verbHandlerSpec.consumes, arrConsumesMimeTypeStrings) && arrayEquals(verbHandlerSpec.produces, arrProducesMimeTypeStrings)) {
|
|
144
|
+
hit = new ResourceMethod(verbHandlerSpec, this.controller, this, this.mappings);
|
|
145
|
+
return;
|
|
146
|
+
}
|
|
147
|
+
});
|
|
148
|
+
if (hit)
|
|
149
|
+
return;
|
|
150
|
+
});
|
|
151
|
+
return hit;
|
|
152
|
+
}
|
|
153
|
+
/**
|
|
154
|
+
* Returns the configuration of this resource.
|
|
155
|
+
*
|
|
156
|
+
* @returns The resource configuration object.
|
|
157
|
+
*/
|
|
158
|
+
configuration() {
|
|
159
|
+
return this.cfg;
|
|
160
|
+
}
|
|
161
|
+
/**
|
|
162
|
+
* Instructs redirection of the request base don the parameter. If it is a stirng representing URI, the request will be
|
|
163
|
+
* redirected to this URI for any method. If it's a function it will be invoked and epxected to return a URI string to redirect to.
|
|
164
|
+
*
|
|
165
|
+
* @param fRedirector The function or string URI to redirect to.
|
|
166
|
+
* @returns The resource instance for method chaining.
|
|
167
|
+
*/
|
|
168
|
+
redirect(fRedirector) {
|
|
169
|
+
if (typeof fRedirector === "string") {
|
|
170
|
+
const redirectUri = fRedirector;
|
|
171
|
+
fRedirector = function() {
|
|
172
|
+
return redirectUri;
|
|
173
|
+
};
|
|
174
|
+
}
|
|
175
|
+
return handlerFunction(this, this.configuration(), "redirect", fRedirector);
|
|
176
|
+
}
|
|
177
|
+
/**
|
|
178
|
+
* Disables the ResourceMethods that match the given constraints
|
|
179
|
+
*
|
|
180
|
+
* @param sVerb The HTTP verb (e.g., "GET").
|
|
181
|
+
* @param arrConsumesTypeStrings The consumes constraint property of the ResourceMethod in search.
|
|
182
|
+
* @param arrProducesTypeStrings The produces constraint property of the ResourceMethod in search.
|
|
183
|
+
* @returns The resource instance for method chaining.
|
|
184
|
+
*/
|
|
185
|
+
disable(sVerb, arrConsumesTypeStrings, arrProducesTypeStrings) {
|
|
186
|
+
Object.keys(this.cfg).filter((sVerbName) => sVerb === void 0 || sVerb && sVerb.toLowerCase() === sVerbName).forEach((sVerbName) => {
|
|
187
|
+
for (let i = this.cfg[sVerbName].length - 1; i >= 0; i--) {
|
|
188
|
+
const verbHandlerSpec = this.cfg[sVerbName][i];
|
|
189
|
+
if (arrayEquals(verbHandlerSpec.consumes, arrConsumesTypeStrings) && arrayEquals(verbHandlerSpec.produces, arrProducesTypeStrings)) {
|
|
190
|
+
this.cfg[sVerbName].splice(i, 1);
|
|
191
|
+
}
|
|
192
|
+
}
|
|
193
|
+
});
|
|
194
|
+
return this;
|
|
195
|
+
}
|
|
196
|
+
/**
|
|
197
|
+
* Disables all but 'read' HTTP methods in this resource (GET, HEAD, TRACE).
|
|
198
|
+
*
|
|
199
|
+
* @returns The resource instance for method chaining.
|
|
200
|
+
*/
|
|
201
|
+
readonly() {
|
|
202
|
+
Object.keys(this.cfg).forEach((method) => {
|
|
203
|
+
if (!["get", "head", "trace"].includes(method)) {
|
|
204
|
+
delete this.cfg[method];
|
|
205
|
+
}
|
|
206
|
+
});
|
|
207
|
+
return this;
|
|
208
|
+
}
|
|
209
|
+
}
|
|
210
|
+
export {
|
|
211
|
+
Resource
|
|
212
|
+
};
|
|
213
|
+
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../../src/http/rs/resource.ts"],
  "sourcesContent": ["import { handlerFunction } from \"./resource-common\";\nimport { ResourceMethod } from \"./resource-method\";\n\n/**\n * Compares two arrays for equality by inspecting if they are arrays, refer to the same instance,\n * have same length and contain equal components in the same order.\n *\n * @param source The source array to compare to.\n * @param target The target array to compare with.\n * @returns true if the arrays are equal, false otherwise.\n */\nfunction arrayEquals(source: any[] | undefined, target: any[] | undefined): boolean {\n\tif (source === target)\n\t\treturn true;\n\tif (!Array.isArray(source) || !Array.isArray(target))\n\t\treturn false;\n\tif (source !== undefined && target === undefined || source === undefined && target !== undefined)\n\t\treturn false;\n\tif (source.length !== target.length)\n\t\treturn false;\n\tfor (let i = 0; i < source.length; i++) {\n\t\tif (source[i] !== target[i])\n\t\t\treturn false;\n\t}\n\treturn true;\n}\n\n/**\n * Constructs a new Resource instance, initialized with the supplied path parameter and optionally with the second, configuration object parameter.\n */\nexport class Resource {\n    /** The URL path for this resource. */\n\tsPath: string;\n    /** The resource configuration mapping methods to handler specifications. */\n\tcfg: any;\n    /** The optional controller instance. */\n\tcontroller: any;\n    /** Bound execute function from the controller. */\n\texecute: Function | undefined;\n    /** Additional mappings object. */\n\tmappings: any;\n\n\t/**\n     * @param sPath The base URL path for the resource.\n     * @param oConfiguration Optional configuration object (map of method handlers).\n     * @param controller Optional controller instance containing an execute method.\n     * @param mappings Optional object for resource mappings.\n     */\n\tconstructor(sPath: string, oConfiguration?: any, controller?: any, mappings?: any) {\n\t\tthis.sPath = sPath;\n\t\tthis.cfg = oConfiguration || {};\n\n\t\tif (controller) {\n\t\t\tthis.controller = controller;\n\t\t\t// Bind the controller's execute function\n\t\t\tthis.execute = controller.execute.bind(controller);\n\t\t}\n\t\tif (mappings) {\n\t\t\tthis.mappings = mappings;\n\t\t}\n\t}\n\n\t/**\n     * Sets the URL path for this resource, overriding the one specified upon its construction,\n     * if a path string is provided as argument ot the method (i.e. acts as setter),\n     * or returns the path set for this resource, if the method is invoked without arguments (i.e. acts as getter).\n     *\n     * @param sPath The path property to be set for this resource.\n     * @returns The resource instance for method chaining (setter mode), or the path set for this resource (getter mode).\n     */\n\tpath(sPath?: string): Resource | string {\n\t\tif (arguments.length === 0)\n\t\t\treturn this.sPath;\n\t\tthis.sPath = sPath!;\n\t\treturn this;\n\t}\n\n\t/**\n\t * Creates a new HTTP method handling specification.\n\t *\n\t * @param sHttpMethod The HTTP method (method) (e.g., \"GET\").\n\t * @param oConfiguration The handler specification(s) for this HTTP method. Can be a single object or array.\n\t * @returns The ResourceMethod instance, or an array of ResourceMethod instances.\n\t */\n\tmethod(sHttpMethod: string, oConfiguration?: any | any[]): ResourceMethod | ResourceMethod[] {\n\t\tif (sHttpMethod === undefined)\n\t\t\tthrow new Error('Illegal sHttpMethod argument: ' + sHttpMethod);\n\n\t\tconst method = sHttpMethod.toLowerCase();\n\n\t\tif (!this.cfg[method])\n\t\t\tthis.cfg[method] = [];\n\n\t\tlet arrConfig: any[] = oConfiguration || {};\n\t\tif (!Array.isArray(arrConfig)) {\n\t\t\tarrConfig = [arrConfig];\n\t\t}\n\n\t\tconst handlers: ResourceMethod[] = [];\n\n\t\tarrConfig.forEach((handlerSpec) => {\n\t\t\t// Type casting to handle object property access for consumes/produces\n\t\t\tconst consumes = (handlerSpec as { consumes?: string[] }).consumes;\n\t\t\tconst produces = (handlerSpec as { produces?: string[] }).produces;\n\n\t\t\tconst _h = this.find(sHttpMethod, consumes, produces);\n\t\t\tif (!_h) {\n\t\t\t\t// create new\n\t\t\t\tthis.cfg[method].push(handlerSpec);\n\t\t\t} else {\n\t\t\t\t// update existing spec in cfg\n\t\t\t\tconst existingSpec = this.cfg[method].find(\n                    (spec: any) => arrayEquals(spec.consumes, consumes) && arrayEquals(spec.produces, produces)\n                );\n\t\t\t\tif (existingSpec) {\n\t\t\t\t\tfor (const propName in handlerSpec) {\n\t\t\t\t\t\tif (Object.prototype.hasOwnProperty.call(handlerSpec, propName)) {\n\t\t\t\t\t\t\texistingSpec[propName] = handlerSpec[propName];\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\n            // Create a new ResourceMethod instance for the (potentially updated) spec\n            const finalHandlerSpec = this.cfg[method].find(\n                (spec: any) => arrayEquals(spec.consumes, consumes) && arrayEquals(spec.produces, produces)\n            );\n\n            if (finalHandlerSpec) {\n                handlers.push(new ResourceMethod(finalHandlerSpec, this.controller, this, this.mappings));\n            }\n\t\t});\n\n\t\treturn handlers.length > 1 ? handlers : handlers[0];\n\t};\n\n\t/**\n     * Internal utility method to handle the logic for HTTP verb shortcut methods (get, post, etc.).\n     *\n     * @param sMethodName The HTTP method name (e.g., 'get').\n     * @param args The arguments passed to the shortcut method.\n     * @returns The ResourceMethod instance or an array of instances.\n     */\n\tprivate buildMethod(sMethodName: string, ...args: (Function | any)[]): ResourceMethod | ResourceMethod[] {\n\t\tif (args.length > 0) {\n\t\t\tif (typeof args[0] === 'function') {\n\t\t\t\t// .get(function) -> .method('get').serve(function)\n                // Note: We need to cast the result of method() to access serve() as it returns a ResourceMethod.\n\t\t\t\treturn (this.method(sMethodName) as ResourceMethod).serve(args[0]);\n\t\t\t} else if (typeof args[0] === 'object' && args[0] !== null) {\n\t\t\t\t// .get({config}) -> .method('get', {config})\n\t\t\t\treturn this.method(sMethodName, args[0]);\n\t\t\t} else {\n\t\t\t\tthrow new Error(`Invalid argument: Resource.${sMethodName} method first argument must be valid javascript function or configuration object, but instead is ${typeof args[0]} ${args[0]}`);\n\t\t\t}\n\t\t} else {\n\t\t\t// .get() -> .method('get')\n\t\t\treturn this.method(sMethodName) as ResourceMethod;\n\t\t}\n\t};\n\n\t/**\n\t * Creates a handling specification for the HTTP method \"GET\".\n\t * @param fServeCb|oConfiguration Serve function callback or configuration object to initialize the method.\n\t * @returns The ResourceMethod instance or array.\n\t */\n\tget(fServeCb: Function): ResourceMethod;\n    get(oConfiguration: any): ResourceMethod | ResourceMethod[];\n    get(): ResourceMethod;\n\tget(): ResourceMethod | ResourceMethod[] {\n\t\treturn this.buildMethod('get', ...arguments);\n\t};\n\n\t/**\n\t * Creates a handling specification for the HTTP method \"POST\".\n\t * @param fServeCb|oConfiguration Serve function callback or configuration object to initialize the method.\n\t * @returns The ResourceMethod instance or array.\n\t */\n\tpost(fServeCb: Function): ResourceMethod;\n    post(oConfiguration: any): ResourceMethod | ResourceMethod[];\n    post(): ResourceMethod;\n\tpost(): ResourceMethod | ResourceMethod[] {\n\t\treturn this.buildMethod('post', ...arguments);\n\t};\n\n\t/**\n\t * Creates a handling specification for the HTTP method \"PUT\".\n\t * @param fServeCb|oConfiguration Serve function callback or configuration object to initialize the method.\n\t * @returns The ResourceMethod instance or array.\n\t */\n\tput(fServeCb: Function): ResourceMethod;\n    put(oConfiguration: any): ResourceMethod | ResourceMethod[];\n    put(): ResourceMethod;\n\tput(): ResourceMethod | ResourceMethod[] {\n\t\treturn this.buildMethod('put', ...arguments);\n\t};\n\n\t/**\n\t * Creates a handling specification for the HTTP method \"DELETE\".\n\t * @param fServeCb|oConfiguration Serve function callback or configuration object to initialize the method.\n\t * @returns The ResourceMethod instance or array.\n\t */\n\tdelete(fServeCb: Function): ResourceMethod;\n    delete(oConfiguration: any): ResourceMethod | ResourceMethod[];\n    delete(): ResourceMethod;\n\tdelete(): ResourceMethod | ResourceMethod[] {\n\t\treturn this.buildMethod('delete', ...arguments);\n\t};\n\n    /**\n\t * Creates a handling specification for the HTTP method \"DELETE\" (alias for delete()).\n\t * @param fServeCb|oConfiguration Serve function callback or configuration object to initialize the method.\n\t * @returns The ResourceMethod instance or array.\n\t */\n    remove(fServeCb: Function): ResourceMethod;\n    remove(oConfiguration: any): ResourceMethod | ResourceMethod[];\n    remove(): ResourceMethod;\n\tremove(): ResourceMethod | ResourceMethod[] {\n\t\treturn this.buildMethod('delete', ...arguments);\n\t}\n\n\t/**\n\t * Finds a ResourceMethod with the given constraints.\n\t *\n\t * @param sVerb The name of the method property of the ResourceMethod in search (e.g., \"GET\").\n\t * @param arrConsumesMimeTypeStrings The consumes constraint property of the ResourceMethod in search.\n\t * @param arrProducesMimeTypeStrings The produces constraint property of the ResourceMethod in search.\n\t * @returns The found ResourceMethod instance, or undefined if not found.\n\t */\n\tfind(sVerb: string, arrConsumesMimeTypeStrings?: string[], arrProducesMimeTypeStrings?: string[]): ResourceMethod | undefined {\n\t\tlet hit: ResourceMethod | undefined;\n\t\tconst sVerbLower = sVerb.toLowerCase();\n\n\t\tObject.keys(this.cfg)\n            .filter((sVerbName) => sVerbName === sVerbLower)\n            .forEach((sVerbName) => {\n\t\t\t    this.cfg[sVerbName].forEach((verbHandlerSpec: any) => {\n\t\t\t\t    if (arrayEquals(verbHandlerSpec.consumes, arrConsumesMimeTypeStrings) && arrayEquals(verbHandlerSpec.produces, arrProducesMimeTypeStrings)) {\n\t\t\t\t\t    hit = new ResourceMethod(verbHandlerSpec, this.controller, this, this.mappings);\n\t\t\t\t\t    return;\n\t\t\t\t    }\n\t\t\t    });\n\t\t\t    if (hit)\n\t\t\t\t    return;\n\t\t});\n\t\treturn hit;\n\t};\n\n\t/**\n\t * Returns the configuration of this resource.\n\t *\n\t * @returns The resource configuration object.\n\t */\n\tconfiguration(): any {\n\t\treturn this.cfg;\n\t};\n\n\t/**\n\t * Instructs redirection of the request base don the parameter. If it is a stirng representing URI, the request will be\n\t * redirected to this URI for any method. If it's a function it will be invoked and epxected to return a URI string to redirect to.\n\t *\n\t * @param fRedirector The function or string URI to redirect to.\n     * @returns The resource instance for method chaining.\n\t */\n\tredirect(fRedirector: string | Function): Resource {\n\t\tif (typeof fRedirector === 'string') {\n\t\t\tconst redirectUri = fRedirector;\n\t\t\tfRedirector = function () {\n\t\t\t\treturn redirectUri;\n\t\t\t}\n\t\t}\n\t\t// The imported handlerFunction is used here\n\t\treturn handlerFunction(this, this.configuration(), 'redirect', fRedirector);\n\t};\n\n\t/**\n\t * Disables the ResourceMethods that match the given constraints\n     *\n     * @param sVerb The HTTP verb (e.g., \"GET\").\n\t * @param arrConsumesTypeStrings The consumes constraint property of the ResourceMethod in search.\n\t * @param arrProducesTypeStrings The produces constraint property of the ResourceMethod in search.\n     * @returns The resource instance for method chaining.\n\t */\n\tdisable(sVerb?: string, arrConsumesTypeStrings?: string[], arrProducesTypeStrings?: string[]): Resource {\n\t\tObject.keys(this.cfg)\n            .filter((sVerbName) => sVerb === undefined || (sVerb && sVerb.toLowerCase() === sVerbName))\n            .forEach((sVerbName) => {\n\t\t\t    // Use a reverse loop for safe splicing\n\t\t\t    for (let i = this.cfg[sVerbName].length - 1; i >= 0; i--) {\n                    const verbHandlerSpec = this.cfg[sVerbName][i];\n\t\t\t\t    if (arrayEquals(verbHandlerSpec.consumes, arrConsumesTypeStrings) && arrayEquals(verbHandlerSpec.produces, arrProducesTypeStrings)) {\n\t\t\t\t\t    this.cfg[sVerbName].splice(i, 1);\n                    }\n                }\n\t\t});\n\t\treturn this;\n\t};\n\n\t/**\n\t * Disables all but 'read' HTTP methods in this resource (GET, HEAD, TRACE).\n     *\n     * @returns The resource instance for method chaining.\n\t */\n\treadonly(): Resource {\n\t\tObject.keys(this.cfg).forEach((method) => {\n\t\t\tif (!['get', 'head', 'trace'].includes(method)) {\n\t\t\t\tdelete this.cfg[method];\n            }\n\t\t});\n\t\treturn this;\n\t};\n}"],
  "mappings": "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",
  "names": []
}

|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import { service, HttpController } from "./rs/resource-http-controller";
|
|
2
|
+
import { ResourceMethod } from "./rs/resource-method";
|
|
3
|
+
import { ResourceMappings } from "./rs/resource-mappings";
|
|
4
|
+
import { Resource } from "./rs/resource";
|
|
5
|
+
export {
|
|
6
|
+
HttpController,
|
|
7
|
+
Resource,
|
|
8
|
+
ResourceMappings,
|
|
9
|
+
ResourceMethod,
|
|
10
|
+
service
|
|
11
|
+
};
|
|
12
|
+
//# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vLi4vc3JjL2h0dHAvcnMudHMiXSwKICAic291cmNlc0NvbnRlbnQiOiBbImV4cG9ydCB7IHNlcnZpY2UsIEh0dHBDb250cm9sbGVyIH0gZnJvbSBcIi4vcnMvcmVzb3VyY2UtaHR0cC1jb250cm9sbGVyXCI7XG5leHBvcnQgeyBSZXNvdXJjZU1ldGhvZCB9IGZyb20gXCIuL3JzL3Jlc291cmNlLW1ldGhvZFwiO1xuZXhwb3J0IHsgUmVzb3VyY2VNYXBwaW5ncyB9IGZyb20gXCIuL3JzL3Jlc291cmNlLW1hcHBpbmdzXCI7XG5leHBvcnQgeyBSZXNvdXJjZSB9IGZyb20gXCIuL3JzL3Jlc291cmNlXCI7Il0sCiAgIm1hcHBpbmdzIjogIkFBQUEsU0FBUyxTQUFTLHNCQUFzQjtBQUN4QyxTQUFTLHNCQUFzQjtBQUMvQixTQUFTLHdCQUF3QjtBQUNqQyxTQUFTLGdCQUFnQjsiLAogICJuYW1lcyI6IFtdCn0K
|
|
@@ -0,0 +1,105 @@
|
|
|
1
|
+
const HttpSessionFacade = Java.type("org.eclipse.dirigible.components.api.http.HttpSessionFacade");
|
|
2
|
+
class Session {
|
|
3
|
+
/**
|
|
4
|
+
* Checks if a session is currently valid and active for the request context.
|
|
5
|
+
* @returns True if the session is valid, false otherwise (e.g., if it has been invalidated or timed out).
|
|
6
|
+
*/
|
|
7
|
+
static isValid() {
|
|
8
|
+
return HttpSessionFacade.isValid();
|
|
9
|
+
}
|
|
10
|
+
/**
|
|
11
|
+
* Retrieves the value of a named attribute stored in the session.
|
|
12
|
+
* Note: The underlying Java facade typically stores strings, but the value may represent
|
|
13
|
+
* serialized data that should be parsed if complex.
|
|
14
|
+
* @param name The name of the attribute.
|
|
15
|
+
* @returns The attribute value as a string, or null/undefined if not found.
|
|
16
|
+
*/
|
|
17
|
+
static getAttribute(name) {
|
|
18
|
+
return HttpSessionFacade.getAttribute(name);
|
|
19
|
+
}
|
|
20
|
+
/**
|
|
21
|
+
* Retrieves an array of all attribute names currently stored in the session.
|
|
22
|
+
* The names are retrieved as a JSON string from the facade and then parsed.
|
|
23
|
+
* @returns An array of attribute names (strings), or an empty array if no attributes are present.
|
|
24
|
+
*/
|
|
25
|
+
static getAttributeNames() {
|
|
26
|
+
const attrNames = HttpSessionFacade.getAttributeNamesJson();
|
|
27
|
+
return attrNames ? JSON.parse(attrNames) : [];
|
|
28
|
+
}
|
|
29
|
+
/**
|
|
30
|
+
* Returns the time at which this session was created, converted to a JavaScript Date object.
|
|
31
|
+
* @returns A Date object representing the session's creation time.
|
|
32
|
+
*/
|
|
33
|
+
static getCreationTime() {
|
|
34
|
+
return new Date(HttpSessionFacade.getCreationTime());
|
|
35
|
+
}
|
|
36
|
+
/**
|
|
37
|
+
* Returns the unique identifier assigned to this session.
|
|
38
|
+
* @returns The session ID string.
|
|
39
|
+
*/
|
|
40
|
+
static getId() {
|
|
41
|
+
return HttpSessionFacade.getId();
|
|
42
|
+
}
|
|
43
|
+
/**
|
|
44
|
+
* Returns the last time the client accessed this session, converted to a JavaScript Date object.
|
|
45
|
+
* Access includes requests that retrieve or set session attributes.
|
|
46
|
+
* @returns A Date object representing the last access time.
|
|
47
|
+
*/
|
|
48
|
+
static getLastAccessedTime() {
|
|
49
|
+
return new Date(HttpSessionFacade.getLastAccessedTime());
|
|
50
|
+
}
|
|
51
|
+
/**
|
|
52
|
+
* Returns the maximum time interval, in seconds, that the server should keep this session open
|
|
53
|
+
* between client requests. After this interval, the session will be invalidated.
|
|
54
|
+
* @returns The maximum inactive interval in seconds.
|
|
55
|
+
*/
|
|
56
|
+
static getMaxInactiveInterval() {
|
|
57
|
+
return HttpSessionFacade.getMaxInactiveInterval();
|
|
58
|
+
}
|
|
59
|
+
/**
|
|
60
|
+
* Invalidates this session, unbinding any objects bound to it.
|
|
61
|
+
* After this call, the session is no longer valid.
|
|
62
|
+
*/
|
|
63
|
+
static invalidate() {
|
|
64
|
+
HttpSessionFacade.invalidate();
|
|
65
|
+
}
|
|
66
|
+
/**
|
|
67
|
+
* Checks if the client does not yet know about the session, typically meaning
|
|
68
|
+
* the server has not yet returned the session ID via a cookie or encoded URL.
|
|
69
|
+
* @returns True if the session is new (not yet used in a response), false otherwise.
|
|
70
|
+
*/
|
|
71
|
+
static isNew() {
|
|
72
|
+
return HttpSessionFacade.isNew();
|
|
73
|
+
}
|
|
74
|
+
/**
|
|
75
|
+
* Binds an object to this session, using the specified name.
|
|
76
|
+
* This is the primary way to store data in the user's session.
|
|
77
|
+
* @param name The name to bind the object under.
|
|
78
|
+
* @param value The value/object to store in the session.
|
|
79
|
+
*/
|
|
80
|
+
static setAttribute(name, value) {
|
|
81
|
+
HttpSessionFacade.setAttribute(name, value);
|
|
82
|
+
}
|
|
83
|
+
/**
|
|
84
|
+
* Removes the attribute with the given name from the session.
|
|
85
|
+
* @param name The name of the attribute to remove.
|
|
86
|
+
*/
|
|
87
|
+
static removeAttribute(name) {
|
|
88
|
+
HttpSessionFacade.removeAttribute(name);
|
|
89
|
+
}
|
|
90
|
+
/**
|
|
91
|
+
* Specifies the maximum time interval, in seconds, that the server should keep this session open
|
|
92
|
+
* between client requests before automatically invalidating it.
|
|
93
|
+
* @param interval The new interval in seconds.
|
|
94
|
+
*/
|
|
95
|
+
static setMaxInactiveInterval(interval) {
|
|
96
|
+
HttpSessionFacade.setMaxInactiveInterval(interval);
|
|
97
|
+
}
|
|
98
|
+
}
|
|
99
|
+
if (typeof module !== "undefined") {
|
|
100
|
+
module.exports = Session;
|
|
101
|
+
}
|
|
102
|
+
export {
|
|
103
|
+
Session
|
|
104
|
+
};
|
|
105
|
+
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../src/http/session.ts"],
  "sourcesContent": ["/**\n * Provides a static fa\u00E7ade (`Session` class) for accessing and manipulating\n * the HTTP session associated with the current request. This module is often used\n * to store user-specific data during their interaction with the application.\n */\n\nconst HttpSessionFacade = Java.type(\"org.eclipse.dirigible.components.api.http.HttpSessionFacade\");\n\n/**\n * The static Session class provides methods to interact with the current user session\n * (e.g., storing attributes, checking status, managing lifetime).\n */\nexport class Session {\n\n\t/**\n\t * Checks if a session is currently valid and active for the request context.\n\t * @returns True if the session is valid, false otherwise (e.g., if it has been invalidated or timed out).\n\t */\n\tpublic static isValid(): boolean {\n\t\treturn HttpSessionFacade.isValid();\n\t}\n\n\t/**\n\t * Retrieves the value of a named attribute stored in the session.\n\t * Note: The underlying Java facade typically stores strings, but the value may represent\n     * serialized data that should be parsed if complex.\n\t * @param name The name of the attribute.\n\t * @returns The attribute value as a string, or null/undefined if not found.\n\t */\n\tpublic static getAttribute(name: string): string {\n\t\treturn HttpSessionFacade.getAttribute(name);\n\t}\n\n\t/**\n\t * Retrieves an array of all attribute names currently stored in the session.\n\t * The names are retrieved as a JSON string from the facade and then parsed.\n\t * @returns An array of attribute names (strings), or an empty array if no attributes are present.\n\t */\n\tpublic static getAttributeNames(): string[] {\n\t\tconst attrNames = HttpSessionFacade.getAttributeNamesJson();\n\t\treturn attrNames ? JSON.parse(attrNames) : [];\n\t}\n\n\t/**\n\t * Returns the time at which this session was created, converted to a JavaScript Date object.\n\t * @returns A Date object representing the session's creation time.\n\t */\n\tpublic static getCreationTime(): Date {\n\t\t// The facade returns time in milliseconds since the epoch, which Date() accepts.\n\t\treturn new Date(HttpSessionFacade.getCreationTime());\n\t}\n\n\t/**\n\t * Returns the unique identifier assigned to this session.\n\t * @returns The session ID string.\n\t */\n\tpublic static getId(): string {\n\t\treturn HttpSessionFacade.getId();\n\t}\n\n\t/**\n\t * Returns the last time the client accessed this session, converted to a JavaScript Date object.\n\t * Access includes requests that retrieve or set session attributes.\n\t * @returns A Date object representing the last access time.\n\t */\n\tpublic static getLastAccessedTime(): Date {\n\t\t// The facade returns time in milliseconds since the epoch.\n\t\treturn new Date(HttpSessionFacade.getLastAccessedTime());\n\t}\n\n\t/**\n\t * Returns the maximum time interval, in seconds, that the server should keep this session open\n\t * between client requests. After this interval, the session will be invalidated.\n\t * @returns The maximum inactive interval in seconds.\n\t */\n\tpublic static getMaxInactiveInterval(): number {\n\t\treturn HttpSessionFacade.getMaxInactiveInterval();\n\t}\n\n\t/**\n\t * Invalidates this session, unbinding any objects bound to it.\n\t * After this call, the session is no longer valid.\n\t */\n\tpublic static invalidate(): void {\n\t\tHttpSessionFacade.invalidate();\n\t}\n\n\t/**\n\t * Checks if the client does not yet know about the session, typically meaning\n\t * the server has not yet returned the session ID via a cookie or encoded URL.\n\t * @returns True if the session is new (not yet used in a response), false otherwise.\n\t */\n\tpublic static isNew(): boolean {\n\t\treturn HttpSessionFacade.isNew();\n\t}\n\n\t/**\n\t * Binds an object to this session, using the specified name.\n\t * This is the primary way to store data in the user's session.\n\t * @param name The name to bind the object under.\n\t * @param value The value/object to store in the session.\n\t */\n\tpublic static setAttribute(name: string, value: any): void {\n\t\tHttpSessionFacade.setAttribute(name, value);\n\t}\n\n\t/**\n\t * Removes the attribute with the given name from the session.\n\t * @param name The name of the attribute to remove.\n\t */\n\tpublic static removeAttribute(name: string): void {\n\t\tHttpSessionFacade.removeAttribute(name);\n\t}\n\n\t/**\n\t * Specifies the maximum time interval, in seconds, that the server should keep this session open\n\t * between client requests before automatically invalidating it.\n\t * @param interval The new interval in seconds.\n\t */\n\tpublic static setMaxInactiveInterval(interval: number): void {\n\t\tHttpSessionFacade.setMaxInactiveInterval(interval);\n\t}\n}\n\n// @ts-ignore\nif (typeof module !== 'undefined') {\n\t// @ts-ignore\n\tmodule.exports = Session;\n}"],
  "mappings": "AAMA,MAAM,oBAAoB,KAAK,KAAK,6DAA6D;AAM1F,MAAM,QAAQ;AAAA;AAAA;AAAA;AAAA;AAAA,EAMpB,OAAc,UAAmB;AAChC,WAAO,kBAAkB,QAAQ;AAAA,EAClC;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EASA,OAAc,aAAa,MAAsB;AAChD,WAAO,kBAAkB,aAAa,IAAI;AAAA,EAC3C;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOA,OAAc,oBAA8B;AAC3C,UAAM,YAAY,kBAAkB,sBAAsB;AAC1D,WAAO,YAAY,KAAK,MAAM,SAAS,IAAI,CAAC;AAAA,EAC7C;AAAA;AAAA;AAAA;AAAA;AAAA,EAMA,OAAc,kBAAwB;AAErC,WAAO,IAAI,KAAK,kBAAkB,gBAAgB,CAAC;AAAA,EACpD;AAAA;AAAA;AAAA;AAAA;AAAA,EAMA,OAAc,QAAgB;AAC7B,WAAO,kBAAkB,MAAM;AAAA,EAChC;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOA,OAAc,sBAA4B;AAEzC,WAAO,IAAI,KAAK,kBAAkB,oBAAoB,CAAC;AAAA,EACxD;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOA,OAAc,yBAAiC;AAC9C,WAAO,kBAAkB,uBAAuB;AAAA,EACjD;AAAA;AAAA;AAAA;AAAA;AAAA,EAMA,OAAc,aAAmB;AAChC,sBAAkB,WAAW;AAAA,EAC9B;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOA,OAAc,QAAiB;AAC9B,WAAO,kBAAkB,MAAM;AAAA,EAChC;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAQA,OAAc,aAAa,MAAc,OAAkB;AAC1D,sBAAkB,aAAa,MAAM,KAAK;AAAA,EAC3C;AAAA;AAAA;AAAA;AAAA;AAAA,EAMA,OAAc,gBAAgB,MAAoB;AACjD,sBAAkB,gBAAgB,IAAI;AAAA,EACvC;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOA,OAAc,uBAAuB,UAAwB;AAC5D,sBAAkB,uBAAuB,QAAQ;AAAA,EAClD;AACD;AAGA,IAAI,OAAO,WAAW,aAAa;AAElC,SAAO,UAAU;AAClB;",
  "names": []
}

|