rivetkit 2.0.2 → 2.0.4

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 (246) hide show
  1. package/README.md +3 -5
  2. package/dist/schemas/actor-persist/v1.ts +225 -0
  3. package/dist/schemas/client-protocol/v1.ts +435 -0
  4. package/dist/schemas/file-system-driver/v1.ts +102 -0
  5. package/dist/tsup/actor/errors.cjs +77 -0
  6. package/dist/tsup/actor/errors.cjs.map +1 -0
  7. package/dist/tsup/actor/errors.d.cts +156 -0
  8. package/dist/tsup/actor/errors.d.ts +156 -0
  9. package/dist/tsup/actor/errors.js +77 -0
  10. package/dist/tsup/actor/errors.js.map +1 -0
  11. package/dist/tsup/chunk-3F2YSRJL.js +117 -0
  12. package/dist/tsup/chunk-3F2YSRJL.js.map +1 -0
  13. package/dist/tsup/chunk-4CXBCT26.cjs +250 -0
  14. package/dist/tsup/chunk-4CXBCT26.cjs.map +1 -0
  15. package/dist/tsup/chunk-4R73YDN3.cjs +20 -0
  16. package/dist/tsup/chunk-4R73YDN3.cjs.map +1 -0
  17. package/dist/tsup/chunk-6LJT3QRL.cjs +539 -0
  18. package/dist/tsup/chunk-6LJT3QRL.cjs.map +1 -0
  19. package/dist/tsup/chunk-GICQ3YCU.cjs +1792 -0
  20. package/dist/tsup/chunk-GICQ3YCU.cjs.map +1 -0
  21. package/dist/tsup/chunk-H26RP6GD.js +251 -0
  22. package/dist/tsup/chunk-H26RP6GD.js.map +1 -0
  23. package/dist/tsup/chunk-HI3HWJRC.js +20 -0
  24. package/dist/tsup/chunk-HI3HWJRC.js.map +1 -0
  25. package/dist/tsup/chunk-HLLF4B4Q.js +1792 -0
  26. package/dist/tsup/chunk-HLLF4B4Q.js.map +1 -0
  27. package/dist/tsup/chunk-IH6CKNDW.cjs +117 -0
  28. package/dist/tsup/chunk-IH6CKNDW.cjs.map +1 -0
  29. package/dist/tsup/chunk-LV2S3OU3.js +250 -0
  30. package/dist/tsup/chunk-LV2S3OU3.js.map +1 -0
  31. package/dist/tsup/chunk-LWNKVZG5.cjs +251 -0
  32. package/dist/tsup/chunk-LWNKVZG5.cjs.map +1 -0
  33. package/dist/tsup/chunk-NFU2BBT5.js +374 -0
  34. package/dist/tsup/chunk-NFU2BBT5.js.map +1 -0
  35. package/dist/tsup/chunk-PQY7KKTL.js +539 -0
  36. package/dist/tsup/chunk-PQY7KKTL.js.map +1 -0
  37. package/dist/tsup/chunk-QK72M5JB.js +45 -0
  38. package/dist/tsup/chunk-QK72M5JB.js.map +1 -0
  39. package/dist/tsup/chunk-QNNXFOQV.cjs +45 -0
  40. package/dist/tsup/chunk-QNNXFOQV.cjs.map +1 -0
  41. package/dist/tsup/chunk-SBHHJ6QS.cjs +374 -0
  42. package/dist/tsup/chunk-SBHHJ6QS.cjs.map +1 -0
  43. package/dist/tsup/chunk-TQ62L3X7.js +325 -0
  44. package/dist/tsup/chunk-TQ62L3X7.js.map +1 -0
  45. package/dist/tsup/chunk-VO7ZRVVD.cjs +6293 -0
  46. package/dist/tsup/chunk-VO7ZRVVD.cjs.map +1 -0
  47. package/dist/tsup/chunk-WHBPJNGW.cjs +325 -0
  48. package/dist/tsup/chunk-WHBPJNGW.cjs.map +1 -0
  49. package/dist/tsup/chunk-XJQHKJ4P.js +6293 -0
  50. package/dist/tsup/chunk-XJQHKJ4P.js.map +1 -0
  51. package/dist/tsup/client/mod.cjs +32 -0
  52. package/dist/tsup/client/mod.cjs.map +1 -0
  53. package/dist/tsup/client/mod.d.cts +20 -0
  54. package/dist/tsup/client/mod.d.ts +20 -0
  55. package/dist/tsup/client/mod.js +32 -0
  56. package/dist/tsup/client/mod.js.map +1 -0
  57. package/dist/tsup/common/log.cjs +21 -0
  58. package/dist/tsup/common/log.cjs.map +1 -0
  59. package/dist/tsup/common/log.d.cts +26 -0
  60. package/dist/tsup/common/log.d.ts +26 -0
  61. package/dist/tsup/common/log.js +21 -0
  62. package/dist/tsup/common/log.js.map +1 -0
  63. package/dist/tsup/common/websocket.cjs +10 -0
  64. package/dist/tsup/common/websocket.cjs.map +1 -0
  65. package/dist/tsup/common/websocket.d.cts +3 -0
  66. package/dist/tsup/common/websocket.d.ts +3 -0
  67. package/dist/tsup/common/websocket.js +10 -0
  68. package/dist/tsup/common/websocket.js.map +1 -0
  69. package/dist/tsup/common-CXCe7s6i.d.cts +218 -0
  70. package/dist/tsup/common-CXCe7s6i.d.ts +218 -0
  71. package/dist/tsup/connection-BI-6UIBJ.d.ts +2087 -0
  72. package/dist/tsup/connection-Dyd4NLGW.d.cts +2087 -0
  73. package/dist/tsup/driver-helpers/mod.cjs +30 -0
  74. package/dist/tsup/driver-helpers/mod.cjs.map +1 -0
  75. package/dist/tsup/driver-helpers/mod.d.cts +17 -0
  76. package/dist/tsup/driver-helpers/mod.d.ts +17 -0
  77. package/dist/tsup/driver-helpers/mod.js +30 -0
  78. package/dist/tsup/driver-helpers/mod.js.map +1 -0
  79. package/dist/tsup/driver-test-suite/mod.cjs +3411 -0
  80. package/dist/tsup/driver-test-suite/mod.cjs.map +1 -0
  81. package/dist/tsup/driver-test-suite/mod.d.cts +63 -0
  82. package/dist/tsup/driver-test-suite/mod.d.ts +63 -0
  83. package/dist/tsup/driver-test-suite/mod.js +3411 -0
  84. package/dist/tsup/driver-test-suite/mod.js.map +1 -0
  85. package/dist/tsup/inspector/mod.cjs +51 -0
  86. package/dist/tsup/inspector/mod.cjs.map +1 -0
  87. package/dist/tsup/inspector/mod.d.cts +408 -0
  88. package/dist/tsup/inspector/mod.d.ts +408 -0
  89. package/dist/tsup/inspector/mod.js +51 -0
  90. package/dist/tsup/inspector/mod.js.map +1 -0
  91. package/dist/tsup/mod.cjs +67 -0
  92. package/dist/tsup/mod.cjs.map +1 -0
  93. package/dist/tsup/mod.d.cts +105 -0
  94. package/dist/tsup/mod.d.ts +105 -0
  95. package/dist/tsup/mod.js +67 -0
  96. package/dist/tsup/mod.js.map +1 -0
  97. package/dist/tsup/router-endpoints-BTe_Rsdn.d.cts +65 -0
  98. package/dist/tsup/router-endpoints-CBSrKHmo.d.ts +65 -0
  99. package/dist/tsup/test/mod.cjs +17 -0
  100. package/dist/tsup/test/mod.cjs.map +1 -0
  101. package/dist/tsup/test/mod.d.cts +26 -0
  102. package/dist/tsup/test/mod.d.ts +26 -0
  103. package/dist/tsup/test/mod.js +17 -0
  104. package/dist/tsup/test/mod.js.map +1 -0
  105. package/dist/tsup/utils-fwx3o3K9.d.cts +18 -0
  106. package/dist/tsup/utils-fwx3o3K9.d.ts +18 -0
  107. package/dist/tsup/utils.cjs +26 -0
  108. package/dist/tsup/utils.cjs.map +1 -0
  109. package/dist/tsup/utils.d.cts +36 -0
  110. package/dist/tsup/utils.d.ts +36 -0
  111. package/dist/tsup/utils.js +26 -0
  112. package/dist/tsup/utils.js.map +1 -0
  113. package/package.json +208 -5
  114. package/src/actor/action.ts +178 -0
  115. package/src/actor/config.ts +497 -0
  116. package/src/actor/connection.ts +257 -0
  117. package/src/actor/context.ts +168 -0
  118. package/src/actor/database.ts +23 -0
  119. package/src/actor/definition.ts +82 -0
  120. package/src/actor/driver.ts +84 -0
  121. package/src/actor/errors.ts +422 -0
  122. package/src/actor/generic-conn-driver.ts +246 -0
  123. package/src/actor/instance.ts +1844 -0
  124. package/src/actor/keys.test.ts +266 -0
  125. package/src/actor/keys.ts +89 -0
  126. package/src/actor/log.ts +6 -0
  127. package/src/actor/mod.ts +108 -0
  128. package/src/actor/persisted.ts +42 -0
  129. package/src/actor/protocol/old.ts +297 -0
  130. package/src/actor/protocol/serde.ts +131 -0
  131. package/src/actor/router-endpoints.ts +688 -0
  132. package/src/actor/router.ts +265 -0
  133. package/src/actor/schedule.ts +17 -0
  134. package/src/actor/unstable-react.ts +110 -0
  135. package/src/actor/utils.ts +102 -0
  136. package/src/client/actor-common.ts +30 -0
  137. package/src/client/actor-conn.ts +865 -0
  138. package/src/client/actor-handle.ts +268 -0
  139. package/src/client/actor-query.ts +65 -0
  140. package/src/client/client.ts +554 -0
  141. package/src/client/config.ts +44 -0
  142. package/src/client/errors.ts +42 -0
  143. package/src/client/log.ts +5 -0
  144. package/src/client/mod.ts +60 -0
  145. package/src/client/raw-utils.ts +149 -0
  146. package/src/client/test.ts +44 -0
  147. package/src/client/utils.ts +152 -0
  148. package/src/common/eventsource-interface.ts +47 -0
  149. package/src/common/eventsource.ts +80 -0
  150. package/src/common/fake-event-source.ts +267 -0
  151. package/src/common/inline-websocket-adapter2.ts +454 -0
  152. package/src/common/log-levels.ts +27 -0
  153. package/src/common/log.ts +214 -0
  154. package/src/common/logfmt.ts +219 -0
  155. package/src/common/network.ts +2 -0
  156. package/src/common/router.ts +80 -0
  157. package/src/common/utils.ts +336 -0
  158. package/src/common/versioned-data.ts +95 -0
  159. package/src/common/websocket-interface.ts +49 -0
  160. package/src/common/websocket.ts +42 -0
  161. package/src/driver-helpers/mod.ts +22 -0
  162. package/src/driver-helpers/utils.ts +17 -0
  163. package/src/driver-test-suite/log.ts +5 -0
  164. package/src/driver-test-suite/mod.ts +239 -0
  165. package/src/driver-test-suite/tests/action-features.ts +136 -0
  166. package/src/driver-test-suite/tests/actor-conn-state.ts +249 -0
  167. package/src/driver-test-suite/tests/actor-conn.ts +349 -0
  168. package/src/driver-test-suite/tests/actor-driver.ts +25 -0
  169. package/src/driver-test-suite/tests/actor-error-handling.ts +158 -0
  170. package/src/driver-test-suite/tests/actor-handle.ts +292 -0
  171. package/src/driver-test-suite/tests/actor-inline-client.ts +152 -0
  172. package/src/driver-test-suite/tests/actor-inspector.ts +570 -0
  173. package/src/driver-test-suite/tests/actor-metadata.ts +116 -0
  174. package/src/driver-test-suite/tests/actor-onstatechange.ts +95 -0
  175. package/src/driver-test-suite/tests/actor-schedule.ts +108 -0
  176. package/src/driver-test-suite/tests/actor-sleep.ts +413 -0
  177. package/src/driver-test-suite/tests/actor-state.ts +54 -0
  178. package/src/driver-test-suite/tests/actor-vars.ts +93 -0
  179. package/src/driver-test-suite/tests/manager-driver.ts +367 -0
  180. package/src/driver-test-suite/tests/raw-http-direct-registry.ts +227 -0
  181. package/src/driver-test-suite/tests/raw-http-request-properties.ts +414 -0
  182. package/src/driver-test-suite/tests/raw-http.ts +347 -0
  183. package/src/driver-test-suite/tests/raw-websocket-direct-registry.ts +393 -0
  184. package/src/driver-test-suite/tests/raw-websocket.ts +484 -0
  185. package/src/driver-test-suite/tests/request-access.ts +230 -0
  186. package/src/driver-test-suite/utils.ts +71 -0
  187. package/src/drivers/default.ts +34 -0
  188. package/src/drivers/engine/actor-driver.ts +369 -0
  189. package/src/drivers/engine/config.ts +31 -0
  190. package/src/drivers/engine/kv.ts +3 -0
  191. package/src/drivers/engine/log.ts +5 -0
  192. package/src/drivers/engine/mod.ts +35 -0
  193. package/src/drivers/file-system/actor.ts +91 -0
  194. package/src/drivers/file-system/global-state.ts +686 -0
  195. package/src/drivers/file-system/log.ts +5 -0
  196. package/src/drivers/file-system/manager.ts +329 -0
  197. package/src/drivers/file-system/mod.ts +48 -0
  198. package/src/drivers/file-system/utils.ts +109 -0
  199. package/src/globals.d.ts +6 -0
  200. package/src/inspector/actor.ts +298 -0
  201. package/src/inspector/config.ts +88 -0
  202. package/src/inspector/log.ts +5 -0
  203. package/src/inspector/manager.ts +86 -0
  204. package/src/inspector/mod.ts +2 -0
  205. package/src/inspector/protocol/actor.ts +10 -0
  206. package/src/inspector/protocol/common.ts +196 -0
  207. package/src/inspector/protocol/manager.ts +10 -0
  208. package/src/inspector/protocol/mod.ts +2 -0
  209. package/src/inspector/utils.ts +76 -0
  210. package/src/manager/driver.ts +88 -0
  211. package/src/manager/hono-websocket-adapter.ts +342 -0
  212. package/src/manager/log.ts +5 -0
  213. package/src/manager/mod.ts +2 -0
  214. package/src/manager/protocol/mod.ts +24 -0
  215. package/src/manager/protocol/query.ts +89 -0
  216. package/src/manager/router.ts +412 -0
  217. package/src/manager-api/routes/actors-create.ts +16 -0
  218. package/src/manager-api/routes/actors-delete.ts +4 -0
  219. package/src/manager-api/routes/actors-get-by-id.ts +7 -0
  220. package/src/manager-api/routes/actors-get-or-create-by-id.ts +29 -0
  221. package/src/manager-api/routes/actors-get.ts +7 -0
  222. package/src/manager-api/routes/common.ts +18 -0
  223. package/src/mod.ts +18 -0
  224. package/src/registry/config.ts +32 -0
  225. package/src/registry/log.ts +5 -0
  226. package/src/registry/mod.ts +157 -0
  227. package/src/registry/run-config.ts +52 -0
  228. package/src/registry/serve.ts +52 -0
  229. package/src/remote-manager-driver/actor-http-client.ts +72 -0
  230. package/src/remote-manager-driver/actor-websocket-client.ts +63 -0
  231. package/src/remote-manager-driver/api-endpoints.ts +79 -0
  232. package/src/remote-manager-driver/api-utils.ts +43 -0
  233. package/src/remote-manager-driver/log.ts +5 -0
  234. package/src/remote-manager-driver/mod.ts +274 -0
  235. package/src/remote-manager-driver/ws-proxy.ts +180 -0
  236. package/src/schemas/actor-persist/mod.ts +1 -0
  237. package/src/schemas/actor-persist/versioned.ts +25 -0
  238. package/src/schemas/client-protocol/mod.ts +1 -0
  239. package/src/schemas/client-protocol/versioned.ts +63 -0
  240. package/src/schemas/file-system-driver/mod.ts +1 -0
  241. package/src/schemas/file-system-driver/versioned.ts +28 -0
  242. package/src/serde.ts +90 -0
  243. package/src/test/config.ts +16 -0
  244. package/src/test/log.ts +5 -0
  245. package/src/test/mod.ts +154 -0
  246. package/src/utils.ts +172 -0
@@ -0,0 +1,250 @@
1
+ import {
2
+ getEnvUniversal
3
+ } from "./chunk-PQY7KKTL.js";
4
+
5
+ // src/common/log.ts
6
+ import {
7
+ pino,
8
+ stdTimeFunctions
9
+ } from "pino";
10
+ import { z } from "zod";
11
+
12
+ // src/common/log-levels.ts
13
+ var LogLevels = {
14
+ TRACE: 0,
15
+ DEBUG: 1,
16
+ INFO: 2,
17
+ WARN: 3,
18
+ ERROR: 4,
19
+ CRITICAL: 5
20
+ };
21
+
22
+ // src/common/logfmt.ts
23
+ var LOG_LEVEL_COLORS = {
24
+ [LogLevels.CRITICAL]: "\x1B[31m",
25
+ // Red
26
+ [LogLevels.ERROR]: "\x1B[31m",
27
+ // Red
28
+ [LogLevels.WARN]: "\x1B[33m",
29
+ // Yellow
30
+ [LogLevels.INFO]: "\x1B[32m",
31
+ // Green
32
+ [LogLevels.DEBUG]: "\x1B[36m",
33
+ // Cyan
34
+ [LogLevels.TRACE]: "\x1B[36m"
35
+ // Cyan
36
+ };
37
+ var RESET_COLOR = "\x1B[0m";
38
+ function stringify(data) {
39
+ let line = "";
40
+ const entries = Object.entries(data);
41
+ for (let i = 0; i < entries.length; i++) {
42
+ const [key, valueRaw] = entries[i];
43
+ let isNull = false;
44
+ let valueString;
45
+ if (valueRaw == null) {
46
+ isNull = true;
47
+ valueString = "";
48
+ } else {
49
+ valueString = valueRaw.toString();
50
+ }
51
+ if (valueString.length > 512 && key !== "msg" && key !== "error")
52
+ valueString = `${valueString.slice(0, 512)}...`;
53
+ const needsQuoting = valueString.indexOf(" ") > -1 || valueString.indexOf("=") > -1;
54
+ const needsEscaping = valueString.indexOf('"') > -1 || valueString.indexOf("\\") > -1;
55
+ valueString = valueString.replace(/\n/g, "\\n");
56
+ if (needsEscaping) valueString = valueString.replace(/["\\]/g, "\\$&");
57
+ if (needsQuoting || needsEscaping) valueString = `"${valueString}"`;
58
+ if (valueString === "" && !isNull) valueString = '""';
59
+ if (LOGGER_CONFIG.enableColor) {
60
+ let color = "\x1B[2m";
61
+ if (key === "level") {
62
+ const level = LogLevels[valueString];
63
+ const levelColor = LOG_LEVEL_COLORS[level];
64
+ if (levelColor) {
65
+ color = levelColor;
66
+ }
67
+ } else if (key === "msg") {
68
+ color = "\x1B[32m";
69
+ } else if (key === "trace") {
70
+ color = "\x1B[34m";
71
+ }
72
+ line += `\x1B[0m\x1B[1m${key}\x1B[0m\x1B[2m=\x1B[0m${color}${valueString}${RESET_COLOR}`;
73
+ } else {
74
+ line += `${key}=${valueString}`;
75
+ }
76
+ if (i !== entries.length - 1) {
77
+ line += " ";
78
+ }
79
+ }
80
+ return line;
81
+ }
82
+ function formatTimestamp(date) {
83
+ const year = date.getUTCFullYear();
84
+ const month = String(date.getUTCMonth() + 1).padStart(2, "0");
85
+ const day = String(date.getUTCDate()).padStart(2, "0");
86
+ const hours = String(date.getUTCHours()).padStart(2, "0");
87
+ const minutes = String(date.getUTCMinutes()).padStart(2, "0");
88
+ const seconds = String(date.getUTCSeconds()).padStart(2, "0");
89
+ const milliseconds = String(date.getUTCMilliseconds()).padStart(3, "0");
90
+ return `${year}-${month}-${day}T${hours}:${minutes}:${seconds}.${milliseconds}Z`;
91
+ }
92
+ function castToLogValue(v) {
93
+ if (typeof v === "string" || typeof v === "number" || typeof v === "bigint" || typeof v === "boolean" || v === null || v === void 0) {
94
+ return v;
95
+ }
96
+ if (v instanceof Error) {
97
+ return String(v);
98
+ }
99
+ try {
100
+ return JSON.stringify(v);
101
+ } catch {
102
+ return "[cannot stringify]";
103
+ }
104
+ }
105
+ var LOGGER_CONFIG = {
106
+ enableColor: false,
107
+ enableSpreadObject: false,
108
+ enableErrorStack: false
109
+ };
110
+
111
+ // src/common/log.ts
112
+ var baseLogger;
113
+ var configuredLogLevel;
114
+ var loggerCache = /* @__PURE__ */ new Map();
115
+ var LogLevelSchema = z.enum([
116
+ "trace",
117
+ "debug",
118
+ "info",
119
+ "warn",
120
+ "error",
121
+ "fatal",
122
+ "silent"
123
+ ]);
124
+ function getPinoLevel(logLevel) {
125
+ if (logLevel) {
126
+ return logLevel;
127
+ }
128
+ if (configuredLogLevel) {
129
+ return configuredLogLevel;
130
+ }
131
+ const raw = (getEnvUniversal("LOG_LEVEL") || "warn").toString().toLowerCase();
132
+ const parsed = LogLevelSchema.safeParse(raw);
133
+ if (parsed.success) {
134
+ return parsed.data;
135
+ }
136
+ return "info";
137
+ }
138
+ function getIncludeTarget() {
139
+ return getEnvUniversal("LOG_TARGET") === "1";
140
+ }
141
+ function configureBaseLogger(logger) {
142
+ baseLogger = logger;
143
+ loggerCache.clear();
144
+ }
145
+ function customWrite(level, o) {
146
+ const entries = {};
147
+ if (getEnvUniversal("LOG_TIMESTAMP") === "1" && o.time) {
148
+ const date = typeof o.time === "number" ? new Date(o.time) : /* @__PURE__ */ new Date();
149
+ entries.ts = formatTimestamp(date);
150
+ }
151
+ entries.level = level.toUpperCase();
152
+ if (o.target) {
153
+ entries.target = o.target;
154
+ }
155
+ if (o.msg) {
156
+ entries.msg = o.msg;
157
+ }
158
+ for (const [key, value] of Object.entries(o)) {
159
+ if (key !== "time" && key !== "level" && key !== "target" && key !== "msg" && key !== "pid" && key !== "hostname") {
160
+ entries[key] = castToLogValue(value);
161
+ }
162
+ }
163
+ const output = stringify(entries);
164
+ console.log(output);
165
+ }
166
+ async function configureDefaultLogger(logLevel) {
167
+ if (logLevel) {
168
+ configuredLogLevel = logLevel;
169
+ }
170
+ baseLogger = pino({
171
+ level: getPinoLevel(logLevel),
172
+ messageKey: "msg",
173
+ // Do not include pid/hostname in output
174
+ base: {},
175
+ // Keep a string level in the output
176
+ formatters: {
177
+ level(_label, number) {
178
+ return { level: number };
179
+ }
180
+ },
181
+ timestamp: getEnvUniversal("LOG_TIMESTAMP") === "1" ? stdTimeFunctions.epochTime : false,
182
+ browser: {
183
+ write: {
184
+ fatal: customWrite.bind(null, "fatal"),
185
+ error: customWrite.bind(null, "error"),
186
+ warn: customWrite.bind(null, "warn"),
187
+ info: customWrite.bind(null, "info"),
188
+ debug: customWrite.bind(null, "debug"),
189
+ trace: customWrite.bind(null, "trace")
190
+ }
191
+ },
192
+ hooks: {
193
+ logMethod(inputArgs, _method, level) {
194
+ const levelMap = {
195
+ 10: "trace",
196
+ 20: "debug",
197
+ 30: "info",
198
+ 40: "warn",
199
+ 50: "error",
200
+ 60: "fatal"
201
+ };
202
+ const levelName = levelMap[level] || "info";
203
+ const time = getEnvUniversal("LOG_TIMESTAMP") === "1" ? Date.now() : void 0;
204
+ if (inputArgs.length >= 2) {
205
+ const [objOrMsg, msg] = inputArgs;
206
+ if (typeof objOrMsg === "object" && objOrMsg !== null) {
207
+ customWrite(levelName, { ...objOrMsg, msg, time });
208
+ } else {
209
+ customWrite(levelName, { msg: String(objOrMsg), time });
210
+ }
211
+ } else if (inputArgs.length === 1) {
212
+ const [objOrMsg] = inputArgs;
213
+ if (typeof objOrMsg === "object" && objOrMsg !== null) {
214
+ customWrite(levelName, { ...objOrMsg, time });
215
+ } else {
216
+ customWrite(levelName, { msg: String(objOrMsg), time });
217
+ }
218
+ }
219
+ }
220
+ }
221
+ });
222
+ loggerCache.clear();
223
+ }
224
+ function getBaseLogger() {
225
+ if (!baseLogger) {
226
+ configureDefaultLogger();
227
+ }
228
+ return baseLogger;
229
+ }
230
+ function getLogger(name = "default") {
231
+ const cached = loggerCache.get(name);
232
+ if (cached) {
233
+ return cached;
234
+ }
235
+ const base = getBaseLogger();
236
+ const child = getIncludeTarget() ? base.child({ target: name }) : base;
237
+ loggerCache.set(name, child);
238
+ return child;
239
+ }
240
+
241
+ export {
242
+ LogLevelSchema,
243
+ getPinoLevel,
244
+ getIncludeTarget,
245
+ configureBaseLogger,
246
+ configureDefaultLogger,
247
+ getBaseLogger,
248
+ getLogger
249
+ };
250
+ //# sourceMappingURL=chunk-LV2S3OU3.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../src/common/log.ts","../../src/common/log-levels.ts","../../src/common/logfmt.ts"],"sourcesContent":["import {\n\ttype LevelWithSilent,\n\ttype Logger,\n\tpino,\n\tstdTimeFunctions,\n} from \"pino\";\nimport { z } from \"zod\";\nimport { getEnvUniversal } from \"@/utils\";\nimport {\n\tcastToLogValue,\n\tformatTimestamp,\n\tLOGGER_CONFIG,\n\tstringify,\n} from \"./logfmt\";\n\nexport type { Logger } from \"pino\";\n\nlet baseLogger: Logger | undefined;\nlet configuredLogLevel: LogLevel | undefined;\n\n/** Cache of child loggers by logger name. */\nconst loggerCache = new Map<string, Logger>();\n\nexport const LogLevelSchema = z.enum([\n\t\"trace\",\n\t\"debug\",\n\t\"info\",\n\t\"warn\",\n\t\"error\",\n\t\"fatal\",\n\t\"silent\",\n]);\n\nexport type LogLevel = z.infer<typeof LogLevelSchema>;\n\nexport function getPinoLevel(logLevel?: LogLevel): LevelWithSilent {\n\t// Priority: provided > configured > env > default\n\tif (logLevel) {\n\t\treturn logLevel;\n\t}\n\n\tif (configuredLogLevel) {\n\t\treturn configuredLogLevel;\n\t}\n\n\tconst raw = (getEnvUniversal(\"LOG_LEVEL\") || \"warn\").toString().toLowerCase();\n\n\tconst parsed = LogLevelSchema.safeParse(raw);\n\tif (parsed.success) {\n\t\treturn parsed.data;\n\t}\n\n\t// Default to info if invalid\n\treturn \"info\";\n}\n\nexport function getIncludeTarget(): boolean {\n\treturn getEnvUniversal(\"LOG_TARGET\") === \"1\";\n}\n\n/**\n * Configure a custom base logger.\n */\nexport function configureBaseLogger(logger: Logger): void {\n\tbaseLogger = logger;\n\tloggerCache.clear();\n}\n\n// TODO: This can be simplified in logfmt.ts\nfunction customWrite(level: string, o: any) {\n\tconst entries: any = {};\n\n\t// Add timestamp if enabled\n\tif (getEnvUniversal(\"LOG_TIMESTAMP\") === \"1\" && o.time) {\n\t\tconst date = typeof o.time === \"number\" ? new Date(o.time) : new Date();\n\t\tentries.ts = formatTimestamp(date);\n\t}\n\n\t// Add level\n\tentries.level = level.toUpperCase();\n\n\t// Add target if present\n\tif (o.target) {\n\t\tentries.target = o.target;\n\t}\n\n\t// Add message\n\tif (o.msg) {\n\t\tentries.msg = o.msg;\n\t}\n\n\t// Add other properties\n\tfor (const [key, value] of Object.entries(o)) {\n\t\tif (\n\t\t\tkey !== \"time\" &&\n\t\t\tkey !== \"level\" &&\n\t\t\tkey !== \"target\" &&\n\t\t\tkey !== \"msg\" &&\n\t\t\tkey !== \"pid\" &&\n\t\t\tkey !== \"hostname\"\n\t\t) {\n\t\t\tentries[key] = castToLogValue(value);\n\t\t}\n\t}\n\n\tconst output = stringify(entries);\n\tconsole.log(output);\n}\n\n/**\n * Configure the default logger with optional log level.\n */\nexport async function configureDefaultLogger(\n\tlogLevel?: LogLevel,\n): Promise<void> {\n\t// Store the configured log level\n\tif (logLevel) {\n\t\tconfiguredLogLevel = logLevel;\n\t}\n\n\tbaseLogger = pino({\n\t\tlevel: getPinoLevel(logLevel),\n\t\tmessageKey: \"msg\",\n\t\t// Do not include pid/hostname in output\n\t\tbase: {},\n\t\t// Keep a string level in the output\n\t\tformatters: {\n\t\t\tlevel(_label: string, number: number) {\n\t\t\t\treturn { level: number };\n\t\t\t},\n\t\t},\n\t\ttimestamp:\n\t\t\tgetEnvUniversal(\"LOG_TIMESTAMP\") === \"1\"\n\t\t\t\t? stdTimeFunctions.epochTime\n\t\t\t\t: false,\n\t\tbrowser: {\n\t\t\twrite: {\n\t\t\t\tfatal: customWrite.bind(null, \"fatal\"),\n\t\t\t\terror: customWrite.bind(null, \"error\"),\n\t\t\t\twarn: customWrite.bind(null, \"warn\"),\n\t\t\t\tinfo: customWrite.bind(null, \"info\"),\n\t\t\t\tdebug: customWrite.bind(null, \"debug\"),\n\t\t\t\ttrace: customWrite.bind(null, \"trace\"),\n\t\t\t},\n\t\t},\n\t\thooks: {\n\t\t\tlogMethod(inputArgs, _method, level) {\n\t\t\t\t// TODO: This is a hack to not implement our own transport target. We can get better perf if we have our own transport target.\n\n\t\t\t\tconst levelMap: Record<number, string> = {\n\t\t\t\t\t10: \"trace\",\n\t\t\t\t\t20: \"debug\",\n\t\t\t\t\t30: \"info\",\n\t\t\t\t\t40: \"warn\",\n\t\t\t\t\t50: \"error\",\n\t\t\t\t\t60: \"fatal\",\n\t\t\t\t};\n\t\t\t\tconst levelName = levelMap[level] || \"info\";\n\t\t\t\tconst time =\n\t\t\t\t\tgetEnvUniversal(\"LOG_TIMESTAMP\") === \"1\" ? Date.now() : undefined;\n\t\t\t\t// TODO: This can be simplified in logfmt.ts\n\t\t\t\tif (inputArgs.length >= 2) {\n\t\t\t\t\tconst [objOrMsg, msg] = inputArgs;\n\t\t\t\t\tif (typeof objOrMsg === \"object\" && objOrMsg !== null) {\n\t\t\t\t\t\tcustomWrite(levelName, { ...objOrMsg, msg, time });\n\t\t\t\t\t} else {\n\t\t\t\t\t\tcustomWrite(levelName, { msg: String(objOrMsg), time });\n\t\t\t\t\t}\n\t\t\t\t} else if (inputArgs.length === 1) {\n\t\t\t\t\tconst [objOrMsg] = inputArgs;\n\t\t\t\t\tif (typeof objOrMsg === \"object\" && objOrMsg !== null) {\n\t\t\t\t\t\tcustomWrite(levelName, { ...objOrMsg, time });\n\t\t\t\t\t} else {\n\t\t\t\t\t\tcustomWrite(levelName, { msg: String(objOrMsg), time });\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t},\n\t\t},\n\t});\n\n\tloggerCache.clear();\n}\n\n/**\n * Get or initialize the base logger.\n */\nexport function getBaseLogger(): Logger {\n\tif (!baseLogger) {\n\t\tconfigureDefaultLogger();\n\t}\n\treturn baseLogger!;\n}\n\n/**\n * Returns a child logger with `target` bound for the given name.\n */\nexport function getLogger(name = \"default\"): Logger {\n\t// Check cache first\n\tconst cached = loggerCache.get(name);\n\tif (cached) {\n\t\treturn cached;\n\t}\n\n\t// Create\n\tconst base = getBaseLogger();\n\n\t// Add target to log if enabled\n\tconst child = getIncludeTarget() ? base.child({ target: name }) : base;\n\n\t// Cache the logger\n\tloggerCache.set(name, child);\n\n\treturn child;\n}\n","export type LogLevel =\n\t| \"TRACE\"\n\t| \"DEBUG\"\n\t| \"INFO\"\n\t| \"WARN\"\n\t| \"ERROR\"\n\t| \"CRITICAL\";\n\nexport const LogLevels: Record<LogLevel, LevelIndex> = {\n\tTRACE: 0,\n\tDEBUG: 1,\n\tINFO: 2,\n\tWARN: 3,\n\tERROR: 4,\n\tCRITICAL: 5,\n} as const;\n\nexport const LevelNameMap: Record<number, LogLevel> = {\n\t0: \"TRACE\",\n\t1: \"DEBUG\",\n\t2: \"INFO\",\n\t3: \"WARN\",\n\t4: \"ERROR\",\n\t5: \"CRITICAL\",\n};\n\nexport type LevelIndex = number;\n","import { type LogLevel, LogLevels } from \"./log-levels\";\n\nconst LOG_LEVEL_COLORS: Record<number, string> = {\n\t[LogLevels.CRITICAL]: \"\\x1b[31m\", // Red\n\t[LogLevels.ERROR]: \"\\x1b[31m\", // Red\n\t[LogLevels.WARN]: \"\\x1b[33m\", // Yellow\n\t[LogLevels.INFO]: \"\\x1b[32m\", // Green\n\t[LogLevels.DEBUG]: \"\\x1b[36m\", // Cyan\n\t[LogLevels.TRACE]: \"\\x1b[36m\", // Cyan\n};\n\nconst RESET_COLOR = \"\\x1b[0m\";\n\n/**\n * Serializes logfmt line from an object.\n *\n * ## Styling Methodology\n *\n * The three things you need to know for every log line is the level, the\n * message, and who called it. These properties are highlighted in different colros\n * and sorted in th eorder that you usually read them.\n *\n * Once you've found a log line you care about, then you want to find the\n * property you need to see. The property names are bolded and the default color\n * while the rest of the data is dim. This lets you scan to find the property\n * name quickly then look closer to read the data associated with the\n * property.\n */\nexport function stringify(data: any) {\n\tlet line = \"\";\n\tconst entries = Object.entries(data);\n\n\tfor (let i = 0; i < entries.length; i++) {\n\t\tconst [key, valueRaw] = entries[i];\n\n\t\tlet isNull = false;\n\t\tlet valueString: string;\n\t\tif (valueRaw == null) {\n\t\t\tisNull = true;\n\t\t\tvalueString = \"\";\n\t\t} else {\n\t\t\tvalueString = valueRaw.toString();\n\t\t}\n\n\t\t// Clip value unless specifically the error message\n\t\tif (valueString.length > 512 && key !== \"msg\" && key !== \"error\")\n\t\t\tvalueString = `${valueString.slice(0, 512)}...`;\n\n\t\tconst needsQuoting =\n\t\t\tvalueString.indexOf(\" \") > -1 || valueString.indexOf(\"=\") > -1;\n\t\tconst needsEscaping =\n\t\t\tvalueString.indexOf('\"') > -1 || valueString.indexOf(\"\\\\\") > -1;\n\n\t\tvalueString = valueString.replace(/\\n/g, \"\\\\n\");\n\t\tif (needsEscaping) valueString = valueString.replace(/[\"\\\\]/g, \"\\\\$&\");\n\t\tif (needsQuoting || needsEscaping) valueString = `\"${valueString}\"`;\n\t\tif (valueString === \"\" && !isNull) valueString = '\"\"';\n\n\t\tif (LOGGER_CONFIG.enableColor) {\n\t\t\t// With color\n\n\t\t\t// Special message colors\n\t\t\tlet color = \"\\x1b[2m\";\n\t\t\tif (key === \"level\") {\n\t\t\t\tconst level = LogLevels[valueString as LogLevel];\n\t\t\t\tconst levelColor = LOG_LEVEL_COLORS[level];\n\t\t\t\tif (levelColor) {\n\t\t\t\t\tcolor = levelColor;\n\t\t\t\t}\n\t\t\t} else if (key === \"msg\") {\n\t\t\t\tcolor = \"\\x1b[32m\";\n\t\t\t} else if (key === \"trace\") {\n\t\t\t\tcolor = \"\\x1b[34m\";\n\t\t\t}\n\n\t\t\t// Format line\n\t\t\tline += `\\x1b[0m\\x1b[1m${key}\\x1b[0m\\x1b[2m=\\x1b[0m${color}${valueString}${RESET_COLOR}`;\n\t\t} else {\n\t\t\t// No color\n\t\t\tline += `${key}=${valueString}`;\n\t\t}\n\n\t\tif (i !== entries.length - 1) {\n\t\t\tline += \" \";\n\t\t}\n\t}\n\n\treturn line;\n}\n\nexport function formatTimestamp(date: Date): string {\n\tconst year = date.getUTCFullYear();\n\tconst month = String(date.getUTCMonth() + 1).padStart(2, \"0\");\n\tconst day = String(date.getUTCDate()).padStart(2, \"0\");\n\tconst hours = String(date.getUTCHours()).padStart(2, \"0\");\n\tconst minutes = String(date.getUTCMinutes()).padStart(2, \"0\");\n\tconst seconds = String(date.getUTCSeconds()).padStart(2, \"0\");\n\tconst milliseconds = String(date.getUTCMilliseconds()).padStart(3, \"0\");\n\n\treturn `${year}-${month}-${day}T${hours}:${minutes}:${seconds}.${milliseconds}Z`;\n}\n\nexport function castToLogValue(v: unknown): any {\n\tif (\n\t\ttypeof v === \"string\" ||\n\t\ttypeof v === \"number\" ||\n\t\ttypeof v === \"bigint\" ||\n\t\ttypeof v === \"boolean\" ||\n\t\tv === null ||\n\t\tv === undefined\n\t) {\n\t\treturn v;\n\t}\n\tif (v instanceof Error) {\n\t\t//args.push(...errorToLogEntries(k, v));\n\t\treturn String(v);\n\t}\n\ttry {\n\t\treturn JSON.stringify(v);\n\t} catch {\n\t\treturn \"[cannot stringify]\";\n\t}\n}\n\n// MARK: Config\ninterface GlobalLoggerConfig {\n\tenableColor: boolean;\n\tenableSpreadObject: boolean;\n\tenableErrorStack: boolean;\n}\n\nexport const LOGGER_CONFIG: GlobalLoggerConfig = {\n\tenableColor: false,\n\tenableSpreadObject: false,\n\tenableErrorStack: false,\n};\n\n// MARK: Utils\n/**\n * Converts an object in to an easier to read KV of entries.\n */\nexport function spreadObjectToLogEntries(base: string, data: unknown): any {\n\tif (\n\t\tLOGGER_CONFIG.enableSpreadObject &&\n\t\ttypeof data === \"object\" &&\n\t\t!Array.isArray(data) &&\n\t\tdata !== null &&\n\t\tObject.keys(data).length !== 0 &&\n\t\tObject.keys(data).length < 16\n\t) {\n\t\tconst logData: any = {};\n\t\tfor (const key in data) {\n\t\t\tObject.assign(\n\t\t\t\tlogData,\n\t\t\t\tspreadObjectToLogEntries(\n\t\t\t\t\t`${base}.${key}`,\n\t\t\t\t\t// biome-ignore lint/suspicious/noExplicitAny: FIXME\n\t\t\t\t\t(data as any)[key],\n\t\t\t\t),\n\t\t\t);\n\t\t}\n\t\treturn logData;\n\t}\n\n\treturn { [base]: JSON.stringify(data) };\n}\n\nexport function errorToLogEntries(base: string, error: unknown): any {\n\tif (error instanceof Error) {\n\t\treturn {\n\t\t\t[`${base}.message`]: error.message,\n\t\t\t...(LOGGER_CONFIG.enableErrorStack && error.stack\n\t\t\t\t? { [`${base}.stack`]: formatStackTrace(error.stack) }\n\t\t\t\t: {}),\n\t\t\t...(error.cause ? errorToLogEntries(`${base}.cause`, error.cause) : {}),\n\t\t};\n\t}\n\treturn { [base]: `${error}` };\n}\n\n// export function errorToLogEntries(base: string, error: unknown): LogEntry[] {\n// \tif (error instanceof RuntimeError) {\n// \t\treturn [\n// \t\t\t[`${base}.code`, error.code],\n// \t\t\t[`${base}.description`, error.errorConfig?.description],\n// \t\t\t[`${base}.module`, error.moduleName],\n// \t\t\t...(error.trace ? [[`${base}.trace`, stringifyTrace(error.trace)] as LogEntry] : []),\n// \t\t\t...(LOGGER_CONFIG.enableErrorStack && error.stack\n// \t\t\t\t? [[`${base}.stack`, formatStackTrace(error.stack)] as LogEntry]\n// \t\t\t\t: []),\n// \t\t\t...(error.meta ? [[`${base}.meta`, JSON.stringify(error.meta)] as LogEntry] : []),\n// \t\t\t...(error.cause ? errorToLogEntries(`${base}.cause`, error.cause) : []),\n// \t\t];\n// \t} else if (error instanceof Error) {\n// \t\treturn [\n// \t\t\t[`${base}.name`, error.name],\n// \t\t\t[`${base}.message`, error.message],\n// \t\t\t...(LOGGER_CONFIG.enableErrorStack && error.stack\n// \t\t\t\t? [[`${base}.stack`, formatStackTrace(error.stack)] as LogEntry]\n// \t\t\t\t: []),\n// \t\t\t...(error.cause ? errorToLogEntries(`${base}.cause`, error.cause) : []),\n// \t\t];\n// \t} else {\n// \t\treturn [\n// \t\t\t[base, `${error}`],\n// \t\t];\n// \t}\n// }\n\n/**\n * Formats a JS stack trace in to a legible one-liner.\n */\nfunction formatStackTrace(stackTrace: string): string {\n\tconst regex = /at (.+?)$/gm;\n\tconst matches = [...stackTrace.matchAll(regex)];\n\t// Reverse array since the stack goes from top level -> bottom level\n\tmatches.reverse();\n\treturn matches.map((match) => match[1].trim()).join(\" > \");\n}\n"],"mappings":"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","names":[]}
@@ -0,0 +1,251 @@
1
+ "use strict";Object.defineProperty(exports, "__esModule", {value: true}); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
2
+
3
+
4
+
5
+
6
+
7
+
8
+
9
+ var _chunkGICQ3YCUcjs = require('./chunk-GICQ3YCU.cjs');
10
+
11
+ // src/inspector/protocol/common.ts
12
+ var _v4 = require('zod/v4'); var _v42 = _interopRequireDefault(_v4);
13
+
14
+ // src/manager/protocol/query.ts
15
+ var _zod = require('zod');
16
+ var MAX_ACTOR_KEY_SIZE = 128;
17
+ var ActorKeySchema = _zod.z.array(_zod.z.string().max(MAX_ACTOR_KEY_SIZE));
18
+ var CreateRequestSchema = _zod.z.object({
19
+ name: _zod.z.string(),
20
+ key: ActorKeySchema,
21
+ input: _zod.z.unknown().optional(),
22
+ region: _zod.z.string().optional()
23
+ });
24
+ var GetForKeyRequestSchema = _zod.z.object({
25
+ name: _zod.z.string(),
26
+ key: ActorKeySchema
27
+ });
28
+ var GetOrCreateRequestSchema = _zod.z.object({
29
+ name: _zod.z.string(),
30
+ key: ActorKeySchema,
31
+ input: _zod.z.unknown().optional(),
32
+ region: _zod.z.string().optional()
33
+ });
34
+ var ActorQuerySchema = _zod.z.union([
35
+ _zod.z.object({
36
+ getForId: _zod.z.object({
37
+ name: _zod.z.string(),
38
+ actorId: _zod.z.string()
39
+ })
40
+ }),
41
+ _zod.z.object({
42
+ getForKey: GetForKeyRequestSchema
43
+ }),
44
+ _zod.z.object({
45
+ getOrCreateForKey: GetOrCreateRequestSchema
46
+ }),
47
+ _zod.z.object({
48
+ create: CreateRequestSchema
49
+ })
50
+ ]);
51
+ var ConnectRequestSchema = _zod.z.object({
52
+ query: ActorQuerySchema.describe(_chunkGICQ3YCUcjs.HEADER_ACTOR_QUERY),
53
+ encoding: _chunkGICQ3YCUcjs.EncodingSchema.describe(_chunkGICQ3YCUcjs.HEADER_ENCODING),
54
+ connParams: _zod.z.string().optional().describe(_chunkGICQ3YCUcjs.HEADER_CONN_PARAMS)
55
+ });
56
+ var ConnectWebSocketRequestSchema = _zod.z.object({
57
+ query: ActorQuerySchema.describe("query"),
58
+ encoding: _chunkGICQ3YCUcjs.EncodingSchema.describe("encoding"),
59
+ connParams: _zod.z.unknown().optional().describe("conn_params")
60
+ });
61
+ var ConnMessageRequestSchema = _zod.z.object({
62
+ actorId: _zod.z.string().describe(_chunkGICQ3YCUcjs.HEADER_ACTOR_ID),
63
+ connId: _zod.z.string().describe(_chunkGICQ3YCUcjs.HEADER_CONN_ID),
64
+ encoding: _chunkGICQ3YCUcjs.EncodingSchema.describe(_chunkGICQ3YCUcjs.HEADER_ENCODING),
65
+ connToken: _zod.z.string().describe(_chunkGICQ3YCUcjs.HEADER_CONN_TOKEN)
66
+ });
67
+ var ResolveRequestSchema = _zod.z.object({
68
+ query: ActorQuerySchema.describe(_chunkGICQ3YCUcjs.HEADER_ACTOR_QUERY),
69
+ connParams: _zod.z.string().optional().describe(_chunkGICQ3YCUcjs.HEADER_CONN_PARAMS)
70
+ });
71
+
72
+ // src/inspector/protocol/common.ts
73
+ var ActorId = _v42.default.string().brand("ActorId");
74
+ var ActorFeature = /* @__PURE__ */ ((ActorFeature2) => {
75
+ ActorFeature2["Logs"] = "logs";
76
+ ActorFeature2["Config"] = "config";
77
+ ActorFeature2["Connections"] = "connections";
78
+ ActorFeature2["State"] = "state";
79
+ ActorFeature2["Console"] = "console";
80
+ ActorFeature2["Runtime"] = "runtime";
81
+ ActorFeature2["Metrics"] = "metrics";
82
+ ActorFeature2["EventsMonitoring"] = "events-monitoring";
83
+ ActorFeature2["Database"] = "database";
84
+ return ActorFeature2;
85
+ })(ActorFeature || {});
86
+ var ActorLogEntry = _v42.default.object({
87
+ level: _v42.default.string(),
88
+ message: _v42.default.string(),
89
+ timestamp: _v42.default.string(),
90
+ metadata: _v42.default.record(_v42.default.string(), _v42.default.any()).optional()
91
+ });
92
+ var ActorSchema = _v42.default.object({
93
+ id: ActorId,
94
+ name: _v42.default.string(),
95
+ key: _v42.default.array(_v42.default.string()),
96
+ tags: _v42.default.record(_v42.default.string(), _v42.default.string()).optional(),
97
+ region: _v42.default.string().optional(),
98
+ createdAt: _v42.default.string().optional(),
99
+ startedAt: _v42.default.string().optional(),
100
+ destroyedAt: _v42.default.string().optional(),
101
+ features: _v42.default.array(_v42.default.enum(ActorFeature)).optional()
102
+ });
103
+ var OperationSchema = _v42.default.discriminatedUnion("op", [
104
+ _v42.default.object({
105
+ op: _v42.default.literal("remove"),
106
+ path: _v42.default.string()
107
+ }),
108
+ _v42.default.object({
109
+ op: _v42.default.literal("add"),
110
+ path: _v42.default.string(),
111
+ value: _v42.default.unknown()
112
+ }),
113
+ _v42.default.object({
114
+ op: _v42.default.literal("replace"),
115
+ path: _v42.default.string(),
116
+ value: _v42.default.unknown()
117
+ }),
118
+ _v42.default.object({
119
+ op: _v42.default.literal("move"),
120
+ path: _v42.default.string(),
121
+ from: _v42.default.string()
122
+ }),
123
+ _v42.default.object({
124
+ op: _v42.default.literal("copy"),
125
+ path: _v42.default.string(),
126
+ from: _v42.default.string()
127
+ }),
128
+ _v42.default.object({
129
+ op: _v42.default.literal("test"),
130
+ path: _v42.default.string(),
131
+ value: _v42.default.unknown()
132
+ })
133
+ ]);
134
+ var PatchSchema = _v42.default.array(OperationSchema);
135
+ var ConnectionSchema = _v42.default.object({
136
+ params: _v42.default.record(_v42.default.string(), _v42.default.any()).optional(),
137
+ id: _v42.default.string(),
138
+ stateEnabled: _v42.default.boolean().optional(),
139
+ state: _v42.default.any().optional(),
140
+ auth: _v42.default.record(_v42.default.string(), _v42.default.any()).optional()
141
+ });
142
+ var RealtimeEventSchema = _v42.default.discriminatedUnion("type", [
143
+ _v42.default.object({
144
+ type: _v42.default.literal("action"),
145
+ name: _v42.default.string(),
146
+ args: _v42.default.array(_v42.default.any()),
147
+ connId: _v42.default.string()
148
+ }),
149
+ _v42.default.object({
150
+ type: _v42.default.literal("broadcast"),
151
+ eventName: _v42.default.string(),
152
+ args: _v42.default.array(_v42.default.any())
153
+ }),
154
+ _v42.default.object({
155
+ type: _v42.default.literal("subscribe"),
156
+ eventName: _v42.default.string(),
157
+ connId: _v42.default.string()
158
+ }),
159
+ _v42.default.object({
160
+ type: _v42.default.literal("unsubscribe"),
161
+ eventName: _v42.default.string(),
162
+ connId: _v42.default.string()
163
+ }),
164
+ _v42.default.object({
165
+ type: _v42.default.literal("event"),
166
+ eventName: _v42.default.string(),
167
+ args: _v42.default.array(_v42.default.any()),
168
+ connId: _v42.default.string()
169
+ })
170
+ ]);
171
+ var RecordedRealtimeEventSchema = RealtimeEventSchema.and(
172
+ _v42.default.object({
173
+ id: _v42.default.string(),
174
+ timestamp: _v42.default.number()
175
+ })
176
+ );
177
+ var DatabaseQuerySchema = _v42.default.object({
178
+ sql: _v42.default.string(),
179
+ args: _v42.default.array(_v42.default.string().or(_v42.default.number()))
180
+ });
181
+ var TableSchema = _v42.default.object({
182
+ schema: _v42.default.string(),
183
+ name: _v42.default.string(),
184
+ type: _v42.default.enum(["table", "view"])
185
+ });
186
+ var TablesSchema = _v42.default.array(TableSchema);
187
+ var ColumnSchema = _v42.default.object({
188
+ cid: _v42.default.number(),
189
+ name: _v42.default.string(),
190
+ type: _v42.default.string().toLowerCase().transform((val) => {
191
+ return _v42.default.enum(["integer", "text", "real", "blob", "numeric", "serial"]).parse(val);
192
+ }),
193
+ notnull: _v42.default.coerce.boolean(),
194
+ dflt_value: _v42.default.string().nullable(),
195
+ pk: _v42.default.coerce.boolean().nullable()
196
+ });
197
+ var ColumnsSchema = _v42.default.array(ColumnSchema);
198
+ var ForeignKeySchema = _v42.default.object({
199
+ id: _v42.default.number(),
200
+ table: _v42.default.string(),
201
+ from: _v42.default.string(),
202
+ to: _v42.default.string()
203
+ });
204
+ var ForeignKeysSchema = _v42.default.array(ForeignKeySchema);
205
+ var BuildSchema = _v42.default.object({
206
+ name: _v42.default.string(),
207
+ createdAt: _v42.default.string().optional(),
208
+ tags: _v42.default.record(_v42.default.string(), _v42.default.string()).optional()
209
+ });
210
+ var BuildsSchema = _v42.default.array(BuildSchema);
211
+ var CreateActorSchema = _v42.default.object({
212
+ name: _v42.default.string(),
213
+ // FIXME: Replace with ActorKeySchema when ready
214
+ key: _v42.default.array(_v42.default.string().max(MAX_ACTOR_KEY_SIZE)),
215
+ input: _v42.default.any()
216
+ });
217
+
218
+ // src/inspector/protocol/actor.ts
219
+ var _client = require('hono/client');
220
+ var client = _client.hc.call(void 0, "");
221
+ var createActorInspectorClient = (...args) => _client.hc.call(void 0, ...args);
222
+
223
+ // src/inspector/protocol/manager.ts
224
+
225
+ var client2 = _client.hc.call(void 0, "");
226
+ var createManagerInspectorClient = (...args) => _client.hc.call(void 0, ...args);
227
+
228
+
229
+
230
+
231
+
232
+
233
+
234
+
235
+
236
+
237
+
238
+
239
+
240
+
241
+
242
+
243
+
244
+
245
+
246
+
247
+
248
+
249
+
250
+ exports.ActorId = ActorId; exports.ActorFeature = ActorFeature; exports.ActorLogEntry = ActorLogEntry; exports.ActorSchema = ActorSchema; exports.OperationSchema = OperationSchema; exports.PatchSchema = PatchSchema; exports.ConnectionSchema = ConnectionSchema; exports.RealtimeEventSchema = RealtimeEventSchema; exports.RecordedRealtimeEventSchema = RecordedRealtimeEventSchema; exports.DatabaseQuerySchema = DatabaseQuerySchema; exports.TableSchema = TableSchema; exports.TablesSchema = TablesSchema; exports.ColumnSchema = ColumnSchema; exports.ColumnsSchema = ColumnsSchema; exports.ForeignKeySchema = ForeignKeySchema; exports.ForeignKeysSchema = ForeignKeysSchema; exports.BuildSchema = BuildSchema; exports.BuildsSchema = BuildsSchema; exports.CreateActorSchema = CreateActorSchema; exports.createActorInspectorClient = createActorInspectorClient; exports.createManagerInspectorClient = createManagerInspectorClient;
251
+ //# sourceMappingURL=chunk-LWNKVZG5.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["/Users/nathan/rivetkit/packages/rivetkit/dist/tsup/chunk-LWNKVZG5.cjs","../../src/inspector/protocol/common.ts","../../src/manager/protocol/query.ts","../../src/inspector/protocol/actor.ts","../../src/inspector/protocol/manager.ts"],"names":["z","ActorFeature","client","hc"],"mappings":"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","file":"/Users/nathan/rivetkit/packages/rivetkit/dist/tsup/chunk-LWNKVZG5.cjs","sourcesContent":[null,"import z from \"zod/v4\";\nimport { ActorKeySchema, MAX_ACTOR_KEY_SIZE } from \"@/manager/protocol/query\";\n\nexport const ActorId = z.string().brand(\"ActorId\");\nexport type ActorId = z.infer<typeof ActorId>;\n\nexport enum ActorFeature {\n\tLogs = \"logs\",\n\tConfig = \"config\",\n\tConnections = \"connections\",\n\tState = \"state\",\n\tConsole = \"console\",\n\tRuntime = \"runtime\",\n\tMetrics = \"metrics\",\n\tEventsMonitoring = \"events-monitoring\",\n\tDatabase = \"database\",\n}\n\nexport const ActorLogEntry = z.object({\n\tlevel: z.string(),\n\tmessage: z.string(),\n\ttimestamp: z.string(),\n\tmetadata: z.record(z.string(), z.any()).optional(),\n});\n\nexport const ActorSchema = z.object({\n\tid: ActorId,\n\tname: z.string(),\n\tkey: z.array(z.string()),\n\ttags: z.record(z.string(), z.string()).optional(),\n\tregion: z.string().optional(),\n\tcreatedAt: z.string().optional(),\n\tstartedAt: z.string().optional(),\n\tdestroyedAt: z.string().optional(),\n\tfeatures: z.array(z.enum(ActorFeature)).optional(),\n});\n\nexport type Actor = z.infer<typeof ActorSchema>;\nexport type ActorLogEntry = z.infer<typeof ActorLogEntry>;\n\n// MARK: State\n\nexport const OperationSchema = z.discriminatedUnion(\"op\", [\n\tz.object({\n\t\top: z.literal(\"remove\"),\n\t\tpath: z.string(),\n\t}),\n\tz.object({\n\t\top: z.literal(\"add\"),\n\t\tpath: z.string(),\n\t\tvalue: z.unknown(),\n\t}),\n\tz.object({\n\t\top: z.literal(\"replace\"),\n\t\tpath: z.string(),\n\t\tvalue: z.unknown(),\n\t}),\n\tz.object({\n\t\top: z.literal(\"move\"),\n\t\tpath: z.string(),\n\t\tfrom: z.string(),\n\t}),\n\tz.object({\n\t\top: z.literal(\"copy\"),\n\t\tpath: z.string(),\n\t\tfrom: z.string(),\n\t}),\n\tz.object({\n\t\top: z.literal(\"test\"),\n\t\tpath: z.string(),\n\t\tvalue: z.unknown(),\n\t}),\n]);\nexport type Operation = z.infer<typeof OperationSchema>;\n\nexport const PatchSchema = z.array(OperationSchema);\nexport type Patch = z.infer<typeof PatchSchema>;\n\n// MARK: Connections\n\nexport const ConnectionSchema = z.object({\n\tparams: z.record(z.string(), z.any()).optional(),\n\tid: z.string(),\n\tstateEnabled: z.boolean().optional(),\n\tstate: z.any().optional(),\n\tauth: z.record(z.string(), z.any()).optional(),\n});\nexport type Connection = z.infer<typeof ConnectionSchema>;\n\n// MARK: Realtime Events\n\nexport const RealtimeEventSchema = z.discriminatedUnion(\"type\", [\n\tz.object({\n\t\ttype: z.literal(\"action\"),\n\t\tname: z.string(),\n\t\targs: z.array(z.any()),\n\t\tconnId: z.string(),\n\t}),\n\tz.object({\n\t\ttype: z.literal(\"broadcast\"),\n\t\teventName: z.string(),\n\t\targs: z.array(z.any()),\n\t}),\n\tz.object({\n\t\ttype: z.literal(\"subscribe\"),\n\t\teventName: z.string(),\n\t\tconnId: z.string(),\n\t}),\n\tz.object({\n\t\ttype: z.literal(\"unsubscribe\"),\n\t\teventName: z.string(),\n\t\tconnId: z.string(),\n\t}),\n\tz.object({\n\t\ttype: z.literal(\"event\"),\n\t\teventName: z.string(),\n\t\targs: z.array(z.any()),\n\t\tconnId: z.string(),\n\t}),\n]);\nexport type RealtimeEvent = z.infer<typeof RealtimeEventSchema>;\nexport const RecordedRealtimeEventSchema = RealtimeEventSchema.and(\n\tz.object({\n\t\tid: z.string(),\n\t\ttimestamp: z.number(),\n\t}),\n);\nexport type RecordedRealtimeEvent = z.infer<typeof RecordedRealtimeEventSchema>;\n\n// MARK: Database\n\nexport const DatabaseQuerySchema = z.object({\n\tsql: z.string(),\n\targs: z.array(z.string().or(z.number())),\n});\nexport type DatabaseQuery = z.infer<typeof DatabaseQuerySchema>;\n\nexport const TableSchema = z.object({\n\tschema: z.string(),\n\tname: z.string(),\n\ttype: z.enum([\"table\", \"view\"]),\n});\nexport type Table = z.infer<typeof TableSchema>;\n\nexport const TablesSchema = z.array(TableSchema);\nexport type Tables = z.infer<typeof TablesSchema>;\n\nexport const ColumnSchema = z.object({\n\tcid: z.number(),\n\tname: z.string(),\n\ttype: z\n\t\t.string()\n\t\t.toLowerCase()\n\t\t.transform((val) => {\n\t\t\treturn z\n\t\t\t\t.enum([\"integer\", \"text\", \"real\", \"blob\", \"numeric\", \"serial\"])\n\t\t\t\t.parse(val);\n\t\t}),\n\tnotnull: z.coerce.boolean(),\n\tdflt_value: z.string().nullable(),\n\tpk: z.coerce.boolean().nullable(),\n});\nexport type Column = z.infer<typeof ColumnSchema>;\n\nexport const ColumnsSchema = z.array(ColumnSchema);\nexport type Columns = z.infer<typeof ColumnsSchema>;\n\nexport const ForeignKeySchema = z.object({\n\tid: z.number(),\n\ttable: z.string(),\n\tfrom: z.string(),\n\tto: z.string(),\n});\nexport type ForeignKey = z.infer<typeof ForeignKeySchema>;\n\nexport const ForeignKeysSchema = z.array(ForeignKeySchema);\nexport type ForeignKeys = z.infer<typeof ForeignKeysSchema>;\n\n// MARK: Builds\n\nexport const BuildSchema = z.object({\n\tname: z.string(),\n\tcreatedAt: z.string().optional(),\n\ttags: z.record(z.string(), z.string()).optional(),\n});\nexport type Build = z.infer<typeof BuildSchema>;\nexport const BuildsSchema = z.array(BuildSchema);\nexport type Builds = z.infer<typeof BuildsSchema>;\n\nexport const CreateActorSchema = z.object({\n\tname: z.string(),\n\t// FIXME: Replace with ActorKeySchema when ready\n\tkey: z.array(z.string().max(MAX_ACTOR_KEY_SIZE)),\n\tinput: z.any(),\n});\nexport type CreateActor = z.infer<typeof CreateActorSchema>;\n","import { z } from \"zod\";\nimport { EncodingSchema } from \"@/actor/protocol/serde\";\nimport {\n\tHEADER_ACTOR_ID,\n\tHEADER_ACTOR_QUERY,\n\tHEADER_CONN_ID,\n\tHEADER_CONN_PARAMS,\n\tHEADER_CONN_TOKEN,\n\tHEADER_ENCODING,\n} from \"@/actor/router-endpoints\";\n\n// Maximum size of a key component in bytes\n// Set to 128 bytes to allow for separators and escape characters in the full key\n// Cloudflare's maximum key size is 512 bytes, so we need to be significantly smaller\nexport const MAX_ACTOR_KEY_SIZE = 128;\n\nexport const ActorKeySchema = z.array(z.string().max(MAX_ACTOR_KEY_SIZE));\n\nexport type ActorKey = z.infer<typeof ActorKeySchema>;\n\nexport const CreateRequestSchema = z.object({\n\tname: z.string(),\n\tkey: ActorKeySchema,\n\tinput: z.unknown().optional(),\n\tregion: z.string().optional(),\n});\n\nexport const GetForKeyRequestSchema = z.object({\n\tname: z.string(),\n\tkey: ActorKeySchema,\n});\n\nexport const GetOrCreateRequestSchema = z.object({\n\tname: z.string(),\n\tkey: ActorKeySchema,\n\tinput: z.unknown().optional(),\n\tregion: z.string().optional(),\n});\n\nexport const ActorQuerySchema = z.union([\n\tz.object({\n\t\tgetForId: z.object({\n\t\t\tname: z.string(),\n\t\t\tactorId: z.string(),\n\t\t}),\n\t}),\n\tz.object({\n\t\tgetForKey: GetForKeyRequestSchema,\n\t}),\n\tz.object({\n\t\tgetOrCreateForKey: GetOrCreateRequestSchema,\n\t}),\n\tz.object({\n\t\tcreate: CreateRequestSchema,\n\t}),\n]);\n\nexport const ConnectRequestSchema = z.object({\n\tquery: ActorQuerySchema.describe(HEADER_ACTOR_QUERY),\n\tencoding: EncodingSchema.describe(HEADER_ENCODING),\n\tconnParams: z.string().optional().describe(HEADER_CONN_PARAMS),\n});\n\nexport const ConnectWebSocketRequestSchema = z.object({\n\tquery: ActorQuerySchema.describe(\"query\"),\n\tencoding: EncodingSchema.describe(\"encoding\"),\n\tconnParams: z.unknown().optional().describe(\"conn_params\"),\n});\n\nexport const ConnMessageRequestSchema = z.object({\n\tactorId: z.string().describe(HEADER_ACTOR_ID),\n\tconnId: z.string().describe(HEADER_CONN_ID),\n\tencoding: EncodingSchema.describe(HEADER_ENCODING),\n\tconnToken: z.string().describe(HEADER_CONN_TOKEN),\n});\n\nexport const ResolveRequestSchema = z.object({\n\tquery: ActorQuerySchema.describe(HEADER_ACTOR_QUERY),\n\tconnParams: z.string().optional().describe(HEADER_CONN_PARAMS),\n});\n\nexport type ActorQuery = z.infer<typeof ActorQuerySchema>;\nexport type GetForKeyRequest = z.infer<typeof GetForKeyRequestSchema>;\nexport type GetOrCreateRequest = z.infer<typeof GetOrCreateRequestSchema>;\nexport type ConnectQuery = z.infer<typeof ConnectRequestSchema>;\n/**\n * Interface representing a request to create a actor.\n */\nexport type CreateRequest = z.infer<typeof CreateRequestSchema>;\n","import { hc } from \"hono/client\";\nimport type { createActorInspectorRouter } from \"../actor\";\n\ntype ActorInspectorRouter = ReturnType<typeof createActorInspectorRouter>;\nconst client = hc<ActorInspectorRouter>(\"\");\nexport type ActorInspectorClient = typeof client;\n\nexport const createActorInspectorClient = (\n\t...args: Parameters<typeof hc>\n): ActorInspectorClient => hc<ActorInspectorRouter>(...args);\n","import { hc } from \"hono/client\";\nimport type { createManagerInspectorRouter } from \"../manager\";\n\ntype ManagerInspectorRouter = ReturnType<typeof createManagerInspectorRouter>;\nconst client = hc<ManagerInspectorRouter>(\"\");\nexport type ManagerInspectorClient = typeof client;\n\nexport const createManagerInspectorClient = (\n\t...args: Parameters<typeof hc>\n): ManagerInspectorClient => hc<ManagerInspectorRouter>(...args);\n"]}