rivetkit 2.1.4 → 2.1.6
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.
- package/dist/browser/client.js +1 -1
- package/dist/browser/client.js.map +1 -1
- package/dist/browser/inspector/client.js +1 -1
- package/dist/browser/inspector/client.js.map +1 -1
- package/dist/inspector.tar.gz +0 -0
- package/dist/tsup/{chunk-4KSHPFXF.cjs → chunk-2Q5WS6QH.cjs} +3 -4
- package/dist/tsup/chunk-2Q5WS6QH.cjs.map +1 -0
- package/dist/tsup/{chunk-H5TSEPN4.cjs → chunk-4YFX2SP2.cjs} +30 -30
- package/dist/tsup/{chunk-H5TSEPN4.cjs.map → chunk-4YFX2SP2.cjs.map} +1 -1
- package/dist/tsup/{chunk-GXRVSSVD.cjs → chunk-7ANRFQJK.cjs} +20 -20
- package/dist/tsup/{chunk-GXRVSSVD.cjs.map → chunk-7ANRFQJK.cjs.map} +1 -1
- package/dist/tsup/{chunk-I6PL6QIY.js → chunk-DOEWKM5V.js} +5 -5
- package/dist/tsup/{chunk-QPADHLDU.cjs → chunk-DSXC3S7Q.cjs} +3 -3
- package/dist/tsup/{chunk-QPADHLDU.cjs.map → chunk-DSXC3S7Q.cjs.map} +1 -1
- package/dist/tsup/{chunk-5UEFNG7P.js → chunk-ELCI2QTU.js} +2 -2
- package/dist/tsup/{chunk-TEUL4UYN.cjs → chunk-GRHLSP4A.cjs} +152 -152
- package/dist/tsup/{chunk-TEUL4UYN.cjs.map → chunk-GRHLSP4A.cjs.map} +1 -1
- package/dist/tsup/{chunk-LK36OGGO.cjs → chunk-GVBTEL2D.cjs} +3 -3
- package/dist/tsup/{chunk-LK36OGGO.cjs.map → chunk-GVBTEL2D.cjs.map} +1 -1
- package/dist/tsup/{chunk-DZXDUGLL.js → chunk-ITLKCAXM.js} +2 -3
- package/dist/tsup/{chunk-DZXDUGLL.js.map → chunk-ITLKCAXM.js.map} +1 -1
- package/dist/tsup/{chunk-AQD4CBZ2.cjs → chunk-J45S63Q5.cjs} +4 -4
- package/dist/tsup/{chunk-AQD4CBZ2.cjs.map → chunk-J45S63Q5.cjs.map} +1 -1
- package/dist/tsup/{chunk-TEFYRRAK.js → chunk-K7JTZNLG.js} +4 -4
- package/dist/tsup/{chunk-3GTO6H3E.js → chunk-KARQFHQH.js} +4 -4
- package/dist/tsup/{chunk-KTWY3K6Z.js → chunk-KJXZTBFN.js} +5 -5
- package/dist/tsup/{chunk-M6H4XIF4.js → chunk-KTQKZOGC.js} +110 -110
- package/dist/tsup/chunk-KTQKZOGC.js.map +1 -0
- package/dist/tsup/{chunk-HBYEYBIC.js → chunk-PB5QRAQX.js} +2 -2
- package/dist/tsup/{chunk-ANKZ2FS6.js → chunk-SFC4YXTL.js} +2 -2
- package/dist/tsup/{chunk-3B6PCYJB.cjs → chunk-TTVNEKBE.cjs} +81 -81
- package/dist/tsup/{chunk-3B6PCYJB.cjs.map → chunk-TTVNEKBE.cjs.map} +1 -1
- package/dist/tsup/{chunk-HKOSZKKZ.cjs → chunk-VQHUWB37.cjs} +192 -192
- package/dist/tsup/chunk-VQHUWB37.cjs.map +1 -0
- package/dist/tsup/{chunk-UDMRZR6A.js → chunk-W735O34B.js} +3 -3
- package/dist/tsup/{chunk-UWAGLDT6.cjs → chunk-Z2X3VVCS.cjs} +235 -235
- package/dist/tsup/{chunk-UWAGLDT6.cjs.map → chunk-Z2X3VVCS.cjs.map} +1 -1
- package/dist/tsup/client/mod.cjs +6 -6
- package/dist/tsup/client/mod.js +5 -5
- package/dist/tsup/common/log.cjs +2 -2
- package/dist/tsup/common/log.js +1 -1
- package/dist/tsup/common/websocket.cjs +3 -3
- package/dist/tsup/common/websocket.js +2 -2
- package/dist/tsup/driver-helpers/mod.cjs +4 -4
- package/dist/tsup/driver-helpers/mod.js +3 -3
- package/dist/tsup/driver-test-suite/mod.cjs +60 -60
- package/dist/tsup/driver-test-suite/mod.js +10 -10
- package/dist/tsup/inspector/mod.cjs +3 -3
- package/dist/tsup/inspector/mod.js +2 -2
- package/dist/tsup/mod.cjs +8 -8
- package/dist/tsup/mod.js +7 -7
- package/dist/tsup/serve-test-suite/mod.cjs +102 -102
- package/dist/tsup/serve-test-suite/mod.js +10 -10
- package/dist/tsup/test/mod.cjs +10 -10
- package/dist/tsup/test/mod.js +6 -6
- package/dist/tsup/utils.cjs +2 -2
- package/dist/tsup/utils.js +1 -1
- package/dist/tsup/workflow/mod.cjs +5 -5
- package/dist/tsup/workflow/mod.js +4 -4
- package/package.json +5 -5
- package/src/registry/index.ts +4 -4
- package/dist/tsup/chunk-4KSHPFXF.cjs.map +0 -1
- package/dist/tsup/chunk-HKOSZKKZ.cjs.map +0 -1
- package/dist/tsup/chunk-M6H4XIF4.js.map +0 -1
- /package/dist/tsup/{chunk-I6PL6QIY.js.map → chunk-DOEWKM5V.js.map} +0 -0
- /package/dist/tsup/{chunk-5UEFNG7P.js.map → chunk-ELCI2QTU.js.map} +0 -0
- /package/dist/tsup/{chunk-TEFYRRAK.js.map → chunk-K7JTZNLG.js.map} +0 -0
- /package/dist/tsup/{chunk-3GTO6H3E.js.map → chunk-KARQFHQH.js.map} +0 -0
- /package/dist/tsup/{chunk-KTWY3K6Z.js.map → chunk-KJXZTBFN.js.map} +0 -0
- /package/dist/tsup/{chunk-HBYEYBIC.js.map → chunk-PB5QRAQX.js.map} +0 -0
- /package/dist/tsup/{chunk-ANKZ2FS6.js.map → chunk-SFC4YXTL.js.map} +0 -0
- /package/dist/tsup/{chunk-UDMRZR6A.js.map → chunk-W735O34B.js.map} +0 -0
|
@@ -5,7 +5,7 @@
|
|
|
5
5
|
|
|
6
6
|
|
|
7
7
|
|
|
8
|
-
var
|
|
8
|
+
var _chunkZ2X3VVCScjs = require('./chunk-Z2X3VVCS.cjs');
|
|
9
9
|
|
|
10
10
|
|
|
11
11
|
|
|
@@ -16,7 +16,7 @@ var _chunkUWAGLDT6cjs = require('./chunk-UWAGLDT6.cjs');
|
|
|
16
16
|
|
|
17
17
|
|
|
18
18
|
|
|
19
|
-
var
|
|
19
|
+
var _chunkGRHLSP4Acjs = require('./chunk-GRHLSP4A.cjs');
|
|
20
20
|
|
|
21
21
|
|
|
22
22
|
|
|
@@ -48,14 +48,14 @@ var _chunkTEUL4UYNcjs = require('./chunk-TEUL4UYN.cjs');
|
|
|
48
48
|
|
|
49
49
|
|
|
50
50
|
|
|
51
|
-
var
|
|
51
|
+
var _chunkTTVNEKBEcjs = require('./chunk-TTVNEKBE.cjs');
|
|
52
52
|
|
|
53
53
|
|
|
54
54
|
|
|
55
55
|
|
|
56
56
|
|
|
57
57
|
|
|
58
|
-
var
|
|
58
|
+
var _chunkGVBTEL2Dcjs = require('./chunk-GVBTEL2D.cjs');
|
|
59
59
|
|
|
60
60
|
|
|
61
61
|
|
|
@@ -73,8 +73,7 @@ var _chunkLK36OGGOcjs = require('./chunk-LK36OGGO.cjs');
|
|
|
73
73
|
|
|
74
74
|
|
|
75
75
|
|
|
76
|
-
|
|
77
|
-
var _chunk4KSHPFXFcjs = require('./chunk-4KSHPFXF.cjs');
|
|
76
|
+
var _chunk2Q5WS6QHcjs = require('./chunk-2Q5WS6QH.cjs');
|
|
78
77
|
|
|
79
78
|
|
|
80
79
|
|
|
@@ -84,11 +83,11 @@ var _chunkL47L3ZWJcjs = require('./chunk-L47L3ZWJ.cjs');
|
|
|
84
83
|
|
|
85
84
|
// src/actor/mod.ts
|
|
86
85
|
function actor(input) {
|
|
87
|
-
const config =
|
|
88
|
-
return new (0,
|
|
86
|
+
const config = _chunkGVBTEL2Dcjs.ActorConfigSchema.parse(input);
|
|
87
|
+
return new (0, _chunkZ2X3VVCScjs.ActorDefinition)(config);
|
|
89
88
|
}
|
|
90
|
-
var event2 =
|
|
91
|
-
var queue2 =
|
|
89
|
+
var event2 = _chunkGVBTEL2Dcjs.event;
|
|
90
|
+
var queue2 = _chunkGVBTEL2Dcjs.queue;
|
|
92
91
|
|
|
93
92
|
// src/drivers/engine/actor-driver.ts
|
|
94
93
|
var _enginerunner = require('@rivetkit/engine-runner');
|
|
@@ -99,7 +98,7 @@ var _invariant = require('invariant'); var _invariant2 = _interopRequireDefault(
|
|
|
99
98
|
|
|
100
99
|
// src/drivers/engine/log.ts
|
|
101
100
|
function logger2() {
|
|
102
|
-
return
|
|
101
|
+
return _chunk2Q5WS6QHcjs.getLogger.call(void 0, "driver-engine");
|
|
103
102
|
}
|
|
104
103
|
|
|
105
104
|
// src/drivers/engine/actor-driver.ts
|
|
@@ -114,8 +113,8 @@ var EngineActorDriver = class {
|
|
|
114
113
|
#runner;
|
|
115
114
|
#actors = /* @__PURE__ */ new Map();
|
|
116
115
|
#actorRouter;
|
|
117
|
-
#runnerStarted =
|
|
118
|
-
#runnerStopped =
|
|
116
|
+
#runnerStarted = _chunk2Q5WS6QHcjs.promiseWithResolvers.call(void 0, (reason) => logger2().warn({ msg: "unhandled runner started promise rejection", reason }));
|
|
117
|
+
#runnerStopped = _chunk2Q5WS6QHcjs.promiseWithResolvers.call(void 0, (reason) => logger2().warn({ msg: "unhandled runner stopped promise rejection", reason }));
|
|
119
118
|
#isRunnerStopped = false;
|
|
120
119
|
// HACK: Track actor stop intent locally since the runner protocol doesn't
|
|
121
120
|
// pass the stop reason to onActorStop. This will be fixed when the runner
|
|
@@ -139,7 +138,7 @@ var EngineActorDriver = class {
|
|
|
139
138
|
this.#managerDriver = managerDriver;
|
|
140
139
|
this.#inlineClient = inlineClient;
|
|
141
140
|
const token = config.token;
|
|
142
|
-
this.#actorRouter =
|
|
141
|
+
this.#actorRouter = _chunkZ2X3VVCScjs.createActorRouter.call(void 0,
|
|
143
142
|
config,
|
|
144
143
|
this,
|
|
145
144
|
void 0,
|
|
@@ -147,16 +146,16 @@ var EngineActorDriver = class {
|
|
|
147
146
|
);
|
|
148
147
|
const engineRunnerConfig = {
|
|
149
148
|
version: config.runner.version,
|
|
150
|
-
endpoint:
|
|
149
|
+
endpoint: _chunkGRHLSP4Acjs.getEndpoint.call(void 0, config),
|
|
151
150
|
token,
|
|
152
151
|
namespace: config.namespace,
|
|
153
152
|
totalSlots: config.runner.totalSlots,
|
|
154
153
|
runnerName: config.runner.runnerName,
|
|
155
154
|
runnerKey: _nullishCoalesce(config.runner.runnerKey, () => ( crypto.randomUUID())),
|
|
156
155
|
metadata: {
|
|
157
|
-
rivetkit: { version:
|
|
156
|
+
rivetkit: { version: _chunk2Q5WS6QHcjs.VERSION }
|
|
158
157
|
},
|
|
159
|
-
prepopulateActorNames:
|
|
158
|
+
prepopulateActorNames: _chunkTTVNEKBEcjs.buildActorNames.call(void 0, config),
|
|
160
159
|
onConnected: () => {
|
|
161
160
|
this.#runnerStarted.resolve(void 0);
|
|
162
161
|
},
|
|
@@ -173,7 +172,7 @@ var EngineActorDriver = class {
|
|
|
173
172
|
},
|
|
174
173
|
onActorStart: this.#runnerOnActorStart.bind(this),
|
|
175
174
|
onActorStop: this.#runnerOnActorStop.bind(this),
|
|
176
|
-
logger:
|
|
175
|
+
logger: _chunk2Q5WS6QHcjs.getLogger.call(void 0, "engine-runner")
|
|
177
176
|
};
|
|
178
177
|
this.#runner = new (0, _enginerunner.Runner)(engineRunnerConfig);
|
|
179
178
|
this.#runner.start();
|
|
@@ -212,7 +211,7 @@ var EngineActorDriver = class {
|
|
|
212
211
|
handler.alarmTimeout = void 0;
|
|
213
212
|
}
|
|
214
213
|
const delay = Math.max(0, timestamp - Date.now());
|
|
215
|
-
handler.alarmTimeout =
|
|
214
|
+
handler.alarmTimeout = _chunk2Q5WS6QHcjs.setLongTimeout.call(void 0, () => {
|
|
216
215
|
actor2.onAlarm();
|
|
217
216
|
handler.alarmTimeout = void 0;
|
|
218
217
|
}, delay);
|
|
@@ -288,7 +287,7 @@ var EngineActorDriver = class {
|
|
|
288
287
|
var _a;
|
|
289
288
|
(_a = handler.actor) == null ? void 0 : _a.rLog.error({
|
|
290
289
|
msg: "onStop errored",
|
|
291
|
-
error:
|
|
290
|
+
error: _chunk2Q5WS6QHcjs.stringifyError.call(void 0, err)
|
|
292
291
|
});
|
|
293
292
|
})
|
|
294
293
|
);
|
|
@@ -371,20 +370,20 @@ var EngineActorDriver = class {
|
|
|
371
370
|
let handler = this.#actors.get(actorId);
|
|
372
371
|
if (!handler) {
|
|
373
372
|
handler = {
|
|
374
|
-
actorStartPromise:
|
|
373
|
+
actorStartPromise: _chunk2Q5WS6QHcjs.promiseWithResolvers.call(void 0, (reason) => logger2().warn({ msg: "unhandled actor start promise rejection", reason }))
|
|
375
374
|
};
|
|
376
375
|
this.#actors.set(actorId, handler);
|
|
377
376
|
}
|
|
378
377
|
handler.actorStartError = void 0;
|
|
379
378
|
const name = actorConfig.name;
|
|
380
379
|
_invariant2.default.call(void 0, actorConfig.key, "actor should have a key");
|
|
381
|
-
const key =
|
|
380
|
+
const key = _chunkTTVNEKBEcjs.deserializeActorKey.call(void 0, actorConfig.key);
|
|
382
381
|
try {
|
|
383
382
|
const [persistDataBuffer] = await this.#runner.kvGet(actorId, [
|
|
384
|
-
|
|
383
|
+
_chunkGVBTEL2Dcjs.KEYS.PERSIST_DATA
|
|
385
384
|
]);
|
|
386
385
|
if (persistDataBuffer === null) {
|
|
387
|
-
const initialKvState =
|
|
386
|
+
const initialKvState = _chunkTTVNEKBEcjs.getInitialActorKvState.call(void 0, input);
|
|
388
387
|
await this.#runner.kvPut(actorId, initialKvState);
|
|
389
388
|
logger2().debug({
|
|
390
389
|
msg: "initialized persist data for new actor",
|
|
@@ -397,7 +396,7 @@ var EngineActorDriver = class {
|
|
|
397
396
|
dataSize: persistDataBuffer.byteLength
|
|
398
397
|
});
|
|
399
398
|
}
|
|
400
|
-
const definition =
|
|
399
|
+
const definition = _chunkZ2X3VVCScjs.lookupInRegistry.call(void 0, this.#config, actorConfig.name);
|
|
401
400
|
handler.actor = await definition.instantiate();
|
|
402
401
|
const protocolMetadata = this.#runner.getProtocolMetadata();
|
|
403
402
|
if (protocolMetadata) {
|
|
@@ -438,7 +437,7 @@ var EngineActorDriver = class {
|
|
|
438
437
|
actorId,
|
|
439
438
|
name,
|
|
440
439
|
key,
|
|
441
|
-
err:
|
|
440
|
+
err: _chunk2Q5WS6QHcjs.stringifyError.call(void 0, error)
|
|
442
441
|
});
|
|
443
442
|
try {
|
|
444
443
|
this.#runner.stopActor(actorId);
|
|
@@ -446,7 +445,7 @@ var EngineActorDriver = class {
|
|
|
446
445
|
logger2().debug({
|
|
447
446
|
msg: "failed to stop actor after start failure",
|
|
448
447
|
actorId,
|
|
449
|
-
err:
|
|
448
|
+
err: _chunk2Q5WS6QHcjs.stringifyError.call(void 0, stopError)
|
|
450
449
|
});
|
|
451
450
|
}
|
|
452
451
|
}
|
|
@@ -468,7 +467,7 @@ var EngineActorDriver = class {
|
|
|
468
467
|
logger2().debug({
|
|
469
468
|
msg: "actor start failed during stop, cleaning up handler",
|
|
470
469
|
actorId,
|
|
471
|
-
err:
|
|
470
|
+
err: _chunk2Q5WS6QHcjs.stringifyError.call(void 0, err)
|
|
472
471
|
});
|
|
473
472
|
}
|
|
474
473
|
}
|
|
@@ -478,7 +477,7 @@ var EngineActorDriver = class {
|
|
|
478
477
|
} catch (err) {
|
|
479
478
|
logger2().error({
|
|
480
479
|
msg: "error in onStop, proceeding with removing actor",
|
|
481
|
-
err:
|
|
480
|
+
err: _chunk2Q5WS6QHcjs.stringifyError.call(void 0, err)
|
|
482
481
|
});
|
|
483
482
|
}
|
|
484
483
|
}
|
|
@@ -511,10 +510,10 @@ var EngineActorDriver = class {
|
|
|
511
510
|
websocketProps: websocketRaw ? Object.keys(websocketRaw).join(", ") : "null"
|
|
512
511
|
});
|
|
513
512
|
const protocols = request.headers.get("sec-websocket-protocol");
|
|
514
|
-
const { encoding, connParams } =
|
|
513
|
+
const { encoding, connParams } = _chunkTTVNEKBEcjs.parseWebSocketProtocols.call(void 0, protocols);
|
|
515
514
|
let wsHandler;
|
|
516
515
|
try {
|
|
517
|
-
wsHandler = await
|
|
516
|
+
wsHandler = await _chunkTTVNEKBEcjs.routeWebSocket.call(void 0,
|
|
518
517
|
request,
|
|
519
518
|
requestPath,
|
|
520
519
|
requestHeaders,
|
|
@@ -537,7 +536,7 @@ var EngineActorDriver = class {
|
|
|
537
536
|
const wsContext = new (0, _ws.WSContext)(websocket);
|
|
538
537
|
const conn = wsHandler.conn;
|
|
539
538
|
const actor2 = wsHandler.actor;
|
|
540
|
-
const connStateManager = conn == null ? void 0 : conn[
|
|
539
|
+
const connStateManager = conn == null ? void 0 : conn[_chunkTTVNEKBEcjs.CONN_STATE_MANAGER_SYMBOL];
|
|
541
540
|
logger2().debug({
|
|
542
541
|
msg: "attaching websocket event listeners",
|
|
543
542
|
actorId,
|
|
@@ -597,7 +596,7 @@ var EngineActorDriver = class {
|
|
|
597
596
|
});
|
|
598
597
|
const entry = this.#hwsMessageIndex.get(conn.id);
|
|
599
598
|
if (entry) {
|
|
600
|
-
const messageLength =
|
|
599
|
+
const messageLength = _chunkTTVNEKBEcjs.getValueLength.call(void 0, event3.data);
|
|
601
600
|
entry.bufferedMessageSize += messageLength;
|
|
602
601
|
if (entry.bufferedMessageSize >= CONN_BUFFERED_MESSAGE_SIZE_THRESHOLD) {
|
|
603
602
|
entry.bufferedMessageSize = 0;
|
|
@@ -668,10 +667,10 @@ var EngineActorDriver = class {
|
|
|
668
667
|
gatewayId: _enginerunner.idToStr.call(void 0, gatewayId),
|
|
669
668
|
requestId: _enginerunner.idToStr.call(void 0, requestId)
|
|
670
669
|
});
|
|
671
|
-
if (path ===
|
|
670
|
+
if (path === _chunkTTVNEKBEcjs.PATH_CONNECT) {
|
|
672
671
|
return true;
|
|
673
|
-
} else if (path ===
|
|
674
|
-
const definition =
|
|
672
|
+
} else if (path === _chunkTTVNEKBEcjs.PATH_WEBSOCKET_BASE || path.startsWith(_chunkTTVNEKBEcjs.PATH_WEBSOCKET_PREFIX)) {
|
|
673
|
+
const definition = _chunkZ2X3VVCScjs.lookupInRegistry.call(void 0,
|
|
675
674
|
this.#config,
|
|
676
675
|
actorInstance.config.name
|
|
677
676
|
);
|
|
@@ -680,7 +679,7 @@ var EngineActorDriver = class {
|
|
|
680
679
|
return true;
|
|
681
680
|
} else if (typeof canHibernateWebSocket === "function") {
|
|
682
681
|
try {
|
|
683
|
-
const newPath =
|
|
682
|
+
const newPath = _chunkTTVNEKBEcjs.truncateRawWebSocketPathPrefix.call(void 0,
|
|
684
683
|
url.pathname
|
|
685
684
|
);
|
|
686
685
|
const truncatedRequest = new Request(
|
|
@@ -699,7 +698,7 @@ var EngineActorDriver = class {
|
|
|
699
698
|
} else {
|
|
700
699
|
return false;
|
|
701
700
|
}
|
|
702
|
-
} else if (path ===
|
|
701
|
+
} else if (path === _chunkTTVNEKBEcjs.PATH_INSPECTOR_CONNECT) {
|
|
703
702
|
return false;
|
|
704
703
|
} else {
|
|
705
704
|
logger2().warn({
|
|
@@ -712,7 +711,7 @@ var EngineActorDriver = class {
|
|
|
712
711
|
async #hwsLoadAll(actorId) {
|
|
713
712
|
const actor2 = await this.loadActor(actorId);
|
|
714
713
|
return actor2.conns.values().map((conn) => {
|
|
715
|
-
const connStateManager = conn[
|
|
714
|
+
const connStateManager = conn[_chunkTTVNEKBEcjs.CONN_STATE_MANAGER_SYMBOL];
|
|
716
715
|
const hibernatable = connStateManager.hibernatableData;
|
|
717
716
|
if (!hibernatable) return void 0;
|
|
718
717
|
return {
|
|
@@ -736,7 +735,7 @@ var EngineActorDriver = class {
|
|
|
736
735
|
await this.#runner.restoreHibernatingRequests(actor2.id, metaEntries);
|
|
737
736
|
}
|
|
738
737
|
onCreateConn(conn) {
|
|
739
|
-
const hibernatable = conn[
|
|
738
|
+
const hibernatable = conn[_chunkTTVNEKBEcjs.CONN_STATE_MANAGER_SYMBOL].hibernatableData;
|
|
740
739
|
if (!hibernatable) return;
|
|
741
740
|
this.#hwsMessageIndex.set(conn.id, {
|
|
742
741
|
serverMessageIndex: hibernatable.serverMessageIndex,
|
|
@@ -758,7 +757,7 @@ var EngineActorDriver = class {
|
|
|
758
757
|
});
|
|
759
758
|
}
|
|
760
759
|
onBeforePersistConn(conn) {
|
|
761
|
-
const stateManager = conn[
|
|
760
|
+
const stateManager = conn[_chunkTTVNEKBEcjs.CONN_STATE_MANAGER_SYMBOL];
|
|
762
761
|
const hibernatable = stateManager.hibernatableDataOrError();
|
|
763
762
|
const entry = this.#hwsMessageIndex.get(conn.id);
|
|
764
763
|
if (!entry) {
|
|
@@ -772,7 +771,7 @@ var EngineActorDriver = class {
|
|
|
772
771
|
entry.serverMessageIndex = hibernatable.serverMessageIndex;
|
|
773
772
|
}
|
|
774
773
|
onAfterPersistConn(conn) {
|
|
775
|
-
const stateManager = conn[
|
|
774
|
+
const stateManager = conn[_chunkTTVNEKBEcjs.CONN_STATE_MANAGER_SYMBOL];
|
|
776
775
|
const hibernatable = stateManager.hibernatableDataOrError();
|
|
777
776
|
const entry = this.#hwsMessageIndex.get(conn.id);
|
|
778
777
|
if (!entry) {
|
|
@@ -797,9 +796,9 @@ var EngineActorDriver = class {
|
|
|
797
796
|
|
|
798
797
|
// src/drivers/engine/config.ts
|
|
799
798
|
var _v4 = require('zod/v4');
|
|
800
|
-
var EngineConfigSchemaBase =
|
|
799
|
+
var EngineConfigSchemaBase = _chunkGRHLSP4Acjs.ClientConfigSchemaBase.extend({
|
|
801
800
|
/** Unique key for this runner. Runners connecting a given key will replace any other runner connected with the same key. */
|
|
802
|
-
runnerKey: _v4.z.string().optional().transform((val) => _nullishCoalesce(val, () => (
|
|
801
|
+
runnerKey: _v4.z.string().optional().transform((val) => _nullishCoalesce(val, () => ( _chunk2Q5WS6QHcjs.getRivetRunnerKey.call(void 0, )))),
|
|
803
802
|
/** How many actors this runner can run. */
|
|
804
803
|
totalSlots: _v4.z.number().default(1e5)
|
|
805
804
|
});
|
|
@@ -811,7 +810,7 @@ var EngineConfigSchema = EngineConfigSchemaTransformed.default(
|
|
|
811
810
|
);
|
|
812
811
|
function transformEngineConfig(config, ctx) {
|
|
813
812
|
return {
|
|
814
|
-
...
|
|
813
|
+
..._chunkGRHLSP4Acjs.transformClientConfig.call(void 0, config, ctx),
|
|
815
814
|
runnerKey: config.runnerKey
|
|
816
815
|
};
|
|
817
816
|
}
|
|
@@ -822,8 +821,8 @@ function createEngineDriver() {
|
|
|
822
821
|
name: "engine",
|
|
823
822
|
displayName: "Engine",
|
|
824
823
|
manager: (config) => {
|
|
825
|
-
const clientConfig =
|
|
826
|
-
return new (0,
|
|
824
|
+
const clientConfig = _chunkGRHLSP4Acjs.convertRegistryConfigToClientConfig.call(void 0, config);
|
|
825
|
+
return new (0, _chunkGRHLSP4Acjs.RemoteManagerDriver)(clientConfig);
|
|
827
826
|
},
|
|
828
827
|
actor: (config, managerDriver, inlineClient) => {
|
|
829
828
|
return new EngineActorDriver(
|
|
@@ -836,101 +835,6 @@ function createEngineDriver() {
|
|
|
836
835
|
};
|
|
837
836
|
}
|
|
838
837
|
|
|
839
|
-
// src/registry/config/legacy-runner.ts
|
|
840
|
-
|
|
841
|
-
var LegacyDriverConfigSchema = _v4.z.object({
|
|
842
|
-
/** Machine-readable name to identify this driver by. */
|
|
843
|
-
name: _v4.z.string(),
|
|
844
|
-
manager: _v4.z.custom(),
|
|
845
|
-
actor: _v4.z.custom()
|
|
846
|
-
});
|
|
847
|
-
var LegacyRunnerConfigSchemaUnmerged = _v4.z.object({
|
|
848
|
-
driver: LegacyDriverConfigSchema.optional(),
|
|
849
|
-
/** @experimental */
|
|
850
|
-
maxIncomingMessageSize: _v4.z.number().optional().default(65536),
|
|
851
|
-
/** @experimental */
|
|
852
|
-
maxOutgoingMessageSize: _v4.z.number().optional().default(1048576),
|
|
853
|
-
/** @experimental */
|
|
854
|
-
inspector: _chunk3B6PCYJBcjs.InspectorConfigSchema,
|
|
855
|
-
/** @experimental */
|
|
856
|
-
disableDefaultServer: _v4.z.boolean().optional().default(false),
|
|
857
|
-
/** @experimental */
|
|
858
|
-
defaultServerPort: _v4.z.number().default(6420),
|
|
859
|
-
/** @experimental */
|
|
860
|
-
runEngine: _v4.z.boolean().optional().default(() => _chunk4KSHPFXFcjs.getRivetRunEngine.call(void 0, )),
|
|
861
|
-
/** @experimental */
|
|
862
|
-
runEngineVersion: _v4.z.string().optional().default(() => _nullishCoalesce(_chunk4KSHPFXFcjs.getRivetRunEngineVersion.call(void 0, ), () => ( _chunk4KSHPFXFcjs.VERSION))),
|
|
863
|
-
/** @experimental */
|
|
864
|
-
overrideServerAddress: _v4.z.string().optional(),
|
|
865
|
-
/** @experimental */
|
|
866
|
-
disableActorDriver: _v4.z.boolean().optional().default(false),
|
|
867
|
-
/**
|
|
868
|
-
* @experimental
|
|
869
|
-
*
|
|
870
|
-
* Whether to run runners normally or have them managed
|
|
871
|
-
* serverlessly (by the Rivet Engine for example).
|
|
872
|
-
*/
|
|
873
|
-
runnerKind: _v4.z.enum(["serverless", "normal"]).optional().default(
|
|
874
|
-
() => _chunk4KSHPFXFcjs.getRivetRunnerKind.call(void 0, ) === "serverless" ? "serverless" : "normal"
|
|
875
|
-
),
|
|
876
|
-
totalSlots: _v4.z.number().optional(),
|
|
877
|
-
/**
|
|
878
|
-
* @experimental
|
|
879
|
-
*
|
|
880
|
-
* Base path for the router. This is used to prefix all routes.
|
|
881
|
-
* For example, if the base path is `/api`, then the route `/actors` will be
|
|
882
|
-
* available at `/api/actors`.
|
|
883
|
-
*/
|
|
884
|
-
basePath: _v4.z.string().optional().default("/"),
|
|
885
|
-
/**
|
|
886
|
-
* @experimental
|
|
887
|
-
*
|
|
888
|
-
* Disable welcome message.
|
|
889
|
-
* */
|
|
890
|
-
noWelcome: _v4.z.boolean().optional().default(false),
|
|
891
|
-
/**
|
|
892
|
-
* @experimental
|
|
893
|
-
* */
|
|
894
|
-
logging: _v4.z.object({
|
|
895
|
-
baseLogger: _v4.z.custom().optional(),
|
|
896
|
-
level: _chunk4KSHPFXFcjs.LogLevelSchema.optional()
|
|
897
|
-
}).optional().default(() => ({})),
|
|
898
|
-
/**
|
|
899
|
-
* @experimental
|
|
900
|
-
*
|
|
901
|
-
* Automatically configure serverless runners in the engine.
|
|
902
|
-
* Can only be used when runnerKind is "serverless".
|
|
903
|
-
* If true, uses default configuration. Can also provide custom configuration.
|
|
904
|
-
*/
|
|
905
|
-
autoConfigureServerless: _v4.z.union([
|
|
906
|
-
_v4.z.boolean(),
|
|
907
|
-
_v4.z.object({
|
|
908
|
-
url: _v4.z.string().optional(),
|
|
909
|
-
headers: _v4.z.record(_v4.z.string(), _v4.z.string()).optional(),
|
|
910
|
-
maxRunners: _v4.z.number().optional(),
|
|
911
|
-
minRunners: _v4.z.number().optional(),
|
|
912
|
-
requestLifespan: _v4.z.number().optional(),
|
|
913
|
-
runnersMargin: _v4.z.number().optional(),
|
|
914
|
-
slotsPerRunner: _v4.z.number().optional(),
|
|
915
|
-
metadata: _v4.z.record(_v4.z.string(), _v4.z.unknown()).optional()
|
|
916
|
-
})
|
|
917
|
-
]).optional(),
|
|
918
|
-
// This is a function to allow for lazy configuration of upgradeWebSocket on the
|
|
919
|
-
// fly. This is required since the dependencies that upgradeWebSocket
|
|
920
|
-
// (specifically Node.js) can sometimes only be specified after the router is
|
|
921
|
-
// created or must be imported async using `await import(...)`
|
|
922
|
-
getUpgradeWebSocket: _v4.z.custom().optional(),
|
|
923
|
-
/** @experimental */
|
|
924
|
-
token: _v4.z.string().optional().transform((v) => v || _chunk4KSHPFXFcjs.getRivetToken.call(void 0, ))
|
|
925
|
-
}).merge(EngineConfigSchemaBase);
|
|
926
|
-
var LegacyRunnerConfigSchemaTransformed = LegacyRunnerConfigSchemaUnmerged.transform((config, ctx) => ({
|
|
927
|
-
...config,
|
|
928
|
-
...transformEngineConfig(config, ctx)
|
|
929
|
-
}));
|
|
930
|
-
var LegacyRunnerConfigSchema = LegacyRunnerConfigSchemaTransformed.default(
|
|
931
|
-
() => LegacyRunnerConfigSchemaTransformed.parse({})
|
|
932
|
-
);
|
|
933
|
-
|
|
934
838
|
// runtime/index.ts
|
|
935
839
|
|
|
936
840
|
|
|
@@ -945,43 +849,43 @@ function chooseDefaultDriver(config) {
|
|
|
945
849
|
return config.driver;
|
|
946
850
|
}
|
|
947
851
|
if (config.endpoint || config.token) {
|
|
948
|
-
|
|
852
|
+
_chunkGVBTEL2Dcjs.loggerWithoutContext.call(void 0, ).debug({
|
|
949
853
|
msg: "using rivet engine driver",
|
|
950
854
|
endpoint: config.endpoint
|
|
951
855
|
});
|
|
952
856
|
return createEngineDriver();
|
|
953
857
|
}
|
|
954
|
-
|
|
858
|
+
_chunkGVBTEL2Dcjs.loggerWithoutContext.call(void 0, ).debug({
|
|
955
859
|
msg: "using default file system driver",
|
|
956
860
|
storagePath: config.storagePath
|
|
957
861
|
});
|
|
958
|
-
return
|
|
862
|
+
return _chunkZ2X3VVCScjs.createFileSystemOrMemoryDriver.call(void 0, true, {
|
|
959
863
|
path: config.storagePath
|
|
960
864
|
});
|
|
961
865
|
}
|
|
962
866
|
|
|
963
867
|
// src/engine-process/log.ts
|
|
964
868
|
function logger3() {
|
|
965
|
-
return
|
|
869
|
+
return _chunk2Q5WS6QHcjs.getLogger.call(void 0, "engine-process");
|
|
966
870
|
}
|
|
967
871
|
|
|
968
872
|
// src/engine-process/mod.ts
|
|
969
873
|
var ENGINE_BASE_URL = "https://releases.rivet.dev/rivet";
|
|
970
874
|
var ENGINE_BINARY_NAME = "rivet-engine";
|
|
971
875
|
async function ensureEngineProcess(options) {
|
|
972
|
-
|
|
876
|
+
_chunkTTVNEKBEcjs.importNodeDependencies.call(void 0, );
|
|
973
877
|
logger3().debug({
|
|
974
878
|
msg: "ensuring engine process",
|
|
975
879
|
version: options.version
|
|
976
880
|
});
|
|
977
|
-
const path =
|
|
978
|
-
const storageRoot =
|
|
881
|
+
const path = _chunkTTVNEKBEcjs.getNodePath.call(void 0, );
|
|
882
|
+
const storageRoot = _chunkZ2X3VVCScjs.getStoragePath.call(void 0, );
|
|
979
883
|
const binDir = path.join(storageRoot, "bin");
|
|
980
884
|
const varDir = path.join(storageRoot, "var");
|
|
981
885
|
const logsDir = path.join(varDir, "logs", "rivet-engine");
|
|
982
|
-
await
|
|
983
|
-
await
|
|
984
|
-
await
|
|
886
|
+
await _chunkZ2X3VVCScjs.ensureDirectoryExists.call(void 0, binDir);
|
|
887
|
+
await _chunkZ2X3VVCScjs.ensureDirectoryExists.call(void 0, varDir);
|
|
888
|
+
await _chunkZ2X3VVCScjs.ensureDirectoryExists.call(void 0, logsDir);
|
|
985
889
|
if (await isEngineRunning()) {
|
|
986
890
|
try {
|
|
987
891
|
const health = await waitForEngineHealth();
|
|
@@ -1006,7 +910,7 @@ async function ensureEngineProcess(options) {
|
|
|
1006
910
|
const timestamp = (/* @__PURE__ */ new Date()).toISOString().replace(/:/g, "-").replace(/\./g, "-");
|
|
1007
911
|
const stdoutLogPath = path.join(logsDir, `engine-${timestamp}-stdout.log`);
|
|
1008
912
|
const stderrLogPath = path.join(logsDir, `engine-${timestamp}-stderr.log`);
|
|
1009
|
-
const fsSync =
|
|
913
|
+
const fsSync = _chunkTTVNEKBEcjs.getNodeFsSync.call(void 0, );
|
|
1010
914
|
const stdoutStream = fsSync.createWriteStream(stdoutLogPath, {
|
|
1011
915
|
flags: "a"
|
|
1012
916
|
});
|
|
@@ -1018,7 +922,7 @@ async function ensureEngineProcess(options) {
|
|
|
1018
922
|
stdout: stdoutLogPath,
|
|
1019
923
|
stderr: stderrLogPath
|
|
1020
924
|
});
|
|
1021
|
-
const childProcess =
|
|
925
|
+
const childProcess = _chunkTTVNEKBEcjs.getNodeChildProcess.call(void 0, );
|
|
1022
926
|
const child = childProcess.spawn(binaryPath, ["start"], {
|
|
1023
927
|
cwd: path.dirname(binaryPath),
|
|
1024
928
|
stdio: ["inherit", "pipe", "pipe"],
|
|
@@ -1154,7 +1058,7 @@ async function downloadEngineBinaryIfNeeded(binaryPath, version, varDir) {
|
|
|
1154
1058
|
`failed to download rivet engine binary from ${downloadUrl}: ${response.status} ${response.statusText}`
|
|
1155
1059
|
);
|
|
1156
1060
|
}
|
|
1157
|
-
const crypto2 =
|
|
1061
|
+
const crypto2 = _chunkTTVNEKBEcjs.getNodeCrypto.call(void 0, );
|
|
1158
1062
|
const tempPath = `${binaryPath}.${crypto2.randomUUID()}.tmp`;
|
|
1159
1063
|
const startTime = Date.now();
|
|
1160
1064
|
logger3().debug({
|
|
@@ -1169,14 +1073,14 @@ async function downloadEngineBinaryIfNeeded(binaryPath, version, varDir) {
|
|
|
1169
1073
|
});
|
|
1170
1074
|
}, 5e3);
|
|
1171
1075
|
try {
|
|
1172
|
-
const stream =
|
|
1173
|
-
const fsSync =
|
|
1076
|
+
const stream = _chunkTTVNEKBEcjs.getNodeStream.call(void 0, );
|
|
1077
|
+
const fsSync = _chunkTTVNEKBEcjs.getNodeFsSync.call(void 0, );
|
|
1174
1078
|
await stream.pipeline(
|
|
1175
1079
|
response.body,
|
|
1176
1080
|
fsSync.createWriteStream(tempPath)
|
|
1177
1081
|
);
|
|
1178
1082
|
clearTimeout(slowDownloadWarning);
|
|
1179
|
-
const fs =
|
|
1083
|
+
const fs = _chunkTTVNEKBEcjs.getNodeFs.call(void 0, );
|
|
1180
1084
|
const stats = await fs.stat(tempPath);
|
|
1181
1085
|
const downloadDuration = Date.now() - startTime;
|
|
1182
1086
|
if (process.platform !== "win32") {
|
|
@@ -1205,7 +1109,7 @@ async function downloadEngineBinaryIfNeeded(binaryPath, version, varDir) {
|
|
|
1205
1109
|
support: "https://rivet.dev/discord"
|
|
1206
1110
|
});
|
|
1207
1111
|
try {
|
|
1208
|
-
const fs =
|
|
1112
|
+
const fs = _chunkTTVNEKBEcjs.getNodeFs.call(void 0, );
|
|
1209
1113
|
await fs.unlink(tempPath);
|
|
1210
1114
|
} catch (unlinkError) {
|
|
1211
1115
|
}
|
|
@@ -1247,7 +1151,7 @@ function resolveTargetTripletFor(platform, arch) {
|
|
|
1247
1151
|
);
|
|
1248
1152
|
}
|
|
1249
1153
|
async function isEngineRunning() {
|
|
1250
|
-
return await checkIfEngineAlreadyRunningOnPort(
|
|
1154
|
+
return await checkIfEngineAlreadyRunningOnPort(_chunkTTVNEKBEcjs.ENGINE_PORT);
|
|
1251
1155
|
}
|
|
1252
1156
|
async function checkIfEngineAlreadyRunningOnPort(port) {
|
|
1253
1157
|
let response;
|
|
@@ -1282,7 +1186,7 @@ async function checkIfEngineAlreadyRunningOnPort(port) {
|
|
|
1282
1186
|
}
|
|
1283
1187
|
async function fileExists(filePath) {
|
|
1284
1188
|
try {
|
|
1285
|
-
const fs =
|
|
1189
|
+
const fs = _chunkTTVNEKBEcjs.getNodeFs.call(void 0, );
|
|
1286
1190
|
await fs.access(filePath);
|
|
1287
1191
|
return true;
|
|
1288
1192
|
} catch (e) {
|
|
@@ -1296,7 +1200,7 @@ async function waitForEngineHealth() {
|
|
|
1296
1200
|
logger3().debug({ msg: "waiting for engine health check" });
|
|
1297
1201
|
for (let i = 0; i < maxRetries; i++) {
|
|
1298
1202
|
try {
|
|
1299
|
-
const response = await fetch(`${
|
|
1203
|
+
const response = await fetch(`${_chunkTTVNEKBEcjs.ENGINE_ENDPOINT}/health`, {
|
|
1300
1204
|
signal: AbortSignal.timeout(1e3)
|
|
1301
1205
|
});
|
|
1302
1206
|
if (response.ok) {
|
|
@@ -1336,7 +1240,7 @@ function getInspectorUrl(config, managerPort) {
|
|
|
1336
1240
|
|
|
1337
1241
|
// src/serverless/log.ts
|
|
1338
1242
|
function logger4() {
|
|
1339
|
-
return
|
|
1243
|
+
return _chunk2Q5WS6QHcjs.getLogger.call(void 0, "serverless");
|
|
1340
1244
|
}
|
|
1341
1245
|
|
|
1342
1246
|
// src/serverless/configure.ts
|
|
@@ -1356,12 +1260,12 @@ async function configureServerlessRunner(config) {
|
|
|
1356
1260
|
}
|
|
1357
1261
|
const customConfig = config.serverless.configureRunnerPool;
|
|
1358
1262
|
_invariant2.default.call(void 0, customConfig, "configureRunnerPool should exist");
|
|
1359
|
-
const clientConfig =
|
|
1263
|
+
const clientConfig = _chunkGRHLSP4Acjs.convertRegistryConfigToClientConfig.call(void 0, config);
|
|
1360
1264
|
logger4().debug({
|
|
1361
1265
|
msg: "fetching datacenters",
|
|
1362
1266
|
endpoint: config.endpoint
|
|
1363
1267
|
});
|
|
1364
|
-
const dcsRes = await
|
|
1268
|
+
const dcsRes = await _chunkGRHLSP4Acjs.getDatacenters.call(void 0, clientConfig);
|
|
1365
1269
|
const runnerName = _nullishCoalesce(customConfig.name, () => ( "default"));
|
|
1366
1270
|
logger4().debug({
|
|
1367
1271
|
msg: "configuring serverless runner",
|
|
@@ -1383,7 +1287,7 @@ async function configureServerlessRunner(config) {
|
|
|
1383
1287
|
drain_on_version_upgrade: _nullishCoalesce(customConfig.drainOnVersionUpgrade, () => ( true)),
|
|
1384
1288
|
metadataPollInterval: _nullishCoalesce(customConfig.metadataPollInterval, () => ( 1e3))
|
|
1385
1289
|
};
|
|
1386
|
-
await
|
|
1290
|
+
await _chunkGRHLSP4Acjs.updateRunnerConfig.call(void 0, clientConfig, runnerName, {
|
|
1387
1291
|
datacenters: Object.fromEntries(
|
|
1388
1292
|
dcsRes.datacenters.map((dc) => [dc.name, serverlessConfig])
|
|
1389
1293
|
)
|
|
@@ -1424,7 +1328,7 @@ var ServerlessStartHeadersSchema = _v4.z.object({
|
|
|
1424
1328
|
|
|
1425
1329
|
// src/serverless/router.ts
|
|
1426
1330
|
function buildServerlessRouter(driverConfig, config) {
|
|
1427
|
-
return
|
|
1331
|
+
return _chunkTTVNEKBEcjs.createRouter.call(void 0, config.serverless.basePath, (router) => {
|
|
1428
1332
|
router.get("/", (c) => {
|
|
1429
1333
|
return c.text(
|
|
1430
1334
|
"This is a RivetKit server.\n\nLearn more at https://rivetkit.org"
|
|
@@ -1473,10 +1377,10 @@ function buildServerlessRouter(driverConfig, config) {
|
|
|
1473
1377
|
runnerKey: void 0
|
|
1474
1378
|
}
|
|
1475
1379
|
};
|
|
1476
|
-
const managerDriver = new (0,
|
|
1477
|
-
|
|
1380
|
+
const managerDriver = new (0, _chunkGRHLSP4Acjs.RemoteManagerDriver)(
|
|
1381
|
+
_chunkGRHLSP4Acjs.convertRegistryConfigToClientConfig.call(void 0, newConfig)
|
|
1478
1382
|
);
|
|
1479
|
-
const client =
|
|
1383
|
+
const client = _chunkGRHLSP4Acjs.createClientWithDriver.call(void 0, managerDriver);
|
|
1480
1384
|
const actorDriver = driverConfig.actor(
|
|
1481
1385
|
newConfig,
|
|
1482
1386
|
managerDriver,
|
|
@@ -1488,10 +1392,10 @@ function buildServerlessRouter(driverConfig, config) {
|
|
|
1488
1392
|
);
|
|
1489
1393
|
return await actorDriver.serverlessHandleStart(c);
|
|
1490
1394
|
});
|
|
1491
|
-
router.get("/health", (c) =>
|
|
1395
|
+
router.get("/health", (c) => _chunkTTVNEKBEcjs.handleHealthRequest.call(void 0, c));
|
|
1492
1396
|
router.get(
|
|
1493
1397
|
"/metadata",
|
|
1494
|
-
(c) =>
|
|
1398
|
+
(c) => _chunkTTVNEKBEcjs.handleMetadataRequest.call(void 0,
|
|
1495
1399
|
c,
|
|
1496
1400
|
config,
|
|
1497
1401
|
{ serverless: {} },
|
|
@@ -1573,12 +1477,12 @@ var Runtime = class _Runtime {
|
|
|
1573
1477
|
}
|
|
1574
1478
|
static async create(registry) {
|
|
1575
1479
|
var _a, _b, _c;
|
|
1576
|
-
|
|
1480
|
+
_chunkTTVNEKBEcjs.logger.call(void 0, ).info("rivetkit starting");
|
|
1577
1481
|
const config = registry.parseConfig();
|
|
1578
1482
|
if ((_a = config.logging) == null ? void 0 : _a.baseLogger) {
|
|
1579
|
-
|
|
1483
|
+
_chunk2Q5WS6QHcjs.configureBaseLogger.call(void 0, config.logging.baseLogger);
|
|
1580
1484
|
} else {
|
|
1581
|
-
|
|
1485
|
+
_chunk2Q5WS6QHcjs.configureDefaultLogger.call(void 0, (_b = config.logging) == null ? void 0 : _b.level);
|
|
1582
1486
|
}
|
|
1583
1487
|
_invariant2.default.call(void 0,
|
|
1584
1488
|
!(config.serverless.spawnEngine && config.serveManager),
|
|
@@ -1588,8 +1492,8 @@ var Runtime = class _Runtime {
|
|
|
1588
1492
|
const managerDriver = driver.manager(config);
|
|
1589
1493
|
let managerPort;
|
|
1590
1494
|
if (config.serverless.spawnEngine) {
|
|
1591
|
-
managerPort =
|
|
1592
|
-
|
|
1495
|
+
managerPort = _chunkTTVNEKBEcjs.ENGINE_PORT;
|
|
1496
|
+
_chunkTTVNEKBEcjs.logger.call(void 0, ).debug({
|
|
1593
1497
|
msg: "spawning engine",
|
|
1594
1498
|
version: config.serverless.engineVersion
|
|
1595
1499
|
});
|
|
@@ -1598,18 +1502,18 @@ var Runtime = class _Runtime {
|
|
|
1598
1502
|
});
|
|
1599
1503
|
} else if (config.serveManager) {
|
|
1600
1504
|
const configuredManagerPort = config.managerPort;
|
|
1601
|
-
const serveRuntime =
|
|
1505
|
+
const serveRuntime = _chunk2Q5WS6QHcjs.detectRuntime.call(void 0, );
|
|
1602
1506
|
let upgradeWebSocket;
|
|
1603
1507
|
const getUpgradeWebSocket = () => upgradeWebSocket;
|
|
1604
1508
|
managerDriver.setGetUpgradeWebSocket(getUpgradeWebSocket);
|
|
1605
|
-
const { router: managerRouter } =
|
|
1509
|
+
const { router: managerRouter } = _chunkTTVNEKBEcjs.buildManagerRouter.call(void 0,
|
|
1606
1510
|
config,
|
|
1607
1511
|
managerDriver,
|
|
1608
1512
|
getUpgradeWebSocket,
|
|
1609
1513
|
serveRuntime
|
|
1610
1514
|
);
|
|
1611
|
-
managerPort = await
|
|
1612
|
-
|
|
1515
|
+
managerPort = await _chunkTTVNEKBEcjs.findFreePort.call(void 0, config.managerPort);
|
|
1516
|
+
_chunkTTVNEKBEcjs.logger.call(void 0, ).debug({
|
|
1613
1517
|
msg: "serving manager",
|
|
1614
1518
|
port: managerPort
|
|
1615
1519
|
});
|
|
@@ -1618,7 +1522,7 @@ var Runtime = class _Runtime {
|
|
|
1618
1522
|
config.serverless.publicEndpoint = config.publicEndpoint;
|
|
1619
1523
|
}
|
|
1620
1524
|
config.managerPort = managerPort;
|
|
1621
|
-
const out = await
|
|
1525
|
+
const out = await _chunkTTVNEKBEcjs.crossPlatformServe.call(void 0,
|
|
1622
1526
|
config,
|
|
1623
1527
|
managerPort,
|
|
1624
1528
|
managerRouter,
|
|
@@ -1634,7 +1538,7 @@ var Runtime = class _Runtime {
|
|
|
1634
1538
|
managerPort
|
|
1635
1539
|
);
|
|
1636
1540
|
const driverLog = _nullishCoalesce(((_c = managerDriver.extraStartupLog) == null ? void 0 : _c.call(managerDriver)), () => ( {}));
|
|
1637
|
-
|
|
1541
|
+
_chunkTTVNEKBEcjs.logger.call(void 0, ).info({
|
|
1638
1542
|
msg: "rivetkit ready",
|
|
1639
1543
|
driver: driver.name,
|
|
1640
1544
|
definitions: Object.keys(config.use).length,
|
|
@@ -1660,8 +1564,8 @@ var Runtime = class _Runtime {
|
|
|
1660
1564
|
_invariant2.default.call(void 0, !this.#startKind, "Runtime already started as serverless");
|
|
1661
1565
|
this.#startKind = "runner";
|
|
1662
1566
|
if (this.#config.runner && this.#driver.autoStartActorDriver) {
|
|
1663
|
-
|
|
1664
|
-
const inlineClient =
|
|
1567
|
+
_chunkTTVNEKBEcjs.logger.call(void 0, ).debug("starting actor driver");
|
|
1568
|
+
const inlineClient = _chunkGRHLSP4Acjs.createClientWithDriver.call(void 0,
|
|
1665
1569
|
this.#managerDriver
|
|
1666
1570
|
);
|
|
1667
1571
|
this.#driver.actor(this.#config, this.#managerDriver, inlineClient);
|
|
@@ -1673,7 +1577,7 @@ var Runtime = class _Runtime {
|
|
|
1673
1577
|
const inspectorUrl = this.managerPort ? getInspectorUrl(this.#config, this.managerPort) : void 0;
|
|
1674
1578
|
console.log();
|
|
1675
1579
|
console.log(
|
|
1676
|
-
` RivetKit ${
|
|
1580
|
+
` RivetKit ${_chunk2Q5WS6QHcjs.package_default.version} (${this.#driver.displayName} - ${this.#startKind === "serverless" ? "Serverless" : "Runner"})`
|
|
1677
1581
|
);
|
|
1678
1582
|
if (this.#config.namespace !== "default") {
|
|
1679
1583
|
logLine("Namespace", this.#config.namespace);
|
|
@@ -1707,6 +1611,101 @@ var Runtime = class _Runtime {
|
|
|
1707
1611
|
}
|
|
1708
1612
|
};
|
|
1709
1613
|
|
|
1614
|
+
// src/registry/config/legacy-runner.ts
|
|
1615
|
+
|
|
1616
|
+
var LegacyDriverConfigSchema = _v4.z.object({
|
|
1617
|
+
/** Machine-readable name to identify this driver by. */
|
|
1618
|
+
name: _v4.z.string(),
|
|
1619
|
+
manager: _v4.z.custom(),
|
|
1620
|
+
actor: _v4.z.custom()
|
|
1621
|
+
});
|
|
1622
|
+
var LegacyRunnerConfigSchemaUnmerged = _v4.z.object({
|
|
1623
|
+
driver: LegacyDriverConfigSchema.optional(),
|
|
1624
|
+
/** @experimental */
|
|
1625
|
+
maxIncomingMessageSize: _v4.z.number().optional().default(65536),
|
|
1626
|
+
/** @experimental */
|
|
1627
|
+
maxOutgoingMessageSize: _v4.z.number().optional().default(1048576),
|
|
1628
|
+
/** @experimental */
|
|
1629
|
+
inspector: _chunkTTVNEKBEcjs.InspectorConfigSchema,
|
|
1630
|
+
/** @experimental */
|
|
1631
|
+
disableDefaultServer: _v4.z.boolean().optional().default(false),
|
|
1632
|
+
/** @experimental */
|
|
1633
|
+
defaultServerPort: _v4.z.number().default(6420),
|
|
1634
|
+
/** @experimental */
|
|
1635
|
+
runEngine: _v4.z.boolean().optional().default(() => _chunk2Q5WS6QHcjs.getRivetRunEngine.call(void 0, )),
|
|
1636
|
+
/** @experimental */
|
|
1637
|
+
runEngineVersion: _v4.z.string().optional().default(() => _nullishCoalesce(_chunk2Q5WS6QHcjs.getRivetRunEngineVersion.call(void 0, ), () => ( _chunk2Q5WS6QHcjs.VERSION))),
|
|
1638
|
+
/** @experimental */
|
|
1639
|
+
overrideServerAddress: _v4.z.string().optional(),
|
|
1640
|
+
/** @experimental */
|
|
1641
|
+
disableActorDriver: _v4.z.boolean().optional().default(false),
|
|
1642
|
+
/**
|
|
1643
|
+
* @experimental
|
|
1644
|
+
*
|
|
1645
|
+
* Whether to run runners normally or have them managed
|
|
1646
|
+
* serverlessly (by the Rivet Engine for example).
|
|
1647
|
+
*/
|
|
1648
|
+
runnerKind: _v4.z.enum(["serverless", "normal"]).optional().default(
|
|
1649
|
+
() => _chunk2Q5WS6QHcjs.getRivetRunnerKind.call(void 0, ) === "serverless" ? "serverless" : "normal"
|
|
1650
|
+
),
|
|
1651
|
+
totalSlots: _v4.z.number().optional(),
|
|
1652
|
+
/**
|
|
1653
|
+
* @experimental
|
|
1654
|
+
*
|
|
1655
|
+
* Base path for the router. This is used to prefix all routes.
|
|
1656
|
+
* For example, if the base path is `/api`, then the route `/actors` will be
|
|
1657
|
+
* available at `/api/actors`.
|
|
1658
|
+
*/
|
|
1659
|
+
basePath: _v4.z.string().optional().default("/"),
|
|
1660
|
+
/**
|
|
1661
|
+
* @experimental
|
|
1662
|
+
*
|
|
1663
|
+
* Disable welcome message.
|
|
1664
|
+
* */
|
|
1665
|
+
noWelcome: _v4.z.boolean().optional().default(false),
|
|
1666
|
+
/**
|
|
1667
|
+
* @experimental
|
|
1668
|
+
* */
|
|
1669
|
+
logging: _v4.z.object({
|
|
1670
|
+
baseLogger: _v4.z.custom().optional(),
|
|
1671
|
+
level: _chunk2Q5WS6QHcjs.LogLevelSchema.optional()
|
|
1672
|
+
}).optional().default(() => ({})),
|
|
1673
|
+
/**
|
|
1674
|
+
* @experimental
|
|
1675
|
+
*
|
|
1676
|
+
* Automatically configure serverless runners in the engine.
|
|
1677
|
+
* Can only be used when runnerKind is "serverless".
|
|
1678
|
+
* If true, uses default configuration. Can also provide custom configuration.
|
|
1679
|
+
*/
|
|
1680
|
+
autoConfigureServerless: _v4.z.union([
|
|
1681
|
+
_v4.z.boolean(),
|
|
1682
|
+
_v4.z.object({
|
|
1683
|
+
url: _v4.z.string().optional(),
|
|
1684
|
+
headers: _v4.z.record(_v4.z.string(), _v4.z.string()).optional(),
|
|
1685
|
+
maxRunners: _v4.z.number().optional(),
|
|
1686
|
+
minRunners: _v4.z.number().optional(),
|
|
1687
|
+
requestLifespan: _v4.z.number().optional(),
|
|
1688
|
+
runnersMargin: _v4.z.number().optional(),
|
|
1689
|
+
slotsPerRunner: _v4.z.number().optional(),
|
|
1690
|
+
metadata: _v4.z.record(_v4.z.string(), _v4.z.unknown()).optional()
|
|
1691
|
+
})
|
|
1692
|
+
]).optional(),
|
|
1693
|
+
// This is a function to allow for lazy configuration of upgradeWebSocket on the
|
|
1694
|
+
// fly. This is required since the dependencies that upgradeWebSocket
|
|
1695
|
+
// (specifically Node.js) can sometimes only be specified after the router is
|
|
1696
|
+
// created or must be imported async using `await import(...)`
|
|
1697
|
+
getUpgradeWebSocket: _v4.z.custom().optional(),
|
|
1698
|
+
/** @experimental */
|
|
1699
|
+
token: _v4.z.string().optional().transform((v) => v || _chunk2Q5WS6QHcjs.getRivetToken.call(void 0, ))
|
|
1700
|
+
}).merge(EngineConfigSchemaBase);
|
|
1701
|
+
var LegacyRunnerConfigSchemaTransformed = LegacyRunnerConfigSchemaUnmerged.transform((config, ctx) => ({
|
|
1702
|
+
...config,
|
|
1703
|
+
...transformEngineConfig(config, ctx)
|
|
1704
|
+
}));
|
|
1705
|
+
var LegacyRunnerConfigSchema = LegacyRunnerConfigSchemaTransformed.default(
|
|
1706
|
+
() => LegacyRunnerConfigSchemaTransformed.parse({})
|
|
1707
|
+
);
|
|
1708
|
+
|
|
1710
1709
|
// src/registry/index.ts
|
|
1711
1710
|
var Registry = class {
|
|
1712
1711
|
#config;
|
|
@@ -1714,14 +1713,15 @@ var Registry = class {
|
|
|
1714
1713
|
return this.#config;
|
|
1715
1714
|
}
|
|
1716
1715
|
parseConfig() {
|
|
1717
|
-
return
|
|
1716
|
+
return _chunkTTVNEKBEcjs.RegistryConfigSchema.parse(this.#config);
|
|
1718
1717
|
}
|
|
1719
1718
|
// Shared runtime instance
|
|
1720
1719
|
#runtime;
|
|
1721
1720
|
#runtimePromise;
|
|
1722
1721
|
constructor(config) {
|
|
1722
|
+
var _a;
|
|
1723
1723
|
this.#config = config;
|
|
1724
|
-
if (
|
|
1724
|
+
if (((_a = config.serverless) == null ? void 0 : _a.spawnEngine) || config.serveManager) {
|
|
1725
1725
|
setTimeout(() => {
|
|
1726
1726
|
this.#ensureRuntime();
|
|
1727
1727
|
}, 0);
|
|
@@ -1782,7 +1782,7 @@ var Registry = class {
|
|
|
1782
1782
|
"autoConfigureServerless can only be configured when runnerKind is 'serverless'"
|
|
1783
1783
|
);
|
|
1784
1784
|
}
|
|
1785
|
-
const isDevEnv =
|
|
1785
|
+
const isDevEnv = _chunk2Q5WS6QHcjs.isDev.call(void 0, );
|
|
1786
1786
|
if (isDevEnv && config.runnerKind === "serverless") {
|
|
1787
1787
|
if ((inputConfig == null ? void 0 : inputConfig.runEngine) === void 0) config.runEngine = true;
|
|
1788
1788
|
if ((inputConfig == null ? void 0 : inputConfig.autoConfigureServerless) === void 0)
|
|
@@ -1795,7 +1795,7 @@ var Registry = class {
|
|
|
1795
1795
|
}
|
|
1796
1796
|
}
|
|
1797
1797
|
#legacyStartServerless(config, _inputConfig) {
|
|
1798
|
-
const client =
|
|
1798
|
+
const client = _chunkGRHLSP4Acjs.createClient.call(void 0, {
|
|
1799
1799
|
endpoint: config.endpoint,
|
|
1800
1800
|
token: config.token,
|
|
1801
1801
|
namespace: config.namespace,
|
|
@@ -1808,7 +1808,7 @@ var Registry = class {
|
|
|
1808
1808
|
}
|
|
1809
1809
|
#legacyStartNormal(config) {
|
|
1810
1810
|
this.#ensureRuntime().then((runtime) => runtime.startRunner());
|
|
1811
|
-
const client =
|
|
1811
|
+
const client = _chunkGRHLSP4Acjs.createClient.call(void 0, {
|
|
1812
1812
|
endpoint: config.endpoint,
|
|
1813
1813
|
token: config.token,
|
|
1814
1814
|
namespace: config.namespace,
|
|
@@ -1832,4 +1832,4 @@ function setup(input) {
|
|
|
1832
1832
|
|
|
1833
1833
|
|
|
1834
1834
|
exports.actor = actor; exports.event = event2; exports.queue = queue2; exports.createEngineDriver = createEngineDriver; exports.Registry = Registry; exports.setup = setup;
|
|
1835
|
-
//# sourceMappingURL=chunk-
|
|
1835
|
+
//# sourceMappingURL=chunk-VQHUWB37.cjs.map
|