zephyr-agent 0.0.0-canary-20241122013202 → 0.0.0-canary-20241122025316

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 (281) hide show
  1. package/dist/index.d.ts +13 -19
  2. package/dist/index.js +36 -38
  3. package/dist/index.js.map +1 -1
  4. package/dist/lib/auth/login.d.ts +2 -1
  5. package/dist/lib/auth/login.js +36 -18
  6. package/dist/lib/auth/login.js.map +1 -1
  7. package/dist/lib/auth/websocket.js.map +1 -1
  8. package/dist/lib/build-context/find-nearest-package-json.d.ts +4 -0
  9. package/dist/lib/build-context/find-nearest-package-json.js +41 -0
  10. package/dist/lib/build-context/find-nearest-package-json.js.map +1 -0
  11. package/dist/lib/build-context/fs-cache-for-package-json.d.ts +3 -0
  12. package/dist/lib/build-context/fs-cache-for-package-json.js +20 -0
  13. package/dist/lib/build-context/fs-cache-for-package-json.js.map +1 -0
  14. package/dist/lib/build-context/ze-package-json.type.d.ts +11 -0
  15. package/dist/lib/{upload/interfaces.js → build-context/ze-package-json.type.js} +1 -1
  16. package/dist/lib/build-context/ze-package-json.type.js.map +1 -0
  17. package/dist/lib/{context-utils → build-context}/ze-util-get-git-info.d.ts +2 -2
  18. package/dist/lib/{context-utils → build-context}/ze-util-get-git-info.js +14 -10
  19. package/dist/lib/build-context/ze-util-get-git-info.js.map +1 -0
  20. package/dist/lib/build-context/ze-util-read-package-json.d.ts +2 -0
  21. package/dist/lib/build-context/ze-util-read-package-json.js +39 -0
  22. package/dist/lib/build-context/ze-util-read-package-json.js.map +1 -0
  23. package/dist/lib/build-context/ze-util-verification.d.ts +11 -0
  24. package/dist/lib/{context-utils → build-context}/ze-util-verification.js +12 -9
  25. package/dist/lib/build-context/ze-util-verification.js.map +1 -0
  26. package/dist/lib/deployment/cloudflare.strategy.d.ts +2 -0
  27. package/dist/lib/deployment/cloudflare.strategy.js +18 -0
  28. package/dist/lib/deployment/cloudflare.strategy.js.map +1 -0
  29. package/dist/lib/deployment/fastly.strategy.d.ts +2 -0
  30. package/dist/lib/deployment/fastly.strategy.js +19 -0
  31. package/dist/lib/deployment/fastly.strategy.js.map +1 -0
  32. package/dist/lib/deployment/get-upload-strategy.d.ts +5 -0
  33. package/dist/lib/deployment/get-upload-strategy.js +19 -0
  34. package/dist/lib/deployment/get-upload-strategy.js.map +1 -0
  35. package/dist/lib/deployment/index.js.map +1 -0
  36. package/dist/lib/deployment/netlify.strategy.d.ts +2 -0
  37. package/dist/lib/deployment/netlify.strategy.js +18 -0
  38. package/dist/lib/deployment/netlify.strategy.js.map +1 -0
  39. package/dist/lib/deployment/upload-base/upload-assets.d.ts +7 -0
  40. package/dist/lib/deployment/upload-base/upload-assets.js +18 -0
  41. package/dist/lib/deployment/upload-base/upload-assets.js.map +1 -0
  42. package/dist/lib/deployment/upload-base/upload-build-stats-and-enable-envs.d.ts +8 -0
  43. package/dist/lib/deployment/upload-base/upload-build-stats-and-enable-envs.js +11 -0
  44. package/dist/lib/deployment/upload-base/upload-build-stats-and-enable-envs.js.map +1 -0
  45. package/dist/lib/edge-actions/index.js.map +1 -0
  46. package/dist/lib/{actions → edge-actions}/ze-enable-snapshot-on-edge.d.ts +1 -1
  47. package/dist/lib/{actions → edge-actions}/ze-enable-snapshot-on-edge.js +9 -7
  48. package/dist/lib/edge-actions/ze-enable-snapshot-on-edge.js.map +1 -0
  49. package/dist/lib/{actions → edge-actions}/ze-enable-snapshot-on-pages.d.ts +1 -1
  50. package/dist/lib/{actions → edge-actions}/ze-enable-snapshot-on-pages.js +9 -7
  51. package/dist/lib/edge-actions/ze-enable-snapshot-on-pages.js.map +1 -0
  52. package/dist/lib/edge-actions/ze-upload-assets.d.ts +3 -0
  53. package/dist/lib/{actions → edge-actions}/ze-upload-assets.js +16 -14
  54. package/dist/lib/edge-actions/ze-upload-assets.js.map +1 -0
  55. package/dist/lib/{actions → edge-actions}/ze-upload-build-stats.js +10 -5
  56. package/dist/lib/edge-actions/ze-upload-build-stats.js.map +1 -0
  57. package/dist/lib/edge-actions/ze-upload-snapshot.d.ts +7 -0
  58. package/dist/lib/edge-actions/ze-upload-snapshot.js +34 -0
  59. package/dist/lib/edge-actions/ze-upload-snapshot.js.map +1 -0
  60. package/dist/lib/{dvcs → edge-hash-list}/distributed-hash-control.js +8 -6
  61. package/dist/lib/edge-hash-list/distributed-hash-control.js.map +1 -0
  62. package/dist/lib/{dvcs → edge-hash-list}/get-cache-key.js +1 -1
  63. package/dist/lib/edge-hash-list/get-cache-key.js.map +1 -0
  64. package/dist/lib/{dvcs → edge-hash-list}/get-missing-assets.d.ts +1 -1
  65. package/dist/lib/{dvcs → edge-hash-list}/get-missing-assets.js +3 -0
  66. package/dist/lib/edge-hash-list/get-missing-assets.js.map +1 -0
  67. package/dist/lib/{application-configuration → edge-requests}/get-application-configuration.d.ts +4 -3
  68. package/dist/lib/{application-configuration → edge-requests}/get-application-configuration.js +21 -13
  69. package/dist/lib/edge-requests/get-application-configuration.js.map +1 -0
  70. package/dist/lib/{ze-api-requests → edge-requests}/get-application-hash-list.d.ts +1 -1
  71. package/dist/lib/{ze-api-requests → edge-requests}/get-application-hash-list.js +6 -5
  72. package/dist/lib/edge-requests/get-application-hash-list.js.map +1 -0
  73. package/dist/lib/{ze-api-requests → edge-requests}/get-build-id.js +9 -5
  74. package/dist/lib/edge-requests/get-build-id.js.map +1 -0
  75. package/dist/lib/errors/codes.d.ts +312 -0
  76. package/dist/lib/errors/codes.js +410 -0
  77. package/dist/lib/errors/codes.js.map +1 -0
  78. package/dist/lib/{custom-errors → errors}/configuration-error.js +2 -2
  79. package/dist/lib/errors/configuration-error.js.map +1 -0
  80. package/dist/lib/errors/index.d.ts +2 -0
  81. package/dist/lib/errors/index.js +6 -0
  82. package/dist/lib/errors/index.js.map +1 -0
  83. package/dist/lib/errors/package-json-not-found-error.js.map +1 -0
  84. package/dist/lib/errors/package-json-not-valid-error.js.map +1 -0
  85. package/dist/lib/errors/package-not-a-json-error.js.map +1 -0
  86. package/dist/lib/errors/zephyr-error.d.ts +524 -0
  87. package/dist/lib/errors/zephyr-error.js +162 -0
  88. package/dist/lib/errors/zephyr-error.js.map +1 -0
  89. package/dist/lib/hacks/resolve-index-html.js +3 -3
  90. package/dist/lib/hacks/resolve-index-html.js.map +1 -1
  91. package/dist/lib/{upload → http}/upload-envs.d.ts +1 -1
  92. package/dist/lib/{upload → http}/upload-envs.js +7 -5
  93. package/dist/lib/http/upload-envs.js.map +1 -0
  94. package/dist/lib/{upload → http}/upload-file.d.ts +1 -1
  95. package/dist/lib/http/upload-file.js +86 -0
  96. package/dist/lib/http/upload-file.js.map +1 -0
  97. package/dist/lib/{upload → http}/upload-snapshot.d.ts +1 -1
  98. package/dist/lib/{upload → http}/upload-snapshot.js +8 -6
  99. package/dist/lib/http/upload-snapshot.js.map +1 -0
  100. package/dist/lib/http/ze-http-request.d.ts +19 -0
  101. package/dist/lib/http/ze-http-request.js +165 -0
  102. package/dist/lib/http/ze-http-request.js.map +1 -0
  103. package/dist/lib/logging/debug-enabled.d.ts +1 -0
  104. package/dist/lib/logging/debug-enabled.js +9 -0
  105. package/dist/lib/logging/debug-enabled.js.map +1 -0
  106. package/dist/lib/logging/debug.d.ts +23 -0
  107. package/dist/lib/logging/debug.js +41 -0
  108. package/dist/lib/logging/debug.js.map +1 -0
  109. package/dist/lib/logging/error-codes-messages.d.ts +206 -0
  110. package/dist/lib/logging/error-codes-messages.js +203 -0
  111. package/dist/lib/logging/error-codes-messages.js.map +1 -0
  112. package/dist/lib/logging/error-formatted-message.d.ts +5 -0
  113. package/dist/lib/logging/error-formatted-message.js +36 -0
  114. package/dist/lib/logging/error-formatted-message.js.map +1 -0
  115. package/dist/lib/logging/index.d.ts +1 -0
  116. package/dist/lib/logging/index.js +6 -0
  117. package/dist/lib/logging/index.js.map +1 -0
  118. package/dist/lib/logging/picocolor.d.ts +43 -0
  119. package/dist/lib/logging/picocolor.js +87 -0
  120. package/dist/lib/logging/picocolor.js.map +1 -0
  121. package/dist/lib/{remote-logs → logging}/ze-log-event.d.ts +8 -3
  122. package/dist/lib/{remote-logs → logging}/ze-log-event.js +21 -18
  123. package/dist/lib/logging/ze-log-event.js.map +1 -0
  124. package/dist/lib/node-persist/app-deploy-result-cache.d.ts +7 -0
  125. package/dist/lib/node-persist/app-deploy-result-cache.js +28 -0
  126. package/dist/lib/node-persist/app-deploy-result-cache.js.map +1 -0
  127. package/dist/lib/node-persist/application-configuration.d.ts +4 -0
  128. package/dist/lib/node-persist/application-configuration.js +29 -0
  129. package/dist/lib/node-persist/application-configuration.js.map +1 -0
  130. package/dist/lib/node-persist/fs-cache.d.ts +3 -0
  131. package/dist/lib/node-persist/fs-cache.js +26 -0
  132. package/dist/lib/node-persist/fs-cache.js.map +1 -0
  133. package/dist/lib/node-persist/hash-cache.d.ts +7 -0
  134. package/dist/lib/node-persist/hash-cache.js +28 -0
  135. package/dist/lib/node-persist/hash-cache.js.map +1 -0
  136. package/dist/lib/node-persist/index.d.ts +1 -0
  137. package/dist/lib/node-persist/index.js +8 -0
  138. package/dist/lib/node-persist/index.js.map +1 -0
  139. package/dist/lib/node-persist/partial-assets-map.d.ts +4 -0
  140. package/dist/lib/node-persist/partial-assets-map.js +31 -0
  141. package/dist/lib/node-persist/partial-assets-map.js.map +1 -0
  142. package/dist/lib/node-persist/secret-token.d.ts +2 -0
  143. package/dist/lib/node-persist/secret-token.js +13 -0
  144. package/dist/lib/node-persist/secret-token.js.map +1 -0
  145. package/dist/lib/node-persist/storage-keys.d.ts +10 -0
  146. package/dist/lib/node-persist/storage-keys.js +15 -0
  147. package/dist/lib/node-persist/storage-keys.js.map +1 -0
  148. package/dist/lib/node-persist/token.d.ts +4 -0
  149. package/dist/lib/node-persist/token.js +36 -0
  150. package/dist/lib/node-persist/token.js.map +1 -0
  151. package/dist/lib/node-persist/upload-provider-options.d.ts +22 -0
  152. package/dist/lib/node-persist/upload-provider-options.js +13 -0
  153. package/dist/lib/node-persist/upload-provider-options.js.map +1 -0
  154. package/dist/lib/{payload-builders → transformers}/ze-build-assets-map.d.ts +2 -3
  155. package/dist/lib/transformers/ze-build-assets-map.js +20 -0
  156. package/dist/lib/transformers/ze-build-assets-map.js.map +1 -0
  157. package/dist/lib/{sync-utils/get-ze-build-asset.d.ts → transformers/ze-build-assets.d.ts} +1 -1
  158. package/dist/lib/{sync-utils/get-ze-build-asset.js → transformers/ze-build-assets.js} +4 -4
  159. package/dist/lib/transformers/ze-build-assets.js.map +1 -0
  160. package/dist/lib/transformers/ze-build-dash-data.d.ts +3 -0
  161. package/dist/lib/transformers/ze-build-dash-data.js +52 -0
  162. package/dist/lib/transformers/ze-build-dash-data.js.map +1 -0
  163. package/dist/lib/transformers/ze-build-snapshot.d.ts +8 -0
  164. package/dist/lib/transformers/ze-build-snapshot.js +56 -0
  165. package/dist/lib/transformers/ze-build-snapshot.js.map +1 -0
  166. package/dist/package.json +6 -2
  167. package/dist/zephyr-engine/index.d.ts +73 -0
  168. package/dist/zephyr-engine/index.js +223 -0
  169. package/dist/zephyr-engine/index.js.map +1 -0
  170. package/dist/zephyr-engine/resolve_remote_dependency.d.ts +13 -0
  171. package/dist/zephyr-engine/resolve_remote_dependency.js +58 -0
  172. package/dist/zephyr-engine/resolve_remote_dependency.js.map +1 -0
  173. package/package.json +7 -3
  174. package/dist/lib/actions/index.js.map +0 -1
  175. package/dist/lib/actions/ze-enable-snapshot-on-edge.js.map +0 -1
  176. package/dist/lib/actions/ze-enable-snapshot-on-pages.js.map +0 -1
  177. package/dist/lib/actions/ze-upload-assets.d.ts +0 -2
  178. package/dist/lib/actions/ze-upload-assets.js.map +0 -1
  179. package/dist/lib/actions/ze-upload-build-stats.js.map +0 -1
  180. package/dist/lib/actions/ze-upload-snapshot.d.ts +0 -6
  181. package/dist/lib/actions/ze-upload-snapshot.js +0 -34
  182. package/dist/lib/actions/ze-upload-snapshot.js.map +0 -1
  183. package/dist/lib/application-configuration/get-application-configuration.js.map +0 -1
  184. package/dist/lib/constants/netlify.constants.d.ts +0 -2
  185. package/dist/lib/constants/netlify.constants.js +0 -6
  186. package/dist/lib/constants/netlify.constants.js.map +0 -1
  187. package/dist/lib/context-utils/ze-util-get-git-info.js.map +0 -1
  188. package/dist/lib/context-utils/ze-util-read-package-json.d.ts +0 -7
  189. package/dist/lib/context-utils/ze-util-read-package-json.js +0 -58
  190. package/dist/lib/context-utils/ze-util-read-package-json.js.map +0 -1
  191. package/dist/lib/context-utils/ze-util-verification.d.ts +0 -4
  192. package/dist/lib/context-utils/ze-util-verification.js.map +0 -1
  193. package/dist/lib/custom-errors/configuration-error.js.map +0 -1
  194. package/dist/lib/custom-errors/could-not-get-build-id.d.ts +0 -4
  195. package/dist/lib/custom-errors/could-not-get-build-id.js +0 -15
  196. package/dist/lib/custom-errors/could-not-get-build-id.js.map +0 -1
  197. package/dist/lib/custom-errors/index.d.ts +0 -5
  198. package/dist/lib/custom-errors/index.js +0 -14
  199. package/dist/lib/custom-errors/index.js.map +0 -1
  200. package/dist/lib/custom-errors/package-json-not-found-error.js.map +0 -1
  201. package/dist/lib/custom-errors/package-json-not-valid-error.js.map +0 -1
  202. package/dist/lib/custom-errors/package-not-a-json-error.js.map +0 -1
  203. package/dist/lib/custom-errors/snapshot-uploads.d.ts +0 -7
  204. package/dist/lib/custom-errors/snapshot-uploads.js +0 -19
  205. package/dist/lib/custom-errors/snapshot-uploads.js.map +0 -1
  206. package/dist/lib/dvcs/distributed-hash-control.js.map +0 -1
  207. package/dist/lib/dvcs/get-cache-key.js.map +0 -1
  208. package/dist/lib/dvcs/get-missing-assets.js.map +0 -1
  209. package/dist/lib/payload-builders/index.d.ts +0 -3
  210. package/dist/lib/payload-builders/index.js +0 -7
  211. package/dist/lib/payload-builders/index.js.map +0 -1
  212. package/dist/lib/payload-builders/ze-build-assets-map.js +0 -55
  213. package/dist/lib/payload-builders/ze-build-assets-map.js.map +0 -1
  214. package/dist/lib/payload-builders/ze-build-snapshot.d.ts +0 -7
  215. package/dist/lib/payload-builders/ze-build-snapshot.js +0 -39
  216. package/dist/lib/payload-builders/ze-build-snapshot.js.map +0 -1
  217. package/dist/lib/payload-builders/ze-get-dash-data.d.ts +0 -38
  218. package/dist/lib/payload-builders/ze-get-dash-data.js +0 -31
  219. package/dist/lib/payload-builders/ze-get-dash-data.js.map +0 -1
  220. package/dist/lib/remote-logs/ze-log-event.js.map +0 -1
  221. package/dist/lib/sync-utils/get-ze-build-asset.js.map +0 -1
  222. package/dist/lib/upload/interfaces.d.ts +0 -4
  223. package/dist/lib/upload/interfaces.js.map +0 -1
  224. package/dist/lib/upload/strategies/cloudflare/enable-pages.d.ts +0 -2
  225. package/dist/lib/upload/strategies/cloudflare/enable-pages.js +0 -13
  226. package/dist/lib/upload/strategies/cloudflare/enable-pages.js.map +0 -1
  227. package/dist/lib/upload/strategies/cloudflare/index.d.ts +0 -2
  228. package/dist/lib/upload/strategies/cloudflare/index.js +0 -8
  229. package/dist/lib/upload/strategies/cloudflare/index.js.map +0 -1
  230. package/dist/lib/upload/strategies/cloudflare/upload-assets.d.ts +0 -9
  231. package/dist/lib/upload/strategies/cloudflare/upload-assets.js +0 -18
  232. package/dist/lib/upload/strategies/cloudflare/upload-assets.js.map +0 -1
  233. package/dist/lib/upload/strategies/cloudflare/upload-build-stats-and-enable-envs.d.ts +0 -10
  234. package/dist/lib/upload/strategies/cloudflare/upload-build-stats-and-enable-envs.js +0 -11
  235. package/dist/lib/upload/strategies/cloudflare/upload-build-stats-and-enable-envs.js.map +0 -1
  236. package/dist/lib/upload/strategies/cloudflare/upload.d.ts +0 -9
  237. package/dist/lib/upload/strategies/cloudflare/upload.js +0 -25
  238. package/dist/lib/upload/strategies/cloudflare/upload.js.map +0 -1
  239. package/dist/lib/upload/strategies/cloudflare/upsert-assets-to-files.d.ts +0 -2
  240. package/dist/lib/upload/strategies/cloudflare/upsert-assets-to-files.js +0 -34
  241. package/dist/lib/upload/strategies/cloudflare/upsert-assets-to-files.js.map +0 -1
  242. package/dist/lib/upload/strategies/cloudflare.strategy.d.ts +0 -2
  243. package/dist/lib/upload/strategies/cloudflare.strategy.js +0 -29
  244. package/dist/lib/upload/strategies/cloudflare.strategy.js.map +0 -1
  245. package/dist/lib/upload/strategies/fastly.strategy.d.ts +0 -2
  246. package/dist/lib/upload/strategies/fastly.strategy.js +0 -45
  247. package/dist/lib/upload/strategies/fastly.strategy.js.map +0 -1
  248. package/dist/lib/upload/strategies/index.js.map +0 -1
  249. package/dist/lib/upload/strategies/netlify.strategy.d.ts +0 -2
  250. package/dist/lib/upload/strategies/netlify.strategy.js +0 -45
  251. package/dist/lib/upload/strategies/netlify.strategy.js.map +0 -1
  252. package/dist/lib/upload/upload-envs.js.map +0 -1
  253. package/dist/lib/upload/upload-file.js +0 -30
  254. package/dist/lib/upload/upload-file.js.map +0 -1
  255. package/dist/lib/upload/upload-snapshot.js.map +0 -1
  256. package/dist/lib/upload/upload.d.ts +0 -16
  257. package/dist/lib/upload/upload.js +0 -40
  258. package/dist/lib/upload/upload.js.map +0 -1
  259. package/dist/lib/util/promise.d.ts +0 -16
  260. package/dist/lib/util/promise.js +0 -34
  261. package/dist/lib/util/promise.js.map +0 -1
  262. package/dist/lib/util/strip-ansi.d.ts +0 -15
  263. package/dist/lib/util/strip-ansi.js +0 -28
  264. package/dist/lib/util/strip-ansi.js.map +0 -1
  265. package/dist/lib/ze-api-requests/get-application-hash-list.js.map +0 -1
  266. package/dist/lib/ze-api-requests/get-build-id.js.map +0 -1
  267. /package/dist/lib/{upload/strategies → deployment}/index.d.ts +0 -0
  268. /package/dist/lib/{upload/strategies → deployment}/index.js +0 -0
  269. /package/dist/lib/{actions → edge-actions}/index.d.ts +0 -0
  270. /package/dist/lib/{actions → edge-actions}/index.js +0 -0
  271. /package/dist/lib/{actions → edge-actions}/ze-upload-build-stats.d.ts +0 -0
  272. /package/dist/lib/{dvcs → edge-hash-list}/distributed-hash-control.d.ts +0 -0
  273. /package/dist/lib/{dvcs → edge-hash-list}/get-cache-key.d.ts +0 -0
  274. /package/dist/lib/{ze-api-requests → edge-requests}/get-build-id.d.ts +0 -0
  275. /package/dist/lib/{custom-errors → errors}/configuration-error.d.ts +0 -0
  276. /package/dist/lib/{custom-errors → errors}/package-json-not-found-error.d.ts +0 -0
  277. /package/dist/lib/{custom-errors → errors}/package-json-not-found-error.js +0 -0
  278. /package/dist/lib/{custom-errors → errors}/package-json-not-valid-error.d.ts +0 -0
  279. /package/dist/lib/{custom-errors → errors}/package-json-not-valid-error.js +0 -0
  280. /package/dist/lib/{custom-errors → errors}/package-not-a-json-error.d.ts +0 -0
  281. /package/dist/lib/{custom-errors → errors}/package-not-a-json-error.js +0 -0
@@ -0,0 +1,162 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.ZephyrError = exports.discordUrl = exports.docsUrl = void 0;
4
+ const tslib_1 = require("tslib");
5
+ const fs = tslib_1.__importStar(require("node:fs"));
6
+ const os = tslib_1.__importStar(require("node:os"));
7
+ const path = tslib_1.__importStar(require("node:path"));
8
+ const util = tslib_1.__importStar(require("node:util"));
9
+ const picocolor_1 = require("../logging/picocolor");
10
+ const codes_1 = require("./codes");
11
+ const zephyr_edge_contract_1 = require("zephyr-edge-contract");
12
+ exports.docsUrl = 'https://docs.zephyr-cloud.io/errors';
13
+ exports.discordUrl = 'https://zephyr-cloud.io/discord';
14
+ /**
15
+ * ZephyrError is the base class for every error thrown by our builder plugins.
16
+ *
17
+ * Some messages have templates that mus be replaced with the `data` object. Use `{{
18
+ * example }}` or `{{ example = value }}` to have a default value
19
+ *
20
+ * It's a subclass of Error, so it can be used in try/catch blocks.
21
+ */
22
+ class ZephyrError extends Error {
23
+ /**
24
+ * Returns {@linkcode cause} if it's a `ZephyrError`, otherwise creates a new
25
+ * `ZephyrError` for the provided type.
26
+ */
27
+ constructor(type, opts) {
28
+ if (ZephyrError.is(opts === null || opts === void 0 ? void 0 : opts.cause)) {
29
+ // Unwraps ERR_UNKNOWN if cause is known
30
+ if ((0, codes_1.isZeErrorEqual)(type, codes_1.ZeErrors.ERR_UNKNOWN)) {
31
+ return opts.cause;
32
+ }
33
+ // Use cause's data if none is provided
34
+ if (!opts.data && opts.cause.data) {
35
+ opts.data = opts.cause.data;
36
+ opts.cause.data = undefined;
37
+ }
38
+ }
39
+ let message = type.message;
40
+ // replace all the templates
41
+ if (opts) {
42
+ message = (0, zephyr_edge_contract_1.formatString)(type.message, opts);
43
+ }
44
+ super(message.trim());
45
+ this.code = ZephyrError.toZeCode(type);
46
+ if (opts) {
47
+ const { cause, data } = opts, template = tslib_1.__rest(opts, ["cause", "data"]);
48
+ this.template = template;
49
+ this.data = opts.data;
50
+ this.cause = opts.cause;
51
+ }
52
+ // Simpler stack traces in VIte
53
+ if (process.env['VITE']) {
54
+ this._stack = this.stack;
55
+ }
56
+ }
57
+ /** Checks if the given error is a ZephyrError and optionally matches the given code. */
58
+ static is(err, codeOrType) {
59
+ if (!(err instanceof ZephyrError)) {
60
+ return false;
61
+ }
62
+ // No kind to filter
63
+ if (!codeOrType) {
64
+ return true;
65
+ }
66
+ return ZephyrError.toZeCode(codeOrType) === err.code;
67
+ }
68
+ /** Formats a Zephyr error code. */
69
+ static toZeCode({ id, kind }) {
70
+ const prefix = codes_1.ZeErrorCategories[kind];
71
+ // we have less categories and more errors, so make sense to be ZEPPIII
72
+ // where ZE is a constant, PP is the category, and I is the error id
73
+ const paddedId = id.toString().padStart(3, '0');
74
+ const paddedPrefix = prefix.toString().padStart(2, '0');
75
+ return `ZE${paddedPrefix}${paddedId}`;
76
+ }
77
+ /**
78
+ * Parses a Zephyr error code into a ZeErrorType.
79
+ *
80
+ * Returns {@linkcode ZeErrors.ERR_UNKNOWN} if the code could not be resolved.
81
+ */
82
+ static fromZeCode(code) {
83
+ // ZEPPIII -> ZE PP III -> ZE (2) (3)
84
+ const prefix = code.slice(2, 4);
85
+ const id = code.slice(4);
86
+ let category;
87
+ for (const errorCategory of Object.keys(codes_1.ZeErrorCategories)) {
88
+ if (codes_1.ZeErrorCategories[errorCategory] === prefix) {
89
+ category = errorCategory;
90
+ break;
91
+ }
92
+ }
93
+ if (!category) {
94
+ return codes_1.ZeErrors.ERR_UNKNOWN;
95
+ }
96
+ for (const error of Object.values(codes_1.ZeErrors)) {
97
+ if (+error.id === +id && error.kind === category) {
98
+ return error;
99
+ }
100
+ }
101
+ return codes_1.ZeErrors.ERR_UNKNOWN;
102
+ }
103
+ static format(error) {
104
+ const zeError = ZephyrError.is(error)
105
+ ? error
106
+ : new ZephyrError(codes_1.ZeErrors.ERR_UNKNOWN, {
107
+ message: (error === null || error === void 0 ? void 0 : error.message) || String(error),
108
+ cause: error,
109
+ });
110
+ const tmpFile = write_error_file(zeError);
111
+ // Strings don't need to be inspected.
112
+ const inspected = typeof zeError.data === 'object'
113
+ ? util.inspect(zeError.data, false, 5, true)
114
+ : zeError.data;
115
+ const messages = [
116
+ `${(0, picocolor_1.bold)((0, picocolor_1.underline)(zeError.code))}: ${zeError.message}`,
117
+ `
118
+
119
+ Visit ${(0, picocolor_1.cyanBright)(`${exports.docsUrl}/${zeError.code}`)} for more information
120
+ Or join our ${(0, picocolor_1.blue)('Discord')} server at ${(0, picocolor_1.cyanBright)(exports.discordUrl)}
121
+
122
+ `.trim(),
123
+ inspected !== '{}' && inspected,
124
+ tmpFile &&
125
+ (0, picocolor_1.blackBright)(`Complete error details available at ${(0, picocolor_1.whiteBright)(tmpFile)}`),
126
+ ];
127
+ return messages
128
+ .filter((x) => !!x)
129
+ .map((x) => x.trim())
130
+ .join('\n\n');
131
+ }
132
+ }
133
+ exports.ZephyrError = ZephyrError;
134
+ /** Attempts to write the error to a file in the temp directory. */
135
+ function write_error_file(zeError) {
136
+ try {
137
+ const tempPath = path.join(os.tmpdir(), `ze${Math.round(Math.random() * 10e9)}.json`);
138
+ fs.writeFileSync(tempPath, JSON.stringify(format_error(zeError)), 'utf8');
139
+ return tempPath;
140
+ }
141
+ catch (_a) {
142
+ return undefined;
143
+ }
144
+ }
145
+ function format_error(err) {
146
+ if (!err) {
147
+ return undefined;
148
+ }
149
+ const error = err;
150
+ return Object.assign(Object.assign(Object.assign(Object.assign({}, error), { template: undefined }), error === null || error === void 0 ? void 0 : error.template), { data: error === null || error === void 0 ? void 0 : error.data, message: error === null || error === void 0 ? void 0 : error.message, stack: split_stack(error.stack, error.message), cause: format_error(error.cause) });
151
+ }
152
+ function split_stack(stack, message) {
153
+ if (!stack) {
154
+ return undefined;
155
+ }
156
+ // removes message from stack
157
+ if (message) {
158
+ stack = stack.slice(`Error: ${message}\n`.length);
159
+ }
160
+ return stack.split('\n').map((line) => (0, zephyr_edge_contract_1.stripAnsi)(line.trim()));
161
+ }
162
+ //# sourceMappingURL=zephyr-error.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"zephyr-error.js","sourceRoot":"","sources":["../../../src/lib/errors/zephyr-error.ts"],"names":[],"mappings":"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"}
@@ -2,17 +2,17 @@
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.onIndexHtmlResolved = exports.resolveIndexHtml = void 0;
4
4
  const node_events_1 = require("node:events");
5
- const zephyr_edge_contract_1 = require("zephyr-edge-contract");
5
+ const logging_1 = require("../logging");
6
6
  const _index_html_emitted = new node_events_1.EventEmitter();
7
7
  const _event_name = 'index-html-resolved';
8
8
  function resolveIndexHtml(content) {
9
- (0, zephyr_edge_contract_1.ze_log)('Index HTML resolved');
9
+ (0, logging_1.ze_log)('Index HTML resolved');
10
10
  _index_html_emitted.emit(_event_name, content);
11
11
  }
12
12
  exports.resolveIndexHtml = resolveIndexHtml;
13
13
  async function onIndexHtmlResolved() {
14
14
  return new Promise((resolve, reject) => {
15
- (0, zephyr_edge_contract_1.ze_log)('Waiting for index HTML to be resolved');
15
+ (0, logging_1.ze_log)('Waiting for index HTML to be resolved');
16
16
  // wait for 1 minute (just in case)
17
17
  setTimeout(reject, 60000);
18
18
  _index_html_emitted.once(_event_name, resolve);
@@ -1 +1 @@
1
- {"version":3,"file":"resolve-index-html.js","sourceRoot":"","sources":["../../../src/lib/hacks/resolve-index-html.ts"],"names":[],"mappings":";;;AAAA,6CAA2C;AAC3C,+DAA8C;AAE9C,MAAM,mBAAmB,GAAG,IAAI,0BAAY,EAAE,CAAC;AAE/C,MAAM,WAAW,GAAG,qBAAqB,CAAC;AAE1C,SAAgB,gBAAgB,CAAC,OAAe;IAC9C,IAAA,6BAAM,EAAC,qBAAqB,CAAC,CAAC;IAC9B,mBAAmB,CAAC,IAAI,CAAC,WAAW,EAAE,OAAO,CAAC,CAAC;AACjD,CAAC;AAHD,4CAGC;AAEM,KAAK,UAAU,mBAAmB;IACvC,OAAO,IAAI,OAAO,CAAC,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE;QACrC,IAAA,6BAAM,EAAC,uCAAuC,CAAC,CAAC;QAChD,mCAAmC;QACnC,UAAU,CAAC,MAAM,EAAE,KAAK,CAAC,CAAC;QAC1B,mBAAmB,CAAC,IAAI,CAAC,WAAW,EAAE,OAAO,CAAC,CAAC;IACjD,CAAC,CAAC,CAAC;AACL,CAAC;AAPD,kDAOC"}
1
+ {"version":3,"file":"resolve-index-html.js","sourceRoot":"","sources":["../../../src/lib/hacks/resolve-index-html.ts"],"names":[],"mappings":";;;AAAA,6CAA2C;AAC3C,wCAAoC;AAEpC,MAAM,mBAAmB,GAAG,IAAI,0BAAY,EAAE,CAAC;AAE/C,MAAM,WAAW,GAAG,qBAAqB,CAAC;AAE1C,SAAgB,gBAAgB,CAAC,OAAe;IAC9C,IAAA,gBAAM,EAAC,qBAAqB,CAAC,CAAC;IAC9B,mBAAmB,CAAC,IAAI,CAAC,WAAW,EAAE,OAAO,CAAC,CAAC;AACjD,CAAC;AAHD,4CAGC;AAEM,KAAK,UAAU,mBAAmB;IACvC,OAAO,IAAI,OAAO,CAAC,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE;QACrC,IAAA,gBAAM,EAAC,uCAAuC,CAAC,CAAC;QAChD,mCAAmC;QACnC,UAAU,CAAC,MAAM,EAAE,KAAK,CAAC,CAAC;QAC1B,mBAAmB,CAAC,IAAI,CAAC,WAAW,EAAE,OAAO,CAAC,CAAC;IACjD,CAAC,CAAC,CAAC;AACL,CAAC;AAPD,kDAOC"}
@@ -1,5 +1,5 @@
1
+ import { LogEvent } from '../logging/ze-log-event';
1
2
  import { ZeUploadBuildStats } from 'zephyr-edge-contract';
2
- import { LogEvent } from '../remote-logs/ze-log-event';
3
3
  export declare function uploadEnvs({ body, application_uid, logEvent, }: {
4
4
  body: ZeUploadBuildStats;
5
5
  application_uid: string;
@@ -1,10 +1,12 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.uploadEnvs = void 0;
4
- const zephyr_edge_contract_1 = require("zephyr-edge-contract");
5
- const get_application_configuration_1 = require("../application-configuration/get-application-configuration");
4
+ const get_application_configuration_1 = require("../edge-requests/get-application-configuration");
5
+ const logging_1 = require("../logging");
6
+ const ze_http_request_1 = require("./ze-http-request");
7
+ const errors_1 = require("../errors");
6
8
  async function uploadEnvs({ body, application_uid, logEvent, }) {
7
- (0, zephyr_edge_contract_1.ze_log)(`Uploading envs to Zephyr, for ${application_uid}`);
9
+ (0, logging_1.ze_log)(`Uploading envs to Zephyr, for ${application_uid}`);
8
10
  const { EDGE_URL, jwt } = await (0, get_application_configuration_1.getApplicationConfiguration)({
9
11
  application_uid,
10
12
  });
@@ -17,7 +19,7 @@ async function uploadEnvs({ body, application_uid, logEvent, }) {
17
19
  can_write_jwt: jwt,
18
20
  },
19
21
  };
20
- const [ok, cause, data] = await zephyr_edge_contract_1.ZeHttpRequest.from({
22
+ const [ok, cause, data] = await ze_http_request_1.ZeHttpRequest.from({
21
23
  path: '/upload',
22
24
  base: EDGE_URL,
23
25
  query: { type: 'envs' },
@@ -28,7 +30,7 @@ async function uploadEnvs({ body, application_uid, logEvent, }) {
28
30
  action: 'deploy:edge:failed',
29
31
  message: 'failed deploying local build to edge',
30
32
  });
31
- throw new zephyr_edge_contract_1.ZephyrError(zephyr_edge_contract_1.ZeErrors.ERR_FAILED_UPLOAD, { type: 'envs', cause: cause });
33
+ throw new errors_1.ZephyrError(errors_1.ZeErrors.ERR_FAILED_UPLOAD, { type: 'envs', cause: cause });
32
34
  }
33
35
  }
34
36
  exports.uploadEnvs = uploadEnvs;
@@ -0,0 +1 @@
1
+ {"version":3,"file":"upload-envs.js","sourceRoot":"","sources":["../../../src/lib/http/upload-envs.ts"],"names":[],"mappings":";;;AACA,kGAA6F;AAG7F,wCAAoC;AACpC,uDAAkD;AAClD,sCAAkD;AAE3C,KAAK,UAAU,UAAU,CAAC,EAC/B,IAAI,EACJ,eAAe,EACf,QAAQ,GAKT;IACC,IAAA,gBAAM,EAAC,iCAAiC,eAAe,EAAE,CAAC,CAAC;IAE3D,MAAM,EAAE,QAAQ,EAAE,GAAG,EAAE,GAAG,MAAM,IAAA,2DAA2B,EAAC;QAC1D,eAAe;KAChB,CAAC,CAAC;IAEH,MAAM,IAAI,GAAG,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC;IAElC,MAAM,OAAO,GAAsB;QACjC,MAAM,EAAE,MAAM;QACd,OAAO,EAAE;YACP,gBAAgB,EAAE,MAAM,CAAC,UAAU,CAAC,IAAI,CAAC;YACzC,cAAc,EAAE,iCAAiC;YACjD,aAAa,EAAE,GAAG;SACnB;KACF,CAAC;IAEF,MAAM,CAAC,EAAE,EAAE,KAAK,EAAE,IAAI,CAAC,GAAG,MAAM,+BAAa,CAAC,IAAI,CAChD;QACE,IAAI,EAAE,SAAS;QACf,IAAI,EAAE,QAAQ;QACd,KAAK,EAAE,EAAE,IAAI,EAAE,MAAM,EAAE;KACxB,EACD,OAAO,EACP,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,CACrB,CAAC;IAEF,IAAI,CAAC,EAAE,IAAI,CAAC,IAAI,EAAE,CAAC;QACjB,QAAQ,CAAC;YACP,KAAK,EAAE,OAAO;YACd,MAAM,EAAE,oBAAoB;YAC5B,OAAO,EAAE,sCAAsC;SAChD,CAAC,CAAC;QAEH,MAAM,IAAI,oBAAW,CAAC,iBAAQ,CAAC,iBAAiB,EAAE,EAAE,IAAI,EAAE,MAAM,EAAE,KAAK,EAAE,KAAK,EAAE,CAAC,CAAC;IACpF,CAAC;AACH,CAAC;AA7CD,gCA6CC"}
@@ -1,5 +1,5 @@
1
1
  import { type UploadableAsset } from 'zephyr-edge-contract';
2
- import { ZeApplicationConfig } from 'zephyr-edge-contract';
2
+ import { ZeApplicationConfig } from '../node-persist/upload-provider-options';
3
3
  export interface UploadFileProps {
4
4
  hash: string;
5
5
  asset: UploadableAsset;
@@ -0,0 +1,86 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.uploadFile = void 0;
4
+ const errors_1 = require("../errors");
5
+ const logging_1 = require("../logging");
6
+ const ze_http_request_1 = require("./ze-http-request");
7
+ const CHUNK_SIZE = 1024 * 50;
8
+ async function uploadFile({ hash, asset }, { EDGE_URL, jwt }) {
9
+ const type = 'file';
10
+ const totalChunks = Math.ceil(asset.size / CHUNK_SIZE);
11
+ (0, logging_1.ze_log)(`Starting to upload file ${asset.path} with ${totalChunks} chunks...`);
12
+ for (let chunkIndex = 0; chunkIndex < totalChunks; chunkIndex++) {
13
+ const start = chunkIndex * CHUNK_SIZE;
14
+ const end = Math.min(start + CHUNK_SIZE, asset.size);
15
+ const chunk = asset.buffer.slice(start, end);
16
+ const options = {
17
+ method: 'POST',
18
+ headers: {
19
+ 'x-file-size': asset.size.toString(),
20
+ 'x-file-path': asset.path,
21
+ 'x-chunk-index': chunkIndex.toString(),
22
+ 'x-total-chunks': totalChunks.toString(),
23
+ can_write_jwt: jwt,
24
+ 'Content-Type': 'application/octet-stream',
25
+ },
26
+ };
27
+ const [ok, cause] = await ze_http_request_1.ZeHttpRequest.from({
28
+ path: '/upload',
29
+ base: EDGE_URL,
30
+ query: { type, hash, filename: asset.path },
31
+ }, options, chunk);
32
+ if (!ok) {
33
+ // Because of `ctx.waitUntil`, the worker will continue to upload the files even if the request failed, and if we immediately throw an error the local process will be terminated, we try again here to at least have another level of effort to continue local process.
34
+ try {
35
+ (0, logging_1.ze_log)(`Failed on first time...trying to upload chunk ${chunkIndex} of file ${asset.path} of total ${totalChunks} chunks...`);
36
+ const [retryOk, retryCause] = await ze_http_request_1.ZeHttpRequest.from({
37
+ path: '/upload',
38
+ base: EDGE_URL,
39
+ query: { type, hash, filename: asset.path },
40
+ }, options, chunk);
41
+ if (!retryOk) {
42
+ try {
43
+ (0, logging_1.ze_log)(`Second time...Trying to upload chunk ${chunkIndex} of file ${asset.path} of total ${totalChunks} chunks...`);
44
+ await ze_http_request_1.ZeHttpRequest.from({
45
+ path: '/upload',
46
+ base: EDGE_URL,
47
+ query: { type, hash, filename: asset.path },
48
+ }, options, chunk);
49
+ }
50
+ catch (error) {
51
+ throw new errors_1.ZephyrError(errors_1.ZeErrors.ERR_FAILED_UPLOAD, {
52
+ type: 'file',
53
+ cause: error,
54
+ data: {
55
+ chunkIndex,
56
+ totalChunks,
57
+ },
58
+ });
59
+ }
60
+ throw new errors_1.ZephyrError(errors_1.ZeErrors.ERR_FAILED_UPLOAD, {
61
+ type: 'file',
62
+ cause: retryCause,
63
+ data: {
64
+ chunkIndex,
65
+ totalChunks,
66
+ },
67
+ });
68
+ }
69
+ }
70
+ catch (error) {
71
+ throw new errors_1.ZephyrError(errors_1.ZeErrors.ERR_FAILED_UPLOAD, {
72
+ type: 'file',
73
+ cause,
74
+ data: {
75
+ error,
76
+ chunkIndex,
77
+ totalChunks,
78
+ },
79
+ });
80
+ }
81
+ }
82
+ (0, logging_1.ze_log)(`Chunk ${chunkIndex} of file ${asset.path} of total ${totalChunks} chunks uploaded`);
83
+ }
84
+ }
85
+ exports.uploadFile = uploadFile;
86
+ //# sourceMappingURL=upload-file.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"upload-file.js","sourceRoot":"","sources":["../../../src/lib/http/upload-file.ts"],"names":[],"mappings":"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"}
@@ -1,5 +1,5 @@
1
1
  import { Snapshot, SnapshotUploadRes } from 'zephyr-edge-contract';
2
- export declare function uploadSnapshot({ body, application_uid }: {
2
+ export declare function uploadSnapshot({ body, application_uid, }: {
3
3
  body: Snapshot;
4
4
  application_uid: string;
5
5
  }): Promise<SnapshotUploadRes>;
@@ -1,9 +1,11 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.uploadSnapshot = void 0;
4
- const zephyr_edge_contract_1 = require("zephyr-edge-contract");
5
- const get_application_configuration_1 = require("../application-configuration/get-application-configuration");
6
- async function uploadSnapshot({ body, application_uid }) {
4
+ const get_application_configuration_1 = require("../edge-requests/get-application-configuration");
5
+ const ze_http_request_1 = require("./ze-http-request");
6
+ const errors_1 = require("../errors");
7
+ const logging_1 = require("../logging");
8
+ async function uploadSnapshot({ body, application_uid, }) {
7
9
  const { EDGE_URL, jwt } = await (0, get_application_configuration_1.getApplicationConfiguration)({
8
10
  application_uid,
9
11
  });
@@ -16,7 +18,7 @@ async function uploadSnapshot({ body, application_uid }) {
16
18
  can_write_jwt: jwt,
17
19
  },
18
20
  };
19
- const [ok, cause, resp] = await zephyr_edge_contract_1.ZeHttpRequest.from({
21
+ const [ok, cause, resp] = await ze_http_request_1.ZeHttpRequest.from({
20
22
  path: '/upload',
21
23
  base: EDGE_URL,
22
24
  query: {
@@ -25,12 +27,12 @@ async function uploadSnapshot({ body, application_uid }) {
25
27
  },
26
28
  }, options, json);
27
29
  if (!ok) {
28
- throw new zephyr_edge_contract_1.ZephyrError(zephyr_edge_contract_1.ZeErrors.ERR_FAILED_UPLOAD, {
30
+ throw new errors_1.ZephyrError(errors_1.ZeErrors.ERR_FAILED_UPLOAD, {
29
31
  type: 'snapshot',
30
32
  cause,
31
33
  });
32
34
  }
33
- (0, zephyr_edge_contract_1.ze_log)('Snapshot uploaded...');
35
+ (0, logging_1.ze_log)('Done: snapshot uploaded...', body);
34
36
  return resp;
35
37
  }
36
38
  exports.uploadSnapshot = uploadSnapshot;
@@ -0,0 +1 @@
1
+ {"version":3,"file":"upload-snapshot.js","sourceRoot":"","sources":["../../../src/lib/http/upload-snapshot.ts"],"names":[],"mappings":";;;AAEA,kGAA6F;AAC7F,uDAAkD;AAClD,sCAAkD;AAClD,wCAAoC;AAE7B,KAAK,UAAU,cAAc,CAAC,EACnC,IAAI,EACJ,eAAe,GAIhB;IACC,MAAM,EAAE,QAAQ,EAAE,GAAG,EAAE,GAAG,MAAM,IAAA,2DAA2B,EAAC;QAC1D,eAAe;KAChB,CAAC,CAAC;IAEH,MAAM,IAAI,GAAG,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC;IAElC,MAAM,OAAO,GAAsB;QACjC,MAAM,EAAE,MAAM;QACd,OAAO,EAAE;YACP,gBAAgB,EAAE,MAAM,CAAC,UAAU,CAAC,IAAI,CAAC;YACzC,cAAc,EAAE,iCAAiC;YACjD,aAAa,EAAE,GAAG;SACnB;KACF,CAAC;IAEF,MAAM,CAAC,EAAE,EAAE,KAAK,EAAE,IAAI,CAAC,GAAG,MAAM,+BAAa,CAAC,IAAI,CAChD;QACE,IAAI,EAAE,SAAS;QACf,IAAI,EAAE,QAAQ;QACd,KAAK,EAAE;YACL,IAAI,EAAE,UAAU;YAChB,WAAW,EAAE,IAAI;SAClB;KACF,EACD,OAAO,EACP,IAAI,CACL,CAAC;IAEF,IAAI,CAAC,EAAE,EAAE,CAAC;QACR,MAAM,IAAI,oBAAW,CAAC,iBAAQ,CAAC,iBAAiB,EAAE;YAChD,IAAI,EAAE,UAAU;YAChB,KAAK;SACN,CAAC,CAAC;IACL,CAAC;IAED,IAAA,gBAAM,EAAC,4BAA4B,EAAE,IAAI,CAAC,CAAC;IAE3C,OAAO,IAAI,CAAC;AACd,CAAC;AA7CD,wCA6CC"}
@@ -0,0 +1,19 @@
1
+ /// <reference types="node" />
2
+ /// <reference types="node" />
3
+ import type { ClientRequestArgs } from 'node:http';
4
+ /** Http request wrapper that returns a tuple with the response data or an error. */
5
+ export type HttpResponse<T> = [ok: true, error: null, data: T] | [ok: false, error: Error];
6
+ export type UrlString = string | URL | {
7
+ path: string;
8
+ base?: string;
9
+ query: Record<string, string | number | boolean>;
10
+ };
11
+ /** Starts a new http request */
12
+ export declare class ZeHttpRequest<T = void> implements PromiseLike<HttpResponse<T>> {
13
+ #private;
14
+ /** Creates a new http request. */
15
+ static from<T = void>(urlStr: UrlString, options?: ClientRequestArgs, data?: string | Buffer): ZeHttpRequest<T>;
16
+ then: <TResult1 = HttpResponse<T>, TResult2 = never>(onfulfilled?: ((value: HttpResponse<T>) => TResult1 | PromiseLike<TResult1>) | null | undefined, onrejected?: ((reason: any) => TResult2 | PromiseLike<TResult2>) | null | undefined) => Promise<TResult1 | TResult2>;
17
+ /** Transforms `Promise<HttpResponse<T>>` into `Promise<T>` */
18
+ unwrap(): Promise<T>;
19
+ }
@@ -0,0 +1,165 @@
1
+ "use strict";
2
+ var _ZeHttpRequest_instances, _ZeHttpRequest_start, _ZeHttpRequest_url, _ZeHttpRequest_options, _ZeHttpRequest_data, _ZeHttpRequest_promise, _ZeHttpRequest_reject, _ZeHttpRequest_resolve, _ZeHttpRequest_request, _ZeHttpRequest_onRequestError, _ZeHttpRequest_onResponse, _ZeHttpRequest_handleUnknownError, _ZeHttpRequest_onResponseAsync, _ZeHttpRequest_redact;
3
+ Object.defineProperty(exports, "__esModule", { value: true });
4
+ exports.ZeHttpRequest = void 0;
5
+ const tslib_1 = require("tslib");
6
+ const http = tslib_1.__importStar(require("node:http"));
7
+ const https = tslib_1.__importStar(require("node:https"));
8
+ const consumers_1 = require("node:stream/consumers");
9
+ const errors_1 = require("../errors");
10
+ const token_1 = require("../node-persist/token");
11
+ const debug_1 = require("../logging/debug");
12
+ const zephyr_edge_contract_1 = require("zephyr-edge-contract");
13
+ /** Starts a new http request */
14
+ class ZeHttpRequest {
15
+ constructor() {
16
+ _ZeHttpRequest_instances.add(this);
17
+ /** The time the request was started. */
18
+ _ZeHttpRequest_start.set(this, Date.now());
19
+ /** The URL to request. */
20
+ _ZeHttpRequest_url.set(this, void 0);
21
+ /** The options for the request. */
22
+ _ZeHttpRequest_options.set(this, void 0);
23
+ /** The data to send with the request. */
24
+ _ZeHttpRequest_data.set(this, void 0);
25
+ // private methods for resolving and rejecting the promise
26
+ _ZeHttpRequest_promise.set(this, (0, zephyr_edge_contract_1.PromiseWithResolvers)());
27
+ // promise extension
28
+ this.then = tslib_1.__classPrivateFieldGet(this, _ZeHttpRequest_promise, "f").promise.then.bind(tslib_1.__classPrivateFieldGet(this, _ZeHttpRequest_promise, "f").promise);
29
+ /** Handles the error when the request fails. */
30
+ _ZeHttpRequest_onRequestError.set(this, (cause) => {
31
+ var _a, _b;
32
+ if ('ERR_TLS_CERT_ALTNAME_INVALID' in cause) {
33
+ tslib_1.__classPrivateFieldGet(this, _ZeHttpRequest_instances, "m", _ZeHttpRequest_reject).call(this, new errors_1.ZephyrError(errors_1.ZeErrors.ERR_TLS_CERT_ALTNAME_INVALID, {
34
+ cause,
35
+ }));
36
+ return;
37
+ }
38
+ tslib_1.__classPrivateFieldGet(this, _ZeHttpRequest_instances, "m", _ZeHttpRequest_reject).call(this, new errors_1.ZephyrError(errors_1.ZeErrors.ERR_HTTP_ERROR, {
39
+ url: tslib_1.__classPrivateFieldGet(this, _ZeHttpRequest_url, "f").toString(),
40
+ method: (_b = (_a = tslib_1.__classPrivateFieldGet(this, _ZeHttpRequest_options, "f").method) === null || _a === void 0 ? void 0 : _a.toUpperCase()) !== null && _b !== void 0 ? _b : 'GET',
41
+ content: 'Could not send request',
42
+ status: '-1',
43
+ cause,
44
+ }));
45
+ });
46
+ /** Handles the response from the server. */
47
+ _ZeHttpRequest_onResponse.set(this, (res) => {
48
+ tslib_1.__classPrivateFieldGet(this, _ZeHttpRequest_onResponseAsync, "f").call(this, res).catch(tslib_1.__classPrivateFieldGet(this, _ZeHttpRequest_handleUnknownError, "f"));
49
+ });
50
+ _ZeHttpRequest_handleUnknownError.set(this, (cause) => {
51
+ tslib_1.__classPrivateFieldGet(this, _ZeHttpRequest_instances, "m", _ZeHttpRequest_reject).call(this, new errors_1.ZephyrError(errors_1.ZeErrors.ERR_UNKNOWN, {
52
+ message: 'Could not process provided http.IncomingMessage',
53
+ cause,
54
+ }));
55
+ });
56
+ _ZeHttpRequest_onResponseAsync.set(this, async (res) => {
57
+ var _a, _b, _c, _d, _e;
58
+ if (res.statusCode === 401) {
59
+ // Clean the tokens and throw an error
60
+ await (0, token_1.cleanTokens)();
61
+ throw new errors_1.ZephyrError(errors_1.ZeErrors.ERR_AUTH_ERROR, {
62
+ message: 'Unauthenticated request',
63
+ });
64
+ }
65
+ if (res.statusCode === 403) {
66
+ throw new errors_1.ZephyrError(errors_1.ZeErrors.ERR_AUTH_FORBIDDEN_ERROR, {
67
+ message: 'Unauthorized request',
68
+ });
69
+ }
70
+ const tuple = await (0, zephyr_edge_contract_1.PromiseTuple)((0, consumers_1.text)(res));
71
+ if (!(0, zephyr_edge_contract_1.isSuccessTuple)(tuple)) {
72
+ return tslib_1.__classPrivateFieldGet(this, _ZeHttpRequest_onRequestError, "f").call(this, tuple[0]);
73
+ }
74
+ const resText = tuple[1];
75
+ const message = tslib_1.__classPrivateFieldGet(this, _ZeHttpRequest_instances, "m", _ZeHttpRequest_redact).call(this, resText);
76
+ if (message === 'Not Implemented') {
77
+ throw new errors_1.ZephyrError(errors_1.ZeErrors.ERR_UNKNOWN, {
78
+ message: 'Not implemented yet. Please get in contact with our support.',
79
+ });
80
+ }
81
+ if (res.statusCode === undefined) {
82
+ throw new errors_1.ZephyrError(errors_1.ZeErrors.ERR_HTTP_ERROR, {
83
+ content: 'No status code found',
84
+ method: (_b = (_a = tslib_1.__classPrivateFieldGet(this, _ZeHttpRequest_options, "f").method) === null || _a === void 0 ? void 0 : _a.toUpperCase()) !== null && _b !== void 0 ? _b : 'GET',
85
+ url: tslib_1.__classPrivateFieldGet(this, _ZeHttpRequest_url, "f").toString(),
86
+ status: -1,
87
+ });
88
+ }
89
+ if (!tslib_1.__classPrivateFieldGet(this, _ZeHttpRequest_url, "f").pathname.includes('application/logs')) {
90
+ (0, debug_1.ze_log)(message);
91
+ }
92
+ // Only parses data if reply content is json
93
+ const resData = (_c = (0, zephyr_edge_contract_1.safe_json_parse)(resText)) !== null && _c !== void 0 ? _c : resText;
94
+ if (res.statusCode >= 300) {
95
+ throw new errors_1.ZephyrError(errors_1.ZeErrors.ERR_HTTP_ERROR, {
96
+ status: res.statusCode,
97
+ url: tslib_1.__classPrivateFieldGet(this, _ZeHttpRequest_url, "f").toString(),
98
+ content: resData,
99
+ method: (_e = (_d = tslib_1.__classPrivateFieldGet(this, _ZeHttpRequest_options, "f").method) === null || _d === void 0 ? void 0 : _d.toUpperCase()) !== null && _e !== void 0 ? _e : 'GET',
100
+ });
101
+ }
102
+ tslib_1.__classPrivateFieldGet(this, _ZeHttpRequest_instances, "m", _ZeHttpRequest_resolve).call(this, resData);
103
+ });
104
+ }
105
+ /** Creates a new http request. */
106
+ static from(urlStr, options = {}, data) {
107
+ const req = new ZeHttpRequest();
108
+ tslib_1.__classPrivateFieldSet(req, _ZeHttpRequest_data, data, "f");
109
+ tslib_1.__classPrivateFieldSet(req, _ZeHttpRequest_options, options, "f");
110
+ // Parse the url into a URL object
111
+ if (typeof urlStr === 'string') {
112
+ tslib_1.__classPrivateFieldSet(req, _ZeHttpRequest_url, new URL(urlStr), "f");
113
+ }
114
+ else if (urlStr instanceof URL) {
115
+ tslib_1.__classPrivateFieldSet(req, _ZeHttpRequest_url, urlStr, "f");
116
+ }
117
+ else {
118
+ tslib_1.__classPrivateFieldSet(req, _ZeHttpRequest_url, new URL(urlStr.path, urlStr.base), "f");
119
+ for (const [key, value] of Object.entries(urlStr.query)) {
120
+ tslib_1.__classPrivateFieldGet(req, _ZeHttpRequest_url, "f").searchParams.append(key, String(value));
121
+ }
122
+ }
123
+ const is_preview = (0, zephyr_edge_contract_1.ZE_IS_PREVIEW)();
124
+ const ze_api_endpoint_host = (0, zephyr_edge_contract_1.ZE_API_ENDPOINT_HOST)();
125
+ const zephyr_api_endpoint = (0, zephyr_edge_contract_1.ZEPHYR_API_ENDPOINT)();
126
+ // Add a query param hint in preview environments
127
+ if (is_preview && tslib_1.__classPrivateFieldGet(req, _ZeHttpRequest_url, "f").host === ze_api_endpoint_host) {
128
+ tslib_1.__classPrivateFieldGet(req, _ZeHttpRequest_url, "f").searchParams.set('api_host', zephyr_api_endpoint);
129
+ }
130
+ tslib_1.__classPrivateFieldGet(req, _ZeHttpRequest_instances, "m", _ZeHttpRequest_request).call(req);
131
+ return req;
132
+ }
133
+ /** Transforms `Promise<HttpResponse<T>>` into `Promise<T>` */
134
+ async unwrap() {
135
+ const [ok, error, data] = await this;
136
+ if (!ok) {
137
+ throw error;
138
+ }
139
+ return data;
140
+ }
141
+ }
142
+ exports.ZeHttpRequest = ZeHttpRequest;
143
+ _ZeHttpRequest_start = new WeakMap(), _ZeHttpRequest_url = new WeakMap(), _ZeHttpRequest_options = new WeakMap(), _ZeHttpRequest_data = new WeakMap(), _ZeHttpRequest_promise = new WeakMap(), _ZeHttpRequest_onRequestError = new WeakMap(), _ZeHttpRequest_onResponse = new WeakMap(), _ZeHttpRequest_handleUnknownError = new WeakMap(), _ZeHttpRequest_onResponseAsync = new WeakMap(), _ZeHttpRequest_instances = new WeakSet(), _ZeHttpRequest_reject = function _ZeHttpRequest_reject(error) {
144
+ tslib_1.__classPrivateFieldGet(this, _ZeHttpRequest_promise, "f").resolve([false, error]);
145
+ }, _ZeHttpRequest_resolve = function _ZeHttpRequest_resolve(data) {
146
+ tslib_1.__classPrivateFieldGet(this, _ZeHttpRequest_promise, "f").resolve([true, null, data]);
147
+ }, _ZeHttpRequest_request = function _ZeHttpRequest_request() {
148
+ var _a;
149
+ const requester = tslib_1.__classPrivateFieldGet(this, _ZeHttpRequest_url, "f").protocol === 'https:' ? https : http;
150
+ const req = requester.request(tslib_1.__classPrivateFieldGet(this, _ZeHttpRequest_url, "f"), (_a = tslib_1.__classPrivateFieldGet(this, _ZeHttpRequest_options, "f")) !== null && _a !== void 0 ? _a : {}, tslib_1.__classPrivateFieldGet(this, _ZeHttpRequest_onResponse, "f"));
151
+ req.on('error', tslib_1.__classPrivateFieldGet(this, _ZeHttpRequest_onRequestError, "f"));
152
+ req.end(tslib_1.__classPrivateFieldGet(this, _ZeHttpRequest_data, "f"));
153
+ }, _ZeHttpRequest_redact = function _ZeHttpRequest_redact(response) {
154
+ var _a, _b;
155
+ const str = [
156
+ `[${tslib_1.__classPrivateFieldGet(this, _ZeHttpRequest_options, "f").method || 'GET'}][${tslib_1.__classPrivateFieldGet(this, _ZeHttpRequest_url, "f")}]: ${Date.now() - tslib_1.__classPrivateFieldGet(this, _ZeHttpRequest_start, "f")}ms`,
157
+ ((_a = tslib_1.__classPrivateFieldGet(this, _ZeHttpRequest_data, "f")) === null || _a === void 0 ? void 0 : _a.length) ? ` - ${(((_b = tslib_1.__classPrivateFieldGet(this, _ZeHttpRequest_data, "f").length) !== null && _b !== void 0 ? _b : 0) / 1024).toFixed(2)}kb` : '',
158
+ response ? `Response: ${response}` : '',
159
+ tslib_1.__classPrivateFieldGet(this, _ZeHttpRequest_options, "f") ? `Options: ${JSON.stringify(tslib_1.__classPrivateFieldGet(this, _ZeHttpRequest_options, "f"))}` : '',
160
+ ].join('\n');
161
+ return str
162
+ .replace(/Bearer ([^"|']+)/gi, 'Bearer [REDACTED]')
163
+ .replace(/"?jwt"?:["|\W']{0,2}([^"|']+)(["|'])/gi, 'jwt: [REDACTED]');
164
+ };
165
+ //# sourceMappingURL=ze-http-request.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ze-http-request.js","sourceRoot":"","sources":["../../../src/lib/http/ze-http-request.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1 @@
1
+ export declare const is_debug_enabled: boolean;
@@ -0,0 +1,9 @@
1
+ "use strict";
2
+ var _a;
3
+ Object.defineProperty(exports, "__esModule", { value: true });
4
+ exports.is_debug_enabled = void 0;
5
+ const tslib_1 = require("tslib");
6
+ const process = tslib_1.__importStar(require("node:process"));
7
+ const _zephyr_debug = (_a = process.env['DEBUG']) === null || _a === void 0 ? void 0 : _a.indexOf('zephyr');
8
+ exports.is_debug_enabled = typeof _zephyr_debug === 'number' && _zephyr_debug !== -1;
9
+ //# sourceMappingURL=debug-enabled.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"debug-enabled.js","sourceRoot":"","sources":["../../../src/lib/logging/debug-enabled.ts"],"names":[],"mappings":";;;;;AAAA,8DAAwC;AAExC,MAAM,aAAa,GAAG,MAAA,OAAO,CAAC,GAAG,CAAC,OAAO,CAAC,0CAAE,OAAO,CAAC,QAAQ,CAAC,CAAC;AAEjD,QAAA,gBAAgB,GAAG,OAAO,aAAa,KAAK,QAAQ,IAAI,aAAa,KAAK,CAAC,CAAC,CAAC"}