@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
@@ -25,195 +25,109 @@ const HttpResponseFacade = Java.type("org.eclipse.dirigible.components.api.http.
25
25
  const OutputStreamWriter = Java.type("java.io.OutputStreamWriter");
26
26
  const StandardCharsets = Java.type("java.nio.charset.StandardCharsets");
27
27
  class Response {
28
- static {
29
- // --- Standard HTTP Status Code Constants (Informational, Success, Redirection, Client Error, Server Error) ---
30
- this.ACCEPTED = 202;
31
- }
32
- static {
33
- this.BAD_GATEWAY = 502;
34
- }
35
- static {
36
- this.BAD_REQUEST = 400;
37
- }
38
- static {
39
- this.CONFLICT = 409;
40
- }
41
- static {
42
- this.CONTINUE = 100;
43
- }
44
- static {
45
- this.CREATED = 201;
46
- }
47
- static {
48
- this.EXPECTATION_FAILED = 417;
49
- }
50
- static {
51
- this.FORBIDDEN = 403;
52
- }
53
- static {
54
- this.FOUND = 302;
55
- }
56
- static {
57
- this.GATEWAY_TIMEOUT = 504;
58
- }
59
- static {
60
- this.GONE = 410;
61
- }
62
- static {
63
- this.HTTP_VERSION_NOT_SUPPORTED = 505;
64
- }
65
- static {
66
- this.INTERNAL_SERVER_ERROR = 500;
67
- }
68
- static {
69
- this.LENGTH_REQUIRED = 411;
70
- }
71
- static {
72
- this.METHOD_NOT_ALLOWED = 405;
73
- }
74
- static {
75
- this.MOVED_PERMANENTLY = 301;
76
- }
77
- static {
78
- this.MOVED_TEMPORARILY = 302;
79
- }
80
- static {
81
- this.MULTIPLE_CHOICES = 300;
82
- }
83
- static {
84
- this.NO_CONTENT = 204;
85
- }
86
- static {
87
- this.NON_AUTHORITATIVE_INFORMATION = 203;
88
- }
89
- static {
90
- this.NOT_ACCEPTABLE = 406;
91
- }
92
- static {
93
- this.NOT_FOUND = 404;
94
- }
95
- static {
96
- this.NOT_IMPLEMENTED = 501;
97
- }
98
- static {
99
- this.NOT_MODIFIED = 304;
100
- }
101
- static {
102
- this.OK = 200;
103
- }
104
- static {
105
- this.PARTIAL_CONTENT = 206;
106
- }
107
- static {
108
- this.PAYMENT_REQUIRED = 402;
109
- }
110
- static {
111
- this.PRECONDITION_FAILED = 412;
112
- }
113
- static {
114
- this.PROXY_AUTHENTICATION_REQUIRED = 407;
115
- }
116
- static {
117
- this.REQUEST_ENTITY_TOO_LARGE = 413;
118
- }
119
- static {
120
- this.REQUEST_TIMEOUT = 408;
121
- }
122
- static {
123
- this.REQUEST_URI_TOO_LONG = 414;
124
- }
125
- static {
126
- this.REQUESTED_RANGE_NOT_SATISFIABLE = 416;
127
- }
128
- static {
129
- this.RESET_CONTENT = 205;
130
- }
131
- static {
132
- this.SEE_OTHER = 303;
133
- }
134
- static {
135
- this.SERVICE_UNAVAILABLE = 503;
136
- }
137
- static {
138
- this.SWITCHING_PROTOCOLS = 101;
139
- }
140
- static {
141
- this.TEMPORARY_REDIRECT = 307;
142
- }
143
- static {
144
- this.UNAUTHORIZED = 401;
145
- }
146
- static {
147
- this.UNSUPPORTED_MEDIA_TYPE = 415;
148
- }
149
- static {
150
- this.USE_PROXY = 305;
151
- }
152
- static {
153
- this.UNPROCESSABLE_CONTENT = 422;
154
- }
155
- static {
28
+ // --- Standard HTTP Status Code Constants (Informational, Success, Redirection, Client Error, Server Error) ---
29
+ static ACCEPTED = 202;
30
+ static BAD_GATEWAY = 502;
31
+ static BAD_REQUEST = 400;
32
+ static CONFLICT = 409;
33
+ static CONTINUE = 100;
34
+ static CREATED = 201;
35
+ static EXPECTATION_FAILED = 417;
36
+ static FORBIDDEN = 403;
37
+ static FOUND = 302;
38
+ static GATEWAY_TIMEOUT = 504;
39
+ static GONE = 410;
40
+ static HTTP_VERSION_NOT_SUPPORTED = 505;
41
+ static INTERNAL_SERVER_ERROR = 500;
42
+ static LENGTH_REQUIRED = 411;
43
+ static METHOD_NOT_ALLOWED = 405;
44
+ static MOVED_PERMANENTLY = 301;
45
+ static MOVED_TEMPORARILY = 302;
46
+ static MULTIPLE_CHOICES = 300;
47
+ static NO_CONTENT = 204;
48
+ static NON_AUTHORITATIVE_INFORMATION = 203;
49
+ static NOT_ACCEPTABLE = 406;
50
+ static NOT_FOUND = 404;
51
+ static NOT_IMPLEMENTED = 501;
52
+ static NOT_MODIFIED = 304;
53
+ static OK = 200;
54
+ static PARTIAL_CONTENT = 206;
55
+ static PAYMENT_REQUIRED = 402;
56
+ static PRECONDITION_FAILED = 412;
57
+ static PROXY_AUTHENTICATION_REQUIRED = 407;
58
+ static REQUEST_ENTITY_TOO_LARGE = 413;
59
+ static REQUEST_TIMEOUT = 408;
60
+ static REQUEST_URI_TOO_LONG = 414;
61
+ static REQUESTED_RANGE_NOT_SATISFIABLE = 416;
62
+ static RESET_CONTENT = 205;
63
+ static SEE_OTHER = 303;
64
+ static SERVICE_UNAVAILABLE = 503;
65
+ static SWITCHING_PROTOCOLS = 101;
66
+ static TEMPORARY_REDIRECT = 307;
67
+ static UNAUTHORIZED = 401;
68
+ static UNSUPPORTED_MEDIA_TYPE = 415;
69
+ static USE_PROXY = 305;
70
+ static UNPROCESSABLE_CONTENT = 422;
71
+ /**
72
+ * Mapping between HTTP response codes (string) and their corresponding reason-phrases
73
+ * as defined in RFC 7231, section 6.1.
74
+ */
75
+ static HttpCodesReasons = {
76
+ "100": "Continue",
77
+ "101": "Switching Protocols",
78
+ "200": "OK",
79
+ "201": "Created",
80
+ "202": "Accepted",
81
+ "203": "Non-Authoritative Information",
82
+ "204": "No Content",
83
+ "205": "Reset Content",
84
+ "206": "Partial Content",
85
+ "300": "Multiple Choices",
86
+ "301": "Moved Permanently",
87
+ "302": "Found",
88
+ "303": "See Other",
89
+ "304": "Not Modified",
90
+ "305": "Use Proxy",
91
+ "307": "Temporary Redirect",
92
+ "400": "Bad Request",
93
+ "401": "Unauthorized",
94
+ "402": "Payment Required",
95
+ "403": "Forbidden",
96
+ "404": "Not Found",
97
+ "405": "Method Not Allowed",
98
+ "406": "Not Acceptable",
99
+ "407": "Proxy Authentication Required",
100
+ "408": "Request Timeout",
101
+ "409": "Conflict",
102
+ "410": "Gone",
103
+ "411": "Length Required",
104
+ "412": "Precondition Failed",
105
+ "413": "Payload Too Large",
106
+ "414": "URI Too Large",
107
+ "415": "Unsupported Media Type",
108
+ "416": "Range Not Satisfiable",
109
+ "417": "Expectation Failed",
110
+ "422": "Unprocessable Content",
111
+ "426": "Upgrade Required",
112
+ "500": "Internal Server Error",
113
+ "501": "Not Implemented",
114
+ "502": "Bad Gateway",
115
+ "503": "Service Unavailable",
116
+ "504": "Gateway Timmeout",
117
+ "505": "HTTP Version Not Supported",
156
118
  /**
157
- * Mapping between HTTP response codes (string) and their corresponding reason-phrases
158
- * as defined in RFC 7231, section 6.1.
159
- */
160
- this.HttpCodesReasons = {
161
- "100": "Continue",
162
- "101": "Switching Protocols",
163
- "200": "OK",
164
- "201": "Created",
165
- "202": "Accepted",
166
- "203": "Non-Authoritative Information",
167
- "204": "No Content",
168
- "205": "Reset Content",
169
- "206": "Partial Content",
170
- "300": "Multiple Choices",
171
- "301": "Moved Permanently",
172
- "302": "Found",
173
- "303": "See Other",
174
- "304": "Not Modified",
175
- "305": "Use Proxy",
176
- "307": "Temporary Redirect",
177
- "400": "Bad Request",
178
- "401": "Unauthorized",
179
- "402": "Payment Required",
180
- "403": "Forbidden",
181
- "404": "Not Found",
182
- "405": "Method Not Allowed",
183
- "406": "Not Acceptable",
184
- "407": "Proxy Authentication Required",
185
- "408": "Request Timeout",
186
- "409": "Conflict",
187
- "410": "Gone",
188
- "411": "Length Required",
189
- "412": "Precondition Failed",
190
- "413": "Payload Too Large",
191
- "414": "URI Too Large",
192
- "415": "Unsupported Media Type",
193
- "416": "Range Not Satisfiable",
194
- "417": "Expectation Failed",
195
- "422": "Unprocessable Content",
196
- "426": "Upgrade Required",
197
- "500": "Internal Server Error",
198
- "501": "Not Implemented",
199
- "502": "Bad Gateway",
200
- "503": "Service Unavailable",
201
- "504": "Gateway Timmeout",
202
- "505": "HTTP Version Not Supported",
203
- /**
204
- * Utility method that accepts an HTTP code and returns its corresponding reason-phrase.
205
- * @param code The HTTP status code (number).
206
- * @returns The reason phrase string.
207
- * @throws Error if the code is not a valid integer in the range [100-505].
208
- */
209
- getReason: (code) => {
210
- if (isNaN(code) || code < 100 || code > 505) {
211
- throw Error("Illegal argument for code[" + code + "]. Valid HTTP codes are integer numbers in the range [100-505].");
212
- }
213
- return Response.HttpCodesReasons[String(code)];
119
+ * Utility method that accepts an HTTP code and returns its corresponding reason-phrase.
120
+ * @param code The HTTP status code (number).
121
+ * @returns The reason phrase string.
122
+ * @throws Error if the code is not a valid integer in the range [100-505].
123
+ */
124
+ getReason: (code) => {
125
+ if (isNaN(code) || code < 100 || code > 505) {
126
+ throw Error("Illegal argument for code[" + code + "]. Valid HTTP codes are integer numbers in the range [100-505].");
214
127
  }
215
- };
216
- }
128
+ return Response.HttpCodesReasons[String(code)];
129
+ }
130
+ };
217
131
  /**
218
132
  * Checks if the response façade is currently valid or connected to an active request context.
219
133
  * @returns True if valid, false otherwise.
@@ -449,4 +363,4 @@ class Response {
449
363
  if (typeof module !== "undefined") {
450
364
  module.exports = Response;
451
365
  }
452
- //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../src/http/response.ts"],
  "sourcesContent": ["/**\n * Provides a static fa\u00E7ade (`Response` class) for managing the HTTP response.\n * This class wraps a native Java HTTP response object, offering methods for setting\n * status codes, headers, cookies, and writing content (text, JSON, or binary).\n */\n\nimport { OutputStream } from \"@aerokit/sdk/io/streams\"\n\nconst HttpResponseFacade = Java.type(\"org.eclipse.dirigible.components.api.http.HttpResponseFacade\");\nconst OutputStreamWriter = Java.type(\"java.io.OutputStreamWriter\");\nconst StandardCharsets = Java.type(\"java.nio.charset.StandardCharsets\");\n\n/**\n * Defines the structure for an HTTP cookie, including its name, value, and optional attributes.\n */\nexport interface Cookie {\n    /** The name of the cookie. */\n    name: string;\n    /** The value of the cookie. */\n    value: string;\n    /** Key-value map of cookie attributes (e.g., 'maxAge', 'path', 'domain', 'secure', 'httpOnly'). */\n    attributes: { [key: string]: string };\n }\n\n/**\n * The static Response class providing standardized HTTP status codes and methods\n * for constructing the server's response.\n */\nexport class Response {\n\n    // --- Standard HTTP Status Code Constants (Informational, Success, Redirection, Client Error, Server Error) ---\n\n    public static readonly ACCEPTED = 202;\n    public static readonly BAD_GATEWAY = 502;\n    public static readonly BAD_REQUEST = 400;\n    public static readonly CONFLICT = 409;\n    public static readonly CONTINUE = 100;\n    public static readonly CREATED = 201;\n    public static readonly EXPECTATION_FAILED = 417;\n    public static readonly FORBIDDEN = 403;\n    public static readonly FOUND = 302;\n    public static readonly GATEWAY_TIMEOUT = 504;\n    public static readonly GONE = 410;\n    public static readonly HTTP_VERSION_NOT_SUPPORTED = 505;\n    public static readonly INTERNAL_SERVER_ERROR = 500;\n    public static readonly LENGTH_REQUIRED = 411;\n    public static readonly METHOD_NOT_ALLOWED = 405;\n    public static readonly MOVED_PERMANENTLY = 301;\n    public static readonly MOVED_TEMPORARILY = 302;\n    public static readonly MULTIPLE_CHOICES = 300;\n    public static readonly NO_CONTENT = 204;\n    public static readonly NON_AUTHORITATIVE_INFORMATION = 203;\n    public static readonly NOT_ACCEPTABLE = 406;\n    public static readonly NOT_FOUND = 404;\n    public static readonly NOT_IMPLEMENTED = 501;\n    public static readonly NOT_MODIFIED = 304;\n    public static readonly OK = 200;\n    public static readonly PARTIAL_CONTENT = 206;\n    public static readonly PAYMENT_REQUIRED = 402;\n    public static readonly PRECONDITION_FAILED = 412;\n    public static readonly PROXY_AUTHENTICATION_REQUIRED = 407;\n    public static readonly REQUEST_ENTITY_TOO_LARGE = 413;\n    public static readonly REQUEST_TIMEOUT = 408;\n    public static readonly REQUEST_URI_TOO_LONG = 414;\n    public static readonly REQUESTED_RANGE_NOT_SATISFIABLE = 416;\n    public static readonly RESET_CONTENT = 205;\n    public static readonly SEE_OTHER = 303;\n    public static readonly SERVICE_UNAVAILABLE = 503;\n    public static readonly SWITCHING_PROTOCOLS = 101;\n    public static readonly TEMPORARY_REDIRECT = 307;\n    public static readonly UNAUTHORIZED = 401;\n    public static readonly UNSUPPORTED_MEDIA_TYPE = 415;\n    public static readonly USE_PROXY = 305;\n    public static readonly UNPROCESSABLE_CONTENT = 422;\n\n    /**\n     * Mapping between HTTP response codes (string) and their corresponding reason-phrases\n     * as defined in RFC 7231, section 6.1.\n     */\n    public static readonly HttpCodesReasons = {\n        \"100\": \"Continue\", \"101\": \"Switching Protocols\", \"200\": \"OK\", \"201\": \"Created\",\n        \"202\": \"Accepted\", \"203\": \"Non-Authoritative Information\", \"204\": \"No Content\",\n        \"205\": \"Reset Content\", \"206\": \"Partial Content\", \"300\": \"Multiple Choices\",\n        \"301\": \"Moved Permanently\", \"302\": \"Found\", \"303\": \"See Other\", \"304\": \"Not Modified\",\n        \"305\": \"Use Proxy\", \"307\": \"Temporary Redirect\", \"400\": \"Bad Request\",\n        \"401\": \"Unauthorized\", \"402\": \"Payment Required\", \"403\": \"Forbidden\",\n        \"404\": \"Not Found\", \"405\": \"Method Not Allowed\", \"406\": \"Not Acceptable\",\n        \"407\": \"Proxy Authentication Required\", \"408\": \"Request Timeout\", \"409\": \"Conflict\",\n        \"410\": \"Gone\", \"411\": \"Length Required\", \"412\": \"Precondition Failed\",\n        \"413\": \"Payload Too Large\", \"414\": \"URI Too Large\", \"415\": \"Unsupported Media Type\",\n        \"416\": \"Range Not Satisfiable\", \"417\": \"Expectation Failed\", \"422\": \"Unprocessable Content\",\n        \"426\": \"Upgrade Required\", \"500\": \"Internal Server Error\", \"501\": \"Not Implemented\",\n        \"502\": \"Bad Gateway\", \"503\": \"Service Unavailable\", \"504\": \"Gateway Timmeout\",\n        \"505\": \"HTTP Version Not Supported\",\n\n        /**\n        * Utility method that accepts an HTTP code and returns its corresponding reason-phrase.\n        * @param code The HTTP status code (number).\n        * @returns The reason phrase string.\n        * @throws Error if the code is not a valid integer in the range [100-505].\n        */\n        getReason: (code: number): string => {\n            if (isNaN(code) || code < 100 || code > 505) {\n                throw Error('Illegal argument for code[' + code + ']. Valid HTTP codes are integer numbers in the range [100-505].')\n            }\n            return Response.HttpCodesReasons[String(code)];\n        }\n    }\n\n    /**\n     * Checks if the response fa\u00E7ade is currently valid or connected to an active request context.\n     * @returns True if valid, false otherwise.\n     */\n    public static isValid(): boolean {\n        return HttpResponseFacade.isValid();\n    }\n\n    /**\n     * Serializes a JavaScript object to JSON, sets the `Content-Type: application/json` header,\n     * and writes the JSON string to the response output stream.\n     * @param obj The JavaScript object to be serialized and sent.\n     */\n    public static json(obj: any): void {\n        Response.addHeader(\"Content-Type\", \"application/json\")\n        const objJson = JSON.stringify(obj);\n        Response.print(objJson);\n    }\n\n    /**\n     * Writes a string of text to the response body using **UTF-8** encoding.\n     * Note: This method automatically handles flushing the output stream.\n     * @param text The string content to write.\n     */\n    public static print(text: string): void {\n        text = (text && text.toString()) || \"\";\n        const out = Response.getOutputStream().native;\n        // Use Java I/O to ensure explicit UTF-8 encoding\n        const writer = new OutputStreamWriter(out, StandardCharsets.UTF_8);\n        writer.write(text);\n        writer.flush();\n    }\n\n    /**\n     * Writes a string of text followed by a newline character (`\\n`) to the response body\n     * using **UTF-8** encoding.\n     * @param text The string content to write.\n     */\n    public static println(text: string): void {\n        text = (text && text.toString()) || \"\";\n        const out = Response.getOutputStream().native;\n        const writer = new OutputStreamWriter(out, StandardCharsets.UTF_8);\n        writer.write(text);\n        writer.write(\"\\n\");\n        writer.flush();\n    }\n\n    /**\n     * Writes an array of bytes directly to the response output stream, typically used for binary data.\n     * @param bytes The array of bytes to write.\n     */\n    public static write(bytes: any[]): void {\n        if (!bytes) {\n            bytes = [];\n        }\n        HttpResponseFacade.write(bytes);\n    }\n\n    /**\n     * Checks if the response headers and status have already been sent to the client.\n     * @returns True if the response is committed, false otherwise.\n     */\n    public static isCommitted(): boolean {\n        return HttpResponseFacade.isCommitted();\n    }\n\n    /**\n     * Sets the value of the `Content-Type` header.\n     * @param contentType The MIME type string (e.g., 'text/html', 'application/pdf').\n     */\n    public static setContentType(contentType: string): void {\n        HttpResponseFacade.setContentType(contentType);\n    }\n\n    /**\n     * Forces any buffered output to be written to the client.\n     */\n    public static flush(): void {\n        HttpResponseFacade.flush();\n    }\n\n    /**\n     * Closes the response output stream.\n     */\n    public static close(): void {\n        HttpResponseFacade.close();\n    }\n\n    /**\n     * Adds a cookie to the response. The cookie object is serialized to JSON before being passed\n     * to the underlying Java facade.\n     * @param cookie The cookie definition object.\n     */\n    public static addCookie(cookie: Cookie): void {\n        HttpResponseFacade.addCookie(JSON.stringify(cookie));\n    }\n\n    /**\n     * Checks if a response header with the specified name has already been set.\n     * @param name The name of the header.\n     * @returns True if the header exists, false otherwise.\n     */\n    public static containsHeader(name: string): boolean {\n        return HttpResponseFacade.containsHeader(name);\n    }\n\n    /**\n     * Encodes a URL for use in redirects or forms, including session information if necessary.\n     * @param url The URL to encode.\n     * @returns The encoded URL string.\n     */\n    public static encodeURL(url: string): string {\n        return HttpResponseFacade.encodeURL(url);\n    }\n\n    /**\n     * Gets the character encoding used for the response body.\n     * @returns The character encoding string.\n     */\n    public static getCharacterEncoding(): string {\n        return HttpResponseFacade.getCharacterEncoding();\n    }\n\n    /**\n     * Encodes a URL for use in the `Location` header of a redirect response.\n     * @param url The redirect URL to encode.\n     * @returns The encoded redirect URL string.\n     */\n    public static encodeRedirectURL(url: string): string {\n        return HttpResponseFacade.encodeRedirectURL(url);\n    }\n\n    /**\n     * Gets the current `Content-Type` header value.\n     * @returns The content type string.\n     */\n    public static getContentType(): string {\n        return HttpResponseFacade.getContentType();\n    }\n\n    /**\n     * Sends an HTTP error response to the client with the specified status code and optional message.\n     * This bypasses the normal response body writing process.\n     * @param status The HTTP status code (e.g., 404, 500).\n     * @param message An optional message to include in the error response.\n     */\n    public static sendError(status: number, message?: string): void {\n        HttpResponseFacade.sendError(status, message);\n    }\n\n    /**\n     * Sets the character encoding to be used for the response body (e.g., 'UTF-8').\n     * @param charset The character set string.\n     */\n    public static setCharacterEncoding(charset: string): void {\n        HttpResponseFacade.setCharacterEncoding(charset);\n    }\n\n    /**\n     * Sends a redirect response (status code 302 by default) to the client.\n     * @param location The new URL to redirect the client to.\n     */\n    public static sendRedirect(location: string): void {\n        HttpResponseFacade.sendRedirect(location);\n    }\n\n    /**\n     * Sets the `Content-Length` header for the response.\n     * @param length The size of the response body in bytes.\n     */\n    public static setContentLength(length: number): void {\n        HttpResponseFacade.setContentLength(length);\n    }\n\n    /**\n     * Sets a response header with the given name and value. If the header already exists, its value is overwritten.\n     * @param name The name of the header.\n     * @param value The value of the header.\n     */\n    public static setHeader(name: string, value: string): void {\n        HttpResponseFacade.setHeader(name, value);\n    }\n\n    /**\n     * Adds a response header with the given name and value. If the header already exists, a second header with the same name is added.\n     * @param name The name of the header.\n     * @param value The value of the header.\n     */\n    public static addHeader(name: string, value: string): void {\n        HttpResponseFacade.addHeader(name, value);\n    }\n\n    /**\n     * Sets the HTTP status code for the response.\n     * @param status The integer status code (e.g., 200, 404).\n     */\n    public static setStatus(status: number): void {\n        HttpResponseFacade.setStatus(status);\n    }\n\n    /**\n     * Clears all buffers, status code, and headers from the response, allowing a new response to be generated.\n     * This is only possible if the response has not yet been committed.\n     */\n    public static reset(): void {\n        HttpResponseFacade.reset();\n    }\n\n    /**\n     * Gets the value of a specific header. If multiple headers with the same name exist, it returns the first one.\n     * @param name The name of the header.\n     * @returns The header value string.\n     */\n    public static getHeader(name: string): string {\n        return HttpResponseFacade.getHeader(name);\n    }\n\n    /**\n     * Sets the locale for the response, which may affect language and date/time formatting.\n     * @param language The language code (e.g., 'en', 'fr').\n     * @param country The optional country code (e.g., 'US', 'GB').\n     * @param variant The optional variant code.\n     */\n    public static setLocale(language: string, country?: string, variant?: string): void {\n        return HttpResponseFacade.setLocale(language, country, variant);\n    }\n\n    /**\n     * Gets all header values for a specific header name as an array of strings.\n     * @param name The name of the header.\n     * @returns An array of header values.\n     */\n    public static getHeaders(name: string): string[] {\n        return JSON.parse(HttpResponseFacade.getHeaders(name));\n    }\n\n    /**\n     * Gets the names of all headers that have been set on the response.\n     * @returns An array of header names.\n     */\n    public static getHeaderNames(): string[] {\n        return JSON.parse(HttpResponseFacade.getHeaderNames());\n    }\n\n    /**\n     * Gets the currently set locale string for the response.\n     * @returns The locale string.\n     */\n    public static getLocale(): string {\n        return HttpResponseFacade.getLocale();\n    }\n\n    /**\n     * Gets the underlying output stream object, wrapped in the SDK's `OutputStream` class.\n     * This is useful for writing raw or large amounts of data.\n     * @returns The output stream object.\n     */\n    public static getOutputStream(): OutputStream {\n        return new OutputStream(HttpResponseFacade.getOutputStream());\n    }\n}\n\n// @ts-ignore\nif (typeof module !== 'undefined') {\n\t// @ts-ignore\n\tmodule.exports = Response;\n}\n"],
  "mappings": ";;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAMA,qBAA6B;AAE7B,MAAM,qBAAqB,KAAK,KAAK,8DAA8D;AACnG,MAAM,qBAAqB,KAAK,KAAK,4BAA4B;AACjE,MAAM,mBAAmB,KAAK,KAAK,mCAAmC;AAkB/D,MAAM,SAAS;AAAA,EAIlB;AAAA;AAAA,SAAuB,WAAW;AAAA;AAAA,EAClC;AAAA,SAAuB,cAAc;AAAA;AAAA,EACrC;AAAA,SAAuB,cAAc;AAAA;AAAA,EACrC;AAAA,SAAuB,WAAW;AAAA;AAAA,EAClC;AAAA,SAAuB,WAAW;AAAA;AAAA,EAClC;AAAA,SAAuB,UAAU;AAAA;AAAA,EACjC;AAAA,SAAuB,qBAAqB;AAAA;AAAA,EAC5C;AAAA,SAAuB,YAAY;AAAA;AAAA,EACnC;AAAA,SAAuB,QAAQ;AAAA;AAAA,EAC/B;AAAA,SAAuB,kBAAkB;AAAA;AAAA,EACzC;AAAA,SAAuB,OAAO;AAAA;AAAA,EAC9B;AAAA,SAAuB,6BAA6B;AAAA;AAAA,EACpD;AAAA,SAAuB,wBAAwB;AAAA;AAAA,EAC/C;AAAA,SAAuB,kBAAkB;AAAA;AAAA,EACzC;AAAA,SAAuB,qBAAqB;AAAA;AAAA,EAC5C;AAAA,SAAuB,oBAAoB;AAAA;AAAA,EAC3C;AAAA,SAAuB,oBAAoB;AAAA;AAAA,EAC3C;AAAA,SAAuB,mBAAmB;AAAA;AAAA,EAC1C;AAAA,SAAuB,aAAa;AAAA;AAAA,EACpC;AAAA,SAAuB,gCAAgC;AAAA;AAAA,EACvD;AAAA,SAAuB,iBAAiB;AAAA;AAAA,EACxC;AAAA,SAAuB,YAAY;AAAA;AAAA,EACnC;AAAA,SAAuB,kBAAkB;AAAA;AAAA,EACzC;AAAA,SAAuB,eAAe;AAAA;AAAA,EACtC;AAAA,SAAuB,KAAK;AAAA;AAAA,EAC5B;AAAA,SAAuB,kBAAkB;AAAA;AAAA,EACzC;AAAA,SAAuB,mBAAmB;AAAA;AAAA,EAC1C;AAAA,SAAuB,sBAAsB;AAAA;AAAA,EAC7C;AAAA,SAAuB,gCAAgC;AAAA;AAAA,EACvD;AAAA,SAAuB,2BAA2B;AAAA;AAAA,EAClD;AAAA,SAAuB,kBAAkB;AAAA;AAAA,EACzC;AAAA,SAAuB,uBAAuB;AAAA;AAAA,EAC9C;AAAA,SAAuB,kCAAkC;AAAA;AAAA,EACzD;AAAA,SAAuB,gBAAgB;AAAA;AAAA,EACvC;AAAA,SAAuB,YAAY;AAAA;AAAA,EACnC;AAAA,SAAuB,sBAAsB;AAAA;AAAA,EAC7C;AAAA,SAAuB,sBAAsB;AAAA;AAAA,EAC7C;AAAA,SAAuB,qBAAqB;AAAA;AAAA,EAC5C;AAAA,SAAuB,eAAe;AAAA;AAAA,EACtC;AAAA,SAAuB,yBAAyB;AAAA;AAAA,EAChD;AAAA,SAAuB,YAAY;AAAA;AAAA,EACnC;AAAA,SAAuB,wBAAwB;AAAA;AAAA,EAM/C;AAAA;AAAA;AAAA;AAAA;AAAA,SAAuB,mBAAmB;AAAA,MACtC,OAAO;AAAA,MAAY,OAAO;AAAA,MAAuB,OAAO;AAAA,MAAM,OAAO;AAAA,MACrE,OAAO;AAAA,MAAY,OAAO;AAAA,MAAiC,OAAO;AAAA,MAClE,OAAO;AAAA,MAAiB,OAAO;AAAA,MAAmB,OAAO;AAAA,MACzD,OAAO;AAAA,MAAqB,OAAO;AAAA,MAAS,OAAO;AAAA,MAAa,OAAO;AAAA,MACvE,OAAO;AAAA,MAAa,OAAO;AAAA,MAAsB,OAAO;AAAA,MACxD,OAAO;AAAA,MAAgB,OAAO;AAAA,MAAoB,OAAO;AAAA,MACzD,OAAO;AAAA,MAAa,OAAO;AAAA,MAAsB,OAAO;AAAA,MACxD,OAAO;AAAA,MAAiC,OAAO;AAAA,MAAmB,OAAO;AAAA,MACzE,OAAO;AAAA,MAAQ,OAAO;AAAA,MAAmB,OAAO;AAAA,MAChD,OAAO;AAAA,MAAqB,OAAO;AAAA,MAAiB,OAAO;AAAA,MAC3D,OAAO;AAAA,MAAyB,OAAO;AAAA,MAAsB,OAAO;AAAA,MACpE,OAAO;AAAA,MAAoB,OAAO;AAAA,MAAyB,OAAO;AAAA,MAClE,OAAO;AAAA,MAAe,OAAO;AAAA,MAAuB,OAAO;AAAA,MAC3D,OAAO;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,MAQP,WAAW,CAAC,SAAyB;AACjC,YAAI,MAAM,IAAI,KAAK,OAAO,OAAO,OAAO,KAAK;AACzC,gBAAM,MAAM,+BAA+B,OAAO,iEAAiE;AAAA,QACvH;AACA,eAAO,SAAS,iBAAiB,OAAO,IAAI,CAAC;AAAA,MACjD;AAAA,IACJ;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAMA,OAAc,UAAmB;AAC7B,WAAO,mBAAmB,QAAQ;AAAA,EACtC;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOA,OAAc,KAAK,KAAgB;AAC/B,aAAS,UAAU,gBAAgB,kBAAkB;AACrD,UAAM,UAAU,KAAK,UAAU,GAAG;AAClC,aAAS,MAAM,OAAO;AAAA,EAC1B;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOA,OAAc,MAAM,MAAoB;AACpC,WAAQ,QAAQ,KAAK,SAAS,KAAM;AACpC,UAAM,MAAM,SAAS,gBAAgB,EAAE;AAEvC,UAAM,SAAS,IAAI,mBAAmB,KAAK,iBAAiB,KAAK;AACjE,WAAO,MAAM,IAAI;AACjB,WAAO,MAAM;AAAA,EACjB;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOA,OAAc,QAAQ,MAAoB;AACtC,WAAQ,QAAQ,KAAK,SAAS,KAAM;AACpC,UAAM,MAAM,SAAS,gBAAgB,EAAE;AACvC,UAAM,SAAS,IAAI,mBAAmB,KAAK,iBAAiB,KAAK;AACjE,WAAO,MAAM,IAAI;AACjB,WAAO,MAAM,IAAI;AACjB,WAAO,MAAM;AAAA,EACjB;AAAA;AAAA;AAAA;AAAA;AAAA,EAMA,OAAc,MAAM,OAAoB;AACpC,QAAI,CAAC,OAAO;AACR,cAAQ,CAAC;AAAA,IACb;AACA,uBAAmB,MAAM,KAAK;AAAA,EAClC;AAAA;AAAA;AAAA;AAAA;AAAA,EAMA,OAAc,cAAuB;AACjC,WAAO,mBAAmB,YAAY;AAAA,EAC1C;AAAA;AAAA;AAAA;AAAA;AAAA,EAMA,OAAc,eAAe,aAA2B;AACpD,uBAAmB,eAAe,WAAW;AAAA,EACjD;AAAA;AAAA;AAAA;AAAA,EAKA,OAAc,QAAc;AACxB,uBAAmB,MAAM;AAAA,EAC7B;AAAA;AAAA;AAAA;AAAA,EAKA,OAAc,QAAc;AACxB,uBAAmB,MAAM;AAAA,EAC7B;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOA,OAAc,UAAU,QAAsB;AAC1C,uBAAmB,UAAU,KAAK,UAAU,MAAM,CAAC;AAAA,EACvD;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOA,OAAc,eAAe,MAAuB;AAChD,WAAO,mBAAmB,eAAe,IAAI;AAAA,EACjD;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOA,OAAc,UAAU,KAAqB;AACzC,WAAO,mBAAmB,UAAU,GAAG;AAAA,EAC3C;AAAA;AAAA;AAAA;AAAA;AAAA,EAMA,OAAc,uBAA+B;AACzC,WAAO,mBAAmB,qBAAqB;AAAA,EACnD;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOA,OAAc,kBAAkB,KAAqB;AACjD,WAAO,mBAAmB,kBAAkB,GAAG;AAAA,EACnD;AAAA;AAAA;AAAA;AAAA;AAAA,EAMA,OAAc,iBAAyB;AACnC,WAAO,mBAAmB,eAAe;AAAA,EAC7C;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAQA,OAAc,UAAU,QAAgB,SAAwB;AAC5D,uBAAmB,UAAU,QAAQ,OAAO;AAAA,EAChD;AAAA;AAAA;AAAA;AAAA;AAAA,EAMA,OAAc,qBAAqB,SAAuB;AACtD,uBAAmB,qBAAqB,OAAO;AAAA,EACnD;AAAA;AAAA;AAAA;AAAA;AAAA,EAMA,OAAc,aAAa,UAAwB;AAC/C,uBAAmB,aAAa,QAAQ;AAAA,EAC5C;AAAA;AAAA;AAAA;AAAA;AAAA,EAMA,OAAc,iBAAiB,QAAsB;AACjD,uBAAmB,iBAAiB,MAAM;AAAA,EAC9C;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOA,OAAc,UAAU,MAAc,OAAqB;AACvD,uBAAmB,UAAU,MAAM,KAAK;AAAA,EAC5C;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOA,OAAc,UAAU,MAAc,OAAqB;AACvD,uBAAmB,UAAU,MAAM,KAAK;AAAA,EAC5C;AAAA;AAAA;AAAA;AAAA;AAAA,EAMA,OAAc,UAAU,QAAsB;AAC1C,uBAAmB,UAAU,MAAM;AAAA,EACvC;AAAA;AAAA;AAAA;AAAA;AAAA,EAMA,OAAc,QAAc;AACxB,uBAAmB,MAAM;AAAA,EAC7B;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOA,OAAc,UAAU,MAAsB;AAC1C,WAAO,mBAAmB,UAAU,IAAI;AAAA,EAC5C;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAQA,OAAc,UAAU,UAAkB,SAAkB,SAAwB;AAChF,WAAO,mBAAmB,UAAU,UAAU,SAAS,OAAO;AAAA,EAClE;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOA,OAAc,WAAW,MAAwB;AAC7C,WAAO,KAAK,MAAM,mBAAmB,WAAW,IAAI,CAAC;AAAA,EACzD;AAAA;AAAA;AAAA;AAAA;AAAA,EAMA,OAAc,iBAA2B;AACrC,WAAO,KAAK,MAAM,mBAAmB,eAAe,CAAC;AAAA,EACzD;AAAA;AAAA;AAAA;AAAA;AAAA,EAMA,OAAc,YAAoB;AAC9B,WAAO,mBAAmB,UAAU;AAAA,EACxC;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOA,OAAc,kBAAgC;AAC1C,WAAO,IAAI,4BAAa,mBAAmB,gBAAgB,CAAC;AAAA,EAChE;AACJ;AAGA,IAAI,OAAO,WAAW,aAAa;AAElC,SAAO,UAAU;AAClB;",
  "names": []
}

366
+ //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../src/http/response.ts"],
  "sourcesContent": ["/**\n * Provides a static fa\u00E7ade (`Response` class) for managing the HTTP response.\n * This class wraps a native Java HTTP response object, offering methods for setting\n * status codes, headers, cookies, and writing content (text, JSON, or binary).\n */\n\nimport { OutputStream } from \"@aerokit/sdk/io/streams\"\n\nconst HttpResponseFacade = Java.type(\"org.eclipse.dirigible.components.api.http.HttpResponseFacade\");\nconst OutputStreamWriter = Java.type(\"java.io.OutputStreamWriter\");\nconst StandardCharsets = Java.type(\"java.nio.charset.StandardCharsets\");\n\n/**\n * Defines the structure for an HTTP cookie, including its name, value, and optional attributes.\n */\nexport interface Cookie {\n    /** The name of the cookie. */\n    name: string;\n    /** The value of the cookie. */\n    value: string;\n    /** Key-value map of cookie attributes (e.g., 'maxAge', 'path', 'domain', 'secure', 'httpOnly'). */\n    attributes: { [key: string]: string };\n }\n\n/**\n * The static Response class providing standardized HTTP status codes and methods\n * for constructing the server's response.\n */\nexport class Response {\n\n    // --- Standard HTTP Status Code Constants (Informational, Success, Redirection, Client Error, Server Error) ---\n\n    public static readonly ACCEPTED = 202;\n    public static readonly BAD_GATEWAY = 502;\n    public static readonly BAD_REQUEST = 400;\n    public static readonly CONFLICT = 409;\n    public static readonly CONTINUE = 100;\n    public static readonly CREATED = 201;\n    public static readonly EXPECTATION_FAILED = 417;\n    public static readonly FORBIDDEN = 403;\n    public static readonly FOUND = 302;\n    public static readonly GATEWAY_TIMEOUT = 504;\n    public static readonly GONE = 410;\n    public static readonly HTTP_VERSION_NOT_SUPPORTED = 505;\n    public static readonly INTERNAL_SERVER_ERROR = 500;\n    public static readonly LENGTH_REQUIRED = 411;\n    public static readonly METHOD_NOT_ALLOWED = 405;\n    public static readonly MOVED_PERMANENTLY = 301;\n    public static readonly MOVED_TEMPORARILY = 302;\n    public static readonly MULTIPLE_CHOICES = 300;\n    public static readonly NO_CONTENT = 204;\n    public static readonly NON_AUTHORITATIVE_INFORMATION = 203;\n    public static readonly NOT_ACCEPTABLE = 406;\n    public static readonly NOT_FOUND = 404;\n    public static readonly NOT_IMPLEMENTED = 501;\n    public static readonly NOT_MODIFIED = 304;\n    public static readonly OK = 200;\n    public static readonly PARTIAL_CONTENT = 206;\n    public static readonly PAYMENT_REQUIRED = 402;\n    public static readonly PRECONDITION_FAILED = 412;\n    public static readonly PROXY_AUTHENTICATION_REQUIRED = 407;\n    public static readonly REQUEST_ENTITY_TOO_LARGE = 413;\n    public static readonly REQUEST_TIMEOUT = 408;\n    public static readonly REQUEST_URI_TOO_LONG = 414;\n    public static readonly REQUESTED_RANGE_NOT_SATISFIABLE = 416;\n    public static readonly RESET_CONTENT = 205;\n    public static readonly SEE_OTHER = 303;\n    public static readonly SERVICE_UNAVAILABLE = 503;\n    public static readonly SWITCHING_PROTOCOLS = 101;\n    public static readonly TEMPORARY_REDIRECT = 307;\n    public static readonly UNAUTHORIZED = 401;\n    public static readonly UNSUPPORTED_MEDIA_TYPE = 415;\n    public static readonly USE_PROXY = 305;\n    public static readonly UNPROCESSABLE_CONTENT = 422;\n\n    /**\n     * Mapping between HTTP response codes (string) and their corresponding reason-phrases\n     * as defined in RFC 7231, section 6.1.\n     */\n    public static readonly HttpCodesReasons = {\n        \"100\": \"Continue\", \"101\": \"Switching Protocols\", \"200\": \"OK\", \"201\": \"Created\",\n        \"202\": \"Accepted\", \"203\": \"Non-Authoritative Information\", \"204\": \"No Content\",\n        \"205\": \"Reset Content\", \"206\": \"Partial Content\", \"300\": \"Multiple Choices\",\n        \"301\": \"Moved Permanently\", \"302\": \"Found\", \"303\": \"See Other\", \"304\": \"Not Modified\",\n        \"305\": \"Use Proxy\", \"307\": \"Temporary Redirect\", \"400\": \"Bad Request\",\n        \"401\": \"Unauthorized\", \"402\": \"Payment Required\", \"403\": \"Forbidden\",\n        \"404\": \"Not Found\", \"405\": \"Method Not Allowed\", \"406\": \"Not Acceptable\",\n        \"407\": \"Proxy Authentication Required\", \"408\": \"Request Timeout\", \"409\": \"Conflict\",\n        \"410\": \"Gone\", \"411\": \"Length Required\", \"412\": \"Precondition Failed\",\n        \"413\": \"Payload Too Large\", \"414\": \"URI Too Large\", \"415\": \"Unsupported Media Type\",\n        \"416\": \"Range Not Satisfiable\", \"417\": \"Expectation Failed\", \"422\": \"Unprocessable Content\",\n        \"426\": \"Upgrade Required\", \"500\": \"Internal Server Error\", \"501\": \"Not Implemented\",\n        \"502\": \"Bad Gateway\", \"503\": \"Service Unavailable\", \"504\": \"Gateway Timmeout\",\n        \"505\": \"HTTP Version Not Supported\",\n\n        /**\n        * Utility method that accepts an HTTP code and returns its corresponding reason-phrase.\n        * @param code The HTTP status code (number).\n        * @returns The reason phrase string.\n        * @throws Error if the code is not a valid integer in the range [100-505].\n        */\n        getReason: (code: number): string => {\n            if (isNaN(code) || code < 100 || code > 505) {\n                throw Error('Illegal argument for code[' + code + ']. Valid HTTP codes are integer numbers in the range [100-505].')\n            }\n            return Response.HttpCodesReasons[String(code)];\n        }\n    }\n\n    /**\n     * Checks if the response fa\u00E7ade is currently valid or connected to an active request context.\n     * @returns True if valid, false otherwise.\n     */\n    public static isValid(): boolean {\n        return HttpResponseFacade.isValid();\n    }\n\n    /**\n     * Serializes a JavaScript object to JSON, sets the `Content-Type: application/json` header,\n     * and writes the JSON string to the response output stream.\n     * @param obj The JavaScript object to be serialized and sent.\n     */\n    public static json(obj: any): void {\n        Response.addHeader(\"Content-Type\", \"application/json\")\n        const objJson = JSON.stringify(obj);\n        Response.print(objJson);\n    }\n\n    /**\n     * Writes a string of text to the response body using **UTF-8** encoding.\n     * Note: This method automatically handles flushing the output stream.\n     * @param text The string content to write.\n     */\n    public static print(text: string): void {\n        text = (text && text.toString()) || \"\";\n        const out = Response.getOutputStream().native;\n        // Use Java I/O to ensure explicit UTF-8 encoding\n        const writer = new OutputStreamWriter(out, StandardCharsets.UTF_8);\n        writer.write(text);\n        writer.flush();\n    }\n\n    /**\n     * Writes a string of text followed by a newline character (`\\n`) to the response body\n     * using **UTF-8** encoding.\n     * @param text The string content to write.\n     */\n    public static println(text: string): void {\n        text = (text && text.toString()) || \"\";\n        const out = Response.getOutputStream().native;\n        const writer = new OutputStreamWriter(out, StandardCharsets.UTF_8);\n        writer.write(text);\n        writer.write(\"\\n\");\n        writer.flush();\n    }\n\n    /**\n     * Writes an array of bytes directly to the response output stream, typically used for binary data.\n     * @param bytes The array of bytes to write.\n     */\n    public static write(bytes: any[]): void {\n        if (!bytes) {\n            bytes = [];\n        }\n        HttpResponseFacade.write(bytes);\n    }\n\n    /**\n     * Checks if the response headers and status have already been sent to the client.\n     * @returns True if the response is committed, false otherwise.\n     */\n    public static isCommitted(): boolean {\n        return HttpResponseFacade.isCommitted();\n    }\n\n    /**\n     * Sets the value of the `Content-Type` header.\n     * @param contentType The MIME type string (e.g., 'text/html', 'application/pdf').\n     */\n    public static setContentType(contentType: string): void {\n        HttpResponseFacade.setContentType(contentType);\n    }\n\n    /**\n     * Forces any buffered output to be written to the client.\n     */\n    public static flush(): void {\n        HttpResponseFacade.flush();\n    }\n\n    /**\n     * Closes the response output stream.\n     */\n    public static close(): void {\n        HttpResponseFacade.close();\n    }\n\n    /**\n     * Adds a cookie to the response. The cookie object is serialized to JSON before being passed\n     * to the underlying Java facade.\n     * @param cookie The cookie definition object.\n     */\n    public static addCookie(cookie: Cookie): void {\n        HttpResponseFacade.addCookie(JSON.stringify(cookie));\n    }\n\n    /**\n     * Checks if a response header with the specified name has already been set.\n     * @param name The name of the header.\n     * @returns True if the header exists, false otherwise.\n     */\n    public static containsHeader(name: string): boolean {\n        return HttpResponseFacade.containsHeader(name);\n    }\n\n    /**\n     * Encodes a URL for use in redirects or forms, including session information if necessary.\n     * @param url The URL to encode.\n     * @returns The encoded URL string.\n     */\n    public static encodeURL(url: string): string {\n        return HttpResponseFacade.encodeURL(url);\n    }\n\n    /**\n     * Gets the character encoding used for the response body.\n     * @returns The character encoding string.\n     */\n    public static getCharacterEncoding(): string {\n        return HttpResponseFacade.getCharacterEncoding();\n    }\n\n    /**\n     * Encodes a URL for use in the `Location` header of a redirect response.\n     * @param url The redirect URL to encode.\n     * @returns The encoded redirect URL string.\n     */\n    public static encodeRedirectURL(url: string): string {\n        return HttpResponseFacade.encodeRedirectURL(url);\n    }\n\n    /**\n     * Gets the current `Content-Type` header value.\n     * @returns The content type string.\n     */\n    public static getContentType(): string {\n        return HttpResponseFacade.getContentType();\n    }\n\n    /**\n     * Sends an HTTP error response to the client with the specified status code and optional message.\n     * This bypasses the normal response body writing process.\n     * @param status The HTTP status code (e.g., 404, 500).\n     * @param message An optional message to include in the error response.\n     */\n    public static sendError(status: number, message?: string): void {\n        HttpResponseFacade.sendError(status, message);\n    }\n\n    /**\n     * Sets the character encoding to be used for the response body (e.g., 'UTF-8').\n     * @param charset The character set string.\n     */\n    public static setCharacterEncoding(charset: string): void {\n        HttpResponseFacade.setCharacterEncoding(charset);\n    }\n\n    /**\n     * Sends a redirect response (status code 302 by default) to the client.\n     * @param location The new URL to redirect the client to.\n     */\n    public static sendRedirect(location: string): void {\n        HttpResponseFacade.sendRedirect(location);\n    }\n\n    /**\n     * Sets the `Content-Length` header for the response.\n     * @param length The size of the response body in bytes.\n     */\n    public static setContentLength(length: number): void {\n        HttpResponseFacade.setContentLength(length);\n    }\n\n    /**\n     * Sets a response header with the given name and value. If the header already exists, its value is overwritten.\n     * @param name The name of the header.\n     * @param value The value of the header.\n     */\n    public static setHeader(name: string, value: string): void {\n        HttpResponseFacade.setHeader(name, value);\n    }\n\n    /**\n     * Adds a response header with the given name and value. If the header already exists, a second header with the same name is added.\n     * @param name The name of the header.\n     * @param value The value of the header.\n     */\n    public static addHeader(name: string, value: string): void {\n        HttpResponseFacade.addHeader(name, value);\n    }\n\n    /**\n     * Sets the HTTP status code for the response.\n     * @param status The integer status code (e.g., 200, 404).\n     */\n    public static setStatus(status: number): void {\n        HttpResponseFacade.setStatus(status);\n    }\n\n    /**\n     * Clears all buffers, status code, and headers from the response, allowing a new response to be generated.\n     * This is only possible if the response has not yet been committed.\n     */\n    public static reset(): void {\n        HttpResponseFacade.reset();\n    }\n\n    /**\n     * Gets the value of a specific header. If multiple headers with the same name exist, it returns the first one.\n     * @param name The name of the header.\n     * @returns The header value string.\n     */\n    public static getHeader(name: string): string {\n        return HttpResponseFacade.getHeader(name);\n    }\n\n    /**\n     * Sets the locale for the response, which may affect language and date/time formatting.\n     * @param language The language code (e.g., 'en', 'fr').\n     * @param country The optional country code (e.g., 'US', 'GB').\n     * @param variant The optional variant code.\n     */\n    public static setLocale(language: string, country?: string, variant?: string): void {\n        return HttpResponseFacade.setLocale(language, country, variant);\n    }\n\n    /**\n     * Gets all header values for a specific header name as an array of strings.\n     * @param name The name of the header.\n     * @returns An array of header values.\n     */\n    public static getHeaders(name: string): string[] {\n        return JSON.parse(HttpResponseFacade.getHeaders(name));\n    }\n\n    /**\n     * Gets the names of all headers that have been set on the response.\n     * @returns An array of header names.\n     */\n    public static getHeaderNames(): string[] {\n        return JSON.parse(HttpResponseFacade.getHeaderNames());\n    }\n\n    /**\n     * Gets the currently set locale string for the response.\n     * @returns The locale string.\n     */\n    public static getLocale(): string {\n        return HttpResponseFacade.getLocale();\n    }\n\n    /**\n     * Gets the underlying output stream object, wrapped in the SDK's `OutputStream` class.\n     * This is useful for writing raw or large amounts of data.\n     * @returns The output stream object.\n     */\n    public static getOutputStream(): OutputStream {\n        return new OutputStream(HttpResponseFacade.getOutputStream());\n    }\n}\n\n// @ts-ignore\nif (typeof module !== 'undefined') {\n\t// @ts-ignore\n\tmodule.exports = Response;\n}\n"],
  "mappings": "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",
  "names": []
}

@@ -43,6 +43,9 @@ function service(oConfig) {
43
43
  return new HttpController(config);
44
44
  }
45
45
  class HttpController {
46
+ resource;
47
+ resourcePath;
48
+ resourceMappings;
46
49
  /**
47
50
  * Constructor function for HttpController instances.
48
51
  *
@@ -304,4 +307,4 @@ const matchMediaType = function(request2, producesMediaTypes, consumesMediaTypes
304
307
  }
305
308
  return isProduceMatched && isConsumeMatched;
306
309
  };
307
- //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../../src/http/rs/resource-http-controller.ts"],
  "sourcesContent": ["import { Response as response } from \"../response\";\nimport { Request as request } from \"../request\";\nimport { ResourceMappings } from \"./resource-mappings\";\nimport { Logging } from \"@aerokit/sdk/log\";\n\n// Declaration for the external dirigibleRequire function and its dependency\ndeclare function dirigibleRequire(module: string): any;\nconst { match } = dirigibleRequire(\"modules/src/http/path-to-regexp/6.2.1/index.js\");\n\nconst logger: any = Logging.getLogger('http.rs.controller');\n\n/**\n * Interface for the context object passed to handler functions (before, serve, catch).\n */\ninterface RequestContext {\n    pathParameters: { [key: string]: any };\n    queryParameters: { [key: string]: any };\n    response: any;\n    res: any;\n    request: any;\n    req: any;\n    // Context properties for error handling might also be attached here\n    suppressStack?: boolean;\n    httpErrorCode?: number;\n    errorMessage?: string;\n    errorName?: string;\n    errorCode?: any;\n}\n\nfunction getRequest(): any {\n    return request;\n}\nfunction getResponse(): any {\n    return response;\n}\n\n/**\n * Creates a service (HttpController) instance, optionally initialized with oMappings.\n *\n * @param oConfig Configuration object or configuration builder with configuration() getter function.\n * @returns A new HttpController instance.\n */\nexport function service(oConfig?: any): HttpController {\n    let config: ResourceMappings | any;\n    if (oConfig !== undefined) {\n        if (typeof oConfig === 'object' || oConfig instanceof ResourceMappings) {\n            config = oConfig;\n        }\n    }\n    return new HttpController(config);\n}\n\n/**\n * The main class for handling HTTP requests and routing them to the correct resource handlers.\n */\nexport class HttpController {\n\n    resource: Function;\n    resourcePath: Function;\n    resourceMappings: ResourceMappings;\n\n    // Index signature to allow dynamic method assignment in the constructor\n    [key: string]: any;\n\n    /**\n     * Constructor function for HttpController instances.\n     *\n     * @param oMappings The mappings configuration for this controller.\n     */\n    constructor(oMappings?: ResourceMappings | any) {\n        if (oMappings instanceof ResourceMappings) {\n            this.resourceMappings = oMappings;\n        } else if (typeof oMappings === 'object' || oMappings === undefined) {\n            this.resourceMappings = new ResourceMappings(oMappings, this);\n        } else {\n            // Default initialization if input is unexpected\n            this.resourceMappings = new ResourceMappings({}, this);\n        }\n\n        // Alias for resourceMappings.resource\n        this.resource = this.resourcePath = this.resourceMappings.resourcePath.bind(this.resourceMappings);\n\n        // weave-in HTTP method-based factory functions - shortcut for service().resource(sPath).method\n        ['get', 'post', 'put', 'delete', 'remove', 'method'].forEach((sMethodName: string) => {\n            this[sMethodName] = (...allArguments: any[]): HttpController => {\n                if (allArguments.length < 1)\n                    throw Error('Insufficient arguments provided to HttpController method ' + sMethodName + '.');\n\n                // sPath is always the first argument\n                let sPath = allArguments[0];\n                if (sPath === undefined)\n                    sPath = \"\";\n\n                // The next arguments (sVerb, arrConsumes, arrProduces) are used by ResourceMappings.find/resource\n                const sVerb = allArguments[1];\n                const arrConsumes = allArguments[2];\n                const arrProduces = allArguments[3];\n\n                // Find existing resource or create a new one based on the path (and other optional constraints)\n                const resource: any = this.resourceMappings.find(sPath, sVerb, arrConsumes, arrProduces) || this.resourceMappings.resource(sPath);\n\n                // Pass all arguments *except* the sPath to the corresponding method of the resource\n                const resourceMethodArgs = allArguments.slice(1);\n                \n                // Execute the method on the resource instance\n                resource[sMethodName].apply(resource, resourceMethodArgs);\n                \n                return this;\n            };\n        });\n    }\n\n    /**\n     * Alias for execute.\n     */\n    listen(request: any, response: any): void {\n        this.execute(request, response);\n    }\n\n    /**\n     * Executes the request handling logic, finding the best matching resource and handler.\n     */\n    execute(request?: any, response?: any): void {\n        request = request || getRequest();\n        const requestPath: string = request.getResourcePath();\n        const method: string = request.getMethod().toLowerCase();\n        const _oConfiguration: any = this.resourceMappings.configuration();\n\n        const matches: any[] = matchRequestUrl(requestPath, method, _oConfiguration);\n        let resourceHandler: any;\n\n        if (matches && matches[0]) {\n            const verbHandlers: any[] = _oConfiguration[matches[0].d][method];\n            if (verbHandlers) {\n                resourceHandler = verbHandlers.filter((handlerDef) => {\n                    return matchMediaType(request, handlerDef.produces, handlerDef.consumes);\n                })[0];\n            }\n        }\n\n        response = response || getResponse();\n        const queryParams: { [key: string]: any } = request.getQueryParametersMap() || {};\n        const acceptsHeader: string[] = normalizeMediaTypeHeaderValue(request.getHeader('Accept')) || [];\n        const contentTypeHeader: string[] = normalizeMediaTypeHeaderValue(request.getHeader('Content-Type')) || [];\n        const resourcePath: string = requestPath;\n\n        if (resourceHandler) {\n            const ctx: RequestContext = {\n                \"pathParameters\": {},\n                \"queryParameters\": {},\n                \"response\": response,\n                \"res\": response,\n                \"request\": request,\n                \"req\": request\n            };\n            if (matches[0].pathParams) {\n                ctx.pathParameters = matches[0].pathParams;\n            }\n            ctx.queryParameters = queryParams;\n\n            const noop = function () { };\n            let _before: Function, _serve: Function, _catch: Function, _finally: Function;\n            _before = resourceHandler.before || noop;\n            _serve = resourceHandler.handler || resourceHandler.serve || noop;\n            _catch = resourceHandler.catch || catchErrorHandler.bind(this, {\n                path: resourcePath,\n                method: method.toUpperCase(),\n                contentType: contentTypeHeader.join(','),\n                accepts: acceptsHeader.join(',')\n            });\n            _finally = resourceHandler.finally || noop;\n\n            const callbackArgs: any[] = [ctx, request, response, resourceHandler, this];\n\n            try {\n                logger.trace('Before serving request for Resource[{}], Method[{}], Content-Type[{}], Accept[{}]', resourcePath, method.toUpperCase(), contentTypeHeader, acceptsHeader);\n                _before.apply(this, callbackArgs);\n\n                if (!response.isCommitted()) {\n                    logger.trace('Serving request for Resource[{}], Method[{}], Content-Type[{}], Accept[{}]', resourcePath, method.toUpperCase(), contentTypeHeader, acceptsHeader);\n                    _serve.apply(this, callbackArgs);\n                    logger.trace('Serving request for Resource[{}], Method[{}], Content-Type[{}], Accept[{}] finished', resourcePath, method.toUpperCase(), contentTypeHeader, acceptsHeader);\n                }\n            } catch (err: any) {\n                try {\n                    callbackArgs.splice(1, 0, err);\n                    _catch.apply(this, callbackArgs);\n                } catch (_catchErr) {\n                    logger.error('Serving request for Resource[{}], Method[{}], Content-Type[{}], Accept[{}] error handler threw error', _catchErr);\n                    throw _catchErr;\n                }\n            } finally {\n                HttpController.prototype.closeResponse.call(this);\n                try {\n                    _finally.apply(this, []);\n                } catch (_finallyErr) {\n                    logger.error('Serving request for Resource[{}], Method[{}], Content-Type[{}], Accept[{}] post handler threw error', _finallyErr);\n                }\n            }\n        } else {\n            logger.error('No suitable resource handler for Resource[{}], Method[{}], Content-Type[{}], Accept[{}] found', resourcePath, method.toUpperCase(), contentTypeHeader, acceptsHeader);\n\t\t\tlogger.error('Registered resource handlers for Resource[{}] are [{}]', resourcePath, JSON.stringify(_oConfiguration));\n            this.sendError(response.BAD_REQUEST, undefined, 'Bad Request', 'No suitable processor for this request.');\n        }\n    }\n\n    /**\n     * Returns the ResourceMappings instance of this controller.\n     */\n    mappings(): ResourceMappings {\n        return this.resourceMappings;\n    };\n\n    /**\n     * Sends an error response to the client, formatted based on the accepted media type.\n     */\n    sendError(httpErrorCode: number, applicationErrorCode: any, errorName: string, errorDetails: string): void {\n        const clientAcceptMediaTypes: string[] = normalizeMediaTypeHeaderValue(request.getHeader('Accept')) || ['application/json'];\n        const isHtml: boolean = clientAcceptMediaTypes.some((acceptMediaType) => isMimeTypeCompatible('*/html', acceptMediaType));\n\n        response.setStatus(httpErrorCode || response.INTERNAL_SERVER_ERROR);\n\n        if (isHtml) {\n            const message: string = errorName + (applicationErrorCode !== undefined ? '[' + applicationErrorCode + ']' : '') + (errorDetails ? ': ' + errorDetails : '');\n            response.sendError(httpErrorCode || response.INTERNAL_SERVER_ERROR, message);\n        } else {\n            const body = {\n                \"code\": applicationErrorCode,\n                \"error\": errorName,\n                \"details\": errorDetails\n            };\n            response.setHeader(\"Content-Type\", \"application/json\");\n            response.print(JSON.stringify(body, null, 2));\n        }\n        this.closeResponse();\n    };\n\n    /**\n     * Flushes and closes the HTTP response stream.\n     */\n    closeResponse(): void {\n        response.flush();\n        response.close();\n    };\n}\n\n/**\n * Custom sort function for matched route definitions, preferring exact matches over those with placeholders.\n */\nfunction matchedRouteDefinitionsSorter(p: any, n: any): number {\n    p.w = calculateMatchedRouteWeight(p);\n    n.w = calculateMatchedRouteWeight(n);\n\n    if (n.w === p.w) {\n        // The one with less placeholders wins\n        const m1 = p.d.match(/{(.*?)}/g);\n        const placeholdersCount1 = m1 !== null ? m1.length : 0;\n        const m2 = n.d.match(/{(.*?)}/g);\n        const placeholdersCount2 = m2 !== null ? m2.length : 0;\n        if (placeholdersCount1 > placeholdersCount2) {\n            n.w = n.w + 1;\n        } else if (placeholdersCount1 < placeholdersCount2) {\n            p.w = p.w + 1;\n        }\n    }\n    return n.w - p.w;\n}\n\n/**\n * Calculates the initial weight of a matched route definition.\n */\nfunction calculateMatchedRouteWeight(matchedRoute: any): number {\n    return (matchedRoute.params && Object.keys(matchedRoute.params).length > 0) ? 0 : 1; // always prefer exact route definitions - set weight to 1\n}\n\n/**\n * Transforms path parameters declared in braces (e.g., '/api/{pathParam}') to path-to-regexp format (e.g., '/api/:pathParam').\n */\nfunction transformPathParamsDeclaredInBraces(pathDefinition: string): string {\n    const pathParamsInBracesMatcher = /({(\\w*\\*?)})/g; // matches cases like '/api/{pathParam}' or '/api/{pathParam*}'\n    return pathDefinition.replace(pathParamsInBracesMatcher, \":$2\"); // transforms matched cases to '/api/:pathParam' or '/api/:pathParam*'\n}\n\n/**\n * Finds all routes in the configuration that match the request path and method.\n */\nfunction matchRequestUrl(requestPath: string, method: string, cfg: any): any[] {\n    return Object.entries(cfg)\n        .filter(([_, handlers]) => handlers && (handlers as any)[method])\n        .map(([path, _]) => path)\n        .reduce((matches: any[], path: string) => matchingRouteDefinitionsReducer(matches, path, requestPath), [])\n        .sort(matchedRouteDefinitionsSorter);\n}\n\n/**\n * Reducer function to attempt matching a defined path against the request path using path-to-regexp.\n */\nfunction matchingRouteDefinitionsReducer(matchedDefinitions: any[], definedPath: string, requestPath: string): any[] {\n    // 'match' from path-to-regexp is used here\n    const pathMatcher = match(transformPathParamsDeclaredInBraces(definedPath));\n    const matched = pathMatcher(requestPath);\n\n    if (matched) {\n        // Ensure pathParams is an object of key/value pairs\n        const pathParams = matched.params;\n\n        const matchedDefinition = {\n            p: requestPath,\n            d: definedPath,\n            pathParams: pathParams\n        };\n        matchedDefinitions.push(matchedDefinition);\n    }\n    return matchedDefinitions;\n}\n\n/**\n * Normalizes an HTTP media type header value (e.g., \"text/plain; q=0.9, application/json\").\n */\nfunction normalizeMediaTypeHeaderValue(sMediaType: string | undefined | null): string[] | undefined {\n    if (sMediaType === undefined || sMediaType === null)\n        return;\n    // convert to array of individual types\n    let arrMediaType = sMediaType.split(',');\n    arrMediaType = arrMediaType.map((mimeTypeEntry) => {\n        // remove escaping, remove quality or other attributes (e.g., '; q=0.9')\n        return mimeTypeEntry.replace('\\\\', '').split(';')[0].trim();\n    });\n    return arrMediaType.filter(type => type.length > 0);\n}\n\n/**\n * Checks if a source MIME type is compatible with a target MIME type, supporting wildcards (*).\n */\nfunction isMimeTypeCompatible(source: string, target: string): boolean {\n    if (source === target)\n        return true;\n\n    const targetM = target.split('/');\n    const sourceM = source.split('/');\n\n    // Target is wildcard type, Source has a specific subtype (e.g., target=*/json, source=application/json)\n    if (targetM[0] === '*' && targetM[1] === sourceM[1])\n        return true;\n    // Source is wildcard type, Target has a specific subtype (e.g., source=*/json, target=application/json)\n    if (sourceM[0] === '*' && targetM[1] === sourceM[1])\n        return true;\n\n    // Target is wildcard subtype, Source has a specific type (e.g., target=application/*, source=application/json)\n    if (targetM[1] === '*' && targetM[0] === sourceM[0])\n        return true;\n    // Source is wildcard subtype, Target has a specific type (e.g., source=application/*, target=application/json)\n    if (sourceM[1] === '*' && targetM[0] === sourceM[0])\n        return true;\n\n    return false;\n}\n\n/**\n * Default error handler function.\n */\nconst catchErrorHandler = function (this: HttpController, logctx: any, ctx: RequestContext, err: any, request: any, response: any): void {\n    if (ctx.suppressStack) {\n        const detailsMsg = (ctx.errorName || \"\") + (ctx.errorCode ? \" [\" + ctx.errorCode + \"]\" : \"\") + (ctx.errorMessage ? \": \" + ctx.errorMessage : \"\");\n        logger.info('Serving resource[{}], Verb[{}], Content-Type[{}], Accept[{}] finished in error. {}', logctx.path, logctx.method, logctx.contentType, logctx.accepts, detailsMsg);\n    } else {\n        logger.error('Serving resource[{}], Verb[{}], Content-Type[{}], Accept[{}] finished in error', logctx.path, logctx.method, logctx.contentType, logctx.accepts, err);\n    }\n\n    const httpErrorCode = ctx.httpErrorCode || response.INTERNAL_SERVER_ERROR;\n    const errorMessage = ctx.errorMessage || (err && err.message);\n    const errorName = ctx.errorName || (err && err.name);\n    const errorCode = ctx.errorCode;\n\n    this.sendError(httpErrorCode, errorCode, errorName, errorMessage);\n};\n\n/**\n * Checks if the request media types match the resource handler's consumes and produces constraints.\n */\nconst matchMediaType = function (request: any, producesMediaTypes: string[], consumesMediaTypes: string[]): boolean {\n    let isProduceMatched = false;\n    const acceptsMediaTypes = normalizeMediaTypeHeaderValue(request.getHeader('Accept'));\n\n    // 1. Check Produces (Accepts header)\n    if (!acceptsMediaTypes || acceptsMediaTypes.length === 0 || acceptsMediaTypes.includes('*/*')) {\n        // Output media type is not restricted by client or client accepts anything\n        isProduceMatched = true;\n    } else {\n        if (producesMediaTypes && producesMediaTypes.length) {\n            const matchedProducesMIME = acceptsMediaTypes.filter((acceptsMediaType) => {\n                return producesMediaTypes.some((producesMediaType) => {\n                    return isMimeTypeCompatible(acceptsMediaType, producesMediaType);\n                });\n            });\n            isProduceMatched = matchedProducesMIME && matchedProducesMIME.length > 0;\n        } else {\n            // Resource doesn't specify produces, so it matches if the client accepts anything or if produces is an empty array\n            isProduceMatched = true;\n        }\n    }\n\n    // 2. Check Consumes (Content-Type header)\n    let isConsumeMatched = false;\n    const contentTypeMediaTypes = normalizeMediaTypeHeaderValue(request.getContentType());\n\n    if (!consumesMediaTypes || consumesMediaTypes.length === 0 || consumesMediaTypes.includes('*/*')) {\n        // Input media type is not restricted by resource or resource accepts anything\n        isConsumeMatched = true;\n    } else {\n        if (contentTypeMediaTypes && consumesMediaTypes && consumesMediaTypes.length) {\n            const matchedConsumesMIME = contentTypeMediaTypes.filter((contentTypeMediaType) => {\n                return consumesMediaTypes.some((consumesMediaType) => {\n                    return isMimeTypeCompatible(contentTypeMediaType, consumesMediaType);\n                });\n            });\n            isConsumeMatched = matchedConsumesMIME && matchedConsumesMIME.length > 0;\n        }\n    }\n\n    return isProduceMatched && isConsumeMatched;\n};\n"],
  "mappings": "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",
  "names": ["request", "response"]
}

310
+ //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../../src/http/rs/resource-http-controller.ts"],
  "sourcesContent": ["import { Response as response } from \"../response\";\nimport { Request as request } from \"../request\";\nimport { ResourceMappings } from \"./resource-mappings\";\nimport { Logging } from \"@aerokit/sdk/log\";\n\n// Declaration for the external dirigibleRequire function and its dependency\ndeclare function dirigibleRequire(module: string): any;\nconst { match } = dirigibleRequire(\"modules/src/http/path-to-regexp/6.2.1/index.js\");\n\nconst logger: any = Logging.getLogger('http.rs.controller');\n\n/**\n * Interface for the context object passed to handler functions (before, serve, catch).\n */\ninterface RequestContext {\n    pathParameters: { [key: string]: any };\n    queryParameters: { [key: string]: any };\n    response: any;\n    res: any;\n    request: any;\n    req: any;\n    // Context properties for error handling might also be attached here\n    suppressStack?: boolean;\n    httpErrorCode?: number;\n    errorMessage?: string;\n    errorName?: string;\n    errorCode?: any;\n}\n\nfunction getRequest(): any {\n    return request;\n}\nfunction getResponse(): any {\n    return response;\n}\n\n/**\n * Creates a service (HttpController) instance, optionally initialized with oMappings.\n *\n * @param oConfig Configuration object or configuration builder with configuration() getter function.\n * @returns A new HttpController instance.\n */\nexport function service(oConfig?: any): HttpController {\n    let config: ResourceMappings | any;\n    if (oConfig !== undefined) {\n        if (typeof oConfig === 'object' || oConfig instanceof ResourceMappings) {\n            config = oConfig;\n        }\n    }\n    return new HttpController(config);\n}\n\n/**\n * The main class for handling HTTP requests and routing them to the correct resource handlers.\n */\nexport class HttpController {\n\n    resource: Function;\n    resourcePath: Function;\n    resourceMappings: ResourceMappings;\n\n    // Index signature to allow dynamic method assignment in the constructor\n    [key: string]: any;\n\n    /**\n     * Constructor function for HttpController instances.\n     *\n     * @param oMappings The mappings configuration for this controller.\n     */\n    constructor(oMappings?: ResourceMappings | any) {\n        if (oMappings instanceof ResourceMappings) {\n            this.resourceMappings = oMappings;\n        } else if (typeof oMappings === 'object' || oMappings === undefined) {\n            this.resourceMappings = new ResourceMappings(oMappings, this);\n        } else {\n            // Default initialization if input is unexpected\n            this.resourceMappings = new ResourceMappings({}, this);\n        }\n\n        // Alias for resourceMappings.resource\n        this.resource = this.resourcePath = this.resourceMappings.resourcePath.bind(this.resourceMappings);\n\n        // weave-in HTTP method-based factory functions - shortcut for service().resource(sPath).method\n        ['get', 'post', 'put', 'delete', 'remove', 'method'].forEach((sMethodName: string) => {\n            this[sMethodName] = (...allArguments: any[]): HttpController => {\n                if (allArguments.length < 1)\n                    throw Error('Insufficient arguments provided to HttpController method ' + sMethodName + '.');\n\n                // sPath is always the first argument\n                let sPath = allArguments[0];\n                if (sPath === undefined)\n                    sPath = \"\";\n\n                // The next arguments (sVerb, arrConsumes, arrProduces) are used by ResourceMappings.find/resource\n                const sVerb = allArguments[1];\n                const arrConsumes = allArguments[2];\n                const arrProduces = allArguments[3];\n\n                // Find existing resource or create a new one based on the path (and other optional constraints)\n                const resource: any = this.resourceMappings.find(sPath, sVerb, arrConsumes, arrProduces) || this.resourceMappings.resource(sPath);\n\n                // Pass all arguments *except* the sPath to the corresponding method of the resource\n                const resourceMethodArgs = allArguments.slice(1);\n                \n                // Execute the method on the resource instance\n                resource[sMethodName].apply(resource, resourceMethodArgs);\n                \n                return this;\n            };\n        });\n    }\n\n    /**\n     * Alias for execute.\n     */\n    listen(request: any, response: any): void {\n        this.execute(request, response);\n    }\n\n    /**\n     * Executes the request handling logic, finding the best matching resource and handler.\n     */\n    execute(request?: any, response?: any): void {\n        request = request || getRequest();\n        const requestPath: string = request.getResourcePath();\n        const method: string = request.getMethod().toLowerCase();\n        const _oConfiguration: any = this.resourceMappings.configuration();\n\n        const matches: any[] = matchRequestUrl(requestPath, method, _oConfiguration);\n        let resourceHandler: any;\n\n        if (matches && matches[0]) {\n            const verbHandlers: any[] = _oConfiguration[matches[0].d][method];\n            if (verbHandlers) {\n                resourceHandler = verbHandlers.filter((handlerDef) => {\n                    return matchMediaType(request, handlerDef.produces, handlerDef.consumes);\n                })[0];\n            }\n        }\n\n        response = response || getResponse();\n        const queryParams: { [key: string]: any } = request.getQueryParametersMap() || {};\n        const acceptsHeader: string[] = normalizeMediaTypeHeaderValue(request.getHeader('Accept')) || [];\n        const contentTypeHeader: string[] = normalizeMediaTypeHeaderValue(request.getHeader('Content-Type')) || [];\n        const resourcePath: string = requestPath;\n\n        if (resourceHandler) {\n            const ctx: RequestContext = {\n                \"pathParameters\": {},\n                \"queryParameters\": {},\n                \"response\": response,\n                \"res\": response,\n                \"request\": request,\n                \"req\": request\n            };\n            if (matches[0].pathParams) {\n                ctx.pathParameters = matches[0].pathParams;\n            }\n            ctx.queryParameters = queryParams;\n\n            const noop = function () { };\n            let _before: Function, _serve: Function, _catch: Function, _finally: Function;\n            _before = resourceHandler.before || noop;\n            _serve = resourceHandler.handler || resourceHandler.serve || noop;\n            _catch = resourceHandler.catch || catchErrorHandler.bind(this, {\n                path: resourcePath,\n                method: method.toUpperCase(),\n                contentType: contentTypeHeader.join(','),\n                accepts: acceptsHeader.join(',')\n            });\n            _finally = resourceHandler.finally || noop;\n\n            const callbackArgs: any[] = [ctx, request, response, resourceHandler, this];\n\n            try {\n                logger.trace('Before serving request for Resource[{}], Method[{}], Content-Type[{}], Accept[{}]', resourcePath, method.toUpperCase(), contentTypeHeader, acceptsHeader);\n                _before.apply(this, callbackArgs);\n\n                if (!response.isCommitted()) {\n                    logger.trace('Serving request for Resource[{}], Method[{}], Content-Type[{}], Accept[{}]', resourcePath, method.toUpperCase(), contentTypeHeader, acceptsHeader);\n                    _serve.apply(this, callbackArgs);\n                    logger.trace('Serving request for Resource[{}], Method[{}], Content-Type[{}], Accept[{}] finished', resourcePath, method.toUpperCase(), contentTypeHeader, acceptsHeader);\n                }\n            } catch (err: any) {\n                try {\n                    callbackArgs.splice(1, 0, err);\n                    _catch.apply(this, callbackArgs);\n                } catch (_catchErr) {\n                    logger.error('Serving request for Resource[{}], Method[{}], Content-Type[{}], Accept[{}] error handler threw error', _catchErr);\n                    throw _catchErr;\n                }\n            } finally {\n                HttpController.prototype.closeResponse.call(this);\n                try {\n                    _finally.apply(this, []);\n                } catch (_finallyErr) {\n                    logger.error('Serving request for Resource[{}], Method[{}], Content-Type[{}], Accept[{}] post handler threw error', _finallyErr);\n                }\n            }\n        } else {\n            logger.error('No suitable resource handler for Resource[{}], Method[{}], Content-Type[{}], Accept[{}] found', resourcePath, method.toUpperCase(), contentTypeHeader, acceptsHeader);\n\t\t\tlogger.error('Registered resource handlers for Resource[{}] are [{}]', resourcePath, JSON.stringify(_oConfiguration));\n            this.sendError(response.BAD_REQUEST, undefined, 'Bad Request', 'No suitable processor for this request.');\n        }\n    }\n\n    /**\n     * Returns the ResourceMappings instance of this controller.\n     */\n    mappings(): ResourceMappings {\n        return this.resourceMappings;\n    };\n\n    /**\n     * Sends an error response to the client, formatted based on the accepted media type.\n     */\n    sendError(httpErrorCode: number, applicationErrorCode: any, errorName: string, errorDetails: string): void {\n        const clientAcceptMediaTypes: string[] = normalizeMediaTypeHeaderValue(request.getHeader('Accept')) || ['application/json'];\n        const isHtml: boolean = clientAcceptMediaTypes.some((acceptMediaType) => isMimeTypeCompatible('*/html', acceptMediaType));\n\n        response.setStatus(httpErrorCode || response.INTERNAL_SERVER_ERROR);\n\n        if (isHtml) {\n            const message: string = errorName + (applicationErrorCode !== undefined ? '[' + applicationErrorCode + ']' : '') + (errorDetails ? ': ' + errorDetails : '');\n            response.sendError(httpErrorCode || response.INTERNAL_SERVER_ERROR, message);\n        } else {\n            const body = {\n                \"code\": applicationErrorCode,\n                \"error\": errorName,\n                \"details\": errorDetails\n            };\n            response.setHeader(\"Content-Type\", \"application/json\");\n            response.print(JSON.stringify(body, null, 2));\n        }\n        this.closeResponse();\n    };\n\n    /**\n     * Flushes and closes the HTTP response stream.\n     */\n    closeResponse(): void {\n        response.flush();\n        response.close();\n    };\n}\n\n/**\n * Custom sort function for matched route definitions, preferring exact matches over those with placeholders.\n */\nfunction matchedRouteDefinitionsSorter(p: any, n: any): number {\n    p.w = calculateMatchedRouteWeight(p);\n    n.w = calculateMatchedRouteWeight(n);\n\n    if (n.w === p.w) {\n        // The one with less placeholders wins\n        const m1 = p.d.match(/{(.*?)}/g);\n        const placeholdersCount1 = m1 !== null ? m1.length : 0;\n        const m2 = n.d.match(/{(.*?)}/g);\n        const placeholdersCount2 = m2 !== null ? m2.length : 0;\n        if (placeholdersCount1 > placeholdersCount2) {\n            n.w = n.w + 1;\n        } else if (placeholdersCount1 < placeholdersCount2) {\n            p.w = p.w + 1;\n        }\n    }\n    return n.w - p.w;\n}\n\n/**\n * Calculates the initial weight of a matched route definition.\n */\nfunction calculateMatchedRouteWeight(matchedRoute: any): number {\n    return (matchedRoute.params && Object.keys(matchedRoute.params).length > 0) ? 0 : 1; // always prefer exact route definitions - set weight to 1\n}\n\n/**\n * Transforms path parameters declared in braces (e.g., '/api/{pathParam}') to path-to-regexp format (e.g., '/api/:pathParam').\n */\nfunction transformPathParamsDeclaredInBraces(pathDefinition: string): string {\n    const pathParamsInBracesMatcher = /({(\\w*\\*?)})/g; // matches cases like '/api/{pathParam}' or '/api/{pathParam*}'\n    return pathDefinition.replace(pathParamsInBracesMatcher, \":$2\"); // transforms matched cases to '/api/:pathParam' or '/api/:pathParam*'\n}\n\n/**\n * Finds all routes in the configuration that match the request path and method.\n */\nfunction matchRequestUrl(requestPath: string, method: string, cfg: any): any[] {\n    return Object.entries(cfg)\n        .filter(([_, handlers]) => handlers && (handlers as any)[method])\n        .map(([path, _]) => path)\n        .reduce((matches: any[], path: string) => matchingRouteDefinitionsReducer(matches, path, requestPath), [])\n        .sort(matchedRouteDefinitionsSorter);\n}\n\n/**\n * Reducer function to attempt matching a defined path against the request path using path-to-regexp.\n */\nfunction matchingRouteDefinitionsReducer(matchedDefinitions: any[], definedPath: string, requestPath: string): any[] {\n    // 'match' from path-to-regexp is used here\n    const pathMatcher = match(transformPathParamsDeclaredInBraces(definedPath));\n    const matched = pathMatcher(requestPath);\n\n    if (matched) {\n        // Ensure pathParams is an object of key/value pairs\n        const pathParams = matched.params;\n\n        const matchedDefinition = {\n            p: requestPath,\n            d: definedPath,\n            pathParams: pathParams\n        };\n        matchedDefinitions.push(matchedDefinition);\n    }\n    return matchedDefinitions;\n}\n\n/**\n * Normalizes an HTTP media type header value (e.g., \"text/plain; q=0.9, application/json\").\n */\nfunction normalizeMediaTypeHeaderValue(sMediaType: string | undefined | null): string[] | undefined {\n    if (sMediaType === undefined || sMediaType === null)\n        return;\n    // convert to array of individual types\n    let arrMediaType = sMediaType.split(',');\n    arrMediaType = arrMediaType.map((mimeTypeEntry) => {\n        // remove escaping, remove quality or other attributes (e.g., '; q=0.9')\n        return mimeTypeEntry.replace('\\\\', '').split(';')[0].trim();\n    });\n    return arrMediaType.filter(type => type.length > 0);\n}\n\n/**\n * Checks if a source MIME type is compatible with a target MIME type, supporting wildcards (*).\n */\nfunction isMimeTypeCompatible(source: string, target: string): boolean {\n    if (source === target)\n        return true;\n\n    const targetM = target.split('/');\n    const sourceM = source.split('/');\n\n    // Target is wildcard type, Source has a specific subtype (e.g., target=*/json, source=application/json)\n    if (targetM[0] === '*' && targetM[1] === sourceM[1])\n        return true;\n    // Source is wildcard type, Target has a specific subtype (e.g., source=*/json, target=application/json)\n    if (sourceM[0] === '*' && targetM[1] === sourceM[1])\n        return true;\n\n    // Target is wildcard subtype, Source has a specific type (e.g., target=application/*, source=application/json)\n    if (targetM[1] === '*' && targetM[0] === sourceM[0])\n        return true;\n    // Source is wildcard subtype, Target has a specific type (e.g., source=application/*, target=application/json)\n    if (sourceM[1] === '*' && targetM[0] === sourceM[0])\n        return true;\n\n    return false;\n}\n\n/**\n * Default error handler function.\n */\nconst catchErrorHandler = function (this: HttpController, logctx: any, ctx: RequestContext, err: any, request: any, response: any): void {\n    if (ctx.suppressStack) {\n        const detailsMsg = (ctx.errorName || \"\") + (ctx.errorCode ? \" [\" + ctx.errorCode + \"]\" : \"\") + (ctx.errorMessage ? \": \" + ctx.errorMessage : \"\");\n        logger.info('Serving resource[{}], Verb[{}], Content-Type[{}], Accept[{}] finished in error. {}', logctx.path, logctx.method, logctx.contentType, logctx.accepts, detailsMsg);\n    } else {\n        logger.error('Serving resource[{}], Verb[{}], Content-Type[{}], Accept[{}] finished in error', logctx.path, logctx.method, logctx.contentType, logctx.accepts, err);\n    }\n\n    const httpErrorCode = ctx.httpErrorCode || response.INTERNAL_SERVER_ERROR;\n    const errorMessage = ctx.errorMessage || (err && err.message);\n    const errorName = ctx.errorName || (err && err.name);\n    const errorCode = ctx.errorCode;\n\n    this.sendError(httpErrorCode, errorCode, errorName, errorMessage);\n};\n\n/**\n * Checks if the request media types match the resource handler's consumes and produces constraints.\n */\nconst matchMediaType = function (request: any, producesMediaTypes: string[], consumesMediaTypes: string[]): boolean {\n    let isProduceMatched = false;\n    const acceptsMediaTypes = normalizeMediaTypeHeaderValue(request.getHeader('Accept'));\n\n    // 1. Check Produces (Accepts header)\n    if (!acceptsMediaTypes || acceptsMediaTypes.length === 0 || acceptsMediaTypes.includes('*/*')) {\n        // Output media type is not restricted by client or client accepts anything\n        isProduceMatched = true;\n    } else {\n        if (producesMediaTypes && producesMediaTypes.length) {\n            const matchedProducesMIME = acceptsMediaTypes.filter((acceptsMediaType) => {\n                return producesMediaTypes.some((producesMediaType) => {\n                    return isMimeTypeCompatible(acceptsMediaType, producesMediaType);\n                });\n            });\n            isProduceMatched = matchedProducesMIME && matchedProducesMIME.length > 0;\n        } else {\n            // Resource doesn't specify produces, so it matches if the client accepts anything or if produces is an empty array\n            isProduceMatched = true;\n        }\n    }\n\n    // 2. Check Consumes (Content-Type header)\n    let isConsumeMatched = false;\n    const contentTypeMediaTypes = normalizeMediaTypeHeaderValue(request.getContentType());\n\n    if (!consumesMediaTypes || consumesMediaTypes.length === 0 || consumesMediaTypes.includes('*/*')) {\n        // Input media type is not restricted by resource or resource accepts anything\n        isConsumeMatched = true;\n    } else {\n        if (contentTypeMediaTypes && consumesMediaTypes && consumesMediaTypes.length) {\n            const matchedConsumesMIME = contentTypeMediaTypes.filter((contentTypeMediaType) => {\n                return consumesMediaTypes.some((consumesMediaType) => {\n                    return isMimeTypeCompatible(contentTypeMediaType, consumesMediaType);\n                });\n            });\n            isConsumeMatched = matchedConsumesMIME && matchedConsumesMIME.length > 0;\n        }\n    }\n\n    return isProduceMatched && isConsumeMatched;\n};\n"],
  "mappings": "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",
  "names": ["request", "response"]
}
