@aerokit/sdk 12.78.0 → 12.80.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.
Files changed (84) hide show
  1. package/dist/cjs/bpm/process.js +4 -1
  2. package/dist/cjs/bpm/tasks.js +3 -1
  3. package/dist/cjs/bpm/tracer.js +3 -1
  4. package/dist/cjs/cms/cmis.js +105 -177
  5. package/dist/cjs/db/database.js +5 -1
  6. package/dist/cjs/db/query.js +19 -1
  7. package/dist/cjs/db/repository.js +2 -1
  8. package/dist/cjs/db/sql.js +5 -2
  9. package/dist/cjs/etcd/client.js +4 -1
  10. package/dist/cjs/http/errors/ForbiddenError.js +9 -9
  11. package/dist/cjs/http/errors/ValidationError.js +9 -9
  12. package/dist/cjs/http/request.js +2 -1
  13. package/dist/cjs/http/response.js +102 -188
  14. package/dist/cjs/http/rs/resource-http-controller.js +4 -1
  15. package/dist/cjs/http/rs/resource-mappings.js +6 -3
  16. package/dist/cjs/http/rs/resource-method.js +10 -1
  17. package/dist/cjs/http/rs/resource.js +11 -1
  18. package/dist/cjs/http/upload.js +3 -1
  19. package/dist/cjs/io/files.js +5 -7
  20. package/dist/cjs/io/streams.js +5 -1
  21. package/dist/cjs/io/zip.js +4 -1
  22. package/dist/cjs/job/scheduler.js +4 -1
  23. package/dist/cjs/kafka/consumer.js +3 -2
  24. package/dist/cjs/kafka/producer.js +3 -1
  25. package/dist/cjs/log/logging.js +2 -1
  26. package/dist/cjs/mail/client.js +2 -1
  27. package/dist/cjs/messaging/consumer.js +3 -1
  28. package/dist/cjs/messaging/producer.js +3 -1
  29. package/dist/cjs/mongodb/client.js +26 -1
  30. package/dist/cjs/mongodb/dao.js +3 -1
  31. package/dist/cjs/net/soap.js +15 -1
  32. package/dist/cjs/net/websockets.js +5 -1
  33. package/dist/cjs/platform/engines.js +2 -1
  34. package/dist/cjs/platform/os.js +7 -9
  35. package/dist/cjs/platform/problems.js +7 -13
  36. package/dist/cjs/platform/registry.js +4 -1
  37. package/dist/cjs/platform/repository.js +4 -1
  38. package/dist/cjs/platform/workspace.js +8 -1
  39. package/dist/cjs/redis/client.js +2 -1
  40. package/dist/cjs/security/oauth.js +2 -1
  41. package/dist/cjs/template/engines.js +6 -1
  42. package/dist/dts/db/query.d.ts +10 -0
  43. package/dist/esm/bpm/process.mjs +4 -1
  44. package/dist/esm/bpm/tasks.mjs +3 -1
  45. package/dist/esm/bpm/tracer.mjs +3 -1
  46. package/dist/esm/cms/cmis.mjs +105 -177
  47. package/dist/esm/db/database.mjs +5 -1
  48. package/dist/esm/db/query.mjs +19 -1
  49. package/dist/esm/db/repository.mjs +2 -1
  50. package/dist/esm/db/sql.mjs +5 -2
  51. package/dist/esm/etcd/client.mjs +4 -1
  52. package/dist/esm/http/errors/ForbiddenError.mjs +9 -9
  53. package/dist/esm/http/errors/ValidationError.mjs +9 -9
  54. package/dist/esm/http/request.mjs +2 -1
  55. package/dist/esm/http/response.mjs +102 -188
  56. package/dist/esm/http/rs/resource-http-controller.mjs +4 -1
  57. package/dist/esm/http/rs/resource-mappings.mjs +6 -3
  58. package/dist/esm/http/rs/resource-method.mjs +10 -1
  59. package/dist/esm/http/rs/resource.mjs +11 -1
  60. package/dist/esm/http/upload.mjs +3 -1
  61. package/dist/esm/io/files.mjs +5 -7
  62. package/dist/esm/io/streams.mjs +5 -1
  63. package/dist/esm/io/zip.mjs +4 -1
  64. package/dist/esm/job/scheduler.mjs +4 -1
  65. package/dist/esm/kafka/consumer.mjs +3 -2
  66. package/dist/esm/kafka/producer.mjs +3 -1
  67. package/dist/esm/log/logging.mjs +2 -1
  68. package/dist/esm/mail/client.mjs +2 -1
  69. package/dist/esm/messaging/consumer.mjs +3 -1
  70. package/dist/esm/messaging/producer.mjs +3 -1
  71. package/dist/esm/mongodb/client.mjs +26 -1
  72. package/dist/esm/mongodb/dao.mjs +3 -1
  73. package/dist/esm/net/soap.mjs +15 -1
  74. package/dist/esm/net/websockets.mjs +5 -1
  75. package/dist/esm/platform/engines.mjs +2 -1
  76. package/dist/esm/platform/os.mjs +7 -9
  77. package/dist/esm/platform/problems.mjs +7 -13
  78. package/dist/esm/platform/registry.mjs +4 -1
  79. package/dist/esm/platform/repository.mjs +4 -1
  80. package/dist/esm/platform/workspace.mjs +8 -1
  81. package/dist/esm/redis/client.mjs +2 -1
  82. package/dist/esm/security/oauth.mjs +2 -1
  83. package/dist/esm/template/engines.mjs +6 -1
  84. package/package.json +1 -1
@@ -22,6 +22,11 @@ __export(resource_mappings_exports, {
22
22
  module.exports = __toCommonJS(resource_mappings_exports);
23
23
  var import_resource = require("./resource");
24
24
  class ResourceMappings {
25
+ // Map of resource path (string) to the Resource instance (typed as any for flexibility)
26
+ resources = {};
27
+ controller;
28
+ // Represents the HttpController instance
29
+ execute;
25
30
  // Bound execute function from the HttpController
26
31
  /**
27
32
  * Constructor function for ResourceMappings instances.
@@ -30,8 +35,6 @@ class ResourceMappings {
30
35
  * @param controller The HttpController instance, for which this ResourceMappings handles configuration.
31
36
  */
32
37
  constructor(oConfiguration, controller) {
33
- // Map of resource path (string) to the Resource instance (typed as any for flexibility)
34
- this.resources = {};
35
38
  if (oConfiguration) {
36
39
  Object.keys(oConfiguration).forEach((sPath) => {
37
40
  this.resources[sPath] = this.resource(sPath, oConfiguration[sPath]);
@@ -127,4 +130,4 @@ class ResourceMappings {
127
130
  return;
128
131
  }
129
132
  }
130
- //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../../src/http/rs/resource-mappings.ts"],
  "sourcesContent": ["import { Resource } from \"./resource\";\n\n/**\n * The ResourceMappings class abstracts the mappings between resource URL path templates\n * and their corresponding resource handler specifications. It acts as the configuration\n * store for the HttpController.\n */\nexport class ResourceMappings {\n    // Map of resource path (string) to the Resource instance (typed as any for flexibility)\n    resources: { [key: string]: any } = {};\n    controller: any; // Represents the HttpController instance\n    execute: any; // Bound execute function from the HttpController\n\n    /**\n     * Constructor function for ResourceMappings instances.\n     *\n     * @param oConfiguration Configuration object defining initial resource paths and their handlers.\n     * @param controller The HttpController instance, for which this ResourceMappings handles configuration.\n     */\n    constructor(oConfiguration: any, controller: any) {\n        if (oConfiguration) {\n            Object.keys(oConfiguration).forEach((sPath: string) => {\n                this.resources[sPath] = this.resource(sPath, oConfiguration[sPath]);\n            });\n        }\n\n        if (controller) {\n            this.controller = controller;\n            this.execute = controller.execute.bind(controller);\n        }\n    }\n\n    /**\n     * Creates or retrieves a Resource object corresponding to the given path.\n     * The second, optional argument can be used to initialize the resource.\n     *\n     * @param sPath The URL path template for the resource (e.g., \"users/{id}\").\n     * @param oConfiguration Optional configuration object for initial resource setup.\n     * @returns The created or existing Resource instance.\n     */\n    path(sPath: string, oConfiguration?: any): Resource {\n        if (sPath !== \"\" && sPath[0] === \"/\") {\n            sPath = sPath.substring(1); // transform \"/test\" into \"test\"\n        }\n\n        if (this.resources[sPath] === undefined) {\n            // Resource is the class imported from \"./resource\"\n            this.resources[sPath] = new Resource(sPath, oConfiguration, this.controller, this);\n        }\n\n        return this.resources[sPath];\n    };\n\n    /**\n     * Alias for path().\n     */\n    resourcePath(sPath: string, oConfiguration?: any): Resource {\n        return this.path(sPath, oConfiguration);\n    }\n\n    /**\n     * Alias for path().\n     */\n    resource(sPath: string, oConfiguration?: any): Resource {\n        return this.path(sPath, oConfiguration);\n    }\n\n    /**\n     * Returns the compiled configuration object for all resources managed by this ResourceMappings.\n     * The configuration is structured to be consumed by the HttpController's routing logic.\n     */\n    configuration(): { [key: string]: any } {\n        const _cfg: { [key: string]: any } = {};\n        Object.keys(this.resources).forEach((sPath: string) => {\n            // Assuming each Resource object has a configuration() method\n            _cfg[sPath] = this.resources[sPath].configuration();\n        });\n        return _cfg;\n    };\n\n    /**\n     * Removes all but GET resource handlers from all managed resources, making them read-only.\n     *\n     * @returns The ResourceMappings instance for method chaining.\n     */\n    readonly(): this {\n        Object.keys(this.resources).forEach((sPath: string) => {\n            this.resources[sPath].readonly();\n        });\n        return this;\n    };\n\n    /**\n     * Disables resource handling specifications matching the arguments, effectively removing them from this API.\n     *\n     * @param sPath The path of the resource.\n     * @param sVerb The HTTP verb (e.g., 'get', 'post').\n     * @param arrConsumes Array of consumed media types.\n     * @param arrProduces Array of produced media types.\n     * @returns The ResourceMappings instance for method chaining.\n     */\n    disable(sPath: string, sVerb: string, arrConsumes: string[], arrProduces: string[]): this {\n        const resource = this.resources[sPath];\n        // Assuming the intention is to find the single Resource instance and call disable on it\n        if (resource && typeof resource.disable === 'function') {\n             resource.disable(sVerb, arrConsumes, arrProduces);\n        }\n        return this;\n    };\n\n    /**\n     * Provides a reference to a handler specification matching the supplied arguments.\n     *\n     * @param sPath The path of the resource.\n     * @param sVerb The HTTP verb (e.g., 'get', 'post').\n     * @param arrConsumes Array of consumed media types.\n     * @param arrProduces Array of produced media types.\n     * @returns The matching Resource handler specification or undefined.\n     */\n    find(sPath: string, sVerb: string, arrConsumes: string[], arrProduces: string[]): any | undefined {\n        if (this.resources[sPath]) {\n            // Assuming Resource instance has a find method\n            const hit = this.resources[sPath].find(sVerb, arrConsumes, arrProduces);\n            if (hit)\n                return hit;\n        }\n        return;\n    };\n}"],
  "mappings": ";;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,sBAAyB;AAOlB,MAAM,iBAAiB;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAY1B,YAAY,gBAAqB,YAAiB;AAVlD;AAAA,qBAAoC,CAAC;AAWjC,QAAI,gBAAgB;AAChB,aAAO,KAAK,cAAc,EAAE,QAAQ,CAAC,UAAkB;AACnD,aAAK,UAAU,KAAK,IAAI,KAAK,SAAS,OAAO,eAAe,KAAK,CAAC;AAAA,MACtE,CAAC;AAAA,IACL;AAEA,QAAI,YAAY;AACZ,WAAK,aAAa;AAClB,WAAK,UAAU,WAAW,QAAQ,KAAK,UAAU;AAAA,IACrD;AAAA,EACJ;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAUA,KAAK,OAAe,gBAAgC;AAChD,QAAI,UAAU,MAAM,MAAM,CAAC,MAAM,KAAK;AAClC,cAAQ,MAAM,UAAU,CAAC;AAAA,IAC7B;AAEA,QAAI,KAAK,UAAU,KAAK,MAAM,QAAW;AAErC,WAAK,UAAU,KAAK,IAAI,IAAI,yBAAS,OAAO,gBAAgB,KAAK,YAAY,IAAI;AAAA,IACrF;AAEA,WAAO,KAAK,UAAU,KAAK;AAAA,EAC/B;AAAA;AAAA;AAAA;AAAA,EAKA,aAAa,OAAe,gBAAgC;AACxD,WAAO,KAAK,KAAK,OAAO,cAAc;AAAA,EAC1C;AAAA;AAAA;AAAA;AAAA,EAKA,SAAS,OAAe,gBAAgC;AACpD,WAAO,KAAK,KAAK,OAAO,cAAc;AAAA,EAC1C;AAAA;AAAA;AAAA;AAAA;AAAA,EAMA,gBAAwC;AACpC,UAAM,OAA+B,CAAC;AACtC,WAAO,KAAK,KAAK,SAAS,EAAE,QAAQ,CAAC,UAAkB;AAEnD,WAAK,KAAK,IAAI,KAAK,UAAU,KAAK,EAAE,cAAc;AAAA,IACtD,CAAC;AACD,WAAO;AAAA,EACX;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOA,WAAiB;AACb,WAAO,KAAK,KAAK,SAAS,EAAE,QAAQ,CAAC,UAAkB;AACnD,WAAK,UAAU,KAAK,EAAE,SAAS;AAAA,IACnC,CAAC;AACD,WAAO;AAAA,EACX;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAWA,QAAQ,OAAe,OAAe,aAAuB,aAA6B;AACtF,UAAM,WAAW,KAAK,UAAU,KAAK;AAErC,QAAI,YAAY,OAAO,SAAS,YAAY,YAAY;AACnD,eAAS,QAAQ,OAAO,aAAa,WAAW;AAAA,IACrD;AACA,WAAO;AAAA,EACX;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAWA,KAAK,OAAe,OAAe,aAAuB,aAAwC;AAC9F,QAAI,KAAK,UAAU,KAAK,GAAG;AAEvB,YAAM,MAAM,KAAK,UAAU,KAAK,EAAE,KAAK,OAAO,aAAa,WAAW;AACtE,UAAI;AACA,eAAO;AAAA,IACf;AACA;AAAA,EACJ;AACJ;",
  "names": []
}

133
+ //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../../src/http/rs/resource-mappings.ts"],
  "sourcesContent": ["import { Resource } from \"./resource\";\n\n/**\n * The ResourceMappings class abstracts the mappings between resource URL path templates\n * and their corresponding resource handler specifications. It acts as the configuration\n * store for the HttpController.\n */\nexport class ResourceMappings {\n    // Map of resource path (string) to the Resource instance (typed as any for flexibility)\n    resources: { [key: string]: any } = {};\n    controller: any; // Represents the HttpController instance\n    execute: any; // Bound execute function from the HttpController\n\n    /**\n     * Constructor function for ResourceMappings instances.\n     *\n     * @param oConfiguration Configuration object defining initial resource paths and their handlers.\n     * @param controller The HttpController instance, for which this ResourceMappings handles configuration.\n     */\n    constructor(oConfiguration: any, controller: any) {\n        if (oConfiguration) {\n            Object.keys(oConfiguration).forEach((sPath: string) => {\n                this.resources[sPath] = this.resource(sPath, oConfiguration[sPath]);\n            });\n        }\n\n        if (controller) {\n            this.controller = controller;\n            this.execute = controller.execute.bind(controller);\n        }\n    }\n\n    /**\n     * Creates or retrieves a Resource object corresponding to the given path.\n     * The second, optional argument can be used to initialize the resource.\n     *\n     * @param sPath The URL path template for the resource (e.g., \"users/{id}\").\n     * @param oConfiguration Optional configuration object for initial resource setup.\n     * @returns The created or existing Resource instance.\n     */\n    path(sPath: string, oConfiguration?: any): Resource {\n        if (sPath !== \"\" && sPath[0] === \"/\") {\n            sPath = sPath.substring(1); // transform \"/test\" into \"test\"\n        }\n\n        if (this.resources[sPath] === undefined) {\n            // Resource is the class imported from \"./resource\"\n            this.resources[sPath] = new Resource(sPath, oConfiguration, this.controller, this);\n        }\n\n        return this.resources[sPath];\n    };\n\n    /**\n     * Alias for path().\n     */\n    resourcePath(sPath: string, oConfiguration?: any): Resource {\n        return this.path(sPath, oConfiguration);\n    }\n\n    /**\n     * Alias for path().\n     */\n    resource(sPath: string, oConfiguration?: any): Resource {\n        return this.path(sPath, oConfiguration);\n    }\n\n    /**\n     * Returns the compiled configuration object for all resources managed by this ResourceMappings.\n     * The configuration is structured to be consumed by the HttpController's routing logic.\n     */\n    configuration(): { [key: string]: any } {\n        const _cfg: { [key: string]: any } = {};\n        Object.keys(this.resources).forEach((sPath: string) => {\n            // Assuming each Resource object has a configuration() method\n            _cfg[sPath] = this.resources[sPath].configuration();\n        });\n        return _cfg;\n    };\n\n    /**\n     * Removes all but GET resource handlers from all managed resources, making them read-only.\n     *\n     * @returns The ResourceMappings instance for method chaining.\n     */\n    readonly(): this {\n        Object.keys(this.resources).forEach((sPath: string) => {\n            this.resources[sPath].readonly();\n        });\n        return this;\n    };\n\n    /**\n     * Disables resource handling specifications matching the arguments, effectively removing them from this API.\n     *\n     * @param sPath The path of the resource.\n     * @param sVerb The HTTP verb (e.g., 'get', 'post').\n     * @param arrConsumes Array of consumed media types.\n     * @param arrProduces Array of produced media types.\n     * @returns The ResourceMappings instance for method chaining.\n     */\n    disable(sPath: string, sVerb: string, arrConsumes: string[], arrProduces: string[]): this {\n        const resource = this.resources[sPath];\n        // Assuming the intention is to find the single Resource instance and call disable on it\n        if (resource && typeof resource.disable === 'function') {\n             resource.disable(sVerb, arrConsumes, arrProduces);\n        }\n        return this;\n    };\n\n    /**\n     * Provides a reference to a handler specification matching the supplied arguments.\n     *\n     * @param sPath The path of the resource.\n     * @param sVerb The HTTP verb (e.g., 'get', 'post').\n     * @param arrConsumes Array of consumed media types.\n     * @param arrProduces Array of produced media types.\n     * @returns The matching Resource handler specification or undefined.\n     */\n    find(sPath: string, sVerb: string, arrConsumes: string[], arrProduces: string[]): any | undefined {\n        if (this.resources[sPath]) {\n            // Assuming Resource instance has a find method\n            const hit = this.resources[sPath].find(sVerb, arrConsumes, arrProduces);\n            if (hit)\n                return hit;\n        }\n        return;\n    };\n}"],
  "mappings": ";;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,sBAAyB;AAOlB,MAAM,iBAAiB;AAAA;AAAA,EAE1B,YAAoC,CAAC;AAAA,EACrC;AAAA;AAAA,EACA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAQA,YAAY,gBAAqB,YAAiB;AAC9C,QAAI,gBAAgB;AAChB,aAAO,KAAK,cAAc,EAAE,QAAQ,CAAC,UAAkB;AACnD,aAAK,UAAU,KAAK,IAAI,KAAK,SAAS,OAAO,eAAe,KAAK,CAAC;AAAA,MACtE,CAAC;AAAA,IACL;AAEA,QAAI,YAAY;AACZ,WAAK,aAAa;AAClB,WAAK,UAAU,WAAW,QAAQ,KAAK,UAAU;AAAA,IACrD;AAAA,EACJ;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAUA,KAAK,OAAe,gBAAgC;AAChD,QAAI,UAAU,MAAM,MAAM,CAAC,MAAM,KAAK;AAClC,cAAQ,MAAM,UAAU,CAAC;AAAA,IAC7B;AAEA,QAAI,KAAK,UAAU,KAAK,MAAM,QAAW;AAErC,WAAK,UAAU,KAAK,IAAI,IAAI,yBAAS,OAAO,gBAAgB,KAAK,YAAY,IAAI;AAAA,IACrF;AAEA,WAAO,KAAK,UAAU,KAAK;AAAA,EAC/B;AAAA;AAAA;AAAA;AAAA,EAKA,aAAa,OAAe,gBAAgC;AACxD,WAAO,KAAK,KAAK,OAAO,cAAc;AAAA,EAC1C;AAAA;AAAA;AAAA;AAAA,EAKA,SAAS,OAAe,gBAAgC;AACpD,WAAO,KAAK,KAAK,OAAO,cAAc;AAAA,EAC1C;AAAA;AAAA;AAAA;AAAA;AAAA,EAMA,gBAAwC;AACpC,UAAM,OAA+B,CAAC;AACtC,WAAO,KAAK,KAAK,SAAS,EAAE,QAAQ,CAAC,UAAkB;AAEnD,WAAK,KAAK,IAAI,KAAK,UAAU,KAAK,EAAE,cAAc;AAAA,IACtD,CAAC;AACD,WAAO;AAAA,EACX;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOA,WAAiB;AACb,WAAO,KAAK,KAAK,SAAS,EAAE,QAAQ,CAAC,UAAkB;AACnD,WAAK,UAAU,KAAK,EAAE,SAAS;AAAA,IACnC,CAAC;AACD,WAAO;AAAA,EACX;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAWA,QAAQ,OAAe,OAAe,aAAuB,aAA6B;AACtF,UAAM,WAAW,KAAK,UAAU,KAAK;AAErC,QAAI,YAAY,OAAO,SAAS,YAAY,YAAY;AACnD,eAAS,QAAQ,OAAO,aAAa,WAAW;AAAA,IACrD;AACA,WAAO;AAAA,EACX;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAWA,KAAK,OAAe,OAAe,aAAuB,aAAwC;AAC9F,QAAI,KAAK,UAAU,KAAK,GAAG;AAEvB,YAAM,MAAM,KAAK,UAAU,KAAK,EAAE,KAAK,OAAO,aAAa,WAAW;AACtE,UAAI;AACA,eAAO;AAAA,IACf;AACA;AAAA,EACJ;AACJ;",
  "names": []
}

@@ -22,6 +22,15 @@ __export(resource_method_exports, {
22
22
  module.exports = __toCommonJS(resource_method_exports);
23
23
  var import_resource_common = require("./resource-common");
24
24
  class ResourceMethod {
25
+ cfg;
26
+ _resource;
27
+ // Reference to the parent Resource instance
28
+ controller;
29
+ // Reference to the HttpController instance
30
+ // Fluent API aliases/delegates bound to ResourceMappings/Resource
31
+ resource;
32
+ resourcePath;
33
+ path;
25
34
  /**
26
35
  * @param oConfiguration Initial configuration object.
27
36
  * @param controller The HttpController instance.
@@ -215,4 +224,4 @@ class ResourceMethod {
215
224
  return this;
216
225
  }
217
226
  }
218
- //# 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": []
}

227
+ //# 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": []
}

@@ -38,6 +38,16 @@ function arrayEquals(source, target) {
38
38
  return true;
39
39
  }
40
40
  class Resource {
41
+ /** The URL path for this resource. */
42
+ sPath;
43
+ /** The resource configuration mapping methods to handler specifications. */
44
+ cfg;
45
+ /** The optional controller instance. */
46
+ controller;
47
+ /** Bound execute function from the controller. */
48
+ execute;
49
+ /** Additional mappings object. */
50
+ mappings;
41
51
  /**
42
52
  * @param sPath The base URL path for the resource.
43
53
  * @param oConfiguration Optional configuration object (map of method handlers).
@@ -229,4 +239,4 @@ class Resource {
229
239
  return this;
230
240
  }
231
241
  }
232
- //# 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": []
}

242
+ //# 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": []
}

@@ -44,6 +44,7 @@ class Upload {
44
44
  }
45
45
  }
46
46
  class FileItems {
47
+ native;
47
48
  /**
48
49
  * @param native The native Java collection object holding the file items.
49
50
  */
@@ -68,6 +69,7 @@ class FileItems {
68
69
  }
69
70
  }
70
71
  class FileItem {
72
+ native;
71
73
  /**
72
74
  * @param native The native Java object representing the file item.
73
75
  */
@@ -141,4 +143,4 @@ class FileItem {
141
143
  if (typeof module !== "undefined") {
142
144
  module.exports = Upload;
143
145
  }
144
- //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../src/http/upload.ts"],
  "sourcesContent": ["/**\n * Provides a static fa\u00E7ade (`Upload` class) for checking and parsing\n * multipart/form-data HTTP requests, typically used for file uploads.\n */\nimport { InputStream } from \"@aerokit/sdk/io/streams\"\nimport { Bytes } from \"@aerokit/sdk/io/bytes\"\n\nconst HttpUploadFacade = Java.type(\"org.eclipse.dirigible.components.api.http.HttpUploadFacade\");\n\n/**\n * The static Upload class provides methods to determine if a request contains\n * multipart content and to parse that content into file items.\n */\nexport class Upload {\n\n    /**\n     * Checks if the current incoming HTTP request contains multipart content\n     * (e.g., from an HTML form with `enctype=\"multipart/form-data\"`).\n     * @returns True if the request is multipart, false otherwise.\n     */\n    public static isMultipartContent(): boolean {\n        return HttpUploadFacade.isMultipartContent();\n    }\n\n    /**\n     * Parses the incoming multipart request content into a collection of file items.\n     * This operation typically consumes the request body.\n     * @returns A FileItems object representing all parts (files and form fields) of the request.\n     */\n    public static parseRequest(): FileItems {\n        // The underlying native execution context (__context) is assumed to contain\n        // the parsed file items under the \"files\" key after the native facade processing.\n        // @ts-ignore: __context is assumed to be globally available in the runtime environment\n        return new FileItems(__context.get(\"files\"));\n    }\n}\n\n/**\n * Represents a collection of uploaded file and form field items parsed from a multipart request.\n */\nexport class FileItems {\n\n    private readonly native: any;\n\n    /**\n     * @param native The native Java collection object holding the file items.\n     */\n    constructor(native: any) {\n        this.native = native;\n    }\n\n    /**\n     * Retrieves a specific item (file or form field) by its index in the collection.\n     * @param index The zero-based index of the item.\n     * @returns A FileItem object representing the item at the specified index.\n     */\n    public get(index: number): FileItem {\n        const native = this.native.get(index);\n        return new FileItem(native);\n    }\n\n    /**\n     * Returns the total number of items (files and form fields) in the collection.\n     * @returns The size of the collection.\n     */\n    public size(): number {\n        return this.native.size();\n    }\n}\n\n/**\n * Represents a single item (either an uploaded file or a regular form field)\n * within a multipart request.\n */\nexport class FileItem {\n\n    private readonly native: any\n\n    /**\n     * @param native The native Java object representing the file item.\n     */\n    constructor(native: any) {\n        this.native = native;\n    }\n\n    /**\n     * For a file upload, returns the original filename as reported by the client.\n     * For a regular form field, this is typically null or undefined.\n     * @returns The original filename string.\n     */\n    public getName(): string {\n        return this.native.getOriginalFilename();\n    }\n\n    /**\n     * Returns the MIME type of the uploaded file or content part.\n     * @returns The content type string (e.g., 'image/png', 'text/plain').\n     */\n    public getContentType(): string {\n        return this.native.getContentType();\n    }\n\n    /**\n     * Checks if the uploaded item is empty (e.g., a file upload with zero bytes).\n     * @returns True if the item is empty, false otherwise.\n     */\n    public isEmpty(): boolean {\n        return this.native.isEmpty();\n    }\n\n    /**\n     * Returns the size of the uploaded item in bytes.\n     * @returns The size as a number.\n     */\n    public getSize(): number {\n        return this.native.getSize();\n    }\n\n    /**\n     * Retrieves the content of the file item as a JavaScript array of bytes.\n     * This uses a utility (`Bytes.toJavaScriptBytes`) to convert the native Java byte array.\n     * @returns An array of bytes (`any[]`).\n     */\n    public getBytes(): any[] {\n        const data = this.getBytesNative();\n        return Bytes.toJavaScriptBytes(data);\n    }\n\n    /**\n     * Retrieves the content of the file item as the native Java byte array.\n     * @returns The native byte array (`any[]`).\n     */\n    public getBytesNative(): any[] {\n        return this.native.getBytes();\n    }\n\n    /**\n     * Retrieves the content of the file item as a string.\n     * Note: This assumes the content is text and may not handle all encodings correctly.\n     * It relies on JavaScript's `String.fromCharCode.apply` for conversion.\n     * @returns The content as a string.\n     */\n    public getText(): string {\n        return String.fromCharCode.apply(null, this.getBytesNative());\n    }\n\n    /**\n     * Gets an input stream for reading the content of the file item.\n     * This is useful for handling large files without loading the entire content into memory.\n     * @returns An InputStream object wrapping the native input stream.\n     */\n    public getInputStream(): InputStream {\n        const native = this.native.getInputStream();\n        return new InputStream(native);\n    }\n}\n\n// @ts-ignore\nif (typeof module !== 'undefined') {\n\t// @ts-ignore\n\tmodule.exports = Upload;\n}\n"],
  "mappings": ";;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAIA,qBAA4B;AAC5B,mBAAsB;AAEtB,MAAM,mBAAmB,KAAK,KAAK,4DAA4D;AAMxF,MAAM,OAAO;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOhB,OAAc,qBAA8B;AACxC,WAAO,iBAAiB,mBAAmB;AAAA,EAC/C;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOA,OAAc,eAA0B;AAIpC,WAAO,IAAI,UAAU,UAAU,IAAI,OAAO,CAAC;AAAA,EAC/C;AACJ;AAKO,MAAM,UAAU;AAAA;AAAA;AAAA;AAAA,EAOnB,YAAY,QAAa;AACrB,SAAK,SAAS;AAAA,EAClB;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOO,IAAI,OAAyB;AAChC,UAAM,SAAS,KAAK,OAAO,IAAI,KAAK;AACpC,WAAO,IAAI,SAAS,MAAM;AAAA,EAC9B;AAAA;AAAA;AAAA;AAAA;AAAA,EAMO,OAAe;AAClB,WAAO,KAAK,OAAO,KAAK;AAAA,EAC5B;AACJ;AAMO,MAAM,SAAS;AAAA;AAAA;AAAA;AAAA,EAOlB,YAAY,QAAa;AACrB,SAAK,SAAS;AAAA,EAClB;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOO,UAAkB;AACrB,WAAO,KAAK,OAAO,oBAAoB;AAAA,EAC3C;AAAA;AAAA;AAAA;AAAA;AAAA,EAMO,iBAAyB;AAC5B,WAAO,KAAK,OAAO,eAAe;AAAA,EACtC;AAAA;AAAA;AAAA;AAAA;AAAA,EAMO,UAAmB;AACtB,WAAO,KAAK,OAAO,QAAQ;AAAA,EAC/B;AAAA;AAAA;AAAA;AAAA;AAAA,EAMO,UAAkB;AACrB,WAAO,KAAK,OAAO,QAAQ;AAAA,EAC/B;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOO,WAAkB;AACrB,UAAM,OAAO,KAAK,eAAe;AACjC,WAAO,mBAAM,kBAAkB,IAAI;AAAA,EACvC;AAAA;AAAA;AAAA;AAAA;AAAA,EAMO,iBAAwB;AAC3B,WAAO,KAAK,OAAO,SAAS;AAAA,EAChC;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAQO,UAAkB;AACrB,WAAO,OAAO,aAAa,MAAM,MAAM,KAAK,eAAe,CAAC;AAAA,EAChE;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOO,iBAA8B;AACjC,UAAM,SAAS,KAAK,OAAO,eAAe;AAC1C,WAAO,IAAI,2BAAY,MAAM;AAAA,EACjC;AACJ;AAGA,IAAI,OAAO,WAAW,aAAa;AAElC,SAAO,UAAU;AAClB;",
  "names": []
}

146
+ //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../src/http/upload.ts"],
  "sourcesContent": ["/**\n * Provides a static fa\u00E7ade (`Upload` class) for checking and parsing\n * multipart/form-data HTTP requests, typically used for file uploads.\n */\nimport { InputStream } from \"@aerokit/sdk/io/streams\"\nimport { Bytes } from \"@aerokit/sdk/io/bytes\"\n\nconst HttpUploadFacade = Java.type(\"org.eclipse.dirigible.components.api.http.HttpUploadFacade\");\n\n/**\n * The static Upload class provides methods to determine if a request contains\n * multipart content and to parse that content into file items.\n */\nexport class Upload {\n\n    /**\n     * Checks if the current incoming HTTP request contains multipart content\n     * (e.g., from an HTML form with `enctype=\"multipart/form-data\"`).\n     * @returns True if the request is multipart, false otherwise.\n     */\n    public static isMultipartContent(): boolean {\n        return HttpUploadFacade.isMultipartContent();\n    }\n\n    /**\n     * Parses the incoming multipart request content into a collection of file items.\n     * This operation typically consumes the request body.\n     * @returns A FileItems object representing all parts (files and form fields) of the request.\n     */\n    public static parseRequest(): FileItems {\n        // The underlying native execution context (__context) is assumed to contain\n        // the parsed file items under the \"files\" key after the native facade processing.\n        // @ts-ignore: __context is assumed to be globally available in the runtime environment\n        return new FileItems(__context.get(\"files\"));\n    }\n}\n\n/**\n * Represents a collection of uploaded file and form field items parsed from a multipart request.\n */\nexport class FileItems {\n\n    private readonly native: any;\n\n    /**\n     * @param native The native Java collection object holding the file items.\n     */\n    constructor(native: any) {\n        this.native = native;\n    }\n\n    /**\n     * Retrieves a specific item (file or form field) by its index in the collection.\n     * @param index The zero-based index of the item.\n     * @returns A FileItem object representing the item at the specified index.\n     */\n    public get(index: number): FileItem {\n        const native = this.native.get(index);\n        return new FileItem(native);\n    }\n\n    /**\n     * Returns the total number of items (files and form fields) in the collection.\n     * @returns The size of the collection.\n     */\n    public size(): number {\n        return this.native.size();\n    }\n}\n\n/**\n * Represents a single item (either an uploaded file or a regular form field)\n * within a multipart request.\n */\nexport class FileItem {\n\n    private readonly native: any\n\n    /**\n     * @param native The native Java object representing the file item.\n     */\n    constructor(native: any) {\n        this.native = native;\n    }\n\n    /**\n     * For a file upload, returns the original filename as reported by the client.\n     * For a regular form field, this is typically null or undefined.\n     * @returns The original filename string.\n     */\n    public getName(): string {\n        return this.native.getOriginalFilename();\n    }\n\n    /**\n     * Returns the MIME type of the uploaded file or content part.\n     * @returns The content type string (e.g., 'image/png', 'text/plain').\n     */\n    public getContentType(): string {\n        return this.native.getContentType();\n    }\n\n    /**\n     * Checks if the uploaded item is empty (e.g., a file upload with zero bytes).\n     * @returns True if the item is empty, false otherwise.\n     */\n    public isEmpty(): boolean {\n        return this.native.isEmpty();\n    }\n\n    /**\n     * Returns the size of the uploaded item in bytes.\n     * @returns The size as a number.\n     */\n    public getSize(): number {\n        return this.native.getSize();\n    }\n\n    /**\n     * Retrieves the content of the file item as a JavaScript array of bytes.\n     * This uses a utility (`Bytes.toJavaScriptBytes`) to convert the native Java byte array.\n     * @returns An array of bytes (`any[]`).\n     */\n    public getBytes(): any[] {\n        const data = this.getBytesNative();\n        return Bytes.toJavaScriptBytes(data);\n    }\n\n    /**\n     * Retrieves the content of the file item as the native Java byte array.\n     * @returns The native byte array (`any[]`).\n     */\n    public getBytesNative(): any[] {\n        return this.native.getBytes();\n    }\n\n    /**\n     * Retrieves the content of the file item as a string.\n     * Note: This assumes the content is text and may not handle all encodings correctly.\n     * It relies on JavaScript's `String.fromCharCode.apply` for conversion.\n     * @returns The content as a string.\n     */\n    public getText(): string {\n        return String.fromCharCode.apply(null, this.getBytesNative());\n    }\n\n    /**\n     * Gets an input stream for reading the content of the file item.\n     * This is useful for handling large files without loading the entire content into memory.\n     * @returns An InputStream object wrapping the native input stream.\n     */\n    public getInputStream(): InputStream {\n        const native = this.native.getInputStream();\n        return new InputStream(native);\n    }\n}\n\n// @ts-ignore\nif (typeof module !== 'undefined') {\n\t// @ts-ignore\n\tmodule.exports = Upload;\n}\n"],
  "mappings": ";;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAIA,qBAA4B;AAC5B,mBAAsB;AAEtB,MAAM,mBAAmB,KAAK,KAAK,4DAA4D;AAMxF,MAAM,OAAO;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOhB,OAAc,qBAA8B;AACxC,WAAO,iBAAiB,mBAAmB;AAAA,EAC/C;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOA,OAAc,eAA0B;AAIpC,WAAO,IAAI,UAAU,UAAU,IAAI,OAAO,CAAC;AAAA,EAC/C;AACJ;AAKO,MAAM,UAAU;AAAA,EAEF;AAAA;AAAA;AAAA;AAAA,EAKjB,YAAY,QAAa;AACrB,SAAK,SAAS;AAAA,EAClB;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOO,IAAI,OAAyB;AAChC,UAAM,SAAS,KAAK,OAAO,IAAI,KAAK;AACpC,WAAO,IAAI,SAAS,MAAM;AAAA,EAC9B;AAAA;AAAA;AAAA;AAAA;AAAA,EAMO,OAAe;AAClB,WAAO,KAAK,OAAO,KAAK;AAAA,EAC5B;AACJ;AAMO,MAAM,SAAS;AAAA,EAED;AAAA;AAAA;AAAA;AAAA,EAKjB,YAAY,QAAa;AACrB,SAAK,SAAS;AAAA,EAClB;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOO,UAAkB;AACrB,WAAO,KAAK,OAAO,oBAAoB;AAAA,EAC3C;AAAA;AAAA;AAAA;AAAA;AAAA,EAMO,iBAAyB;AAC5B,WAAO,KAAK,OAAO,eAAe;AAAA,EACtC;AAAA;AAAA;AAAA;AAAA;AAAA,EAMO,UAAmB;AACtB,WAAO,KAAK,OAAO,QAAQ;AAAA,EAC/B;AAAA;AAAA;AAAA;AAAA;AAAA,EAMO,UAAkB;AACrB,WAAO,KAAK,OAAO,QAAQ;AAAA,EAC/B;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOO,WAAkB;AACrB,UAAM,OAAO,KAAK,eAAe;AACjC,WAAO,mBAAM,kBAAkB,IAAI;AAAA,EACvC;AAAA;AAAA;AAAA;AAAA;AAAA,EAMO,iBAAwB;AAC3B,WAAO,KAAK,OAAO,SAAS;AAAA,EAChC;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAQO,UAAkB;AACrB,WAAO,OAAO,aAAa,MAAM,MAAM,KAAK,eAAe,CAAC;AAAA,EAChE;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOO,iBAA8B;AACjC,UAAM,SAAS,KAAK,OAAO,eAAe;AAC1C,WAAO,IAAI,2BAAY,MAAM;AAAA,EACjC;AACJ;AAGA,IAAI,OAAO,WAAW,aAAa;AAElC,SAAO,UAAU;AAClB;",
  "names": []
}

@@ -25,12 +25,10 @@ var import_bytes = require("@aerokit/sdk/io/bytes");
25
25
  const FilesFacade = Java.type("org.eclipse.dirigible.components.api.io.FilesFacade");
26
26
  const File = Java.type("java.io.File");
27
27
  class Files {
28
- static {
29
- /**
30
- * The file system-dependent name separator character (e.g., "/" on Unix, "\" on Windows).
31
- */
32
- this.separator = File.separator;
33
- }
28
+ /**
29
+ * The file system-dependent name separator character (e.g., "/" on Unix, "\" on Windows).
30
+ */
31
+ static separator = File.separator;
34
32
  /**
35
33
  * Checks if a file or directory exists at the given path.
36
34
  * @param path The path to check.
@@ -341,4 +339,4 @@ class Files {
341
339
  if (typeof module !== "undefined") {
342
340
  module.exports = Files;
343
341
  }
344
- //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../src/io/files.ts"],
  "sourcesContent": ["/**\n * Provides a comprehensive static fa\u00E7ade for file and directory operations,\n * abstracting the underlying Java file system implementation.\n */\nimport { InputStream, OutputStream } from \"@aerokit/sdk/io/streams\";\nimport { Bytes } from \"@aerokit/sdk/io/bytes\";\n\nconst FilesFacade = Java.type(\"org.eclipse.dirigible.components.api.io.FilesFacade\");\nconst File = Java.type(\"java.io.File\")\n\n/**\n * Represents a generic file system object (file or directory).\n */\nexport interface FileObject {\n    /** The simple name of the file or folder. */\n    name: string;\n    /** The absolute path of the file or folder. */\n    path: string;\n}\n\n/**\n * Represents a folder object, extending the basic file object with lists of its contents.\n */\nexport interface FolderObject extends FileObject {\n    /** A list of file objects contained within this folder. */\n    files: FileObject[];\n    /** A list of sub-folder objects contained within this folder. */\n    folders: FolderObject[];\n}\n\n/**\n * The Files class provides static methods for high-level file system manipulation,\n * including checking properties, reading/writing content, and navigating the structure.\n */\nexport class Files {\n\n\t/**\n\t * The file system-dependent name separator character (e.g., \"/\" on Unix, \"\\\" on Windows).\n\t */\n\tpublic static readonly separator: string = File.separator;\n\n    /**\n\t * Checks if a file or directory exists at the given path.\n\t * @param path The path to check.\n\t * @returns True if the path exists, false otherwise.\n\t */\n\tpublic static exists(path: string): boolean {\n\t\treturn FilesFacade.exists(path);\n\t}\n\n\t/**\n\t * Checks if the file or directory at the given path is executable.\n\t * @param path The path to check.\n\t * @returns True if executable, false otherwise.\n\t */\n\tpublic static isExecutable(path: string): boolean {\n\t\treturn FilesFacade.isExecutable(path);\n\t}\n\n\t/**\n\t * Checks if the file or directory at the given path is readable.\n\t * @param path The path to check.\n\t * @returns True if readable, false otherwise.\n\t */\n\tpublic static isReadable(path: string): boolean {\n\t\treturn FilesFacade.isReadable(path);\n\t}\n\n\t/**\n\t * Checks if the file or directory at the given path is writable.\n\t * @param path The path to check.\n\t * @returns True if writable, false otherwise.\n\t */\n\tpublic static isWritable(path: string): boolean {\n\t\treturn FilesFacade.isWritable(path);\n\t}\n\n\t/**\n\t * Checks if the file or directory at the given path is hidden.\n\t * @param path The path to check.\n\t * @returns True if hidden, false otherwise.\n\t */\n\tpublic static isHidden(path: string): boolean {\n\t\treturn FilesFacade.isHidden(path);\n\t}\n\n\t/**\n\t * Checks if the path refers to a directory.\n\t * @param path The path to check.\n\t * @returns True if it's a directory, false otherwise.\n\t */\n\tpublic static isDirectory(path: string): boolean {\n\t\treturn FilesFacade.isDirectory(path);\n\t}\n\n\t/**\n\t * Checks if the path refers to a regular file.\n\t * @param path The path to check.\n\t * @returns True if it's a file, false otherwise.\n\t */\n\tpublic static isFile(path: string): boolean {\n\t\treturn FilesFacade.isFile(path);\n\t}\n\n\t/**\n\t * Checks if two paths refer to the same underlying file system object.\n\t * @param path1 The first path.\n\t * @param path2 The second path.\n\t * @returns True if they reference the same file/directory, false otherwise.\n\t */\n\tpublic static isSameFile(path1: string, path2: string): boolean {\n\t\treturn FilesFacade.isSameFile(path1, path2);\n\t}\n\n\t/**\n\t * Returns the canonical (absolute and normalized) path for the given path.\n\t * @param path The path to normalize.\n\t * @returns The canonical path string.\n\t */\n\tpublic static getCanonicalPath(path: string): string {\n\t\treturn FilesFacade.getCanonicalPath(path);\n\t}\n\n\t/**\n\t * Gets the simple name of the file or directory at the given path (the last element).\n\t * @param path The path.\n\t * @returns The name.\n\t */\n\tpublic static getName(path: string): string {\n\t\treturn FilesFacade.getName(path);\n\t}\n\n\t/**\n\t * Gets the path of the parent directory.\n\t * @param path The path.\n\t * @returns The parent path string, or null/empty if none exists.\n\t */\n\tpublic static getParentPath(path: string): string {\n\t\treturn FilesFacade.getParentPath(path);\n\t}\n\n\t/**\n\t * Reads all bytes from a file into a JavaScript byte array (an array of numbers).\n\t *\n\t * Note: This method automatically converts the native Java byte array to a\n\t * JavaScript array using `Bytes.toJavaScriptBytes()`.\n\t * @param path The path to the file.\n\t * @returns A JavaScript array of byte values.\n\t */\n\tpublic static readBytes(path: string): any[] {\n\t\tconst native = FilesFacade.readBytes(path);\n\t\treturn Bytes.toJavaScriptBytes(native);\n\t}\n\n\t/**\n\t * Reads all bytes from a file and returns the native Java byte array object.\n\t * @param path The path to the file.\n\t * @returns The native Java byte array.\n\t */\n\tpublic static readBytesNative(path: string): any[] {\n\t\treturn FilesFacade.readBytes(path);\n\t}\n\n\t/**\n\t * Reads all text content from a file using the platform's default character encoding.\n\t * @param path The path to the file.\n\t * @returns The content of the file as a string.\n\t */\n\tpublic static readText(path: string): string {\n\t\treturn FilesFacade.readText(path);\n\t}\n\n\t/**\n\t * Writes the content of a JavaScript byte array to a file. Overwrites existing content.\n\t *\n\t * Note: This method automatically converts the JavaScript array to a native\n\t * Java byte array using `Bytes.toJavaBytes()` before writing.\n\t * @param path The path to the file.\n\t * @param data The JavaScript array of byte values to write.\n\t */\n\tpublic static writeBytes(path: string, data: any[]): void {\n\t\tconst native = Bytes.toJavaBytes(data);\n\t\tFilesFacade.writeBytesNative(path, native);\n\t}\n\n\t/**\n\t * Writes the content of a native Java byte array to a file. Overwrites existing content.\n\t * @param path The path to the file.\n\t * @param data The native Java byte array to write.\n\t */\n\tpublic static writeBytesNative(path: string, data: any[]): void {\n\t\tFilesFacade.writeBytesNative(path, data);\n\t}\n\n\t/**\n\t * Writes a string of text to a file using the platform's default character encoding. Overwrites existing content.\n\t * @param path The path to the file.\n\t * @param text The string content to write.\n\t */\n\tpublic static writeText(path: string, text: string): void {\n\t\tFilesFacade.writeText(path, text);\n\t}\n\n\t/**\n\t * Gets the last modified time of the file or directory.\n\t * @param path The path to the file or directory.\n\t * @returns A JavaScript Date object representing the last modified time.\n\t */\n\tpublic static getLastModified(path: string): Date {\n\t\treturn new Date(FilesFacade.getLastModified(path));\n\t}\n\n\t/**\n\t * Sets the last modified time of the file or directory.\n\t * @param path The path to the file or directory.\n\t * @param time The new Date object to set as the last modified time.\n\t */\n\tpublic static setLastModified(path: string, time: Date): void {\n\t\tFilesFacade.setLastModified(path, time.getTime());\n\t}\n\n\t/**\n\t * Gets the owner of the file or directory.\n\t * @param path The path to the file or directory.\n\t * @returns The owner name as a string.\n\t */\n\tpublic static getOwner(path: string): string {\n\t\treturn FilesFacade.getOwner(path);\n\t}\n\n\t/**\n\t * Sets the owner of the file or directory.\n\t * @param path The path to the file or directory.\n\t * @param owner The new owner name.\n\t */\n\tpublic static setOwner(path: string, owner: string): void {\n\t\tFilesFacade.setOwner(path, owner);\n\t}\n\n\t/**\n\t * Gets the permissions string for the file or directory (implementation dependent).\n\t * @param path The path to the file or directory.\n\t * @returns The permissions string.\n\t */\n\tpublic static getPermissions(path: string): string {\n\t\treturn FilesFacade.getPermissions(path);\n\t}\n\n\t/**\n\t * Sets the permissions for the file or directory (implementation dependent).\n\t * @param path The path to the file or directory.\n\t * @param permissions The permissions string.\n\t */\n\tpublic static setPermissions(path: string, permissions: string): void {\n\t\tFilesFacade.setPermissions(path, permissions);\n\t}\n\n\t/**\n\t * Gets the size of the file in bytes.\n\t * @param path The path to the file.\n\t * @returns The size in bytes.\n\t */\n\tpublic static size(path: string): number {\n\t\treturn FilesFacade.size(path);\n\t}\n\n\t/**\n\t * Creates a new, empty file at the specified path.\n\t * @param path The path where the file should be created.\n\t */\n\tpublic static createFile(path: string): void {\n\t\tFilesFacade.createFile(path);\n\t}\n\n\t/**\n\t * Creates a new directory at the specified path.\n\t * @param path The path where the directory should be created.\n\t */\n\tpublic static createDirectory(path: string): void {\n\t\tFilesFacade.createDirectory(path);\n\t}\n\n\t/**\n\t * Copies a file or directory from a source path to a target path.\n\t * @param source The source path.\n\t * @param target The target path.\n\t */\n\tpublic static copy(source: string, target: string): void {\n\t\tFilesFacade.copy(source, target);\n\t}\n\n\t/**\n\t * Moves or renames a file or directory.\n\t * @param source The source path.\n\t * @param target The target path.\n\t */\n\tpublic static move(source: string, target: string): void {\n\t\tFilesFacade.move(source, target);\n\t}\n\n\t/**\n\t * Deletes the file at the specified path.\n\t * @param path The path to the file to delete.\n\t */\n\tpublic static deleteFile(path: string): void {\n\t\tFilesFacade.deleteFile(path);\n\t}\n\n\t/**\n\t * Deletes the directory at the specified path.\n\t * @param path The path to the directory to delete.\n\t * @param forced If true, recursively deletes the directory and its contents.\n\t */\n\tpublic static deleteDirectory(path: string, forced?: boolean): void {\n\t\tFilesFacade.deleteDirectory(path, forced);\n\t}\n\n\t/**\n\t * Creates a new temporary file with the given prefix and suffix.\n\t * @param prefix The prefix string to be used in generating the file's name.\n\t * @param suffix The suffix string to be used in generating the file's name.\n\t * @returns The path of the created temporary file.\n\t */\n\tpublic static createTempFile(prefix: string, suffix: string): string {\n\t\treturn FilesFacade.createTempFile(prefix, suffix);\n\t}\n\n\t/**\n\t * Creates a new temporary directory with the given prefix.\n\t * @param prefix The prefix string to be used in generating the directory's name.\n\t * @returns The path of the created temporary directory.\n\t */\n\tpublic static createTempDirectory(prefix: string): string {\n\t\treturn FilesFacade.createTempDirectory(prefix);\n\t}\n\n\t/**\n\t * Creates and returns a new {@link InputStream} for reading data from the file.\n\t * @param path The path to the file.\n\t * @returns A new InputStream instance.\n\t */\n\tpublic static createInputStream(path: string): InputStream {\n\t\tconst native = FilesFacade.createInputStream(path);\n\t\treturn new InputStream(native);\n\t}\n\n\t/**\n\t * Creates and returns a new {@link OutputStream} for writing data to the file.\n\t * @param path The path to the file.\n\t * @returns A new OutputStream instance.\n\t */\n\tpublic static createOutputStream(path: string): OutputStream {\n\t\tconst native = FilesFacade.createOutputStream(path);\n\t\treturn new OutputStream(native);\n\t}\n\n\t/**\n\t * Traverses a directory and returns a structured {@link FolderObject} hierarchy.\n\t * @param path The path to the folder to traverse.\n\t * @returns The root FolderObject containing the file system tree structure.\n\t */\n\tpublic static traverse(path: string): FolderObject[] {\n\t\treturn JSON.parse(FilesFacade.traverse(path));\n\t}\n\n\t/**\n\t * Lists the direct children (files and folders) of a directory, returning only their paths.\n\t * @param path The path to the directory.\n\t * @returns An array of string paths for the contents of the directory.\n\t */\n\tpublic static list(path: string): string[] {\n\t\t// The native facade returns a JSON array of objects, which is then mapped to an array of paths.\n\t\treturn JSON.parse(FilesFacade.list(path)).map(e => e.path);\n\t}\n\n\t/**\n\t * Finds files and directories matching a specified glob pattern within a directory tree.\n\t * @param path The starting path for the search.\n\t * @param pattern The glob pattern to match (e.g., \"*.js\", \"**.txt\").\n\t * @returns An array of string paths that match the pattern.\n\t */\n\tpublic static find(path: string, pattern: string): string[] {\n\t\treturn JSON.parse(FilesFacade.find(path, pattern));\n\t}\n}\n\n// @ts-ignore\nif (typeof module !== 'undefined') {\n\t// @ts-ignore\n\tmodule.exports = Files;\n}\n"],
  "mappings": "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",
  "names": []
}

342
+ //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../src/io/files.ts"],
  "sourcesContent": ["/**\n * Provides a comprehensive static fa\u00E7ade for file and directory operations,\n * abstracting the underlying Java file system implementation.\n */\nimport { InputStream, OutputStream } from \"@aerokit/sdk/io/streams\";\nimport { Bytes } from \"@aerokit/sdk/io/bytes\";\n\nconst FilesFacade = Java.type(\"org.eclipse.dirigible.components.api.io.FilesFacade\");\nconst File = Java.type(\"java.io.File\")\n\n/**\n * Represents a generic file system object (file or directory).\n */\nexport interface FileObject {\n    /** The simple name of the file or folder. */\n    name: string;\n    /** The absolute path of the file or folder. */\n    path: string;\n}\n\n/**\n * Represents a folder object, extending the basic file object with lists of its contents.\n */\nexport interface FolderObject extends FileObject {\n    /** A list of file objects contained within this folder. */\n    files: FileObject[];\n    /** A list of sub-folder objects contained within this folder. */\n    folders: FolderObject[];\n}\n\n/**\n * The Files class provides static methods for high-level file system manipulation,\n * including checking properties, reading/writing content, and navigating the structure.\n */\nexport class Files {\n\n\t/**\n\t * The file system-dependent name separator character (e.g., \"/\" on Unix, \"\\\" on Windows).\n\t */\n\tpublic static readonly separator: string = File.separator;\n\n    /**\n\t * Checks if a file or directory exists at the given path.\n\t * @param path The path to check.\n\t * @returns True if the path exists, false otherwise.\n\t */\n\tpublic static exists(path: string): boolean {\n\t\treturn FilesFacade.exists(path);\n\t}\n\n\t/**\n\t * Checks if the file or directory at the given path is executable.\n\t * @param path The path to check.\n\t * @returns True if executable, false otherwise.\n\t */\n\tpublic static isExecutable(path: string): boolean {\n\t\treturn FilesFacade.isExecutable(path);\n\t}\n\n\t/**\n\t * Checks if the file or directory at the given path is readable.\n\t * @param path The path to check.\n\t * @returns True if readable, false otherwise.\n\t */\n\tpublic static isReadable(path: string): boolean {\n\t\treturn FilesFacade.isReadable(path);\n\t}\n\n\t/**\n\t * Checks if the file or directory at the given path is writable.\n\t * @param path The path to check.\n\t * @returns True if writable, false otherwise.\n\t */\n\tpublic static isWritable(path: string): boolean {\n\t\treturn FilesFacade.isWritable(path);\n\t}\n\n\t/**\n\t * Checks if the file or directory at the given path is hidden.\n\t * @param path The path to check.\n\t * @returns True if hidden, false otherwise.\n\t */\n\tpublic static isHidden(path: string): boolean {\n\t\treturn FilesFacade.isHidden(path);\n\t}\n\n\t/**\n\t * Checks if the path refers to a directory.\n\t * @param path The path to check.\n\t * @returns True if it's a directory, false otherwise.\n\t */\n\tpublic static isDirectory(path: string): boolean {\n\t\treturn FilesFacade.isDirectory(path);\n\t}\n\n\t/**\n\t * Checks if the path refers to a regular file.\n\t * @param path The path to check.\n\t * @returns True if it's a file, false otherwise.\n\t */\n\tpublic static isFile(path: string): boolean {\n\t\treturn FilesFacade.isFile(path);\n\t}\n\n\t/**\n\t * Checks if two paths refer to the same underlying file system object.\n\t * @param path1 The first path.\n\t * @param path2 The second path.\n\t * @returns True if they reference the same file/directory, false otherwise.\n\t */\n\tpublic static isSameFile(path1: string, path2: string): boolean {\n\t\treturn FilesFacade.isSameFile(path1, path2);\n\t}\n\n\t/**\n\t * Returns the canonical (absolute and normalized) path for the given path.\n\t * @param path The path to normalize.\n\t * @returns The canonical path string.\n\t */\n\tpublic static getCanonicalPath(path: string): string {\n\t\treturn FilesFacade.getCanonicalPath(path);\n\t}\n\n\t/**\n\t * Gets the simple name of the file or directory at the given path (the last element).\n\t * @param path The path.\n\t * @returns The name.\n\t */\n\tpublic static getName(path: string): string {\n\t\treturn FilesFacade.getName(path);\n\t}\n\n\t/**\n\t * Gets the path of the parent directory.\n\t * @param path The path.\n\t * @returns The parent path string, or null/empty if none exists.\n\t */\n\tpublic static getParentPath(path: string): string {\n\t\treturn FilesFacade.getParentPath(path);\n\t}\n\n\t/**\n\t * Reads all bytes from a file into a JavaScript byte array (an array of numbers).\n\t *\n\t * Note: This method automatically converts the native Java byte array to a\n\t * JavaScript array using `Bytes.toJavaScriptBytes()`.\n\t * @param path The path to the file.\n\t * @returns A JavaScript array of byte values.\n\t */\n\tpublic static readBytes(path: string): any[] {\n\t\tconst native = FilesFacade.readBytes(path);\n\t\treturn Bytes.toJavaScriptBytes(native);\n\t}\n\n\t/**\n\t * Reads all bytes from a file and returns the native Java byte array object.\n\t * @param path The path to the file.\n\t * @returns The native Java byte array.\n\t */\n\tpublic static readBytesNative(path: string): any[] {\n\t\treturn FilesFacade.readBytes(path);\n\t}\n\n\t/**\n\t * Reads all text content from a file using the platform's default character encoding.\n\t * @param path The path to the file.\n\t * @returns The content of the file as a string.\n\t */\n\tpublic static readText(path: string): string {\n\t\treturn FilesFacade.readText(path);\n\t}\n\n\t/**\n\t * Writes the content of a JavaScript byte array to a file. Overwrites existing content.\n\t *\n\t * Note: This method automatically converts the JavaScript array to a native\n\t * Java byte array using `Bytes.toJavaBytes()` before writing.\n\t * @param path The path to the file.\n\t * @param data The JavaScript array of byte values to write.\n\t */\n\tpublic static writeBytes(path: string, data: any[]): void {\n\t\tconst native = Bytes.toJavaBytes(data);\n\t\tFilesFacade.writeBytesNative(path, native);\n\t}\n\n\t/**\n\t * Writes the content of a native Java byte array to a file. Overwrites existing content.\n\t * @param path The path to the file.\n\t * @param data The native Java byte array to write.\n\t */\n\tpublic static writeBytesNative(path: string, data: any[]): void {\n\t\tFilesFacade.writeBytesNative(path, data);\n\t}\n\n\t/**\n\t * Writes a string of text to a file using the platform's default character encoding. Overwrites existing content.\n\t * @param path The path to the file.\n\t * @param text The string content to write.\n\t */\n\tpublic static writeText(path: string, text: string): void {\n\t\tFilesFacade.writeText(path, text);\n\t}\n\n\t/**\n\t * Gets the last modified time of the file or directory.\n\t * @param path The path to the file or directory.\n\t * @returns A JavaScript Date object representing the last modified time.\n\t */\n\tpublic static getLastModified(path: string): Date {\n\t\treturn new Date(FilesFacade.getLastModified(path));\n\t}\n\n\t/**\n\t * Sets the last modified time of the file or directory.\n\t * @param path The path to the file or directory.\n\t * @param time The new Date object to set as the last modified time.\n\t */\n\tpublic static setLastModified(path: string, time: Date): void {\n\t\tFilesFacade.setLastModified(path, time.getTime());\n\t}\n\n\t/**\n\t * Gets the owner of the file or directory.\n\t * @param path The path to the file or directory.\n\t * @returns The owner name as a string.\n\t */\n\tpublic static getOwner(path: string): string {\n\t\treturn FilesFacade.getOwner(path);\n\t}\n\n\t/**\n\t * Sets the owner of the file or directory.\n\t * @param path The path to the file or directory.\n\t * @param owner The new owner name.\n\t */\n\tpublic static setOwner(path: string, owner: string): void {\n\t\tFilesFacade.setOwner(path, owner);\n\t}\n\n\t/**\n\t * Gets the permissions string for the file or directory (implementation dependent).\n\t * @param path The path to the file or directory.\n\t * @returns The permissions string.\n\t */\n\tpublic static getPermissions(path: string): string {\n\t\treturn FilesFacade.getPermissions(path);\n\t}\n\n\t/**\n\t * Sets the permissions for the file or directory (implementation dependent).\n\t * @param path The path to the file or directory.\n\t * @param permissions The permissions string.\n\t */\n\tpublic static setPermissions(path: string, permissions: string): void {\n\t\tFilesFacade.setPermissions(path, permissions);\n\t}\n\n\t/**\n\t * Gets the size of the file in bytes.\n\t * @param path The path to the file.\n\t * @returns The size in bytes.\n\t */\n\tpublic static size(path: string): number {\n\t\treturn FilesFacade.size(path);\n\t}\n\n\t/**\n\t * Creates a new, empty file at the specified path.\n\t * @param path The path where the file should be created.\n\t */\n\tpublic static createFile(path: string): void {\n\t\tFilesFacade.createFile(path);\n\t}\n\n\t/**\n\t * Creates a new directory at the specified path.\n\t * @param path The path where the directory should be created.\n\t */\n\tpublic static createDirectory(path: string): void {\n\t\tFilesFacade.createDirectory(path);\n\t}\n\n\t/**\n\t * Copies a file or directory from a source path to a target path.\n\t * @param source The source path.\n\t * @param target The target path.\n\t */\n\tpublic static copy(source: string, target: string): void {\n\t\tFilesFacade.copy(source, target);\n\t}\n\n\t/**\n\t * Moves or renames a file or directory.\n\t * @param source The source path.\n\t * @param target The target path.\n\t */\n\tpublic static move(source: string, target: string): void {\n\t\tFilesFacade.move(source, target);\n\t}\n\n\t/**\n\t * Deletes the file at the specified path.\n\t * @param path The path to the file to delete.\n\t */\n\tpublic static deleteFile(path: string): void {\n\t\tFilesFacade.deleteFile(path);\n\t}\n\n\t/**\n\t * Deletes the directory at the specified path.\n\t * @param path The path to the directory to delete.\n\t * @param forced If true, recursively deletes the directory and its contents.\n\t */\n\tpublic static deleteDirectory(path: string, forced?: boolean): void {\n\t\tFilesFacade.deleteDirectory(path, forced);\n\t}\n\n\t/**\n\t * Creates a new temporary file with the given prefix and suffix.\n\t * @param prefix The prefix string to be used in generating the file's name.\n\t * @param suffix The suffix string to be used in generating the file's name.\n\t * @returns The path of the created temporary file.\n\t */\n\tpublic static createTempFile(prefix: string, suffix: string): string {\n\t\treturn FilesFacade.createTempFile(prefix, suffix);\n\t}\n\n\t/**\n\t * Creates a new temporary directory with the given prefix.\n\t * @param prefix The prefix string to be used in generating the directory's name.\n\t * @returns The path of the created temporary directory.\n\t */\n\tpublic static createTempDirectory(prefix: string): string {\n\t\treturn FilesFacade.createTempDirectory(prefix);\n\t}\n\n\t/**\n\t * Creates and returns a new {@link InputStream} for reading data from the file.\n\t * @param path The path to the file.\n\t * @returns A new InputStream instance.\n\t */\n\tpublic static createInputStream(path: string): InputStream {\n\t\tconst native = FilesFacade.createInputStream(path);\n\t\treturn new InputStream(native);\n\t}\n\n\t/**\n\t * Creates and returns a new {@link OutputStream} for writing data to the file.\n\t * @param path The path to the file.\n\t * @returns A new OutputStream instance.\n\t */\n\tpublic static createOutputStream(path: string): OutputStream {\n\t\tconst native = FilesFacade.createOutputStream(path);\n\t\treturn new OutputStream(native);\n\t}\n\n\t/**\n\t * Traverses a directory and returns a structured {@link FolderObject} hierarchy.\n\t * @param path The path to the folder to traverse.\n\t * @returns The root FolderObject containing the file system tree structure.\n\t */\n\tpublic static traverse(path: string): FolderObject[] {\n\t\treturn JSON.parse(FilesFacade.traverse(path));\n\t}\n\n\t/**\n\t * Lists the direct children (files and folders) of a directory, returning only their paths.\n\t * @param path The path to the directory.\n\t * @returns An array of string paths for the contents of the directory.\n\t */\n\tpublic static list(path: string): string[] {\n\t\t// The native facade returns a JSON array of objects, which is then mapped to an array of paths.\n\t\treturn JSON.parse(FilesFacade.list(path)).map(e => e.path);\n\t}\n\n\t/**\n\t * Finds files and directories matching a specified glob pattern within a directory tree.\n\t * @param path The starting path for the search.\n\t * @param pattern The glob pattern to match (e.g., \"*.js\", \"**.txt\").\n\t * @returns An array of string paths that match the pattern.\n\t */\n\tpublic static find(path: string, pattern: string): string[] {\n\t\treturn JSON.parse(FilesFacade.find(path, pattern));\n\t}\n}\n\n// @ts-ignore\nif (typeof module !== 'undefined') {\n\t// @ts-ignore\n\tmodule.exports = Files;\n}\n"],
  "mappings": "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",
  "names": []
}

@@ -102,6 +102,8 @@ class Streams {
102
102
  }
103
103
  }
104
104
  class InputStream {
105
+ /** The underlying native Java stream object. */
106
+ native;
105
107
  /**
106
108
  * @param native The native Java InputStream object.
107
109
  */
@@ -156,6 +158,8 @@ class InputStream {
156
158
  }
157
159
  }
158
160
  class OutputStream {
161
+ /** The underlying native Java stream object. */
162
+ native;
159
163
  /**
160
164
  * @param native The native Java OutputStream object.
161
165
  */
@@ -240,4 +244,4 @@ class OutputStream {
240
244
  if (typeof module !== "undefined") {
241
245
  module.exports = Streams;
242
246
  }
243
- //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../src/io/streams.ts"],
  "sourcesContent": ["/**\n * Provides core functionality for input/output stream management,\n * including stream creation, data transfer, and byte array handling.\n */\nimport { Bytes } from \"@aerokit/sdk/io/bytes\";\n\nconst StreamsFacade = Java.type(\"org.eclipse.dirigible.components.api.io.StreamsFacade\");\n\n/**\n * The Streams class provides static utility methods for stream creation,\n * manipulation, and data copying.\n */\nexport class Streams {\n\n\t/**\n\t * Copies all bytes from the input stream to the output stream.\n\t * This method is generally used for smaller streams.\n\t *\n\t * @param input The source {@link InputStream}.\n\t * @param output The destination {@link OutputStream}.\n\t */\n\tpublic static copy(input: InputStream, output: OutputStream): void {\n\t\tStreamsFacade.copy(input.native, output.native);\n\t}\n\n\t/**\n\t * Copies all bytes from the input stream to the output stream using a large buffer,\n\t * suitable for large file transfers.\n\t *\n\t * @param input The source {@link InputStream}.\n\t * @param output The destination {@link OutputStream}.\n\t */\n\tpublic static copyLarge(input: InputStream, output: OutputStream): void {\n\t\tStreamsFacade.copyLarge(input.native, output.native);\n\t}\n\n\t/**\n\t * Creates a new {@link InputStream} from a resource accessible via the class loader.\n\t * This is typically used to read bundled resources within the application runtime.\n\t *\n\t * @param path The path to the resource.\n\t * @returns A new {@link InputStream} instance for the resource.\n\t */\n\tpublic static getResourceAsByteArrayInputStream(path: string): InputStream {\n\t\tconst native = StreamsFacade.getResourceAsByteArrayInputStream(path);\n\t\treturn new InputStream(native);\n\t}\n\n\t/**\n\t * Creates a new {@link InputStream} from a JavaScript byte array (`any[]`).\n\t *\n\t * @param data The JavaScript array of byte values (`number[]`).\n\t * @returns A new {@link InputStream} instance initialized with the byte data.\n\t */\n\tpublic static createByteArrayInputStream(data: any[]): InputStream {\n\t\t// Convert JavaScript byte array to native Java byte array\n\t\tconst array = Bytes.toJavaBytes(data);\n\t\tconst native = StreamsFacade.createByteArrayInputStream(array);\n\t\treturn new InputStream(native);\n\t}\n\n\t/**\n\t * Creates a new {@link OutputStream} that writes data into an in-memory byte array.\n\t * This is typically used as a buffer to capture output before processing it.\n\t *\n\t * @returns A new {@link OutputStream} instance backed by a byte array.\n\t */\n\tpublic static createByteArrayOutputStream(): OutputStream {\n\t\tconst native = StreamsFacade.createByteArrayOutputStream();\n\t\treturn new OutputStream(native);\n\t}\n\n\t/**\n\t * Wraps a native (Java) InputStream object into a new JavaScript {@link InputStream} instance.\n\t *\n\t * @param native The underlying native InputStream object.\n\t * @returns A new {@link InputStream} wrapper.\n\t */\n\tpublic static createInputStream(native: any): InputStream {\n\t\tconst inputStream = new InputStream(native);\n\t\treturn inputStream;\n\t}\n\n\t/**\n\t * Wraps a native (Java) OutputStream object into a new JavaScript {@link OutputStream} instance.\n\t *\n\t * Note: This method is not static in the original definition, but is placed here for completeness\n\t * and consistency with other factory methods.\n\t *\n\t * @param native The underlying native OutputStream object.\n\t * @returns A new {@link OutputStream} wrapper.\n\t */\n\tpublic createOutputStream(native: any): OutputStream {\n\t\tconst outputStream = new OutputStream(native);\n\t\treturn outputStream;\n\t}\n}\n\n/**\n * Represents an input stream for reading bytes.\n * This class wraps a native stream object and provides methods for reading data.\n */\nexport class InputStream {\n\n\t/** The underlying native Java stream object. */\n\tpublic readonly native: any;\n\n\t/**\n\t * @param native The native Java InputStream object.\n\t */\n\tconstructor(native: any) {\n\t\tthis.native = native;\n\t}\n\n\t/**\n\t * Reads the next byte of data from this input stream.\n\t * @returns The next byte of data, or -1 if the end of the stream is reached.\n\t */\n\tpublic read(): number {\n\t\treturn StreamsFacade.read(this.native);\n\t}\n\n\t/**\n\t * Reads all remaining bytes from the stream and returns them as a JavaScript array.\n\t *\n\t * @returns A JavaScript array (`number[]`) of the byte values.\n\t */\n\tpublic readBytes(): any[] {\n\t\tconst native = StreamsFacade.readBytes(this.native);\n\t\treturn Bytes.toJavaScriptBytes(native);\n\t}\n\n\t/**\n\t * Reads all remaining bytes from the stream and returns the native Java byte array.\n\t *\n\t * @returns The native Java byte array object.\n\t */\n\tpublic readBytesNative(): any[] {\n\t\treturn StreamsFacade.readBytes(this.native);\n\t}\n\n\t/**\n\t * Reads all remaining bytes from the stream and converts them to a string\n\t * using the platform's default character encoding.\n\t *\n\t * @returns The content of the stream as a string.\n\t */\n\tpublic readText(): string {\n\t\treturn StreamsFacade.readText(this.native);\n\t}\n\n\t/**\n\t * Closes this input stream and releases any system resources associated with it.\n\t */\n\tpublic close(): void {\n\t\tStreamsFacade.close(this.native);\n\t}\n\n\t/**\n\t * Checks if the underlying native stream object is defined and non-null.\n\t * @returns True if the stream is valid, false otherwise.\n\t */\n\tpublic isValid(): boolean {\n\t\treturn this.native !== undefined && this.native !== null;\n\t}\n}\n\n/**\n * Represents an output stream for writing bytes.\n * This class wraps a native stream object and provides methods for writing data.\n */\nexport class OutputStream {\n\n\t/** The underlying native Java stream object. */\n\tpublic readonly native: any;\n\n\t/**\n\t * @param native The native Java OutputStream object.\n\t */\n\tconstructor(native: any) {\n\t\tthis.native = native;\n\t}\n\n\t/**\n\t * Writes the specified byte to this output stream.\n\t * @param byte The byte (as a number 0-255) to write.\n\t */\n\tpublic write(byte: number): void {\n\t\tStreamsFacade.write(this.native, byte);\n\t}\n\n\t/**\n\t * Writes the entire content of a JavaScript byte array to this output stream.\n\t *\n\t * @param data The JavaScript array (`number[]`) of byte values to write.\n\t */\n\tpublic writeBytes(data: any[]): void {\n\t\t// Convert JavaScript byte array to native Java byte array\n\t\tconst native = Bytes.toJavaBytes(data);\n\t\tStreamsFacade.writeBytes(this.native, native);\n\t}\n\n\t/**\n\t * Writes the entire content of a native Java byte array to this output stream.\n\t *\n\t * @param data The native Java byte array object to write.\n\t */\n\tpublic writeBytesNative(data: any[]): void {\n\t\tStreamsFacade.writeBytes(this.native, data);\n\t}\n\n\t/**\n\t * Converts the string to bytes using the platform's default character encoding\n\t * and writes them to this output stream.\n\t *\n\t * @param text The string content to write.\n\t */\n\tpublic writeText(text: string): void {\n\t\tStreamsFacade.writeText(this.native, text);\n\t}\n\n\t/**\n\t * Closes this output stream and releases any system resources associated with it.\n\t */\n\tpublic close(): void {\n\t\tStreamsFacade.close(this.native);\n\t}\n\n\t/**\n\t * Retrieves the content written to this stream as a JavaScript byte array.\n\t * This is typically used with a ByteArrayOutputStream.\n\t *\n\t * @returns A JavaScript array (`number[]`) of the byte values written to the stream.\n\t */\n\tpublic getBytes(): any[] {\n\t\tconst native = StreamsFacade.getBytes(this.native);\n\t\treturn Bytes.toJavaScriptBytes(native);\n\t}\n\n\t/**\n\t * Retrieves the content written to this stream as the native Java byte array.\n\t * This is typically used with a ByteArrayOutputStream.\n\t *\n\t * @returns The native Java byte array object.\n\t */\n\tpublic getBytesNative(): any[] {\n\t\treturn StreamsFacade.getBytes(this.native);\n\t}\n\n\t/**\n\t * Retrieves the content written to this stream as a string using the platform's\n\t * default character encoding. This is typically used with a ByteArrayOutputStream.\n\t *\n\t * @returns The content of the stream as a string.\n\t */\n\tpublic getText(): string {\n\t\treturn StreamsFacade.getText(this.native);\n\t}\n\n\t/**\n\t * Checks if the underlying native stream object is defined and non-null.\n\t * @returns True if the stream is valid, false otherwise.\n\t */\n\tpublic isValid(): boolean {\n\t\treturn this.native !== undefined && this.native !== null;\n\t}\n}\n\n// @ts-ignore\nif (typeof module !== 'undefined') {\n\t// @ts-ignore\n\tmodule.exports = Streams;\n}\n"],
  "mappings": "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",
  "names": []
}

247
+ //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../src/io/streams.ts"],
  "sourcesContent": ["/**\n * Provides core functionality for input/output stream management,\n * including stream creation, data transfer, and byte array handling.\n */\nimport { Bytes } from \"@aerokit/sdk/io/bytes\";\n\nconst StreamsFacade = Java.type(\"org.eclipse.dirigible.components.api.io.StreamsFacade\");\n\n/**\n * The Streams class provides static utility methods for stream creation,\n * manipulation, and data copying.\n */\nexport class Streams {\n\n\t/**\n\t * Copies all bytes from the input stream to the output stream.\n\t * This method is generally used for smaller streams.\n\t *\n\t * @param input The source {@link InputStream}.\n\t * @param output The destination {@link OutputStream}.\n\t */\n\tpublic static copy(input: InputStream, output: OutputStream): void {\n\t\tStreamsFacade.copy(input.native, output.native);\n\t}\n\n\t/**\n\t * Copies all bytes from the input stream to the output stream using a large buffer,\n\t * suitable for large file transfers.\n\t *\n\t * @param input The source {@link InputStream}.\n\t * @param output The destination {@link OutputStream}.\n\t */\n\tpublic static copyLarge(input: InputStream, output: OutputStream): void {\n\t\tStreamsFacade.copyLarge(input.native, output.native);\n\t}\n\n\t/**\n\t * Creates a new {@link InputStream} from a resource accessible via the class loader.\n\t * This is typically used to read bundled resources within the application runtime.\n\t *\n\t * @param path The path to the resource.\n\t * @returns A new {@link InputStream} instance for the resource.\n\t */\n\tpublic static getResourceAsByteArrayInputStream(path: string): InputStream {\n\t\tconst native = StreamsFacade.getResourceAsByteArrayInputStream(path);\n\t\treturn new InputStream(native);\n\t}\n\n\t/**\n\t * Creates a new {@link InputStream} from a JavaScript byte array (`any[]`).\n\t *\n\t * @param data The JavaScript array of byte values (`number[]`).\n\t * @returns A new {@link InputStream} instance initialized with the byte data.\n\t */\n\tpublic static createByteArrayInputStream(data: any[]): InputStream {\n\t\t// Convert JavaScript byte array to native Java byte array\n\t\tconst array = Bytes.toJavaBytes(data);\n\t\tconst native = StreamsFacade.createByteArrayInputStream(array);\n\t\treturn new InputStream(native);\n\t}\n\n\t/**\n\t * Creates a new {@link OutputStream} that writes data into an in-memory byte array.\n\t * This is typically used as a buffer to capture output before processing it.\n\t *\n\t * @returns A new {@link OutputStream} instance backed by a byte array.\n\t */\n\tpublic static createByteArrayOutputStream(): OutputStream {\n\t\tconst native = StreamsFacade.createByteArrayOutputStream();\n\t\treturn new OutputStream(native);\n\t}\n\n\t/**\n\t * Wraps a native (Java) InputStream object into a new JavaScript {@link InputStream} instance.\n\t *\n\t * @param native The underlying native InputStream object.\n\t * @returns A new {@link InputStream} wrapper.\n\t */\n\tpublic static createInputStream(native: any): InputStream {\n\t\tconst inputStream = new InputStream(native);\n\t\treturn inputStream;\n\t}\n\n\t/**\n\t * Wraps a native (Java) OutputStream object into a new JavaScript {@link OutputStream} instance.\n\t *\n\t * Note: This method is not static in the original definition, but is placed here for completeness\n\t * and consistency with other factory methods.\n\t *\n\t * @param native The underlying native OutputStream object.\n\t * @returns A new {@link OutputStream} wrapper.\n\t */\n\tpublic createOutputStream(native: any): OutputStream {\n\t\tconst outputStream = new OutputStream(native);\n\t\treturn outputStream;\n\t}\n}\n\n/**\n * Represents an input stream for reading bytes.\n * This class wraps a native stream object and provides methods for reading data.\n */\nexport class InputStream {\n\n\t/** The underlying native Java stream object. */\n\tpublic readonly native: any;\n\n\t/**\n\t * @param native The native Java InputStream object.\n\t */\n\tconstructor(native: any) {\n\t\tthis.native = native;\n\t}\n\n\t/**\n\t * Reads the next byte of data from this input stream.\n\t * @returns The next byte of data, or -1 if the end of the stream is reached.\n\t */\n\tpublic read(): number {\n\t\treturn StreamsFacade.read(this.native);\n\t}\n\n\t/**\n\t * Reads all remaining bytes from the stream and returns them as a JavaScript array.\n\t *\n\t * @returns A JavaScript array (`number[]`) of the byte values.\n\t */\n\tpublic readBytes(): any[] {\n\t\tconst native = StreamsFacade.readBytes(this.native);\n\t\treturn Bytes.toJavaScriptBytes(native);\n\t}\n\n\t/**\n\t * Reads all remaining bytes from the stream and returns the native Java byte array.\n\t *\n\t * @returns The native Java byte array object.\n\t */\n\tpublic readBytesNative(): any[] {\n\t\treturn StreamsFacade.readBytes(this.native);\n\t}\n\n\t/**\n\t * Reads all remaining bytes from the stream and converts them to a string\n\t * using the platform's default character encoding.\n\t *\n\t * @returns The content of the stream as a string.\n\t */\n\tpublic readText(): string {\n\t\treturn StreamsFacade.readText(this.native);\n\t}\n\n\t/**\n\t * Closes this input stream and releases any system resources associated with it.\n\t */\n\tpublic close(): void {\n\t\tStreamsFacade.close(this.native);\n\t}\n\n\t/**\n\t * Checks if the underlying native stream object is defined and non-null.\n\t * @returns True if the stream is valid, false otherwise.\n\t */\n\tpublic isValid(): boolean {\n\t\treturn this.native !== undefined && this.native !== null;\n\t}\n}\n\n/**\n * Represents an output stream for writing bytes.\n * This class wraps a native stream object and provides methods for writing data.\n */\nexport class OutputStream {\n\n\t/** The underlying native Java stream object. */\n\tpublic readonly native: any;\n\n\t/**\n\t * @param native The native Java OutputStream object.\n\t */\n\tconstructor(native: any) {\n\t\tthis.native = native;\n\t}\n\n\t/**\n\t * Writes the specified byte to this output stream.\n\t * @param byte The byte (as a number 0-255) to write.\n\t */\n\tpublic write(byte: number): void {\n\t\tStreamsFacade.write(this.native, byte);\n\t}\n\n\t/**\n\t * Writes the entire content of a JavaScript byte array to this output stream.\n\t *\n\t * @param data The JavaScript array (`number[]`) of byte values to write.\n\t */\n\tpublic writeBytes(data: any[]): void {\n\t\t// Convert JavaScript byte array to native Java byte array\n\t\tconst native = Bytes.toJavaBytes(data);\n\t\tStreamsFacade.writeBytes(this.native, native);\n\t}\n\n\t/**\n\t * Writes the entire content of a native Java byte array to this output stream.\n\t *\n\t * @param data The native Java byte array object to write.\n\t */\n\tpublic writeBytesNative(data: any[]): void {\n\t\tStreamsFacade.writeBytes(this.native, data);\n\t}\n\n\t/**\n\t * Converts the string to bytes using the platform's default character encoding\n\t * and writes them to this output stream.\n\t *\n\t * @param text The string content to write.\n\t */\n\tpublic writeText(text: string): void {\n\t\tStreamsFacade.writeText(this.native, text);\n\t}\n\n\t/**\n\t * Closes this output stream and releases any system resources associated with it.\n\t */\n\tpublic close(): void {\n\t\tStreamsFacade.close(this.native);\n\t}\n\n\t/**\n\t * Retrieves the content written to this stream as a JavaScript byte array.\n\t * This is typically used with a ByteArrayOutputStream.\n\t *\n\t * @returns A JavaScript array (`number[]`) of the byte values written to the stream.\n\t */\n\tpublic getBytes(): any[] {\n\t\tconst native = StreamsFacade.getBytes(this.native);\n\t\treturn Bytes.toJavaScriptBytes(native);\n\t}\n\n\t/**\n\t * Retrieves the content written to this stream as the native Java byte array.\n\t * This is typically used with a ByteArrayOutputStream.\n\t *\n\t * @returns The native Java byte array object.\n\t */\n\tpublic getBytesNative(): any[] {\n\t\treturn StreamsFacade.getBytes(this.native);\n\t}\n\n\t/**\n\t * Retrieves the content written to this stream as a string using the platform's\n\t * default character encoding. This is typically used with a ByteArrayOutputStream.\n\t *\n\t * @returns The content of the stream as a string.\n\t */\n\tpublic getText(): string {\n\t\treturn StreamsFacade.getText(this.native);\n\t}\n\n\t/**\n\t * Checks if the underlying native stream object is defined and non-null.\n\t * @returns True if the stream is valid, false otherwise.\n\t */\n\tpublic isValid(): boolean {\n\t\treturn this.native !== undefined && this.native !== null;\n\t}\n}\n\n// @ts-ignore\nif (typeof module !== 'undefined') {\n\t// @ts-ignore\n\tmodule.exports = Streams;\n}\n"],
  "mappings": ";;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAIA,mBAAsB;AAEtB,MAAM,gBAAgB,KAAK,KAAK,uDAAuD;AAMhF,MAAM,QAAQ;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EASpB,OAAc,KAAK,OAAoB,QAA4B;AAClE,kBAAc,KAAK,MAAM,QAAQ,OAAO,MAAM;AAAA,EAC/C;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EASA,OAAc,UAAU,OAAoB,QAA4B;AACvE,kBAAc,UAAU,MAAM,QAAQ,OAAO,MAAM;AAAA,EACpD;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EASA,OAAc,kCAAkC,MAA2B;AAC1E,UAAM,SAAS,cAAc,kCAAkC,IAAI;AACnE,WAAO,IAAI,YAAY,MAAM;AAAA,EAC9B;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAQA,OAAc,2BAA2B,MAA0B;AAElE,UAAM,QAAQ,mBAAM,YAAY,IAAI;AACpC,UAAM,SAAS,cAAc,2BAA2B,KAAK;AAC7D,WAAO,IAAI,YAAY,MAAM;AAAA,EAC9B;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAQA,OAAc,8BAA4C;AACzD,UAAM,SAAS,cAAc,4BAA4B;AACzD,WAAO,IAAI,aAAa,MAAM;AAAA,EAC/B;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAQA,OAAc,kBAAkB,QAA0B;AACzD,UAAM,cAAc,IAAI,YAAY,MAAM;AAC1C,WAAO;AAAA,EACR;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAWO,mBAAmB,QAA2B;AACpD,UAAM,eAAe,IAAI,aAAa,MAAM;AAC5C,WAAO;AAAA,EACR;AACD;AAMO,MAAM,YAAY;AAAA;AAAA,EAGR;AAAA;AAAA;AAAA;AAAA,EAKhB,YAAY,QAAa;AACxB,SAAK,SAAS;AAAA,EACf;AAAA;AAAA;AAAA;AAAA;AAAA,EAMO,OAAe;AACrB,WAAO,cAAc,KAAK,KAAK,MAAM;AAAA,EACtC;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOO,YAAmB;AACzB,UAAM,SAAS,cAAc,UAAU,KAAK,MAAM;AAClD,WAAO,mBAAM,kBAAkB,MAAM;AAAA,EACtC;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOO,kBAAyB;AAC/B,WAAO,cAAc,UAAU,KAAK,MAAM;AAAA,EAC3C;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAQO,WAAmB;AACzB,WAAO,cAAc,SAAS,KAAK,MAAM;AAAA,EAC1C;AAAA;AAAA;AAAA;AAAA,EAKO,QAAc;AACpB,kBAAc,MAAM,KAAK,MAAM;AAAA,EAChC;AAAA;AAAA;AAAA;AAAA;AAAA,EAMO,UAAmB;AACzB,WAAO,KAAK,WAAW,UAAa,KAAK,WAAW;AAAA,EACrD;AACD;AAMO,MAAM,aAAa;AAAA;AAAA,EAGT;AAAA;AAAA;AAAA;AAAA,EAKhB,YAAY,QAAa;AACxB,SAAK,SAAS;AAAA,EACf;AAAA;AAAA;AAAA;AAAA;AAAA,EAMO,MAAM,MAAoB;AAChC,kBAAc,MAAM,KAAK,QAAQ,IAAI;AAAA,EACtC;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOO,WAAW,MAAmB;AAEpC,UAAM,SAAS,mBAAM,YAAY,IAAI;AACrC,kBAAc,WAAW,KAAK,QAAQ,MAAM;AAAA,EAC7C;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOO,iBAAiB,MAAmB;AAC1C,kBAAc,WAAW,KAAK,QAAQ,IAAI;AAAA,EAC3C;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAQO,UAAU,MAAoB;AACpC,kBAAc,UAAU,KAAK,QAAQ,IAAI;AAAA,EAC1C;AAAA;AAAA;AAAA;AAAA,EAKO,QAAc;AACpB,kBAAc,MAAM,KAAK,MAAM;AAAA,EAChC;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAQO,WAAkB;AACxB,UAAM,SAAS,cAAc,SAAS,KAAK,MAAM;AACjD,WAAO,mBAAM,kBAAkB,MAAM;AAAA,EACtC;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAQO,iBAAwB;AAC9B,WAAO,cAAc,SAAS,KAAK,MAAM;AAAA,EAC1C;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAQO,UAAkB;AACxB,WAAO,cAAc,QAAQ,KAAK,MAAM;AAAA,EACzC;AAAA;AAAA;AAAA;AAAA;AAAA,EAMO,UAAmB;AACzB,WAAO,KAAK,WAAW,UAAa,KAAK,WAAW;AAAA,EACrD;AACD;AAGA,IAAI,OAAO,WAAW,aAAa;AAElC,SAAO,UAAU;AAClB;",
  "names": []
}
