@aerokit/sdk 12.44.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (399) hide show
  1. package/LICENSE +277 -0
  2. package/README.md +170 -0
  3. package/dist/cjs/bpm/deployer.js +57 -0
  4. package/dist/cjs/bpm/index.js +35 -0
  5. package/dist/cjs/bpm/process.js +636 -0
  6. package/dist/cjs/bpm/tasks.js +973 -0
  7. package/dist/cjs/bpm/values.js +82 -0
  8. package/dist/cjs/cache/cache.js +64 -0
  9. package/dist/cjs/cache/index.js +26 -0
  10. package/dist/cjs/cms/cmis.js +689 -0
  11. package/dist/cjs/cms/index.js +26 -0
  12. package/dist/cjs/component/decorators.js +126 -0
  13. package/dist/cjs/component/index.js +36 -0
  14. package/dist/cjs/core/configurations.js +110 -0
  15. package/dist/cjs/core/context.js +47 -0
  16. package/dist/cjs/core/env.js +45 -0
  17. package/dist/cjs/core/globals.js +54 -0
  18. package/dist/cjs/core/index.js +35 -0
  19. package/dist/cjs/db/dao.js +795 -0
  20. package/dist/cjs/db/database.js +904 -0
  21. package/dist/cjs/db/decorators.js +167 -0
  22. package/dist/cjs/db/index.js +72 -0
  23. package/dist/cjs/db/insert.js +51 -0
  24. package/dist/cjs/db/orm.js +245 -0
  25. package/dist/cjs/db/ormstatements.js +243 -0
  26. package/dist/cjs/db/procedure.js +112 -0
  27. package/dist/cjs/db/query.js +57 -0
  28. package/dist/cjs/db/repository.js +148 -0
  29. package/dist/cjs/db/sequence.js +59 -0
  30. package/dist/cjs/db/sql.js +516 -0
  31. package/dist/cjs/db/store.js +172 -0
  32. package/dist/cjs/db/translator.js +100 -0
  33. package/dist/cjs/db/update.js +43 -0
  34. package/dist/cjs/etcd/client.js +174 -0
  35. package/dist/cjs/etcd/index.js +26 -0
  36. package/dist/cjs/extensions/decorators.js +40 -0
  37. package/dist/cjs/extensions/extensions.js +108 -0
  38. package/dist/cjs/extensions/index.js +39 -0
  39. package/dist/cjs/git/client.js +277 -0
  40. package/dist/cjs/git/index.js +26 -0
  41. package/dist/cjs/http/client-async.js +224 -0
  42. package/dist/cjs/http/client.js +145 -0
  43. package/dist/cjs/http/decorators.js +76 -0
  44. package/dist/cjs/http/errors/ForbiddenError.js +41 -0
  45. package/dist/cjs/http/errors/ValidationError.js +41 -0
  46. package/dist/cjs/http/errors.js +26 -0
  47. package/dist/cjs/http/index.js +59 -0
  48. package/dist/cjs/http/request.js +281 -0
  49. package/dist/cjs/http/response.js +452 -0
  50. package/dist/cjs/http/rs/resource-common.js +32 -0
  51. package/dist/cjs/http/rs/resource-http-controller.js +306 -0
  52. package/dist/cjs/http/rs/resource-mappings.js +130 -0
  53. package/dist/cjs/http/rs/resource-method.js +218 -0
  54. package/dist/cjs/http/rs/resource.js +232 -0
  55. package/dist/cjs/http/rs.js +31 -0
  56. package/dist/cjs/http/session.js +124 -0
  57. package/dist/cjs/http/upload.js +144 -0
  58. package/dist/cjs/http/utils.js +106 -0
  59. package/dist/cjs/index.js +1 -0
  60. package/dist/cjs/indexing/index.js +29 -0
  61. package/dist/cjs/indexing/searcher.js +70 -0
  62. package/dist/cjs/indexing/writer.js +45 -0
  63. package/dist/cjs/integrations/index.js +26 -0
  64. package/dist/cjs/integrations/integrations.js +55 -0
  65. package/dist/cjs/io/bytes.js +101 -0
  66. package/dist/cjs/io/files.js +344 -0
  67. package/dist/cjs/io/image.js +43 -0
  68. package/dist/cjs/io/index.js +38 -0
  69. package/dist/cjs/io/streams.js +243 -0
  70. package/dist/cjs/io/zip.js +251 -0
  71. package/dist/cjs/job/decorators.js +40 -0
  72. package/dist/cjs/job/index.js +39 -0
  73. package/dist/cjs/job/scheduler.js +347 -0
  74. package/dist/cjs/junit/index.js +18 -0
  75. package/dist/cjs/junit/junit.js +67 -0
  76. package/dist/cjs/kafka/consumer.js +70 -0
  77. package/dist/cjs/kafka/index.js +29 -0
  78. package/dist/cjs/kafka/producer.js +70 -0
  79. package/dist/cjs/log/index.js +26 -0
  80. package/dist/cjs/log/logging.js +174 -0
  81. package/dist/cjs/mail/client.js +153 -0
  82. package/dist/cjs/mail/index.js +26 -0
  83. package/dist/cjs/messaging/consumer.js +83 -0
  84. package/dist/cjs/messaging/decorators.js +40 -0
  85. package/dist/cjs/messaging/index.js +42 -0
  86. package/dist/cjs/messaging/producer.js +81 -0
  87. package/dist/cjs/mongodb/client.js +627 -0
  88. package/dist/cjs/mongodb/dao.js +390 -0
  89. package/dist/cjs/mongodb/index.js +36 -0
  90. package/dist/cjs/net/decorators.js +40 -0
  91. package/dist/cjs/net/index.js +42 -0
  92. package/dist/cjs/net/soap.js +228 -0
  93. package/dist/cjs/net/websockets.js +151 -0
  94. package/dist/cjs/net/wrappers/onClose.js +2 -0
  95. package/dist/cjs/net/wrappers/onError.js +2 -0
  96. package/dist/cjs/net/wrappers/onMessage.js +2 -0
  97. package/dist/cjs/net/wrappers/onOpen.js +2 -0
  98. package/dist/cjs/pdf/index.js +26 -0
  99. package/dist/cjs/pdf/pdf.js +160 -0
  100. package/dist/cjs/platform/command.js +47 -0
  101. package/dist/cjs/platform/engines.js +70 -0
  102. package/dist/cjs/platform/index.js +47 -0
  103. package/dist/cjs/platform/lifecycle.js +49 -0
  104. package/dist/cjs/platform/os.js +51 -0
  105. package/dist/cjs/platform/problems.js +127 -0
  106. package/dist/cjs/platform/registry.js +319 -0
  107. package/dist/cjs/platform/repository.js +498 -0
  108. package/dist/cjs/platform/workspace.js +574 -0
  109. package/dist/cjs/qldb/index.js +26 -0
  110. package/dist/cjs/qldb/qldb.js +24 -0
  111. package/dist/cjs/rabbitmq/consumer.js +50 -0
  112. package/dist/cjs/rabbitmq/index.js +29 -0
  113. package/dist/cjs/rabbitmq/producer.js +38 -0
  114. package/dist/cjs/redis/client.js +190 -0
  115. package/dist/cjs/redis/index.js +26 -0
  116. package/dist/cjs/security/decorators.js +48 -0
  117. package/dist/cjs/security/index.js +40 -0
  118. package/dist/cjs/security/oauth.js +75 -0
  119. package/dist/cjs/security/user.js +88 -0
  120. package/dist/cjs/template/engines.js +139 -0
  121. package/dist/cjs/template/index.js +26 -0
  122. package/dist/cjs/utils/alphanumeric.js +107 -0
  123. package/dist/cjs/utils/base64.js +104 -0
  124. package/dist/cjs/utils/converter.js +78 -0
  125. package/dist/cjs/utils/digest.js +167 -0
  126. package/dist/cjs/utils/escape.js +160 -0
  127. package/dist/cjs/utils/hex.js +104 -0
  128. package/dist/cjs/utils/index.js +68 -0
  129. package/dist/cjs/utils/jsonpath.js +489 -0
  130. package/dist/cjs/utils/qrcode.js +41 -0
  131. package/dist/cjs/utils/url.js +82 -0
  132. package/dist/cjs/utils/utf8.js +61 -0
  133. package/dist/cjs/utils/uuid.js +48 -0
  134. package/dist/cjs/utils/xml.js +57 -0
  135. package/dist/dts/bpm/deployer.d.ts +29 -0
  136. package/dist/dts/bpm/index.d.ts +8 -0
  137. package/dist/dts/bpm/process.d.ts +433 -0
  138. package/dist/dts/bpm/tasks.d.ts +2022 -0
  139. package/dist/dts/bpm/values.d.ts +38 -0
  140. package/dist/dts/cache/cache.d.ts +30 -0
  141. package/dist/dts/cache/index.d.ts +2 -0
  142. package/dist/dts/cms/cmis.d.ts +413 -0
  143. package/dist/dts/cms/index.d.ts +2 -0
  144. package/dist/dts/component/decorators.d.ts +52 -0
  145. package/dist/dts/component/index.d.ts +2 -0
  146. package/dist/dts/core/configurations.d.ts +65 -0
  147. package/dist/dts/core/context.d.ts +19 -0
  148. package/dist/dts/core/env.d.ts +23 -0
  149. package/dist/dts/core/globals.d.ts +30 -0
  150. package/dist/dts/core/index.d.ts +8 -0
  151. package/dist/dts/db/dao.d.ts +8 -0
  152. package/dist/dts/db/database.d.ts +507 -0
  153. package/dist/dts/db/decorators.d.ts +89 -0
  154. package/dist/dts/db/index.d.ts +25 -0
  155. package/dist/dts/db/insert.d.ts +32 -0
  156. package/dist/dts/db/orm.d.ts +44 -0
  157. package/dist/dts/db/ormstatements.d.ts +4 -0
  158. package/dist/dts/db/procedure.d.ts +25 -0
  159. package/dist/dts/db/query.d.ts +48 -0
  160. package/dist/dts/db/repository.d.ts +64 -0
  161. package/dist/dts/db/sequence.d.ts +34 -0
  162. package/dist/dts/db/sql.d.ts +267 -0
  163. package/dist/dts/db/store.d.ts +138 -0
  164. package/dist/dts/db/translator.d.ts +26 -0
  165. package/dist/dts/db/update.d.ts +21 -0
  166. package/dist/dts/etcd/client.d.ts +92 -0
  167. package/dist/dts/etcd/index.d.ts +2 -0
  168. package/dist/dts/extensions/decorators.d.ts +11 -0
  169. package/dist/dts/extensions/extensions.d.ts +41 -0
  170. package/dist/dts/extensions/index.d.ts +4 -0
  171. package/dist/dts/git/client.d.ts +478 -0
  172. package/dist/dts/git/index.d.ts +2 -0
  173. package/dist/dts/http/client-async.d.ts +158 -0
  174. package/dist/dts/http/client.d.ts +180 -0
  175. package/dist/dts/http/decorators.d.ts +11 -0
  176. package/dist/dts/http/errors/ForbiddenError.d.ts +20 -0
  177. package/dist/dts/http/errors/ValidationError.d.ts +20 -0
  178. package/dist/dts/http/errors.d.ts +2 -0
  179. package/dist/dts/http/index.d.ts +16 -0
  180. package/dist/dts/http/request.d.ts +158 -0
  181. package/dist/dts/http/response.d.ts +281 -0
  182. package/dist/dts/http/rs/resource-common.d.ts +11 -0
  183. package/dist/dts/http/rs/resource-http-controller.d.ts +43 -0
  184. package/dist/dts/http/rs/resource-mappings.d.ts +70 -0
  185. package/dist/dts/http/rs/resource-method.d.ts +206 -0
  186. package/dist/dts/http/rs/resource.d.ts +126 -0
  187. package/dist/dts/http/rs.d.ts +4 -0
  188. package/dist/dts/http/session.d.ts +81 -0
  189. package/dist/dts/http/upload.d.ts +100 -0
  190. package/dist/dts/http/utils.d.ts +54 -0
  191. package/dist/dts/index.d.ts +0 -0
  192. package/dist/dts/indexing/index.d.ts +4 -0
  193. package/dist/dts/indexing/searcher.d.ts +47 -0
  194. package/dist/dts/indexing/writer.d.ts +22 -0
  195. package/dist/dts/integrations/index.d.ts +2 -0
  196. package/dist/dts/integrations/integrations.d.ts +118 -0
  197. package/dist/dts/io/bytes.d.ts +56 -0
  198. package/dist/dts/io/files.d.ts +261 -0
  199. package/dist/dts/io/image.d.ts +22 -0
  200. package/dist/dts/io/index.d.ts +10 -0
  201. package/dist/dts/io/streams.d.ts +172 -0
  202. package/dist/dts/io/zip.d.ts +178 -0
  203. package/dist/dts/job/decorators.d.ts +11 -0
  204. package/dist/dts/job/index.d.ts +4 -0
  205. package/dist/dts/job/scheduler.d.ts +250 -0
  206. package/dist/dts/junit/index.d.ts +1 -0
  207. package/dist/dts/junit/junit.d.ts +50 -0
  208. package/dist/dts/kafka/consumer.d.ts +48 -0
  209. package/dist/dts/kafka/index.d.ts +4 -0
  210. package/dist/dts/kafka/producer.d.ts +50 -0
  211. package/dist/dts/log/index.d.ts +2 -0
  212. package/dist/dts/log/logging.d.ts +102 -0
  213. package/dist/dts/mail/client.d.ts +90 -0
  214. package/dist/dts/mail/index.d.ts +2 -0
  215. package/dist/dts/messaging/consumer.d.ts +61 -0
  216. package/dist/dts/messaging/decorators.d.ts +11 -0
  217. package/dist/dts/messaging/index.d.ts +6 -0
  218. package/dist/dts/messaging/producer.d.ts +59 -0
  219. package/dist/dts/mongodb/client.d.ts +367 -0
  220. package/dist/dts/mongodb/dao.d.ts +24 -0
  221. package/dist/dts/mongodb/index.d.ts +2 -0
  222. package/dist/dts/net/decorators.d.ts +11 -0
  223. package/dist/dts/net/index.d.ts +6 -0
  224. package/dist/dts/net/soap.d.ts +115 -0
  225. package/dist/dts/net/websockets.d.ts +100 -0
  226. package/dist/dts/net/wrappers/onClose.d.ts +0 -0
  227. package/dist/dts/net/wrappers/onError.d.ts +0 -0
  228. package/dist/dts/net/wrappers/onMessage.d.ts +0 -0
  229. package/dist/dts/net/wrappers/onOpen.d.ts +0 -0
  230. package/dist/dts/pdf/index.d.ts +2 -0
  231. package/dist/dts/pdf/pdf.d.ts +72 -0
  232. package/dist/dts/platform/command.d.ts +41 -0
  233. package/dist/dts/platform/engines.d.ts +35 -0
  234. package/dist/dts/platform/index.d.ts +16 -0
  235. package/dist/dts/platform/lifecycle.d.ts +22 -0
  236. package/dist/dts/platform/os.d.ts +23 -0
  237. package/dist/dts/platform/problems.d.ts +114 -0
  238. package/dist/dts/platform/registry.d.ts +227 -0
  239. package/dist/dts/platform/repository.d.ts +354 -0
  240. package/dist/dts/platform/workspace.d.ts +421 -0
  241. package/dist/dts/qldb/index.d.ts +2 -0
  242. package/dist/dts/qldb/qldb.d.ts +1 -0
  243. package/dist/dts/rabbitmq/consumer.d.ts +25 -0
  244. package/dist/dts/rabbitmq/index.d.ts +4 -0
  245. package/dist/dts/rabbitmq/producer.d.ts +15 -0
  246. package/dist/dts/redis/client.d.ts +134 -0
  247. package/dist/dts/redis/index.d.ts +2 -0
  248. package/dist/dts/security/decorators.d.ts +4 -0
  249. package/dist/dts/security/index.d.ts +5 -0
  250. package/dist/dts/security/oauth.d.ts +39 -0
  251. package/dist/dts/security/user.d.ts +51 -0
  252. package/dist/dts/template/engines.d.ts +98 -0
  253. package/dist/dts/template/index.d.ts +2 -0
  254. package/dist/dts/utils/alphanumeric.d.ts +39 -0
  255. package/dist/dts/utils/base64.d.ts +48 -0
  256. package/dist/dts/utils/converter.d.ts +44 -0
  257. package/dist/dts/utils/digest.d.ts +50 -0
  258. package/dist/dts/utils/escape.d.ts +110 -0
  259. package/dist/dts/utils/hex.d.ts +48 -0
  260. package/dist/dts/utils/index.d.ts +23 -0
  261. package/dist/dts/utils/jsonpath.d.ts +22 -0
  262. package/dist/dts/utils/qrcode.d.ts +16 -0
  263. package/dist/dts/utils/url.d.ts +50 -0
  264. package/dist/dts/utils/utf8.d.ts +33 -0
  265. package/dist/dts/utils/uuid.d.ts +21 -0
  266. package/dist/dts/utils/xml.d.ts +22 -0
  267. package/dist/esm/bpm/deployer.mjs +38 -0
  268. package/dist/esm/bpm/index.mjs +15 -0
  269. package/dist/esm/bpm/process.mjs +617 -0
  270. package/dist/esm/bpm/tasks.mjs +954 -0
  271. package/dist/esm/bpm/values.mjs +63 -0
  272. package/dist/esm/cache/cache.mjs +45 -0
  273. package/dist/esm/cache/index.mjs +6 -0
  274. package/dist/esm/cms/cmis.mjs +660 -0
  275. package/dist/esm/cms/index.mjs +6 -0
  276. package/dist/esm/component/decorators.mjs +107 -0
  277. package/dist/esm/component/index.mjs +6 -0
  278. package/dist/esm/core/configurations.mjs +91 -0
  279. package/dist/esm/core/context.mjs +28 -0
  280. package/dist/esm/core/env.mjs +26 -0
  281. package/dist/esm/core/globals.mjs +35 -0
  282. package/dist/esm/core/index.mjs +15 -0
  283. package/dist/esm/db/dao.mjs +775 -0
  284. package/dist/esm/db/database.mjs +885 -0
  285. package/dist/esm/db/decorators.mjs +148 -0
  286. package/dist/esm/db/index.mjs +42 -0
  287. package/dist/esm/db/insert.mjs +32 -0
  288. package/dist/esm/db/orm.mjs +225 -0
  289. package/dist/esm/db/ormstatements.mjs +223 -0
  290. package/dist/esm/db/procedure.mjs +93 -0
  291. package/dist/esm/db/query.mjs +38 -0
  292. package/dist/esm/db/repository.mjs +129 -0
  293. package/dist/esm/db/sequence.mjs +40 -0
  294. package/dist/esm/db/sql.mjs +497 -0
  295. package/dist/esm/db/store.mjs +153 -0
  296. package/dist/esm/db/translator.mjs +81 -0
  297. package/dist/esm/db/update.mjs +24 -0
  298. package/dist/esm/etcd/client.mjs +155 -0
  299. package/dist/esm/etcd/index.mjs +6 -0
  300. package/dist/esm/extensions/decorators.mjs +21 -0
  301. package/dist/esm/extensions/extensions.mjs +89 -0
  302. package/dist/esm/extensions/index.mjs +9 -0
  303. package/dist/esm/git/client.mjs +258 -0
  304. package/dist/esm/git/index.mjs +6 -0
  305. package/dist/esm/http/client-async.mjs +205 -0
  306. package/dist/esm/http/client.mjs +126 -0
  307. package/dist/esm/http/decorators.mjs +47 -0
  308. package/dist/esm/http/errors/ForbiddenError.mjs +22 -0
  309. package/dist/esm/http/errors/ValidationError.mjs +22 -0
  310. package/dist/esm/http/errors.mjs +7 -0
  311. package/dist/esm/http/index.mjs +29 -0
  312. package/dist/esm/http/request.mjs +262 -0
  313. package/dist/esm/http/response.mjs +433 -0
  314. package/dist/esm/http/rs/resource-common.mjs +13 -0
  315. package/dist/esm/http/rs/resource-http-controller.mjs +287 -0
  316. package/dist/esm/http/rs/resource-mappings.mjs +111 -0
  317. package/dist/esm/http/rs/resource-method.mjs +199 -0
  318. package/dist/esm/http/rs/resource.mjs +213 -0
  319. package/dist/esm/http/rs.mjs +12 -0
  320. package/dist/esm/http/session.mjs +105 -0
  321. package/dist/esm/http/upload.mjs +125 -0
  322. package/dist/esm/http/utils.mjs +87 -0
  323. package/dist/esm/index.mjs +1 -0
  324. package/dist/esm/indexing/index.mjs +9 -0
  325. package/dist/esm/indexing/searcher.mjs +51 -0
  326. package/dist/esm/indexing/writer.mjs +26 -0
  327. package/dist/esm/integrations/index.mjs +6 -0
  328. package/dist/esm/integrations/integrations.mjs +36 -0
  329. package/dist/esm/io/bytes.mjs +82 -0
  330. package/dist/esm/io/files.mjs +325 -0
  331. package/dist/esm/io/image.mjs +24 -0
  332. package/dist/esm/io/index.mjs +18 -0
  333. package/dist/esm/io/streams.mjs +224 -0
  334. package/dist/esm/io/zip.mjs +232 -0
  335. package/dist/esm/job/decorators.mjs +21 -0
  336. package/dist/esm/job/index.mjs +9 -0
  337. package/dist/esm/job/scheduler.mjs +328 -0
  338. package/dist/esm/junit/index.mjs +2 -0
  339. package/dist/esm/junit/junit.mjs +48 -0
  340. package/dist/esm/kafka/consumer.mjs +51 -0
  341. package/dist/esm/kafka/index.mjs +9 -0
  342. package/dist/esm/kafka/producer.mjs +51 -0
  343. package/dist/esm/log/index.mjs +6 -0
  344. package/dist/esm/log/logging.mjs +155 -0
  345. package/dist/esm/mail/client.mjs +134 -0
  346. package/dist/esm/mail/index.mjs +6 -0
  347. package/dist/esm/messaging/consumer.mjs +64 -0
  348. package/dist/esm/messaging/decorators.mjs +21 -0
  349. package/dist/esm/messaging/index.mjs +12 -0
  350. package/dist/esm/messaging/producer.mjs +62 -0
  351. package/dist/esm/mongodb/client.mjs +608 -0
  352. package/dist/esm/mongodb/dao.mjs +360 -0
  353. package/dist/esm/mongodb/index.mjs +7 -0
  354. package/dist/esm/net/decorators.mjs +21 -0
  355. package/dist/esm/net/index.mjs +12 -0
  356. package/dist/esm/net/soap.mjs +209 -0
  357. package/dist/esm/net/websockets.mjs +132 -0
  358. package/dist/esm/net/wrappers/onClose.mjs +2 -0
  359. package/dist/esm/net/wrappers/onError.mjs +2 -0
  360. package/dist/esm/net/wrappers/onMessage.mjs +2 -0
  361. package/dist/esm/net/wrappers/onOpen.mjs +2 -0
  362. package/dist/esm/pdf/index.mjs +6 -0
  363. package/dist/esm/pdf/pdf.mjs +141 -0
  364. package/dist/esm/platform/command.mjs +28 -0
  365. package/dist/esm/platform/engines.mjs +51 -0
  366. package/dist/esm/platform/index.mjs +27 -0
  367. package/dist/esm/platform/lifecycle.mjs +30 -0
  368. package/dist/esm/platform/os.mjs +32 -0
  369. package/dist/esm/platform/problems.mjs +108 -0
  370. package/dist/esm/platform/registry.mjs +300 -0
  371. package/dist/esm/platform/repository.mjs +479 -0
  372. package/dist/esm/platform/workspace.mjs +555 -0
  373. package/dist/esm/qldb/index.mjs +6 -0
  374. package/dist/esm/qldb/qldb.mjs +5 -0
  375. package/dist/esm/rabbitmq/consumer.mjs +31 -0
  376. package/dist/esm/rabbitmq/index.mjs +9 -0
  377. package/dist/esm/rabbitmq/producer.mjs +19 -0
  378. package/dist/esm/redis/client.mjs +171 -0
  379. package/dist/esm/redis/index.mjs +6 -0
  380. package/dist/esm/security/decorators.mjs +29 -0
  381. package/dist/esm/security/index.mjs +10 -0
  382. package/dist/esm/security/oauth.mjs +56 -0
  383. package/dist/esm/security/user.mjs +69 -0
  384. package/dist/esm/template/engines.mjs +120 -0
  385. package/dist/esm/template/index.mjs +6 -0
  386. package/dist/esm/utils/alphanumeric.mjs +88 -0
  387. package/dist/esm/utils/base64.mjs +85 -0
  388. package/dist/esm/utils/converter.mjs +59 -0
  389. package/dist/esm/utils/digest.mjs +148 -0
  390. package/dist/esm/utils/escape.mjs +141 -0
  391. package/dist/esm/utils/hex.mjs +85 -0
  392. package/dist/esm/utils/index.mjs +38 -0
  393. package/dist/esm/utils/jsonpath.mjs +470 -0
  394. package/dist/esm/utils/qrcode.mjs +22 -0
  395. package/dist/esm/utils/url.mjs +63 -0
  396. package/dist/esm/utils/utf8.mjs +42 -0
  397. package/dist/esm/utils/uuid.mjs +29 -0
  398. package/dist/esm/utils/xml.mjs +38 -0
  399. package/package.json +58 -0
@@ -0,0 +1,452 @@
1
+ var __defProp = Object.defineProperty;
2
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
3
+ var __getOwnPropNames = Object.getOwnPropertyNames;
4
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
5
+ var __export = (target, all) => {
6
+ for (var name in all)
7
+ __defProp(target, name, { get: all[name], enumerable: true });
8
+ };
9
+ var __copyProps = (to, from, except, desc) => {
10
+ if (from && typeof from === "object" || typeof from === "function") {
11
+ for (let key of __getOwnPropNames(from))
12
+ if (!__hasOwnProp.call(to, key) && key !== except)
13
+ __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
14
+ }
15
+ return to;
16
+ };
17
+ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
18
+ var response_exports = {};
19
+ __export(response_exports, {
20
+ Response: () => Response
21
+ });
22
+ module.exports = __toCommonJS(response_exports);
23
+ var import_streams = require("@aerokit/sdk/io/streams");
24
+ const HttpResponseFacade = Java.type("org.eclipse.dirigible.components.api.http.HttpResponseFacade");
25
+ const OutputStreamWriter = Java.type("java.io.OutputStreamWriter");
26
+ const StandardCharsets = Java.type("java.nio.charset.StandardCharsets");
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 {
156
+ /**
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)];
214
+ }
215
+ };
216
+ }
217
+ /**
218
+ * Checks if the response façade is currently valid or connected to an active request context.
219
+ * @returns True if valid, false otherwise.
220
+ */
221
+ static isValid() {
222
+ return HttpResponseFacade.isValid();
223
+ }
224
+ /**
225
+ * Serializes a JavaScript object to JSON, sets the `Content-Type: application/json` header,
226
+ * and writes the JSON string to the response output stream.
227
+ * @param obj The JavaScript object to be serialized and sent.
228
+ */
229
+ static json(obj) {
230
+ Response.addHeader("Content-Type", "application/json");
231
+ const objJson = JSON.stringify(obj);
232
+ Response.print(objJson);
233
+ }
234
+ /**
235
+ * Writes a string of text to the response body using **UTF-8** encoding.
236
+ * Note: This method automatically handles flushing the output stream.
237
+ * @param text The string content to write.
238
+ */
239
+ static print(text) {
240
+ text = text && text.toString() || "";
241
+ const out = Response.getOutputStream().native;
242
+ const writer = new OutputStreamWriter(out, StandardCharsets.UTF_8);
243
+ writer.write(text);
244
+ writer.flush();
245
+ }
246
+ /**
247
+ * Writes a string of text followed by a newline character (`\n`) to the response body
248
+ * using **UTF-8** encoding.
249
+ * @param text The string content to write.
250
+ */
251
+ static println(text) {
252
+ text = text && text.toString() || "";
253
+ const out = Response.getOutputStream().native;
254
+ const writer = new OutputStreamWriter(out, StandardCharsets.UTF_8);
255
+ writer.write(text);
256
+ writer.write("\n");
257
+ writer.flush();
258
+ }
259
+ /**
260
+ * Writes an array of bytes directly to the response output stream, typically used for binary data.
261
+ * @param bytes The array of bytes to write.
262
+ */
263
+ static write(bytes) {
264
+ if (!bytes) {
265
+ bytes = [];
266
+ }
267
+ HttpResponseFacade.write(bytes);
268
+ }
269
+ /**
270
+ * Checks if the response headers and status have already been sent to the client.
271
+ * @returns True if the response is committed, false otherwise.
272
+ */
273
+ static isCommitted() {
274
+ return HttpResponseFacade.isCommitted();
275
+ }
276
+ /**
277
+ * Sets the value of the `Content-Type` header.
278
+ * @param contentType The MIME type string (e.g., 'text/html', 'application/pdf').
279
+ */
280
+ static setContentType(contentType) {
281
+ HttpResponseFacade.setContentType(contentType);
282
+ }
283
+ /**
284
+ * Forces any buffered output to be written to the client.
285
+ */
286
+ static flush() {
287
+ HttpResponseFacade.flush();
288
+ }
289
+ /**
290
+ * Closes the response output stream.
291
+ */
292
+ static close() {
293
+ HttpResponseFacade.close();
294
+ }
295
+ /**
296
+ * Adds a cookie to the response. The cookie object is serialized to JSON before being passed
297
+ * to the underlying Java facade.
298
+ * @param cookie The cookie definition object.
299
+ */
300
+ static addCookie(cookie) {
301
+ HttpResponseFacade.addCookie(JSON.stringify(cookie));
302
+ }
303
+ /**
304
+ * Checks if a response header with the specified name has already been set.
305
+ * @param name The name of the header.
306
+ * @returns True if the header exists, false otherwise.
307
+ */
308
+ static containsHeader(name) {
309
+ return HttpResponseFacade.containsHeader(name);
310
+ }
311
+ /**
312
+ * Encodes a URL for use in redirects or forms, including session information if necessary.
313
+ * @param url The URL to encode.
314
+ * @returns The encoded URL string.
315
+ */
316
+ static encodeURL(url) {
317
+ return HttpResponseFacade.encodeURL(url);
318
+ }
319
+ /**
320
+ * Gets the character encoding used for the response body.
321
+ * @returns The character encoding string.
322
+ */
323
+ static getCharacterEncoding() {
324
+ return HttpResponseFacade.getCharacterEncoding();
325
+ }
326
+ /**
327
+ * Encodes a URL for use in the `Location` header of a redirect response.
328
+ * @param url The redirect URL to encode.
329
+ * @returns The encoded redirect URL string.
330
+ */
331
+ static encodeRedirectURL(url) {
332
+ return HttpResponseFacade.encodeRedirectURL(url);
333
+ }
334
+ /**
335
+ * Gets the current `Content-Type` header value.
336
+ * @returns The content type string.
337
+ */
338
+ static getContentType() {
339
+ return HttpResponseFacade.getContentType();
340
+ }
341
+ /**
342
+ * Sends an HTTP error response to the client with the specified status code and optional message.
343
+ * This bypasses the normal response body writing process.
344
+ * @param status The HTTP status code (e.g., 404, 500).
345
+ * @param message An optional message to include in the error response.
346
+ */
347
+ static sendError(status, message) {
348
+ HttpResponseFacade.sendError(status, message);
349
+ }
350
+ /**
351
+ * Sets the character encoding to be used for the response body (e.g., 'UTF-8').
352
+ * @param charset The character set string.
353
+ */
354
+ static setCharacterEncoding(charset) {
355
+ HttpResponseFacade.setCharacterEncoding(charset);
356
+ }
357
+ /**
358
+ * Sends a redirect response (status code 302 by default) to the client.
359
+ * @param location The new URL to redirect the client to.
360
+ */
361
+ static sendRedirect(location) {
362
+ HttpResponseFacade.sendRedirect(location);
363
+ }
364
+ /**
365
+ * Sets the `Content-Length` header for the response.
366
+ * @param length The size of the response body in bytes.
367
+ */
368
+ static setContentLength(length) {
369
+ HttpResponseFacade.setContentLength(length);
370
+ }
371
+ /**
372
+ * Sets a response header with the given name and value. If the header already exists, its value is overwritten.
373
+ * @param name The name of the header.
374
+ * @param value The value of the header.
375
+ */
376
+ static setHeader(name, value) {
377
+ HttpResponseFacade.setHeader(name, value);
378
+ }
379
+ /**
380
+ * Adds a response header with the given name and value. If the header already exists, a second header with the same name is added.
381
+ * @param name The name of the header.
382
+ * @param value The value of the header.
383
+ */
384
+ static addHeader(name, value) {
385
+ HttpResponseFacade.addHeader(name, value);
386
+ }
387
+ /**
388
+ * Sets the HTTP status code for the response.
389
+ * @param status The integer status code (e.g., 200, 404).
390
+ */
391
+ static setStatus(status) {
392
+ HttpResponseFacade.setStatus(status);
393
+ }
394
+ /**
395
+ * Clears all buffers, status code, and headers from the response, allowing a new response to be generated.
396
+ * This is only possible if the response has not yet been committed.
397
+ */
398
+ static reset() {
399
+ HttpResponseFacade.reset();
400
+ }
401
+ /**
402
+ * Gets the value of a specific header. If multiple headers with the same name exist, it returns the first one.
403
+ * @param name The name of the header.
404
+ * @returns The header value string.
405
+ */
406
+ static getHeader(name) {
407
+ return HttpResponseFacade.getHeader(name);
408
+ }
409
+ /**
410
+ * Sets the locale for the response, which may affect language and date/time formatting.
411
+ * @param language The language code (e.g., 'en', 'fr').
412
+ * @param country The optional country code (e.g., 'US', 'GB').
413
+ * @param variant The optional variant code.
414
+ */
415
+ static setLocale(language, country, variant) {
416
+ return HttpResponseFacade.setLocale(language, country, variant);
417
+ }
418
+ /**
419
+ * Gets all header values for a specific header name as an array of strings.
420
+ * @param name The name of the header.
421
+ * @returns An array of header values.
422
+ */
423
+ static getHeaders(name) {
424
+ return JSON.parse(HttpResponseFacade.getHeaders(name));
425
+ }
426
+ /**
427
+ * Gets the names of all headers that have been set on the response.
428
+ * @returns An array of header names.
429
+ */
430
+ static getHeaderNames() {
431
+ return JSON.parse(HttpResponseFacade.getHeaderNames());
432
+ }
433
+ /**
434
+ * Gets the currently set locale string for the response.
435
+ * @returns The locale string.
436
+ */
437
+ static getLocale() {
438
+ return HttpResponseFacade.getLocale();
439
+ }
440
+ /**
441
+ * Gets the underlying output stream object, wrapped in the SDK's `OutputStream` class.
442
+ * This is useful for writing raw or large amounts of data.
443
+ * @returns The output stream object.
444
+ */
445
+ static getOutputStream() {
446
+ return new import_streams.OutputStream(HttpResponseFacade.getOutputStream());
447
+ }
448
+ }
449
+ if (typeof module !== "undefined") {
450
+ module.exports = Response;
451
+ }
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": "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",
  "names": []
}

@@ -0,0 +1,32 @@
1
+ var __defProp = Object.defineProperty;
2
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
3
+ var __getOwnPropNames = Object.getOwnPropertyNames;
4
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
5
+ var __export = (target, all) => {
6
+ for (var name in all)
7
+ __defProp(target, name, { get: all[name], enumerable: true });
8
+ };
9
+ var __copyProps = (to, from, except, desc) => {
10
+ if (from && typeof from === "object" || typeof from === "function") {
11
+ for (let key of __getOwnPropNames(from))
12
+ if (!__hasOwnProp.call(to, key) && key !== except)
13
+ __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
14
+ }
15
+ return to;
16
+ };
17
+ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
18
+ var resource_common_exports = {};
19
+ __export(resource_common_exports, {
20
+ handlerFunction: () => handlerFunction
21
+ });
22
+ module.exports = __toCommonJS(resource_common_exports);
23
+ function handlerFunction(thiz, configuration, sHandlerFuncName, fHandler) {
24
+ if (fHandler !== void 0) {
25
+ if (typeof fHandler !== "function" && typeof fHandler !== "string") {
26
+ throw new Error(`Invalid argument: ${sHandlerFuncName} method argument must be a valid javascript function or string, but instead is ${typeof fHandler}`);
27
+ }
28
+ configuration[sHandlerFuncName] = fHandler;
29
+ }
30
+ return thiz;
31
+ }
32
+ //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vLi4vLi4vc3JjL2h0dHAvcnMvcmVzb3VyY2UtY29tbW9uLnRzIl0sCiAgInNvdXJjZXNDb250ZW50IjogWyIvKipcbiAqIENvbW1tb24gZnVuY3Rpb24gZm9yIGluaXRpYWxpem5nIHRoZSBjYWxsYmFjayBmdW5jdGlvbnMgaW4gdGhlIFJlc291cmNlTWV0aG9kIGluc3RhbmNlcy5cbiAqXG4gKiBAcGFyYW0gdGhpeiBUaGUgUmVzb3VyY2VNZXRob2QgaW5zdGFuY2UgdG8gd2hpY2ggdGhlIGZ1bmN0aW9uIGlzIGJvdW5kIChvciBSZXNvdXJjZSBpbnN0YW5jZSBpbiB0aGUgY2FzZSBvZiByZWRpcmVjdCkuXG4gKiBAcGFyYW0gY29uZmlndXJhdGlvbiBUaGUgY29uZmlndXJhdGlvbiBvYmplY3Qgd2hlcmUgdGhlIGhhbmRsZXIgd2lsbCBiZSBhdHRhY2hlZC5cbiAqIEBwYXJhbSBzSGFuZGxlckZ1bmNOYW1lIFRoZSBuYW1lIG9mIHRoZSBmdW5jdGlvbiB0aGF0IHdpbGwgYmUgYXR0YWNoZWQgdG8gdGhlIHJlc291cmNlIG1hcHBpbmdzIGNvbmZpZ3VyYXRpb24gKGUuZy4sICdzZXJ2ZScsICdyZWRpcmVjdCcpLlxuICogQHBhcmFtIGZIYW5kbGVyIFRoZSBoYW5kbGVyIGZ1bmN0aW9uIG9yIHZhbHVlIHRoYXQgd2lsbCBiZSBhdHRhY2hlZCB0byB0aGUgcmVzb3VyY2UgbWFwcGluZ3MgY29uZmlndXJhdGlvbi5cbiAqIEByZXR1cm5zIFRoZSBpbnN0YW5jZSBwYXNzZWQgaW4gYXMgJ3RoaXonIGZvciBtZXRob2QgY2hhaW5pbmcuXG4gKiBAcHJpdmF0ZVxuICovXG5leHBvcnQgZnVuY3Rpb24gaGFuZGxlckZ1bmN0aW9uKHRoaXo6IGFueSwgY29uZmlndXJhdGlvbjogYW55LCBzSGFuZGxlckZ1bmNOYW1lOiBzdHJpbmcsIGZIYW5kbGVyOiBGdW5jdGlvbiB8IHN0cmluZyk6IGFueSB7XG4gICAgaWYgKGZIYW5kbGVyICE9PSB1bmRlZmluZWQpIHtcbiAgICAgICAgLy8gSWYgZkhhbmRsZXIgaXMgYSBzdHJpbmcgKG9ubHkgdXNlZCBmb3IgJ3JlZGlyZWN0JyksIGl0J3MgdmFsaWQuXG4gICAgICAgIC8vIElmIGZIYW5kbGVyIGlzIGEgZnVuY3Rpb24sIGl0J3MgdmFsaWQuXG4gICAgICAgIGlmICh0eXBlb2YgZkhhbmRsZXIgIT09ICdmdW5jdGlvbicgJiYgdHlwZW9mIGZIYW5kbGVyICE9PSAnc3RyaW5nJykge1xuICAgICAgICAgICAgdGhyb3cgbmV3IEVycm9yKGBJbnZhbGlkIGFyZ3VtZW50OiAke3NIYW5kbGVyRnVuY05hbWV9IG1ldGhvZCBhcmd1bWVudCBtdXN0IGJlIGEgdmFsaWQgamF2YXNjcmlwdCBmdW5jdGlvbiBvciBzdHJpbmcsIGJ1dCBpbnN0ZWFkIGlzICR7dHlwZW9mIGZIYW5kbGVyfWApO1xuICAgICAgICB9XG4gICAgICAgIGNvbmZpZ3VyYXRpb25bc0hhbmRsZXJGdW5jTmFtZV0gPSBmSGFuZGxlcjtcbiAgICB9XG5cbiAgICAvLyBSZXR1cm4gdGhlIGNoYWluaW5nIG9iamVjdCAoUmVzb3VyY2Ugb3IgUmVzb3VyY2VNZXRob2QpXG4gICAgcmV0dXJuIHRoaXo7XG59Il0sCiAgIm1hcHBpbmdzIjogIjs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBVU8sU0FBUyxnQkFBZ0IsTUFBVyxlQUFvQixrQkFBMEIsVUFBa0M7QUFDdkgsTUFBSSxhQUFhLFFBQVc7QUFHeEIsUUFBSSxPQUFPLGFBQWEsY0FBYyxPQUFPLGFBQWEsVUFBVTtBQUNoRSxZQUFNLElBQUksTUFBTSxxQkFBcUIsZ0JBQWdCLGtGQUFrRixPQUFPLFFBQVEsRUFBRTtBQUFBLElBQzVKO0FBQ0Esa0JBQWMsZ0JBQWdCLElBQUk7QUFBQSxFQUN0QztBQUdBLFNBQU87QUFDWDsiLAogICJuYW1lcyI6IFtdCn0K