@congzhen/changewayguard 6.8.12

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 (329) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +270 -0
  3. package/dashboard-dist/api/104.index.js +1420 -0
  4. package/dashboard-dist/api/104.index.js.map +1 -0
  5. package/dashboard-dist/api/113.index.js +496 -0
  6. package/dashboard-dist/api/113.index.js.map +1 -0
  7. package/dashboard-dist/api/18.index.js +67 -0
  8. package/dashboard-dist/api/18.index.js.map +1 -0
  9. package/dashboard-dist/api/217.index.js +44 -0
  10. package/dashboard-dist/api/217.index.js.map +1 -0
  11. package/dashboard-dist/api/222.index.js +90 -0
  12. package/dashboard-dist/api/222.index.js.map +1 -0
  13. package/dashboard-dist/api/25.index.js +3562 -0
  14. package/dashboard-dist/api/25.index.js.map +1 -0
  15. package/dashboard-dist/api/280.index.js +206 -0
  16. package/dashboard-dist/api/280.index.js.map +1 -0
  17. package/dashboard-dist/api/369.index.js +115 -0
  18. package/dashboard-dist/api/369.index.js.map +1 -0
  19. package/dashboard-dist/api/377.index.js +1176 -0
  20. package/dashboard-dist/api/377.index.js.map +1 -0
  21. package/dashboard-dist/api/411.index.js +4250 -0
  22. package/dashboard-dist/api/411.index.js.map +1 -0
  23. package/dashboard-dist/api/424.index.js +135 -0
  24. package/dashboard-dist/api/424.index.js.map +1 -0
  25. package/dashboard-dist/api/573.index.js +806 -0
  26. package/dashboard-dist/api/573.index.js.map +1 -0
  27. package/dashboard-dist/api/598.index.js +328 -0
  28. package/dashboard-dist/api/598.index.js.map +1 -0
  29. package/dashboard-dist/api/62.index.js +4151 -0
  30. package/dashboard-dist/api/62.index.js.map +1 -0
  31. package/dashboard-dist/api/67.index.js +23383 -0
  32. package/dashboard-dist/api/67.index.js.map +1 -0
  33. package/dashboard-dist/api/678.index.js +2734 -0
  34. package/dashboard-dist/api/678.index.js.map +1 -0
  35. package/dashboard-dist/api/698.index.js +1896 -0
  36. package/dashboard-dist/api/698.index.js.map +1 -0
  37. package/dashboard-dist/api/720.index.js +98 -0
  38. package/dashboard-dist/api/720.index.js.map +1 -0
  39. package/dashboard-dist/api/830.index.js +95 -0
  40. package/dashboard-dist/api/830.index.js.map +1 -0
  41. package/dashboard-dist/api/831.index.js +99 -0
  42. package/dashboard-dist/api/831.index.js.map +1 -0
  43. package/dashboard-dist/api/84.index.js +64 -0
  44. package/dashboard-dist/api/84.index.js.map +1 -0
  45. package/dashboard-dist/api/900.index.js +65 -0
  46. package/dashboard-dist/api/900.index.js.map +1 -0
  47. package/dashboard-dist/api/917.index.js +88 -0
  48. package/dashboard-dist/api/917.index.js.map +1 -0
  49. package/dashboard-dist/api/948.index.js +64 -0
  50. package/dashboard-dist/api/948.index.js.map +1 -0
  51. package/dashboard-dist/api/953.index.js +67 -0
  52. package/dashboard-dist/api/953.index.js.map +1 -0
  53. package/dashboard-dist/api/975.index.js +374 -0
  54. package/dashboard-dist/api/975.index.js.map +1 -0
  55. package/dashboard-dist/api/drizzle/sqlite/0000_short_captain_stacy.sql +70 -0
  56. package/dashboard-dist/api/drizzle/sqlite/0001_closed_magus.sql +10 -0
  57. package/dashboard-dist/api/drizzle/sqlite/0002_agent_capability_observation.sql +38 -0
  58. package/dashboard-dist/api/drizzle/sqlite/0003_auth_magic_link.sql +28 -0
  59. package/dashboard-dist/api/drizzle/sqlite/0004_static_scan_fields.sql +8 -0
  60. package/dashboard-dist/api/drizzle/sqlite/0005_gateway_activity.sql +24 -0
  61. package/dashboard-dist/api/drizzle/sqlite/0006_sour_marauders.sql +41 -0
  62. package/dashboard-dist/api/drizzle/sqlite/meta/0000_snapshot.json +460 -0
  63. package/dashboard-dist/api/drizzle/sqlite/meta/0001_snapshot.json +536 -0
  64. package/dashboard-dist/api/drizzle/sqlite/meta/0006_snapshot.json +1249 -0
  65. package/dashboard-dist/api/drizzle/sqlite/meta/_journal.json +55 -0
  66. package/dashboard-dist/api/index.js +27340 -0
  67. package/dashboard-dist/api/index.js.map +1 -0
  68. package/dashboard-dist/api/package.json +16 -0
  69. package/dashboard-dist/api/sourcemap-register.cjs +1 -0
  70. package/dashboard-dist/web/assets/index-CqWIeBTD.js +158 -0
  71. package/dashboard-dist/web/assets/index-Dw7--9q4.css +1 -0
  72. package/dashboard-dist/web/changeway-logo.png +0 -0
  73. package/dashboard-dist/web/favicon.svg +29 -0
  74. package/dashboard-dist/web/index.html +14 -0
  75. package/dashboard-dist/web/logo.svg +16 -0
  76. package/dist/agent/auth.d.ts +37 -0
  77. package/dist/agent/auth.d.ts.map +1 -0
  78. package/dist/agent/auth.js +151 -0
  79. package/dist/agent/auth.js.map +1 -0
  80. package/dist/agent/behavior-detector.d.ts +150 -0
  81. package/dist/agent/behavior-detector.d.ts.map +1 -0
  82. package/dist/agent/behavior-detector.js +573 -0
  83. package/dist/agent/behavior-detector.js.map +1 -0
  84. package/dist/agent/business-reporter.d.ts +114 -0
  85. package/dist/agent/business-reporter.d.ts.map +1 -0
  86. package/dist/agent/business-reporter.js +359 -0
  87. package/dist/agent/business-reporter.js.map +1 -0
  88. package/dist/agent/config-sync.d.ts +70 -0
  89. package/dist/agent/config-sync.d.ts.map +1 -0
  90. package/dist/agent/config-sync.js +133 -0
  91. package/dist/agent/config-sync.js.map +1 -0
  92. package/dist/agent/config.d.ts +97 -0
  93. package/dist/agent/config.d.ts.map +1 -0
  94. package/dist/agent/config.js +359 -0
  95. package/dist/agent/config.js.map +1 -0
  96. package/dist/agent/content-injection-scanner.d.ts +35 -0
  97. package/dist/agent/content-injection-scanner.d.ts.map +1 -0
  98. package/dist/agent/content-injection-scanner.js +270 -0
  99. package/dist/agent/content-injection-scanner.js.map +1 -0
  100. package/dist/agent/engine-log-writer.d.ts +6 -0
  101. package/dist/agent/engine-log-writer.d.ts.map +1 -0
  102. package/dist/agent/engine-log-writer.js +18 -0
  103. package/dist/agent/engine-log-writer.js.map +1 -0
  104. package/dist/agent/env.d.ts +19 -0
  105. package/dist/agent/env.d.ts.map +1 -0
  106. package/dist/agent/env.js +43 -0
  107. package/dist/agent/env.js.map +1 -0
  108. package/dist/agent/event-reporter.d.ts +87 -0
  109. package/dist/agent/event-reporter.d.ts.map +1 -0
  110. package/dist/agent/event-reporter.js +315 -0
  111. package/dist/agent/event-reporter.js.map +1 -0
  112. package/dist/agent/file-watcher.d.ts +50 -0
  113. package/dist/agent/file-watcher.d.ts.map +1 -0
  114. package/dist/agent/file-watcher.js +135 -0
  115. package/dist/agent/file-watcher.js.map +1 -0
  116. package/dist/agent/fs-utils.d.ts +22 -0
  117. package/dist/agent/fs-utils.d.ts.map +1 -0
  118. package/dist/agent/fs-utils.js +41 -0
  119. package/dist/agent/fs-utils.js.map +1 -0
  120. package/dist/agent/gateway-manager.d.ts +59 -0
  121. package/dist/agent/gateway-manager.d.ts.map +1 -0
  122. package/dist/agent/gateway-manager.js +583 -0
  123. package/dist/agent/gateway-manager.js.map +1 -0
  124. package/dist/agent/hook-types.d.ts +276 -0
  125. package/dist/agent/hook-types.d.ts.map +1 -0
  126. package/dist/agent/hook-types.js +51 -0
  127. package/dist/agent/hook-types.js.map +1 -0
  128. package/dist/agent/index.d.ts +8 -0
  129. package/dist/agent/index.d.ts.map +1 -0
  130. package/dist/agent/index.js +8 -0
  131. package/dist/agent/index.js.map +1 -0
  132. package/dist/agent/prompt-gate.d.ts +13 -0
  133. package/dist/agent/prompt-gate.d.ts.map +1 -0
  134. package/dist/agent/prompt-gate.js +28 -0
  135. package/dist/agent/prompt-gate.js.map +1 -0
  136. package/dist/agent/prompt-input.d.ts +9 -0
  137. package/dist/agent/prompt-input.d.ts.map +1 -0
  138. package/dist/agent/prompt-input.js +158 -0
  139. package/dist/agent/prompt-input.js.map +1 -0
  140. package/dist/agent/prompt-output.d.ts +4 -0
  141. package/dist/agent/prompt-output.d.ts.map +1 -0
  142. package/dist/agent/prompt-output.js +19 -0
  143. package/dist/agent/prompt-output.js.map +1 -0
  144. package/dist/agent/runner.d.ts +23 -0
  145. package/dist/agent/runner.d.ts.map +1 -0
  146. package/dist/agent/runner.js +154 -0
  147. package/dist/agent/runner.js.map +1 -0
  148. package/dist/agent/sanitizer.d.ts +10 -0
  149. package/dist/agent/sanitizer.d.ts.map +1 -0
  150. package/dist/agent/sanitizer.js +175 -0
  151. package/dist/agent/sanitizer.js.map +1 -0
  152. package/dist/agent/scan-activity.d.ts +18 -0
  153. package/dist/agent/scan-activity.d.ts.map +1 -0
  154. package/dist/agent/scan-activity.js +32 -0
  155. package/dist/agent/scan-activity.js.map +1 -0
  156. package/dist/agent/types.d.ts +177 -0
  157. package/dist/agent/types.d.ts.map +1 -0
  158. package/dist/agent/types.js +5 -0
  159. package/dist/agent/types.js.map +1 -0
  160. package/dist/agent/workspace-scanner.d.ts +35 -0
  161. package/dist/agent/workspace-scanner.d.ts.map +1 -0
  162. package/dist/agent/workspace-scanner.js +137 -0
  163. package/dist/agent/workspace-scanner.js.map +1 -0
  164. package/dist/dashboard-launcher.d.ts +52 -0
  165. package/dist/dashboard-launcher.d.ts.map +1 -0
  166. package/dist/dashboard-launcher.js +363 -0
  167. package/dist/dashboard-launcher.js.map +1 -0
  168. package/dist/gateway/activity.d.ts +52 -0
  169. package/dist/gateway/activity.d.ts.map +1 -0
  170. package/dist/gateway/activity.js +111 -0
  171. package/dist/gateway/activity.js.map +1 -0
  172. package/dist/gateway/config.d.ts +50 -0
  173. package/dist/gateway/config.d.ts.map +1 -0
  174. package/dist/gateway/config.js +200 -0
  175. package/dist/gateway/config.js.map +1 -0
  176. package/dist/gateway/gateway/activity.d.ts +52 -0
  177. package/dist/gateway/gateway/activity.d.ts.map +1 -0
  178. package/dist/gateway/gateway/activity.js +111 -0
  179. package/dist/gateway/gateway/activity.js.map +1 -0
  180. package/dist/gateway/gateway/config.d.ts +50 -0
  181. package/dist/gateway/gateway/config.d.ts.map +1 -0
  182. package/dist/gateway/gateway/config.js +200 -0
  183. package/dist/gateway/gateway/config.js.map +1 -0
  184. package/dist/gateway/gateway/handlers/anthropic.d.ts +12 -0
  185. package/dist/gateway/gateway/handlers/anthropic.d.ts.map +1 -0
  186. package/dist/gateway/gateway/handlers/anthropic.js +254 -0
  187. package/dist/gateway/gateway/handlers/anthropic.js.map +1 -0
  188. package/dist/gateway/gateway/handlers/gemini.d.ts +12 -0
  189. package/dist/gateway/gateway/handlers/gemini.d.ts.map +1 -0
  190. package/dist/gateway/gateway/handlers/gemini.js +101 -0
  191. package/dist/gateway/gateway/handlers/gemini.js.map +1 -0
  192. package/dist/gateway/gateway/handlers/models.d.ts +4 -0
  193. package/dist/gateway/gateway/handlers/models.d.ts.map +1 -0
  194. package/dist/gateway/gateway/handlers/models.js +36 -0
  195. package/dist/gateway/gateway/handlers/models.js.map +1 -0
  196. package/dist/gateway/gateway/handlers/openai.d.ts +16 -0
  197. package/dist/gateway/gateway/handlers/openai.d.ts.map +1 -0
  198. package/dist/gateway/gateway/handlers/openai.js +254 -0
  199. package/dist/gateway/gateway/handlers/openai.js.map +1 -0
  200. package/dist/gateway/gateway/index.d.ts +27 -0
  201. package/dist/gateway/gateway/index.d.ts.map +1 -0
  202. package/dist/gateway/gateway/index.js +293 -0
  203. package/dist/gateway/gateway/index.js.map +1 -0
  204. package/dist/gateway/gateway/mapping-store.d.ts +38 -0
  205. package/dist/gateway/gateway/mapping-store.d.ts.map +1 -0
  206. package/dist/gateway/gateway/mapping-store.js +74 -0
  207. package/dist/gateway/gateway/mapping-store.js.map +1 -0
  208. package/dist/gateway/gateway/restorer.d.ts +63 -0
  209. package/dist/gateway/gateway/restorer.d.ts.map +1 -0
  210. package/dist/gateway/gateway/restorer.js +284 -0
  211. package/dist/gateway/gateway/restorer.js.map +1 -0
  212. package/dist/gateway/gateway/sanitizer.d.ts +17 -0
  213. package/dist/gateway/gateway/sanitizer.d.ts.map +1 -0
  214. package/dist/gateway/gateway/sanitizer.js +228 -0
  215. package/dist/gateway/gateway/sanitizer.js.map +1 -0
  216. package/dist/gateway/gateway/types.d.ts +53 -0
  217. package/dist/gateway/gateway/types.d.ts.map +1 -0
  218. package/dist/gateway/gateway/types.js +5 -0
  219. package/dist/gateway/gateway/types.js.map +1 -0
  220. package/dist/gateway/handlers/anthropic.d.ts +12 -0
  221. package/dist/gateway/handlers/anthropic.d.ts.map +1 -0
  222. package/dist/gateway/handlers/anthropic.js +254 -0
  223. package/dist/gateway/handlers/anthropic.js.map +1 -0
  224. package/dist/gateway/handlers/gemini.d.ts +12 -0
  225. package/dist/gateway/handlers/gemini.d.ts.map +1 -0
  226. package/dist/gateway/handlers/gemini.js +101 -0
  227. package/dist/gateway/handlers/gemini.js.map +1 -0
  228. package/dist/gateway/handlers/models.d.ts +4 -0
  229. package/dist/gateway/handlers/models.d.ts.map +1 -0
  230. package/dist/gateway/handlers/models.js +36 -0
  231. package/dist/gateway/handlers/models.js.map +1 -0
  232. package/dist/gateway/handlers/openai.d.ts +16 -0
  233. package/dist/gateway/handlers/openai.d.ts.map +1 -0
  234. package/dist/gateway/handlers/openai.js +254 -0
  235. package/dist/gateway/handlers/openai.js.map +1 -0
  236. package/dist/gateway/index.d.ts +27 -0
  237. package/dist/gateway/index.d.ts.map +1 -0
  238. package/dist/gateway/index.js +293 -0
  239. package/dist/gateway/index.js.map +1 -0
  240. package/dist/gateway/mapping-store.d.ts +38 -0
  241. package/dist/gateway/mapping-store.d.ts.map +1 -0
  242. package/dist/gateway/mapping-store.js +74 -0
  243. package/dist/gateway/mapping-store.js.map +1 -0
  244. package/dist/gateway/restorer.d.ts +63 -0
  245. package/dist/gateway/restorer.d.ts.map +1 -0
  246. package/dist/gateway/restorer.js +284 -0
  247. package/dist/gateway/restorer.js.map +1 -0
  248. package/dist/gateway/sanitizer.d.ts +17 -0
  249. package/dist/gateway/sanitizer.d.ts.map +1 -0
  250. package/dist/gateway/sanitizer.js +228 -0
  251. package/dist/gateway/sanitizer.js.map +1 -0
  252. package/dist/gateway/types.d.ts +53 -0
  253. package/dist/gateway/types.d.ts.map +1 -0
  254. package/dist/gateway/types.js +5 -0
  255. package/dist/gateway/types.js.map +1 -0
  256. package/dist/index.d.ts +19 -0
  257. package/dist/index.d.ts.map +1 -0
  258. package/dist/index.js +2084 -0
  259. package/dist/index.js.map +1 -0
  260. package/dist/memory/index.d.ts +5 -0
  261. package/dist/memory/index.d.ts.map +1 -0
  262. package/dist/memory/index.js +5 -0
  263. package/dist/memory/index.js.map +1 -0
  264. package/dist/memory/store.d.ts +82 -0
  265. package/dist/memory/store.d.ts.map +1 -0
  266. package/dist/memory/store.js +194 -0
  267. package/dist/memory/store.js.map +1 -0
  268. package/dist/platform-client/index.d.ts +63 -0
  269. package/dist/platform-client/index.d.ts.map +1 -0
  270. package/dist/platform-client/index.js +294 -0
  271. package/dist/platform-client/index.js.map +1 -0
  272. package/dist/platform-client/types.d.ts +109 -0
  273. package/dist/platform-client/types.d.ts.map +1 -0
  274. package/dist/platform-client/types.js +3 -0
  275. package/dist/platform-client/types.js.map +1 -0
  276. package/gateway/activity.d.ts +52 -0
  277. package/gateway/activity.d.ts.map +1 -0
  278. package/gateway/activity.js +111 -0
  279. package/gateway/activity.js.map +1 -0
  280. package/gateway/config.d.ts +50 -0
  281. package/gateway/config.d.ts.map +1 -0
  282. package/gateway/config.js +200 -0
  283. package/gateway/config.js.map +1 -0
  284. package/gateway/handlers/anthropic.d.ts +12 -0
  285. package/gateway/handlers/anthropic.d.ts.map +1 -0
  286. package/gateway/handlers/anthropic.js +254 -0
  287. package/gateway/handlers/anthropic.js.map +1 -0
  288. package/gateway/handlers/gemini.d.ts +12 -0
  289. package/gateway/handlers/gemini.d.ts.map +1 -0
  290. package/gateway/handlers/gemini.js +101 -0
  291. package/gateway/handlers/gemini.js.map +1 -0
  292. package/gateway/handlers/models.d.ts +4 -0
  293. package/gateway/handlers/models.d.ts.map +1 -0
  294. package/gateway/handlers/models.js +36 -0
  295. package/gateway/handlers/models.js.map +1 -0
  296. package/gateway/handlers/openai.d.ts +16 -0
  297. package/gateway/handlers/openai.d.ts.map +1 -0
  298. package/gateway/handlers/openai.js +254 -0
  299. package/gateway/handlers/openai.js.map +1 -0
  300. package/gateway/index.d.ts +27 -0
  301. package/gateway/index.d.ts.map +1 -0
  302. package/gateway/index.js +293 -0
  303. package/gateway/index.js.map +1 -0
  304. package/gateway/mapping-store.d.ts +38 -0
  305. package/gateway/mapping-store.d.ts.map +1 -0
  306. package/gateway/mapping-store.js +74 -0
  307. package/gateway/mapping-store.js.map +1 -0
  308. package/gateway/restorer.d.ts +63 -0
  309. package/gateway/restorer.d.ts.map +1 -0
  310. package/gateway/restorer.js +284 -0
  311. package/gateway/restorer.js.map +1 -0
  312. package/gateway/sanitizer.d.ts +17 -0
  313. package/gateway/sanitizer.d.ts.map +1 -0
  314. package/gateway/sanitizer.js +228 -0
  315. package/gateway/sanitizer.js.map +1 -0
  316. package/gateway/types.d.ts +53 -0
  317. package/gateway/types.d.ts.map +1 -0
  318. package/gateway/types.js +5 -0
  319. package/gateway/types.js.map +1 -0
  320. package/openclaw.plugin.json +86 -0
  321. package/package.json +74 -0
  322. package/samples/Untitled +1 -0
  323. package/samples/clean-email.txt +20 -0
  324. package/samples/test-document.md +53 -0
  325. package/samples/test-email-popup.txt +44 -0
  326. package/samples/test-email.txt +32 -0
  327. package/samples/test-webpage.html +51 -0
  328. package/scripts/enterprise-enroll.sh +89 -0
  329. package/scripts/enterprise-unenroll.sh +75 -0
@@ -0,0 +1 @@
1
+ {"version":3,"file":"678.index.js","mappings":";;;;;;;;;;;;;;;;;;;;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;AC5KA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;ACpDA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;;;;;AC9WA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;ACfA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;AC9BA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;AC7EA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;ACriCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;ACpRA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;ACrEA;AACA;AACA;AAgBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA","sources":["../../../node_modules/.pnpm/postgres@3.4.8/node_modules/postgres/src/query.js","../../../node_modules/.pnpm/postgres@3.4.8/node_modules/postgres/src/errors.js","../../../node_modules/.pnpm/postgres@3.4.8/node_modules/postgres/src/types.js","../../../node_modules/.pnpm/postgres@3.4.8/node_modules/postgres/src/result.js","../../../node_modules/.pnpm/postgres@3.4.8/node_modules/postgres/src/queue.js","../../../node_modules/.pnpm/postgres@3.4.8/node_modules/postgres/src/bytes.js","../../../node_modules/.pnpm/postgres@3.4.8/node_modules/postgres/src/connection.js","../../../node_modules/.pnpm/postgres@3.4.8/node_modules/postgres/src/subscribe.js","../../../node_modules/.pnpm/postgres@3.4.8/node_modules/postgres/src/large.js","../../../node_modules/.pnpm/postgres@3.4.8/node_modules/postgres/src/index.js"],"sourcesContent":["const originCache = new Map()\n , originStackCache = new Map()\n , originError = Symbol('OriginError')\n\nexport const CLOSE = {}\nexport class Query extends Promise {\n constructor(strings, args, handler, canceller, options = {}) {\n let resolve\n , reject\n\n super((a, b) => {\n resolve = a\n reject = b\n })\n\n this.tagged = Array.isArray(strings.raw)\n this.strings = strings\n this.args = args\n this.handler = handler\n this.canceller = canceller\n this.options = options\n\n this.state = null\n this.statement = null\n\n this.resolve = x => (this.active = false, resolve(x))\n this.reject = x => (this.active = false, reject(x))\n\n this.active = false\n this.cancelled = null\n this.executed = false\n this.signature = ''\n\n this[originError] = this.handler.debug\n ? new Error()\n : this.tagged && cachedError(this.strings)\n }\n\n get origin() {\n return (this.handler.debug\n ? this[originError].stack\n : this.tagged && originStackCache.has(this.strings)\n ? originStackCache.get(this.strings)\n : originStackCache.set(this.strings, this[originError].stack).get(this.strings)\n ) || ''\n }\n\n static get [Symbol.species]() {\n return Promise\n }\n\n cancel() {\n return this.canceller && (this.canceller(this), this.canceller = null)\n }\n\n simple() {\n this.options.simple = true\n this.options.prepare = false\n return this\n }\n\n async readable() {\n this.simple()\n this.streaming = true\n return this\n }\n\n async writable() {\n this.simple()\n this.streaming = true\n return this\n }\n\n cursor(rows = 1, fn) {\n this.options.simple = false\n if (typeof rows === 'function') {\n fn = rows\n rows = 1\n }\n\n this.cursorRows = rows\n\n if (typeof fn === 'function')\n return (this.cursorFn = fn, this)\n\n let prev\n return {\n [Symbol.asyncIterator]: () => ({\n next: () => {\n if (this.executed && !this.active)\n return { done: true }\n\n prev && prev()\n const promise = new Promise((resolve, reject) => {\n this.cursorFn = value => {\n resolve({ value, done: false })\n return new Promise(r => prev = r)\n }\n this.resolve = () => (this.active = false, resolve({ done: true }))\n this.reject = x => (this.active = false, reject(x))\n })\n this.execute()\n return promise\n },\n return() {\n prev && prev(CLOSE)\n return { done: true }\n }\n })\n }\n }\n\n describe() {\n this.options.simple = false\n this.onlyDescribe = this.options.prepare = true\n return this\n }\n\n stream() {\n throw new Error('.stream has been renamed to .forEach')\n }\n\n forEach(fn) {\n this.forEachFn = fn\n this.handle()\n return this\n }\n\n raw() {\n this.isRaw = true\n return this\n }\n\n values() {\n this.isRaw = 'values'\n return this\n }\n\n async handle() {\n !this.executed && (this.executed = true) && await 1 && this.handler(this)\n }\n\n execute() {\n this.handle()\n return this\n }\n\n then() {\n this.handle()\n return super.then.apply(this, arguments)\n }\n\n catch() {\n this.handle()\n return super.catch.apply(this, arguments)\n }\n\n finally() {\n this.handle()\n return super.finally.apply(this, arguments)\n }\n}\n\nfunction cachedError(xs) {\n if (originCache.has(xs))\n return originCache.get(xs)\n\n const x = Error.stackTraceLimit\n Error.stackTraceLimit = 4\n originCache.set(xs, new Error())\n Error.stackTraceLimit = x\n return originCache.get(xs)\n}\n","export class PostgresError extends Error {\n constructor(x) {\n super(x.message)\n this.name = this.constructor.name\n Object.assign(this, x)\n }\n}\n\nexport const Errors = {\n connection,\n postgres,\n generic,\n notSupported\n}\n\nfunction connection(x, options, socket) {\n const { host, port } = socket || options\n const error = Object.assign(\n new Error(('write ' + x + ' ' + (options.path || (host + ':' + port)))),\n {\n code: x,\n errno: x,\n address: options.path || host\n }, options.path ? {} : { port: port }\n )\n Error.captureStackTrace(error, connection)\n return error\n}\n\nfunction postgres(x) {\n const error = new PostgresError(x)\n Error.captureStackTrace(error, postgres)\n return error\n}\n\nfunction generic(code, message) {\n const error = Object.assign(new Error(code + ': ' + message), { code })\n Error.captureStackTrace(error, generic)\n return error\n}\n\n/* c8 ignore next 10 */\nfunction notSupported(x) {\n const error = Object.assign(\n new Error(x + ' (B) is not supported'),\n {\n code: 'MESSAGE_NOT_SUPPORTED',\n name: x\n }\n )\n Error.captureStackTrace(error, notSupported)\n return error\n}\n","import { Query } from './query.js'\nimport { Errors } from './errors.js'\n\nexport const types = {\n string: {\n to: 25,\n from: null, // defaults to string\n serialize: x => '' + x\n },\n number: {\n to: 0,\n from: [21, 23, 26, 700, 701],\n serialize: x => '' + x,\n parse: x => +x\n },\n json: {\n to: 114,\n from: [114, 3802],\n serialize: x => JSON.stringify(x),\n parse: x => JSON.parse(x)\n },\n boolean: {\n to: 16,\n from: 16,\n serialize: x => x === true ? 't' : 'f',\n parse: x => x === 't'\n },\n date: {\n to: 1184,\n from: [1082, 1114, 1184],\n serialize: x => (x instanceof Date ? x : new Date(x)).toISOString(),\n parse: x => new Date(x)\n },\n bytea: {\n to: 17,\n from: 17,\n serialize: x => '\\\\x' + Buffer.from(x).toString('hex'),\n parse: x => Buffer.from(x.slice(2), 'hex')\n }\n}\n\nclass NotTagged { then() { notTagged() } catch() { notTagged() } finally() { notTagged() }}\n\nexport class Identifier extends NotTagged {\n constructor(value) {\n super()\n this.value = escapeIdentifier(value)\n }\n}\n\nexport class Parameter extends NotTagged {\n constructor(value, type, array) {\n super()\n this.value = value\n this.type = type\n this.array = array\n }\n}\n\nexport class Builder extends NotTagged {\n constructor(first, rest) {\n super()\n this.first = first\n this.rest = rest\n }\n\n build(before, parameters, types, options) {\n const keyword = builders.map(([x, fn]) => ({ fn, i: before.search(x) })).sort((a, b) => a.i - b.i).pop()\n return keyword.i === -1\n ? escapeIdentifiers(this.first, options)\n : keyword.fn(this.first, this.rest, parameters, types, options)\n }\n}\n\nexport function handleValue(x, parameters, types, options) {\n let value = x instanceof Parameter ? x.value : x\n if (value === undefined) {\n x instanceof Parameter\n ? x.value = options.transform.undefined\n : value = x = options.transform.undefined\n\n if (value === undefined)\n throw Errors.generic('UNDEFINED_VALUE', 'Undefined values are not allowed')\n }\n\n return '$' + (types.push(\n x instanceof Parameter\n ? (parameters.push(x.value), x.array\n ? x.array[x.type || inferType(x.value)] || x.type || firstIsString(x.value)\n : x.type\n )\n : (parameters.push(x), inferType(x))\n ))\n}\n\nconst defaultHandlers = typeHandlers(types)\n\nexport function stringify(q, string, value, parameters, types, options) { // eslint-disable-line\n for (let i = 1; i < q.strings.length; i++) {\n string += (stringifyValue(string, value, parameters, types, options)) + q.strings[i]\n value = q.args[i]\n }\n\n return string\n}\n\nfunction stringifyValue(string, value, parameters, types, o) {\n return (\n value instanceof Builder ? value.build(string, parameters, types, o) :\n value instanceof Query ? fragment(value, parameters, types, o) :\n value instanceof Identifier ? value.value :\n value && value[0] instanceof Query ? value.reduce((acc, x) => acc + ' ' + fragment(x, parameters, types, o), '') :\n handleValue(value, parameters, types, o)\n )\n}\n\nfunction fragment(q, parameters, types, options) {\n q.fragment = true\n return stringify(q, q.strings[0], q.args[0], parameters, types, options)\n}\n\nfunction valuesBuilder(first, parameters, types, columns, options) {\n return first.map(row =>\n '(' + columns.map(column =>\n stringifyValue('values', row[column], parameters, types, options)\n ).join(',') + ')'\n ).join(',')\n}\n\nfunction values(first, rest, parameters, types, options) {\n const multi = Array.isArray(first[0])\n const columns = rest.length ? rest.flat() : Object.keys(multi ? first[0] : first)\n return valuesBuilder(multi ? first : [first], parameters, types, columns, options)\n}\n\nfunction select(first, rest, parameters, types, options) {\n typeof first === 'string' && (first = [first].concat(rest))\n if (Array.isArray(first))\n return escapeIdentifiers(first, options)\n\n let value\n const columns = rest.length ? rest.flat() : Object.keys(first)\n return columns.map(x => {\n value = first[x]\n return (\n value instanceof Query ? fragment(value, parameters, types, options) :\n value instanceof Identifier ? value.value :\n handleValue(value, parameters, types, options)\n ) + ' as ' + escapeIdentifier(options.transform.column.to ? options.transform.column.to(x) : x)\n }).join(',')\n}\n\nconst builders = Object.entries({\n values,\n in: (...xs) => {\n const x = values(...xs)\n return x === '()' ? '(null)' : x\n },\n select,\n as: select,\n returning: select,\n '\\\\(': select,\n\n update(first, rest, parameters, types, options) {\n return (rest.length ? rest.flat() : Object.keys(first)).map(x =>\n escapeIdentifier(options.transform.column.to ? options.transform.column.to(x) : x) +\n '=' + stringifyValue('values', first[x], parameters, types, options)\n )\n },\n\n insert(first, rest, parameters, types, options) {\n const columns = rest.length ? rest.flat() : Object.keys(Array.isArray(first) ? first[0] : first)\n return '(' + escapeIdentifiers(columns, options) + ')values' +\n valuesBuilder(Array.isArray(first) ? first : [first], parameters, types, columns, options)\n }\n}).map(([x, fn]) => ([new RegExp('((?:^|[\\\\s(])' + x + '(?:$|[\\\\s(]))(?![\\\\s\\\\S]*\\\\1)', 'i'), fn]))\n\nfunction notTagged() {\n throw Errors.generic('NOT_TAGGED_CALL', 'Query not called as a tagged template literal')\n}\n\nexport const serializers = defaultHandlers.serializers\nexport const parsers = defaultHandlers.parsers\n\nexport const END = {}\n\nfunction firstIsString(x) {\n if (Array.isArray(x))\n return firstIsString(x[0])\n return typeof x === 'string' ? 1009 : 0\n}\n\nexport const mergeUserTypes = function(types) {\n const user = typeHandlers(types || {})\n return {\n serializers: Object.assign({}, serializers, user.serializers),\n parsers: Object.assign({}, parsers, user.parsers)\n }\n}\n\nfunction typeHandlers(types) {\n return Object.keys(types).reduce((acc, k) => {\n types[k].from && [].concat(types[k].from).forEach(x => acc.parsers[x] = types[k].parse)\n if (types[k].serialize) {\n acc.serializers[types[k].to] = types[k].serialize\n types[k].from && [].concat(types[k].from).forEach(x => acc.serializers[x] = types[k].serialize)\n }\n return acc\n }, { parsers: {}, serializers: {} })\n}\n\nfunction escapeIdentifiers(xs, { transform: { column } }) {\n return xs.map(x => escapeIdentifier(column.to ? column.to(x) : x)).join(',')\n}\n\nexport const escapeIdentifier = function escape(str) {\n return '\"' + str.replace(/\"/g, '\"\"').replace(/\\./g, '\".\"') + '\"'\n}\n\nexport const inferType = function inferType(x) {\n return (\n x instanceof Parameter ? x.type :\n x instanceof Date ? 1184 :\n x instanceof Uint8Array ? 17 :\n (x === true || x === false) ? 16 :\n typeof x === 'bigint' ? 20 :\n Array.isArray(x) ? inferType(x[0]) :\n 0\n )\n}\n\nconst escapeBackslash = /\\\\/g\nconst escapeQuote = /\"/g\n\nfunction arrayEscape(x) {\n return x\n .replace(escapeBackslash, '\\\\\\\\')\n .replace(escapeQuote, '\\\\\"')\n}\n\nexport const arraySerializer = function arraySerializer(xs, serializer, options, typarray) {\n if (Array.isArray(xs) === false)\n return xs\n\n if (!xs.length)\n return '{}'\n\n const first = xs[0]\n // Only _box (1020) has the ';' delimiter for arrays, all other types use the ',' delimiter\n const delimiter = typarray === 1020 ? ';' : ','\n\n if (Array.isArray(first) && !first.type)\n return '{' + xs.map(x => arraySerializer(x, serializer, options, typarray)).join(delimiter) + '}'\n\n return '{' + xs.map(x => {\n if (x === undefined) {\n x = options.transform.undefined\n if (x === undefined)\n throw Errors.generic('UNDEFINED_VALUE', 'Undefined values are not allowed')\n }\n\n return x === null\n ? 'null'\n : '\"' + arrayEscape(serializer ? serializer(x.type ? x.value : x) : '' + x) + '\"'\n }).join(delimiter) + '}'\n}\n\nconst arrayParserState = {\n i: 0,\n char: null,\n str: '',\n quoted: false,\n last: 0\n}\n\nexport const arrayParser = function arrayParser(x, parser, typarray) {\n arrayParserState.i = arrayParserState.last = 0\n return arrayParserLoop(arrayParserState, x, parser, typarray)\n}\n\nfunction arrayParserLoop(s, x, parser, typarray) {\n const xs = []\n // Only _box (1020) has the ';' delimiter for arrays, all other types use the ',' delimiter\n const delimiter = typarray === 1020 ? ';' : ','\n for (; s.i < x.length; s.i++) {\n s.char = x[s.i]\n if (s.quoted) {\n if (s.char === '\\\\') {\n s.str += x[++s.i]\n } else if (s.char === '\"') {\n xs.push(parser ? parser(s.str) : s.str)\n s.str = ''\n s.quoted = x[s.i + 1] === '\"'\n s.last = s.i + 2\n } else {\n s.str += s.char\n }\n } else if (s.char === '\"') {\n s.quoted = true\n } else if (s.char === '{') {\n s.last = ++s.i\n xs.push(arrayParserLoop(s, x, parser, typarray))\n } else if (s.char === '}') {\n s.quoted = false\n s.last < s.i && xs.push(parser ? parser(x.slice(s.last, s.i)) : x.slice(s.last, s.i))\n s.last = s.i + 1\n break\n } else if (s.char === delimiter && s.p !== '}' && s.p !== '\"') {\n xs.push(parser ? parser(x.slice(s.last, s.i)) : x.slice(s.last, s.i))\n s.last = s.i + 1\n }\n s.p = s.char\n }\n s.last < s.i && xs.push(parser ? parser(x.slice(s.last, s.i + 1)) : x.slice(s.last, s.i + 1))\n return xs\n}\n\nexport const toCamel = x => {\n let str = x[0]\n for (let i = 1; i < x.length; i++)\n str += x[i] === '_' ? x[++i].toUpperCase() : x[i]\n return str\n}\n\nexport const toPascal = x => {\n let str = x[0].toUpperCase()\n for (let i = 1; i < x.length; i++)\n str += x[i] === '_' ? x[++i].toUpperCase() : x[i]\n return str\n}\n\nexport const toKebab = x => x.replace(/_/g, '-')\n\nexport const fromCamel = x => x.replace(/([A-Z])/g, '_$1').toLowerCase()\nexport const fromPascal = x => (x.slice(0, 1) + x.slice(1).replace(/([A-Z])/g, '_$1')).toLowerCase()\nexport const fromKebab = x => x.replace(/-/g, '_')\n\nfunction createJsonTransform(fn) {\n return function jsonTransform(x, column) {\n return typeof x === 'object' && x !== null && (column.type === 114 || column.type === 3802)\n ? Array.isArray(x)\n ? x.map(x => jsonTransform(x, column))\n : Object.entries(x).reduce((acc, [k, v]) => Object.assign(acc, { [fn(k)]: jsonTransform(v, column) }), {})\n : x\n }\n}\n\ntoCamel.column = { from: toCamel }\ntoCamel.value = { from: createJsonTransform(toCamel) }\nfromCamel.column = { to: fromCamel }\n\nexport const camel = { ...toCamel }\ncamel.column.to = fromCamel\n\ntoPascal.column = { from: toPascal }\ntoPascal.value = { from: createJsonTransform(toPascal) }\nfromPascal.column = { to: fromPascal }\n\nexport const pascal = { ...toPascal }\npascal.column.to = fromPascal\n\ntoKebab.column = { from: toKebab }\ntoKebab.value = { from: createJsonTransform(toKebab) }\nfromKebab.column = { to: fromKebab }\n\nexport const kebab = { ...toKebab }\nkebab.column.to = fromKebab\n","export default class Result extends Array {\n constructor() {\n super()\n Object.defineProperties(this, {\n count: { value: null, writable: true },\n state: { value: null, writable: true },\n command: { value: null, writable: true },\n columns: { value: null, writable: true },\n statement: { value: null, writable: true }\n })\n }\n\n static get [Symbol.species]() {\n return Array\n }\n}\n","export default Queue\n\nfunction Queue(initial = []) {\n let xs = initial.slice()\n let index = 0\n\n return {\n get length() {\n return xs.length - index\n },\n remove: (x) => {\n const index = xs.indexOf(x)\n return index === -1\n ? null\n : (xs.splice(index, 1), x)\n },\n push: (x) => (xs.push(x), x),\n shift: () => {\n const out = xs[index++]\n\n if (index === xs.length) {\n index = 0\n xs = []\n } else {\n xs[index - 1] = undefined\n }\n\n return out\n }\n }\n}\n","const size = 256\nlet buffer = Buffer.allocUnsafe(size)\n\nconst messages = 'BCcDdEFfHPpQSX'.split('').reduce((acc, x) => {\n const v = x.charCodeAt(0)\n acc[x] = () => {\n buffer[0] = v\n b.i = 5\n return b\n }\n return acc\n}, {})\n\nconst b = Object.assign(reset, messages, {\n N: String.fromCharCode(0),\n i: 0,\n inc(x) {\n b.i += x\n return b\n },\n str(x) {\n const length = Buffer.byteLength(x)\n fit(length)\n b.i += buffer.write(x, b.i, length, 'utf8')\n return b\n },\n i16(x) {\n fit(2)\n buffer.writeUInt16BE(x, b.i)\n b.i += 2\n return b\n },\n i32(x, i) {\n if (i || i === 0) {\n buffer.writeUInt32BE(x, i)\n return b\n }\n fit(4)\n buffer.writeUInt32BE(x, b.i)\n b.i += 4\n return b\n },\n z(x) {\n fit(x)\n buffer.fill(0, b.i, b.i + x)\n b.i += x\n return b\n },\n raw(x) {\n buffer = Buffer.concat([buffer.subarray(0, b.i), x])\n b.i = buffer.length\n return b\n },\n end(at = 1) {\n buffer.writeUInt32BE(b.i - at, at)\n const out = buffer.subarray(0, b.i)\n b.i = 0\n buffer = Buffer.allocUnsafe(size)\n return out\n }\n})\n\nexport default b\n\nfunction fit(x) {\n if (buffer.length - b.i < x) {\n const prev = buffer\n , length = prev.length\n\n buffer = Buffer.allocUnsafe(length + (length >> 1) + x)\n prev.copy(buffer)\n }\n}\n\nfunction reset() {\n b.i = 0\n return b\n}\n","import net from 'net'\nimport tls from 'tls'\nimport crypto from 'crypto'\nimport Stream from 'stream'\nimport { performance } from 'perf_hooks'\n\nimport { stringify, handleValue, arrayParser, arraySerializer } from './types.js'\nimport { Errors } from './errors.js'\nimport Result from './result.js'\nimport Queue from './queue.js'\nimport { Query, CLOSE } from './query.js'\nimport b from './bytes.js'\n\nexport default Connection\n\nlet uid = 1\n\nconst Sync = b().S().end()\n , Flush = b().H().end()\n , SSLRequest = b().i32(8).i32(80877103).end(8)\n , ExecuteUnnamed = Buffer.concat([b().E().str(b.N).i32(0).end(), Sync])\n , DescribeUnnamed = b().D().str('S').str(b.N).end()\n , noop = () => { /* noop */ }\n\nconst retryRoutines = new Set([\n 'FetchPreparedStatement',\n 'RevalidateCachedQuery',\n 'transformAssignedExpr'\n])\n\nconst errorFields = {\n 83 : 'severity_local', // S\n 86 : 'severity', // V\n 67 : 'code', // C\n 77 : 'message', // M\n 68 : 'detail', // D\n 72 : 'hint', // H\n 80 : 'position', // P\n 112 : 'internal_position', // p\n 113 : 'internal_query', // q\n 87 : 'where', // W\n 115 : 'schema_name', // s\n 116 : 'table_name', // t\n 99 : 'column_name', // c\n 100 : 'data type_name', // d\n 110 : 'constraint_name', // n\n 70 : 'file', // F\n 76 : 'line', // L\n 82 : 'routine' // R\n}\n\nfunction Connection(options, queues = {}, { onopen = noop, onend = noop, onclose = noop } = {}) {\n const {\n sslnegotiation,\n ssl,\n max,\n user,\n host,\n port,\n database,\n parsers,\n transform,\n onnotice,\n onnotify,\n onparameter,\n max_pipeline,\n keep_alive,\n backoff,\n target_session_attrs\n } = options\n\n const sent = Queue()\n , id = uid++\n , backend = { pid: null, secret: null }\n , idleTimer = timer(end, options.idle_timeout)\n , lifeTimer = timer(end, options.max_lifetime)\n , connectTimer = timer(connectTimedOut, options.connect_timeout)\n\n let socket = null\n , cancelMessage\n , errorResponse = null\n , result = new Result()\n , incoming = Buffer.alloc(0)\n , needsTypes = options.fetch_types\n , backendParameters = {}\n , statements = {}\n , statementId = Math.random().toString(36).slice(2)\n , statementCount = 1\n , closedTime = 0\n , remaining = 0\n , hostIndex = 0\n , retries = 0\n , length = 0\n , delay = 0\n , rows = 0\n , serverSignature = null\n , nextWriteTimer = null\n , terminated = false\n , incomings = null\n , results = null\n , initial = null\n , ending = null\n , stream = null\n , chunk = null\n , ended = null\n , nonce = null\n , query = null\n , final = null\n\n const connection = {\n queue: queues.closed,\n idleTimer,\n connect(query) {\n initial = query\n reconnect()\n },\n terminate,\n execute,\n cancel,\n end,\n count: 0,\n id\n }\n\n queues.closed && queues.closed.push(connection)\n\n return connection\n\n async function createSocket() {\n let x\n try {\n x = options.socket\n ? (await Promise.resolve(options.socket(options)))\n : new net.Socket()\n } catch (e) {\n error(e)\n return\n }\n x.on('error', error)\n x.on('close', closed)\n x.on('drain', drain)\n return x\n }\n\n async function cancel({ pid, secret }, resolve, reject) {\n try {\n cancelMessage = b().i32(16).i32(80877102).i32(pid).i32(secret).end(16)\n await connect()\n socket.once('error', reject)\n socket.once('close', resolve)\n } catch (error) {\n reject(error)\n }\n }\n\n function execute(q) {\n if (terminated)\n return queryError(q, Errors.connection('CONNECTION_DESTROYED', options))\n\n if (stream)\n return queryError(q, Errors.generic('COPY_IN_PROGRESS', 'You cannot execute queries during copy'))\n\n if (q.cancelled)\n return\n\n try {\n q.state = backend\n query\n ? sent.push(q)\n : (query = q, query.active = true)\n\n build(q)\n return write(toBuffer(q))\n && !q.describeFirst\n && !q.cursorFn\n && sent.length < max_pipeline\n && (!q.options.onexecute || q.options.onexecute(connection))\n } catch (error) {\n sent.length === 0 && write(Sync)\n errored(error)\n return true\n }\n }\n\n function toBuffer(q) {\n if (q.parameters.length >= 65534)\n throw Errors.generic('MAX_PARAMETERS_EXCEEDED', 'Max number of parameters (65534) exceeded')\n\n return q.options.simple\n ? b().Q().str(q.statement.string + b.N).end()\n : q.describeFirst\n ? Buffer.concat([describe(q), Flush])\n : q.prepare\n ? q.prepared\n ? prepared(q)\n : Buffer.concat([describe(q), prepared(q)])\n : unnamed(q)\n }\n\n function describe(q) {\n return Buffer.concat([\n Parse(q.statement.string, q.parameters, q.statement.types, q.statement.name),\n Describe('S', q.statement.name)\n ])\n }\n\n function prepared(q) {\n return Buffer.concat([\n Bind(q.parameters, q.statement.types, q.statement.name, q.cursorName),\n q.cursorFn\n ? Execute('', q.cursorRows)\n : ExecuteUnnamed\n ])\n }\n\n function unnamed(q) {\n return Buffer.concat([\n Parse(q.statement.string, q.parameters, q.statement.types),\n DescribeUnnamed,\n prepared(q)\n ])\n }\n\n function build(q) {\n const parameters = []\n , types = []\n\n const string = stringify(q, q.strings[0], q.args[0], parameters, types, options)\n\n !q.tagged && q.args.forEach(x => handleValue(x, parameters, types, options))\n\n q.prepare = options.prepare && ('prepare' in q.options ? q.options.prepare : true)\n q.string = string\n q.signature = q.prepare && types + string\n q.onlyDescribe && (delete statements[q.signature])\n q.parameters = q.parameters || parameters\n q.prepared = q.prepare && q.signature in statements\n q.describeFirst = q.onlyDescribe || (parameters.length && !q.prepared)\n q.statement = q.prepared\n ? statements[q.signature]\n : { string, types, name: q.prepare ? statementId + statementCount++ : '' }\n\n typeof options.debug === 'function' && options.debug(id, string, parameters, types)\n }\n\n function write(x, fn) {\n chunk = chunk ? Buffer.concat([chunk, x]) : Buffer.from(x)\n if (fn || chunk.length >= 1024)\n return nextWrite(fn)\n nextWriteTimer === null && (nextWriteTimer = setImmediate(nextWrite))\n return true\n }\n\n function nextWrite(fn) {\n const x = socket.write(chunk, fn)\n nextWriteTimer !== null && clearImmediate(nextWriteTimer)\n chunk = nextWriteTimer = null\n return x\n }\n\n function connectTimedOut() {\n errored(Errors.connection('CONNECT_TIMEOUT', options, socket))\n socket.destroy()\n }\n\n async function secure() {\n if (sslnegotiation !== 'direct') {\n write(SSLRequest)\n const canSSL = await new Promise(r => socket.once('data', x => r(x[0] === 83))) // S\n\n if (!canSSL && ssl === 'prefer')\n return connected()\n }\n\n const options = {\n socket,\n servername: net.isIP(socket.host) ? undefined : socket.host\n }\n\n if (sslnegotiation === 'direct')\n options.ALPNProtocols = ['postgresql']\n\n if (ssl === 'require' || ssl === 'allow' || ssl === 'prefer')\n options.rejectUnauthorized = false\n else if (typeof ssl === 'object')\n Object.assign(options, ssl)\n\n socket.removeAllListeners()\n socket = tls.connect(options)\n socket.on('secureConnect', connected)\n socket.on('error', error)\n socket.on('close', closed)\n socket.on('drain', drain)\n }\n\n /* c8 ignore next 3 */\n function drain() {\n !query && onopen(connection)\n }\n\n function data(x) {\n if (incomings) {\n incomings.push(x)\n remaining -= x.length\n if (remaining > 0)\n return\n }\n\n incoming = incomings\n ? Buffer.concat(incomings, length - remaining)\n : incoming.length === 0\n ? x\n : Buffer.concat([incoming, x], incoming.length + x.length)\n\n while (incoming.length > 4) {\n length = incoming.readUInt32BE(1)\n if (length >= incoming.length) {\n remaining = length - incoming.length\n incomings = [incoming]\n break\n }\n\n try {\n handle(incoming.subarray(0, length + 1))\n } catch (e) {\n query && (query.cursorFn || query.describeFirst) && write(Sync)\n errored(e)\n }\n incoming = incoming.subarray(length + 1)\n remaining = 0\n incomings = null\n }\n }\n\n async function connect() {\n terminated = false\n backendParameters = {}\n socket || (socket = await createSocket())\n\n if (!socket)\n return\n\n connectTimer.start()\n\n if (options.socket)\n return ssl ? secure() : connected()\n\n socket.on('connect', ssl ? secure : connected)\n\n if (options.path)\n return socket.connect(options.path)\n\n socket.ssl = ssl\n socket.connect(port[hostIndex], host[hostIndex])\n socket.host = host[hostIndex]\n socket.port = port[hostIndex]\n\n hostIndex = (hostIndex + 1) % port.length\n }\n\n function reconnect() {\n setTimeout(connect, closedTime ? Math.max(0, closedTime + delay - performance.now()) : 0)\n }\n\n function connected() {\n try {\n statements = {}\n needsTypes = options.fetch_types\n statementId = Math.random().toString(36).slice(2)\n statementCount = 1\n lifeTimer.start()\n socket.on('data', data)\n keep_alive && socket.setKeepAlive && socket.setKeepAlive(true, 1000 * keep_alive)\n const s = StartupMessage()\n write(s)\n } catch (err) {\n error(err)\n }\n }\n\n function error(err) {\n if (connection.queue === queues.connecting && options.host[retries + 1])\n return\n\n errored(err)\n while (sent.length)\n queryError(sent.shift(), err)\n }\n\n function errored(err) {\n stream && (stream.destroy(err), stream = null)\n query && queryError(query, err)\n initial && (queryError(initial, err), initial = null)\n }\n\n function queryError(query, err) {\n if (query.reserve)\n return query.reject(err)\n\n if (!err || typeof err !== 'object')\n err = new Error(err)\n\n 'query' in err || 'parameters' in err || Object.defineProperties(err, {\n stack: { value: err.stack + query.origin.replace(/.*\\n/, '\\n'), enumerable: options.debug },\n query: { value: query.string, enumerable: options.debug },\n parameters: { value: query.parameters, enumerable: options.debug },\n args: { value: query.args, enumerable: options.debug },\n types: { value: query.statement && query.statement.types, enumerable: options.debug }\n })\n query.reject(err)\n }\n\n function end() {\n return ending || (\n !connection.reserved && onend(connection),\n !connection.reserved && !initial && !query && sent.length === 0\n ? (terminate(), new Promise(r => socket && socket.readyState !== 'closed' ? socket.once('close', r) : r()))\n : ending = new Promise(r => ended = r)\n )\n }\n\n function terminate() {\n terminated = true\n if (stream || query || initial || sent.length)\n error(Errors.connection('CONNECTION_DESTROYED', options))\n\n clearImmediate(nextWriteTimer)\n if (socket) {\n socket.removeListener('data', data)\n socket.removeListener('connect', connected)\n socket.readyState === 'open' && socket.end(b().X().end())\n }\n ended && (ended(), ending = ended = null)\n }\n\n async function closed(hadError) {\n incoming = Buffer.alloc(0)\n remaining = 0\n incomings = null\n clearImmediate(nextWriteTimer)\n socket.removeListener('data', data)\n socket.removeListener('connect', connected)\n idleTimer.cancel()\n lifeTimer.cancel()\n connectTimer.cancel()\n\n socket.removeAllListeners()\n socket = null\n\n if (initial)\n return reconnect()\n\n !hadError && (query || sent.length) && error(Errors.connection('CONNECTION_CLOSED', options, socket))\n closedTime = performance.now()\n hadError && options.shared.retries++\n delay = (typeof backoff === 'function' ? backoff(options.shared.retries) : backoff) * 1000\n onclose(connection, Errors.connection('CONNECTION_CLOSED', options, socket))\n }\n\n /* Handlers */\n function handle(xs, x = xs[0]) {\n (\n x === 68 ? DataRow : // D\n x === 100 ? CopyData : // d\n x === 65 ? NotificationResponse : // A\n x === 83 ? ParameterStatus : // S\n x === 90 ? ReadyForQuery : // Z\n x === 67 ? CommandComplete : // C\n x === 50 ? BindComplete : // 2\n x === 49 ? ParseComplete : // 1\n x === 116 ? ParameterDescription : // t\n x === 84 ? RowDescription : // T\n x === 82 ? Authentication : // R\n x === 110 ? NoData : // n\n x === 75 ? BackendKeyData : // K\n x === 69 ? ErrorResponse : // E\n x === 115 ? PortalSuspended : // s\n x === 51 ? CloseComplete : // 3\n x === 71 ? CopyInResponse : // G\n x === 78 ? NoticeResponse : // N\n x === 72 ? CopyOutResponse : // H\n x === 99 ? CopyDone : // c\n x === 73 ? EmptyQueryResponse : // I\n x === 86 ? FunctionCallResponse : // V\n x === 118 ? NegotiateProtocolVersion : // v\n x === 87 ? CopyBothResponse : // W\n /* c8 ignore next */\n UnknownMessage\n )(xs)\n }\n\n function DataRow(x) {\n let index = 7\n let length\n let column\n let value\n\n const row = query.isRaw ? new Array(query.statement.columns.length) : {}\n for (let i = 0; i < query.statement.columns.length; i++) {\n column = query.statement.columns[i]\n length = x.readInt32BE(index)\n index += 4\n\n value = length === -1\n ? null\n : query.isRaw === true\n ? x.subarray(index, index += length)\n : column.parser === undefined\n ? x.toString('utf8', index, index += length)\n : column.parser.array === true\n ? column.parser(x.toString('utf8', index + 1, index += length))\n : column.parser(x.toString('utf8', index, index += length))\n\n query.isRaw\n ? (row[i] = query.isRaw === true\n ? value\n : transform.value.from ? transform.value.from(value, column) : value)\n : (row[column.name] = transform.value.from ? transform.value.from(value, column) : value)\n }\n\n query.forEachFn\n ? query.forEachFn(transform.row.from ? transform.row.from(row) : row, result)\n : (result[rows++] = transform.row.from ? transform.row.from(row) : row)\n }\n\n function ParameterStatus(x) {\n const [k, v] = x.toString('utf8', 5, x.length - 1).split(b.N)\n backendParameters[k] = v\n if (options.parameters[k] !== v) {\n options.parameters[k] = v\n onparameter && onparameter(k, v)\n }\n }\n\n function ReadyForQuery(x) {\n if (query) {\n if (errorResponse) {\n query.retried\n ? errored(query.retried)\n : query.prepared && retryRoutines.has(errorResponse.routine)\n ? retry(query, errorResponse)\n : errored(errorResponse)\n } else {\n query.resolve(results || result)\n }\n } else if (errorResponse) {\n errored(errorResponse)\n }\n\n query = results = errorResponse = null\n result = new Result()\n connectTimer.cancel()\n\n if (initial) {\n if (target_session_attrs) {\n if (!backendParameters.in_hot_standby || !backendParameters.default_transaction_read_only)\n return fetchState()\n else if (tryNext(target_session_attrs, backendParameters))\n return terminate()\n }\n\n if (needsTypes) {\n initial.reserve && (initial = null)\n return fetchArrayTypes()\n }\n\n initial && !initial.reserve && execute(initial)\n options.shared.retries = retries = 0\n initial = null\n return\n }\n\n while (sent.length && (query = sent.shift()) && (query.active = true, query.cancelled))\n Connection(options).cancel(query.state, query.cancelled.resolve, query.cancelled.reject)\n\n if (query)\n return // Consider opening if able and sent.length < 50\n\n connection.reserved\n ? !connection.reserved.release && x[5] === 73 // I\n ? ending\n ? terminate()\n : (connection.reserved = null, onopen(connection))\n : connection.reserved()\n : ending\n ? terminate()\n : onopen(connection)\n }\n\n function CommandComplete(x) {\n rows = 0\n\n for (let i = x.length - 1; i > 0; i--) {\n if (x[i] === 32 && x[i + 1] < 58 && result.count === null)\n result.count = +x.toString('utf8', i + 1, x.length - 1)\n if (x[i - 1] >= 65) {\n result.command = x.toString('utf8', 5, i)\n result.state = backend\n break\n }\n }\n\n final && (final(), final = null)\n\n if (result.command === 'BEGIN' && max !== 1 && !connection.reserved)\n return errored(Errors.generic('UNSAFE_TRANSACTION', 'Only use sql.begin, sql.reserved or max: 1'))\n\n if (query.options.simple)\n return BindComplete()\n\n if (query.cursorFn) {\n result.count && query.cursorFn(result)\n write(Sync)\n }\n }\n\n function ParseComplete() {\n query.parsing = false\n }\n\n function BindComplete() {\n !result.statement && (result.statement = query.statement)\n result.columns = query.statement.columns\n }\n\n function ParameterDescription(x) {\n const length = x.readUInt16BE(5)\n\n for (let i = 0; i < length; ++i)\n !query.statement.types[i] && (query.statement.types[i] = x.readUInt32BE(7 + i * 4))\n\n query.prepare && (statements[query.signature] = query.statement)\n query.describeFirst && !query.onlyDescribe && (write(prepared(query)), query.describeFirst = false)\n }\n\n function RowDescription(x) {\n if (result.command) {\n results = results || [result]\n results.push(result = new Result())\n result.count = null\n query.statement.columns = null\n }\n\n const length = x.readUInt16BE(5)\n let index = 7\n let start\n\n query.statement.columns = Array(length)\n\n for (let i = 0; i < length; ++i) {\n start = index\n while (x[index++] !== 0);\n const table = x.readUInt32BE(index)\n const number = x.readUInt16BE(index + 4)\n const type = x.readUInt32BE(index + 6)\n query.statement.columns[i] = {\n name: transform.column.from\n ? transform.column.from(x.toString('utf8', start, index - 1))\n : x.toString('utf8', start, index - 1),\n parser: parsers[type],\n table,\n number,\n type\n }\n index += 18\n }\n\n result.statement = query.statement\n if (query.onlyDescribe)\n return (query.resolve(query.statement), write(Sync))\n }\n\n async function Authentication(x, type = x.readUInt32BE(5)) {\n (\n type === 3 ? AuthenticationCleartextPassword :\n type === 5 ? AuthenticationMD5Password :\n type === 10 ? SASL :\n type === 11 ? SASLContinue :\n type === 12 ? SASLFinal :\n type !== 0 ? UnknownAuth :\n noop\n )(x, type)\n }\n\n /* c8 ignore next 5 */\n async function AuthenticationCleartextPassword() {\n const payload = await Pass()\n write(\n b().p().str(payload).z(1).end()\n )\n }\n\n async function AuthenticationMD5Password(x) {\n const payload = 'md5' + (\n await md5(\n Buffer.concat([\n Buffer.from(await md5((await Pass()) + user)),\n x.subarray(9)\n ])\n )\n )\n write(\n b().p().str(payload).z(1).end()\n )\n }\n\n async function SASL() {\n nonce = (await crypto.randomBytes(18)).toString('base64')\n b().p().str('SCRAM-SHA-256' + b.N)\n const i = b.i\n write(b.inc(4).str('n,,n=*,r=' + nonce).i32(b.i - i - 4, i).end())\n }\n\n async function SASLContinue(x) {\n const res = x.toString('utf8', 9).split(',').reduce((acc, x) => (acc[x[0]] = x.slice(2), acc), {})\n\n const saltedPassword = await crypto.pbkdf2Sync(\n await Pass(),\n Buffer.from(res.s, 'base64'),\n parseInt(res.i), 32,\n 'sha256'\n )\n\n const clientKey = await hmac(saltedPassword, 'Client Key')\n\n const auth = 'n=*,r=' + nonce + ','\n + 'r=' + res.r + ',s=' + res.s + ',i=' + res.i\n + ',c=biws,r=' + res.r\n\n serverSignature = (await hmac(await hmac(saltedPassword, 'Server Key'), auth)).toString('base64')\n\n const payload = 'c=biws,r=' + res.r + ',p=' + xor(\n clientKey, Buffer.from(await hmac(await sha256(clientKey), auth))\n ).toString('base64')\n\n write(\n b().p().str(payload).end()\n )\n }\n\n function SASLFinal(x) {\n if (x.toString('utf8', 9).split(b.N, 1)[0].slice(2) === serverSignature)\n return\n /* c8 ignore next 5 */\n errored(Errors.generic('SASL_SIGNATURE_MISMATCH', 'The server did not return the correct signature'))\n socket.destroy()\n }\n\n function Pass() {\n return Promise.resolve(typeof options.pass === 'function'\n ? options.pass()\n : options.pass\n )\n }\n\n function NoData() {\n result.statement = query.statement\n result.statement.columns = []\n if (query.onlyDescribe)\n return (query.resolve(query.statement), write(Sync))\n }\n\n function BackendKeyData(x) {\n backend.pid = x.readUInt32BE(5)\n backend.secret = x.readUInt32BE(9)\n }\n\n async function fetchArrayTypes() {\n needsTypes = false\n const types = await new Query([`\n select b.oid, b.typarray\n from pg_catalog.pg_type a\n left join pg_catalog.pg_type b on b.oid = a.typelem\n where a.typcategory = 'A'\n group by b.oid, b.typarray\n order by b.oid\n `], [], execute)\n types.forEach(({ oid, typarray }) => addArrayType(oid, typarray))\n }\n\n function addArrayType(oid, typarray) {\n if (!!options.parsers[typarray] && !!options.serializers[typarray]) return\n const parser = options.parsers[oid]\n options.shared.typeArrayMap[oid] = typarray\n options.parsers[typarray] = (xs) => arrayParser(xs, parser, typarray)\n options.parsers[typarray].array = true\n options.serializers[typarray] = (xs) => arraySerializer(xs, options.serializers[oid], options, typarray)\n }\n\n function tryNext(x, xs) {\n return (\n (x === 'read-write' && xs.default_transaction_read_only === 'on') ||\n (x === 'read-only' && xs.default_transaction_read_only === 'off') ||\n (x === 'primary' && xs.in_hot_standby === 'on') ||\n (x === 'standby' && xs.in_hot_standby === 'off') ||\n (x === 'prefer-standby' && xs.in_hot_standby === 'off' && options.host[retries])\n )\n }\n\n function fetchState() {\n const query = new Query([`\n show transaction_read_only;\n select pg_catalog.pg_is_in_recovery()\n `], [], execute, null, { simple: true })\n query.resolve = ([[a], [b]]) => {\n backendParameters.default_transaction_read_only = a.transaction_read_only\n backendParameters.in_hot_standby = b.pg_is_in_recovery ? 'on' : 'off'\n }\n query.execute()\n }\n\n function ErrorResponse(x) {\n if (query) {\n (query.cursorFn || query.describeFirst) && write(Sync)\n errorResponse = Errors.postgres(parseError(x))\n } else {\n errored(Errors.postgres(parseError(x)))\n }\n }\n\n function retry(q, error) {\n delete statements[q.signature]\n q.retried = error\n execute(q)\n }\n\n function NotificationResponse(x) {\n if (!onnotify)\n return\n\n let index = 9\n while (x[index++] !== 0);\n onnotify(\n x.toString('utf8', 9, index - 1),\n x.toString('utf8', index, x.length - 1)\n )\n }\n\n async function PortalSuspended() {\n try {\n const x = await Promise.resolve(query.cursorFn(result))\n rows = 0\n x === CLOSE\n ? write(Close(query.portal))\n : (result = new Result(), write(Execute('', query.cursorRows)))\n } catch (err) {\n write(Sync)\n query.reject(err)\n }\n }\n\n function CloseComplete() {\n result.count && query.cursorFn(result)\n query.resolve(result)\n }\n\n function CopyInResponse() {\n stream = new Stream.Writable({\n autoDestroy: true,\n write(chunk, encoding, callback) {\n socket.write(b().d().raw(chunk).end(), callback)\n },\n destroy(error, callback) {\n callback(error)\n socket.write(b().f().str(error + b.N).end())\n stream = null\n },\n final(callback) {\n socket.write(b().c().end())\n final = callback\n stream = null\n }\n })\n query.resolve(stream)\n }\n\n function CopyOutResponse() {\n stream = new Stream.Readable({\n read() { socket.resume() }\n })\n query.resolve(stream)\n }\n\n /* c8 ignore next 3 */\n function CopyBothResponse() {\n stream = new Stream.Duplex({\n autoDestroy: true,\n read() { socket.resume() },\n /* c8 ignore next 11 */\n write(chunk, encoding, callback) {\n socket.write(b().d().raw(chunk).end(), callback)\n },\n destroy(error, callback) {\n callback(error)\n socket.write(b().f().str(error + b.N).end())\n stream = null\n },\n final(callback) {\n socket.write(b().c().end())\n final = callback\n }\n })\n query.resolve(stream)\n }\n\n function CopyData(x) {\n stream && (stream.push(x.subarray(5)) || socket.pause())\n }\n\n function CopyDone() {\n stream && stream.push(null)\n stream = null\n }\n\n function NoticeResponse(x) {\n onnotice\n ? onnotice(parseError(x))\n : console.log(parseError(x)) // eslint-disable-line\n\n }\n\n /* c8 ignore next 3 */\n function EmptyQueryResponse() {\n /* noop */\n }\n\n /* c8 ignore next 3 */\n function FunctionCallResponse() {\n errored(Errors.notSupported('FunctionCallResponse'))\n }\n\n /* c8 ignore next 3 */\n function NegotiateProtocolVersion() {\n errored(Errors.notSupported('NegotiateProtocolVersion'))\n }\n\n /* c8 ignore next 3 */\n function UnknownMessage(x) {\n console.error('Postgres.js : Unknown Message:', x[0]) // eslint-disable-line\n }\n\n /* c8 ignore next 3 */\n function UnknownAuth(x, type) {\n console.error('Postgres.js : Unknown Auth:', type) // eslint-disable-line\n }\n\n /* Messages */\n function Bind(parameters, types, statement = '', portal = '') {\n let prev\n , type\n\n b().B().str(portal + b.N).str(statement + b.N).i16(0).i16(parameters.length)\n\n parameters.forEach((x, i) => {\n if (x === null)\n return b.i32(0xFFFFFFFF)\n\n type = types[i]\n parameters[i] = x = type in options.serializers\n ? options.serializers[type](x)\n : '' + x\n\n prev = b.i\n b.inc(4).str(x).i32(b.i - prev - 4, prev)\n })\n\n b.i16(0)\n\n return b.end()\n }\n\n function Parse(str, parameters, types, name = '') {\n b().P().str(name + b.N).str(str + b.N).i16(parameters.length)\n parameters.forEach((x, i) => b.i32(types[i] || 0))\n return b.end()\n }\n\n function Describe(x, name = '') {\n return b().D().str(x).str(name + b.N).end()\n }\n\n function Execute(portal = '', rows = 0) {\n return Buffer.concat([\n b().E().str(portal + b.N).i32(rows).end(),\n Flush\n ])\n }\n\n function Close(portal = '') {\n return Buffer.concat([\n b().C().str('P').str(portal + b.N).end(),\n b().S().end()\n ])\n }\n\n function StartupMessage() {\n return cancelMessage || b().inc(4).i16(3).z(2).str(\n Object.entries(Object.assign({\n user,\n database,\n client_encoding: 'UTF8'\n },\n options.connection\n )).filter(([, v]) => v).map(([k, v]) => k + b.N + v).join(b.N)\n ).z(2).end(0)\n }\n\n}\n\nfunction parseError(x) {\n const error = {}\n let start = 5\n for (let i = 5; i < x.length - 1; i++) {\n if (x[i] === 0) {\n error[errorFields[x[start]]] = x.toString('utf8', start + 1, i)\n start = i + 1\n }\n }\n return error\n}\n\nfunction md5(x) {\n return crypto.createHash('md5').update(x).digest('hex')\n}\n\nfunction hmac(key, x) {\n return crypto.createHmac('sha256', key).update(x).digest()\n}\n\nfunction sha256(x) {\n return crypto.createHash('sha256').update(x).digest()\n}\n\nfunction xor(a, b) {\n const length = Math.max(a.length, b.length)\n const buffer = Buffer.allocUnsafe(length)\n for (let i = 0; i < length; i++)\n buffer[i] = a[i] ^ b[i]\n return buffer\n}\n\nfunction timer(fn, seconds) {\n seconds = typeof seconds === 'function' ? seconds() : seconds\n if (!seconds)\n return { cancel: noop, start: noop }\n\n let timer\n return {\n cancel() {\n timer && (clearTimeout(timer), timer = null)\n },\n start() {\n timer && clearTimeout(timer)\n timer = setTimeout(done, seconds * 1000, arguments)\n }\n }\n\n function done(args) {\n fn.apply(null, args)\n timer = null\n }\n}\n","const noop = () => { /* noop */ }\n\nexport default function Subscribe(postgres, options) {\n const subscribers = new Map()\n , slot = 'postgresjs_' + Math.random().toString(36).slice(2)\n , state = {}\n\n let connection\n , stream\n , ended = false\n\n const sql = subscribe.sql = postgres({\n ...options,\n transform: { column: {}, value: {}, row: {} },\n max: 1,\n fetch_types: false,\n idle_timeout: null,\n max_lifetime: null,\n connection: {\n ...options.connection,\n replication: 'database'\n },\n onclose: async function() {\n if (ended)\n return\n stream = null\n state.pid = state.secret = undefined\n connected(await init(sql, slot, options.publications))\n subscribers.forEach(event => event.forEach(({ onsubscribe }) => onsubscribe()))\n },\n no_subscribe: true\n })\n\n const end = sql.end\n , close = sql.close\n\n sql.end = async() => {\n ended = true\n stream && (await new Promise(r => (stream.once('close', r), stream.end())))\n return end()\n }\n\n sql.close = async() => {\n stream && (await new Promise(r => (stream.once('close', r), stream.end())))\n return close()\n }\n\n return subscribe\n\n async function subscribe(event, fn, onsubscribe = noop, onerror = noop) {\n event = parseEvent(event)\n\n if (!connection)\n connection = init(sql, slot, options.publications)\n\n const subscriber = { fn, onsubscribe }\n const fns = subscribers.has(event)\n ? subscribers.get(event).add(subscriber)\n : subscribers.set(event, new Set([subscriber])).get(event)\n\n const unsubscribe = () => {\n fns.delete(subscriber)\n fns.size === 0 && subscribers.delete(event)\n }\n\n return connection.then(x => {\n connected(x)\n onsubscribe()\n stream && stream.on('error', onerror)\n return { unsubscribe, state, sql }\n })\n }\n\n function connected(x) {\n stream = x.stream\n state.pid = x.state.pid\n state.secret = x.state.secret\n }\n\n async function init(sql, slot, publications) {\n if (!publications)\n throw new Error('Missing publication names')\n\n const xs = await sql.unsafe(\n `CREATE_REPLICATION_SLOT ${ slot } TEMPORARY LOGICAL pgoutput NOEXPORT_SNAPSHOT`\n )\n\n const [x] = xs\n\n const stream = await sql.unsafe(\n `START_REPLICATION SLOT ${ slot } LOGICAL ${\n x.consistent_point\n } (proto_version '1', publication_names '${ publications }')`\n ).writable()\n\n const state = {\n lsn: Buffer.concat(x.consistent_point.split('/').map(x => Buffer.from(('00000000' + x).slice(-8), 'hex')))\n }\n\n stream.on('data', data)\n stream.on('error', error)\n stream.on('close', sql.close)\n\n return { stream, state: xs.state }\n\n function error(e) {\n console.error('Unexpected error during logical streaming - reconnecting', e) // eslint-disable-line\n }\n\n function data(x) {\n if (x[0] === 0x77) {\n parse(x.subarray(25), state, sql.options.parsers, handle, options.transform)\n } else if (x[0] === 0x6b && x[17]) {\n state.lsn = x.subarray(1, 9)\n pong()\n }\n }\n\n function handle(a, b) {\n const path = b.relation.schema + '.' + b.relation.table\n call('*', a, b)\n call('*:' + path, a, b)\n b.relation.keys.length && call('*:' + path + '=' + b.relation.keys.map(x => a[x.name]), a, b)\n call(b.command, a, b)\n call(b.command + ':' + path, a, b)\n b.relation.keys.length && call(b.command + ':' + path + '=' + b.relation.keys.map(x => a[x.name]), a, b)\n }\n\n function pong() {\n const x = Buffer.alloc(34)\n x[0] = 'r'.charCodeAt(0)\n x.fill(state.lsn, 1)\n x.writeBigInt64BE(BigInt(Date.now() - Date.UTC(2000, 0, 1)) * BigInt(1000), 25)\n stream.write(x)\n }\n }\n\n function call(x, a, b) {\n subscribers.has(x) && subscribers.get(x).forEach(({ fn }) => fn(a, b, x))\n }\n}\n\nfunction Time(x) {\n return new Date(Date.UTC(2000, 0, 1) + Number(x / BigInt(1000)))\n}\n\nfunction parse(x, state, parsers, handle, transform) {\n const char = (acc, [k, v]) => (acc[k.charCodeAt(0)] = v, acc)\n\n Object.entries({\n R: x => { // Relation\n let i = 1\n const r = state[x.readUInt32BE(i)] = {\n schema: x.toString('utf8', i += 4, i = x.indexOf(0, i)) || 'pg_catalog',\n table: x.toString('utf8', i + 1, i = x.indexOf(0, i + 1)),\n columns: Array(x.readUInt16BE(i += 2)),\n keys: []\n }\n i += 2\n\n let columnIndex = 0\n , column\n\n while (i < x.length) {\n column = r.columns[columnIndex++] = {\n key: x[i++],\n name: transform.column.from\n ? transform.column.from(x.toString('utf8', i, i = x.indexOf(0, i)))\n : x.toString('utf8', i, i = x.indexOf(0, i)),\n type: x.readUInt32BE(i += 1),\n parser: parsers[x.readUInt32BE(i)],\n atttypmod: x.readUInt32BE(i += 4)\n }\n\n column.key && r.keys.push(column)\n i += 4\n }\n },\n Y: () => { /* noop */ }, // Type\n O: () => { /* noop */ }, // Origin\n B: x => { // Begin\n state.date = Time(x.readBigInt64BE(9))\n state.lsn = x.subarray(1, 9)\n },\n I: x => { // Insert\n let i = 1\n const relation = state[x.readUInt32BE(i)]\n const { row } = tuples(x, relation.columns, i += 7, transform)\n\n handle(row, {\n command: 'insert',\n relation\n })\n },\n D: x => { // Delete\n let i = 1\n const relation = state[x.readUInt32BE(i)]\n i += 4\n const key = x[i] === 75\n handle(key || x[i] === 79\n ? tuples(x, relation.columns, i += 3, transform).row\n : null\n , {\n command: 'delete',\n relation,\n key\n })\n },\n U: x => { // Update\n let i = 1\n const relation = state[x.readUInt32BE(i)]\n i += 4\n const key = x[i] === 75\n const xs = key || x[i] === 79\n ? tuples(x, relation.columns, i += 3, transform)\n : null\n\n xs && (i = xs.i)\n\n const { row } = tuples(x, relation.columns, i + 3, transform)\n\n handle(row, {\n command: 'update',\n relation,\n key,\n old: xs && xs.row\n })\n },\n T: () => { /* noop */ }, // Truncate,\n C: () => { /* noop */ } // Commit\n }).reduce(char, {})[x[0]](x)\n}\n\nfunction tuples(x, columns, xi, transform) {\n let type\n , column\n , value\n\n const row = transform.raw ? new Array(columns.length) : {}\n for (let i = 0; i < columns.length; i++) {\n type = x[xi++]\n column = columns[i]\n value = type === 110 // n\n ? null\n : type === 117 // u\n ? undefined\n : column.parser === undefined\n ? x.toString('utf8', xi + 4, xi += 4 + x.readUInt32BE(xi))\n : column.parser.array === true\n ? column.parser(x.toString('utf8', xi + 5, xi += 4 + x.readUInt32BE(xi)))\n : column.parser(x.toString('utf8', xi + 4, xi += 4 + x.readUInt32BE(xi)))\n\n transform.raw\n ? (row[i] = transform.raw === true\n ? value\n : transform.value.from ? transform.value.from(value, column) : value)\n : (row[column.name] = transform.value.from\n ? transform.value.from(value, column)\n : value\n )\n }\n\n return { i: xi, row: transform.row.from ? transform.row.from(row) : row }\n}\n\nfunction parseEvent(x) {\n const xs = x.match(/^(\\*|insert|update|delete)?:?([^.]+?\\.?[^=]+)?=?(.+)?/i) || []\n\n if (!xs)\n throw new Error('Malformed subscribe pattern: ' + x)\n\n const [, command, path, key] = xs\n\n return (command || '*')\n + (path ? ':' + (path.indexOf('.') === -1 ? 'public.' + path : path) : '')\n + (key ? '=' + key : '')\n}\n","import Stream from 'stream'\n\nexport default function largeObject(sql, oid, mode = 0x00020000 | 0x00040000) {\n return new Promise(async(resolve, reject) => {\n await sql.begin(async sql => {\n let finish\n !oid && ([{ oid }] = await sql`select lo_creat(-1) as oid`)\n const [{ fd }] = await sql`select lo_open(${ oid }, ${ mode }) as fd`\n\n const lo = {\n writable,\n readable,\n close : () => sql`select lo_close(${ fd })`.then(finish),\n tell : () => sql`select lo_tell64(${ fd })`,\n read : (x) => sql`select loread(${ fd }, ${ x }) as data`,\n write : (x) => sql`select lowrite(${ fd }, ${ x })`,\n truncate : (x) => sql`select lo_truncate64(${ fd }, ${ x })`,\n seek : (x, whence = 0) => sql`select lo_lseek64(${ fd }, ${ x }, ${ whence })`,\n size : () => sql`\n select\n lo_lseek64(${ fd }, location, 0) as position,\n seek.size\n from (\n select\n lo_lseek64($1, 0, 2) as size,\n tell.location\n from (select lo_tell64($1) as location) tell\n ) seek\n `\n }\n\n resolve(lo)\n\n return new Promise(async r => finish = r)\n\n async function readable({\n highWaterMark = 2048 * 8,\n start = 0,\n end = Infinity\n } = {}) {\n let max = end - start\n start && await lo.seek(start)\n return new Stream.Readable({\n highWaterMark,\n async read(size) {\n const l = size > max ? size - max : size\n max -= size\n const [{ data }] = await lo.read(l)\n this.push(data)\n if (data.length < size)\n this.push(null)\n }\n })\n }\n\n async function writable({\n highWaterMark = 2048 * 8,\n start = 0\n } = {}) {\n start && await lo.seek(start)\n return new Stream.Writable({\n highWaterMark,\n write(chunk, encoding, callback) {\n lo.write(chunk).then(() => callback(), callback)\n }\n })\n }\n }).catch(reject)\n })\n}\n","import os from 'os'\nimport fs from 'fs'\n\nimport {\n mergeUserTypes,\n inferType,\n Parameter,\n Identifier,\n Builder,\n toPascal,\n pascal,\n toCamel,\n camel,\n toKebab,\n kebab,\n fromPascal,\n fromCamel,\n fromKebab\n} from './types.js'\n\nimport Connection from './connection.js'\nimport { Query, CLOSE } from './query.js'\nimport Queue from './queue.js'\nimport { Errors, PostgresError } from './errors.js'\nimport Subscribe from './subscribe.js'\nimport largeObject from './large.js'\n\nObject.assign(Postgres, {\n PostgresError,\n toPascal,\n pascal,\n toCamel,\n camel,\n toKebab,\n kebab,\n fromPascal,\n fromCamel,\n fromKebab,\n BigInt: {\n to: 20,\n from: [20],\n parse: x => BigInt(x), // eslint-disable-line\n serialize: x => x.toString()\n }\n})\n\nexport default Postgres\n\nfunction Postgres(a, b) {\n const options = parseOptions(a, b)\n , subscribe = options.no_subscribe || Subscribe(Postgres, { ...options })\n\n let ending = false\n\n const queries = Queue()\n , connecting = Queue()\n , reserved = Queue()\n , closed = Queue()\n , ended = Queue()\n , open = Queue()\n , busy = Queue()\n , full = Queue()\n , queues = { connecting, reserved, closed, ended, open, busy, full }\n\n const connections = [...Array(options.max)].map(() => Connection(options, queues, { onopen, onend, onclose }))\n\n const sql = Sql(handler)\n\n Object.assign(sql, {\n get parameters() { return options.parameters },\n largeObject: largeObject.bind(null, sql),\n subscribe,\n CLOSE,\n END: CLOSE,\n PostgresError,\n options,\n reserve,\n listen,\n begin,\n close,\n end\n })\n\n return sql\n\n function Sql(handler) {\n handler.debug = options.debug\n\n Object.entries(options.types).reduce((acc, [name, type]) => {\n acc[name] = (x) => new Parameter(x, type.to)\n return acc\n }, typed)\n\n Object.assign(sql, {\n types: typed,\n typed,\n unsafe,\n notify,\n array,\n json,\n file\n })\n\n return sql\n\n function typed(value, type) {\n return new Parameter(value, type)\n }\n\n function sql(strings, ...args) {\n const query = strings && Array.isArray(strings.raw)\n ? new Query(strings, args, handler, cancel)\n : typeof strings === 'string' && !args.length\n ? new Identifier(options.transform.column.to ? options.transform.column.to(strings) : strings)\n : new Builder(strings, args)\n return query\n }\n\n function unsafe(string, args = [], options = {}) {\n arguments.length === 2 && !Array.isArray(args) && (options = args, args = [])\n const query = new Query([string], args, handler, cancel, {\n prepare: false,\n ...options,\n simple: 'simple' in options ? options.simple : args.length === 0\n })\n return query\n }\n\n function file(path, args = [], options = {}) {\n arguments.length === 2 && !Array.isArray(args) && (options = args, args = [])\n const query = new Query([], args, (query) => {\n fs.readFile(path, 'utf8', (err, string) => {\n if (err)\n return query.reject(err)\n\n query.strings = [string]\n handler(query)\n })\n }, cancel, {\n ...options,\n simple: 'simple' in options ? options.simple : args.length === 0\n })\n return query\n }\n }\n\n async function listen(name, fn, onlisten) {\n const listener = { fn, onlisten }\n\n const sql = listen.sql || (listen.sql = Postgres({\n ...options,\n max: 1,\n idle_timeout: null,\n max_lifetime: null,\n fetch_types: false,\n onclose() {\n Object.entries(listen.channels).forEach(([name, { listeners }]) => {\n delete listen.channels[name]\n Promise.all(listeners.map(l => listen(name, l.fn, l.onlisten).catch(() => { /* noop */ })))\n })\n },\n onnotify(c, x) {\n c in listen.channels && listen.channels[c].listeners.forEach(l => l.fn(x))\n }\n }))\n\n const channels = listen.channels || (listen.channels = {})\n , exists = name in channels\n\n if (exists) {\n channels[name].listeners.push(listener)\n const result = await channels[name].result\n listener.onlisten && listener.onlisten()\n return { state: result.state, unlisten }\n }\n\n channels[name] = { result: sql`listen ${\n sql.unsafe('\"' + name.replace(/\"/g, '\"\"') + '\"')\n }`, listeners: [listener] }\n const result = await channels[name].result\n listener.onlisten && listener.onlisten()\n return { state: result.state, unlisten }\n\n async function unlisten() {\n if (name in channels === false)\n return\n\n channels[name].listeners = channels[name].listeners.filter(x => x !== listener)\n if (channels[name].listeners.length)\n return\n\n delete channels[name]\n return sql`unlisten ${\n sql.unsafe('\"' + name.replace(/\"/g, '\"\"') + '\"')\n }`\n }\n }\n\n async function notify(channel, payload) {\n return await sql`select pg_notify(${ channel }, ${ '' + payload })`\n }\n\n async function reserve() {\n const queue = Queue()\n const c = open.length\n ? open.shift()\n : await new Promise((resolve, reject) => {\n const query = { reserve: resolve, reject }\n queries.push(query)\n closed.length && connect(closed.shift(), query)\n })\n\n move(c, reserved)\n c.reserved = () => queue.length\n ? c.execute(queue.shift())\n : move(c, reserved)\n c.reserved.release = true\n\n const sql = Sql(handler)\n sql.release = () => {\n c.reserved = null\n onopen(c)\n }\n\n return sql\n\n function handler(q) {\n c.queue === full\n ? queue.push(q)\n : c.execute(q) || move(c, full)\n }\n }\n\n async function begin(options, fn) {\n !fn && (fn = options, options = '')\n const queries = Queue()\n let savepoints = 0\n , connection\n , prepare = null\n\n try {\n await sql.unsafe('begin ' + options.replace(/[^a-z ]/ig, ''), [], { onexecute }).execute()\n return await Promise.race([\n scope(connection, fn),\n new Promise((_, reject) => connection.onclose = reject)\n ])\n } catch (error) {\n throw error\n }\n\n async function scope(c, fn, name) {\n const sql = Sql(handler)\n sql.savepoint = savepoint\n sql.prepare = x => prepare = x.replace(/[^a-z0-9$-_. ]/gi)\n let uncaughtError\n , result\n\n name && await sql`savepoint ${ sql(name) }`\n try {\n result = await new Promise((resolve, reject) => {\n const x = fn(sql)\n Promise.resolve(Array.isArray(x) ? Promise.all(x) : x).then(resolve, reject)\n })\n\n if (uncaughtError)\n throw uncaughtError\n } catch (e) {\n await (name\n ? sql`rollback to ${ sql(name) }`\n : sql`rollback`\n )\n throw e instanceof PostgresError && e.code === '25P02' && uncaughtError || e\n }\n\n if (!name) {\n prepare\n ? await sql`prepare transaction '${ sql.unsafe(prepare) }'`\n : await sql`commit`\n }\n\n return result\n\n function savepoint(name, fn) {\n if (name && Array.isArray(name.raw))\n return savepoint(sql => sql.apply(sql, arguments))\n\n arguments.length === 1 && (fn = name, name = null)\n return scope(c, fn, 's' + savepoints++ + (name ? '_' + name : ''))\n }\n\n function handler(q) {\n q.catch(e => uncaughtError || (uncaughtError = e))\n c.queue === full\n ? queries.push(q)\n : c.execute(q) || move(c, full)\n }\n }\n\n function onexecute(c) {\n connection = c\n move(c, reserved)\n c.reserved = () => queries.length\n ? c.execute(queries.shift())\n : move(c, reserved)\n }\n }\n\n function move(c, queue) {\n c.queue.remove(c)\n queue.push(c)\n c.queue = queue\n queue === open\n ? c.idleTimer.start()\n : c.idleTimer.cancel()\n return c\n }\n\n function json(x) {\n return new Parameter(x, 3802)\n }\n\n function array(x, type) {\n if (!Array.isArray(x))\n return array(Array.from(arguments))\n\n return new Parameter(x, type || (x.length ? inferType(x) || 25 : 0), options.shared.typeArrayMap)\n }\n\n function handler(query) {\n if (ending)\n return query.reject(Errors.connection('CONNECTION_ENDED', options, options))\n\n if (open.length)\n return go(open.shift(), query)\n\n if (closed.length)\n return connect(closed.shift(), query)\n\n busy.length\n ? go(busy.shift(), query)\n : queries.push(query)\n }\n\n function go(c, query) {\n return c.execute(query)\n ? move(c, busy)\n : move(c, full)\n }\n\n function cancel(query) {\n return new Promise((resolve, reject) => {\n query.state\n ? query.active\n ? Connection(options).cancel(query.state, resolve, reject)\n : query.cancelled = { resolve, reject }\n : (\n queries.remove(query),\n query.cancelled = true,\n query.reject(Errors.generic('57014', 'canceling statement due to user request')),\n resolve()\n )\n })\n }\n\n async function end({ timeout = null } = {}) {\n if (ending)\n return ending\n\n await 1\n let timer\n return ending = Promise.race([\n new Promise(r => timeout !== null && (timer = setTimeout(destroy, timeout * 1000, r))),\n Promise.all(connections.map(c => c.end()).concat(\n listen.sql ? listen.sql.end({ timeout: 0 }) : [],\n subscribe.sql ? subscribe.sql.end({ timeout: 0 }) : []\n ))\n ]).then(() => clearTimeout(timer))\n }\n\n async function close() {\n await Promise.all(connections.map(c => c.end()))\n }\n\n async function destroy(resolve) {\n await Promise.all(connections.map(c => c.terminate()))\n while (queries.length)\n queries.shift().reject(Errors.connection('CONNECTION_DESTROYED', options))\n resolve()\n }\n\n function connect(c, query) {\n move(c, connecting)\n c.connect(query)\n return c\n }\n\n function onend(c) {\n move(c, ended)\n }\n\n function onopen(c) {\n if (queries.length === 0)\n return move(c, open)\n\n let max = Math.ceil(queries.length / (connecting.length + 1))\n , ready = true\n\n while (ready && queries.length && max-- > 0) {\n const query = queries.shift()\n if (query.reserve)\n return query.reserve(c)\n\n ready = c.execute(query)\n }\n\n ready\n ? move(c, busy)\n : move(c, full)\n }\n\n function onclose(c, e) {\n move(c, closed)\n c.reserved = null\n c.onclose && (c.onclose(e), c.onclose = null)\n options.onclose && options.onclose(c.id)\n queries.length && connect(c, queries.shift())\n }\n}\n\nfunction parseOptions(a, b) {\n if (a && a.shared)\n return a\n\n const env = process.env // eslint-disable-line\n , o = (!a || typeof a === 'string' ? b : a) || {}\n , { url, multihost } = parseUrl(a)\n , query = [...url.searchParams].reduce((a, [b, c]) => (a[b] = c, a), {})\n , host = o.hostname || o.host || multihost || url.hostname || env.PGHOST || 'localhost'\n , port = o.port || url.port || env.PGPORT || 5432\n , user = o.user || o.username || url.username || env.PGUSERNAME || env.PGUSER || osUsername()\n\n o.no_prepare && (o.prepare = false)\n query.sslmode && (query.ssl = query.sslmode, delete query.sslmode)\n 'timeout' in o && (console.log('The timeout option is deprecated, use idle_timeout instead'), o.idle_timeout = o.timeout) // eslint-disable-line\n query.sslrootcert === 'system' && (query.ssl = 'verify-full')\n\n const ints = ['idle_timeout', 'connect_timeout', 'max_lifetime', 'max_pipeline', 'backoff', 'keep_alive']\n const defaults = {\n max : globalThis.Cloudflare ? 3 : 10,\n ssl : false,\n sslnegotiation : null,\n idle_timeout : null,\n connect_timeout : 30,\n max_lifetime : max_lifetime,\n max_pipeline : 100,\n backoff : backoff,\n keep_alive : 60,\n prepare : true,\n debug : false,\n fetch_types : true,\n publications : 'alltables',\n target_session_attrs: null\n }\n\n return {\n host : Array.isArray(host) ? host : host.split(',').map(x => x.split(':')[0]),\n port : Array.isArray(port) ? port : host.split(',').map(x => parseInt(x.split(':')[1] || port)),\n path : o.path || host.indexOf('/') > -1 && host + '/.s.PGSQL.' + port,\n database : o.database || o.db || (url.pathname || '').slice(1) || env.PGDATABASE || user,\n user : user,\n pass : o.pass || o.password || url.password || env.PGPASSWORD || '',\n ...Object.entries(defaults).reduce(\n (acc, [k, d]) => {\n const value = k in o ? o[k] : k in query\n ? (query[k] === 'disable' || query[k] === 'false' ? false : query[k])\n : env['PG' + k.toUpperCase()] || d\n acc[k] = typeof value === 'string' && ints.includes(k)\n ? +value\n : value\n return acc\n },\n {}\n ),\n connection : {\n application_name: env.PGAPPNAME || 'postgres.js',\n ...o.connection,\n ...Object.entries(query).reduce((acc, [k, v]) => (k in defaults || (acc[k] = v), acc), {})\n },\n types : o.types || {},\n target_session_attrs: tsa(o, url, env),\n onnotice : o.onnotice,\n onnotify : o.onnotify,\n onclose : o.onclose,\n onparameter : o.onparameter,\n socket : o.socket,\n transform : parseTransform(o.transform || { undefined: undefined }),\n parameters : {},\n shared : { retries: 0, typeArrayMap: {} },\n ...mergeUserTypes(o.types)\n }\n}\n\nfunction tsa(o, url, env) {\n const x = o.target_session_attrs || url.searchParams.get('target_session_attrs') || env.PGTARGETSESSIONATTRS\n if (!x || ['read-write', 'read-only', 'primary', 'standby', 'prefer-standby'].includes(x))\n return x\n\n throw new Error('target_session_attrs ' + x + ' is not supported')\n}\n\nfunction backoff(retries) {\n return (0.5 + Math.random() / 2) * Math.min(3 ** retries / 100, 20)\n}\n\nfunction max_lifetime() {\n return 60 * (30 + Math.random() * 30)\n}\n\nfunction parseTransform(x) {\n return {\n undefined: x.undefined,\n column: {\n from: typeof x.column === 'function' ? x.column : x.column && x.column.from,\n to: x.column && x.column.to\n },\n value: {\n from: typeof x.value === 'function' ? x.value : x.value && x.value.from,\n to: x.value && x.value.to\n },\n row: {\n from: typeof x.row === 'function' ? x.row : x.row && x.row.from,\n to: x.row && x.row.to\n }\n }\n}\n\nfunction parseUrl(url) {\n if (!url || typeof url !== 'string')\n return { url: { searchParams: new Map() } }\n\n let host = url\n host = host.slice(host.indexOf('://') + 3).split(/[?/]/)[0]\n host = decodeURIComponent(host.slice(host.indexOf('@') + 1))\n\n const urlObj = new URL(url.replace(host, host.split(',')[0]))\n\n return {\n url: {\n username: decodeURIComponent(urlObj.username),\n password: decodeURIComponent(urlObj.password),\n host: urlObj.host,\n hostname: urlObj.hostname,\n port: urlObj.port,\n pathname: urlObj.pathname,\n searchParams: urlObj.searchParams\n },\n multihost: host.indexOf(',') > -1 && host\n }\n}\n\nfunction osUsername() {\n try {\n return os.userInfo().username // eslint-disable-line\n } catch (_) {\n return process.env.USERNAME || process.env.USER || process.env.LOGNAME // eslint-disable-line\n }\n}\n"],"names":[],"sourceRoot":""}