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.
- package/README.md +3 -5
- package/dist/schemas/actor-persist/v1.ts +225 -0
- package/dist/schemas/client-protocol/v1.ts +435 -0
- package/dist/schemas/file-system-driver/v1.ts +102 -0
- package/dist/tsup/actor/errors.cjs +77 -0
- package/dist/tsup/actor/errors.cjs.map +1 -0
- package/dist/tsup/actor/errors.d.cts +156 -0
- package/dist/tsup/actor/errors.d.ts +156 -0
- package/dist/tsup/actor/errors.js +77 -0
- package/dist/tsup/actor/errors.js.map +1 -0
- package/dist/tsup/chunk-3F2YSRJL.js +117 -0
- package/dist/tsup/chunk-3F2YSRJL.js.map +1 -0
- package/dist/tsup/chunk-4CXBCT26.cjs +250 -0
- package/dist/tsup/chunk-4CXBCT26.cjs.map +1 -0
- package/dist/tsup/chunk-4R73YDN3.cjs +20 -0
- package/dist/tsup/chunk-4R73YDN3.cjs.map +1 -0
- package/dist/tsup/chunk-6LJT3QRL.cjs +539 -0
- package/dist/tsup/chunk-6LJT3QRL.cjs.map +1 -0
- package/dist/tsup/chunk-GICQ3YCU.cjs +1792 -0
- package/dist/tsup/chunk-GICQ3YCU.cjs.map +1 -0
- package/dist/tsup/chunk-H26RP6GD.js +251 -0
- package/dist/tsup/chunk-H26RP6GD.js.map +1 -0
- package/dist/tsup/chunk-HI3HWJRC.js +20 -0
- package/dist/tsup/chunk-HI3HWJRC.js.map +1 -0
- package/dist/tsup/chunk-HLLF4B4Q.js +1792 -0
- package/dist/tsup/chunk-HLLF4B4Q.js.map +1 -0
- package/dist/tsup/chunk-IH6CKNDW.cjs +117 -0
- package/dist/tsup/chunk-IH6CKNDW.cjs.map +1 -0
- package/dist/tsup/chunk-LV2S3OU3.js +250 -0
- package/dist/tsup/chunk-LV2S3OU3.js.map +1 -0
- package/dist/tsup/chunk-LWNKVZG5.cjs +251 -0
- package/dist/tsup/chunk-LWNKVZG5.cjs.map +1 -0
- package/dist/tsup/chunk-NFU2BBT5.js +374 -0
- package/dist/tsup/chunk-NFU2BBT5.js.map +1 -0
- package/dist/tsup/chunk-PQY7KKTL.js +539 -0
- package/dist/tsup/chunk-PQY7KKTL.js.map +1 -0
- package/dist/tsup/chunk-QK72M5JB.js +45 -0
- package/dist/tsup/chunk-QK72M5JB.js.map +1 -0
- package/dist/tsup/chunk-QNNXFOQV.cjs +45 -0
- package/dist/tsup/chunk-QNNXFOQV.cjs.map +1 -0
- package/dist/tsup/chunk-SBHHJ6QS.cjs +374 -0
- package/dist/tsup/chunk-SBHHJ6QS.cjs.map +1 -0
- package/dist/tsup/chunk-TQ62L3X7.js +325 -0
- package/dist/tsup/chunk-TQ62L3X7.js.map +1 -0
- package/dist/tsup/chunk-VO7ZRVVD.cjs +6293 -0
- package/dist/tsup/chunk-VO7ZRVVD.cjs.map +1 -0
- package/dist/tsup/chunk-WHBPJNGW.cjs +325 -0
- package/dist/tsup/chunk-WHBPJNGW.cjs.map +1 -0
- package/dist/tsup/chunk-XJQHKJ4P.js +6293 -0
- package/dist/tsup/chunk-XJQHKJ4P.js.map +1 -0
- package/dist/tsup/client/mod.cjs +32 -0
- package/dist/tsup/client/mod.cjs.map +1 -0
- package/dist/tsup/client/mod.d.cts +20 -0
- package/dist/tsup/client/mod.d.ts +20 -0
- package/dist/tsup/client/mod.js +32 -0
- package/dist/tsup/client/mod.js.map +1 -0
- package/dist/tsup/common/log.cjs +21 -0
- package/dist/tsup/common/log.cjs.map +1 -0
- package/dist/tsup/common/log.d.cts +26 -0
- package/dist/tsup/common/log.d.ts +26 -0
- package/dist/tsup/common/log.js +21 -0
- package/dist/tsup/common/log.js.map +1 -0
- package/dist/tsup/common/websocket.cjs +10 -0
- package/dist/tsup/common/websocket.cjs.map +1 -0
- package/dist/tsup/common/websocket.d.cts +3 -0
- package/dist/tsup/common/websocket.d.ts +3 -0
- package/dist/tsup/common/websocket.js +10 -0
- package/dist/tsup/common/websocket.js.map +1 -0
- package/dist/tsup/common-CXCe7s6i.d.cts +218 -0
- package/dist/tsup/common-CXCe7s6i.d.ts +218 -0
- package/dist/tsup/connection-BI-6UIBJ.d.ts +2087 -0
- package/dist/tsup/connection-Dyd4NLGW.d.cts +2087 -0
- package/dist/tsup/driver-helpers/mod.cjs +30 -0
- package/dist/tsup/driver-helpers/mod.cjs.map +1 -0
- package/dist/tsup/driver-helpers/mod.d.cts +17 -0
- package/dist/tsup/driver-helpers/mod.d.ts +17 -0
- package/dist/tsup/driver-helpers/mod.js +30 -0
- package/dist/tsup/driver-helpers/mod.js.map +1 -0
- package/dist/tsup/driver-test-suite/mod.cjs +3411 -0
- package/dist/tsup/driver-test-suite/mod.cjs.map +1 -0
- package/dist/tsup/driver-test-suite/mod.d.cts +63 -0
- package/dist/tsup/driver-test-suite/mod.d.ts +63 -0
- package/dist/tsup/driver-test-suite/mod.js +3411 -0
- package/dist/tsup/driver-test-suite/mod.js.map +1 -0
- package/dist/tsup/inspector/mod.cjs +51 -0
- package/dist/tsup/inspector/mod.cjs.map +1 -0
- package/dist/tsup/inspector/mod.d.cts +408 -0
- package/dist/tsup/inspector/mod.d.ts +408 -0
- package/dist/tsup/inspector/mod.js +51 -0
- package/dist/tsup/inspector/mod.js.map +1 -0
- package/dist/tsup/mod.cjs +67 -0
- package/dist/tsup/mod.cjs.map +1 -0
- package/dist/tsup/mod.d.cts +105 -0
- package/dist/tsup/mod.d.ts +105 -0
- package/dist/tsup/mod.js +67 -0
- package/dist/tsup/mod.js.map +1 -0
- package/dist/tsup/router-endpoints-BTe_Rsdn.d.cts +65 -0
- package/dist/tsup/router-endpoints-CBSrKHmo.d.ts +65 -0
- package/dist/tsup/test/mod.cjs +17 -0
- package/dist/tsup/test/mod.cjs.map +1 -0
- package/dist/tsup/test/mod.d.cts +26 -0
- package/dist/tsup/test/mod.d.ts +26 -0
- package/dist/tsup/test/mod.js +17 -0
- package/dist/tsup/test/mod.js.map +1 -0
- package/dist/tsup/utils-fwx3o3K9.d.cts +18 -0
- package/dist/tsup/utils-fwx3o3K9.d.ts +18 -0
- package/dist/tsup/utils.cjs +26 -0
- package/dist/tsup/utils.cjs.map +1 -0
- package/dist/tsup/utils.d.cts +36 -0
- package/dist/tsup/utils.d.ts +36 -0
- package/dist/tsup/utils.js +26 -0
- package/dist/tsup/utils.js.map +1 -0
- package/package.json +208 -5
- package/src/actor/action.ts +178 -0
- package/src/actor/config.ts +497 -0
- package/src/actor/connection.ts +257 -0
- package/src/actor/context.ts +168 -0
- package/src/actor/database.ts +23 -0
- package/src/actor/definition.ts +82 -0
- package/src/actor/driver.ts +84 -0
- package/src/actor/errors.ts +422 -0
- package/src/actor/generic-conn-driver.ts +246 -0
- package/src/actor/instance.ts +1844 -0
- package/src/actor/keys.test.ts +266 -0
- package/src/actor/keys.ts +89 -0
- package/src/actor/log.ts +6 -0
- package/src/actor/mod.ts +108 -0
- package/src/actor/persisted.ts +42 -0
- package/src/actor/protocol/old.ts +297 -0
- package/src/actor/protocol/serde.ts +131 -0
- package/src/actor/router-endpoints.ts +688 -0
- package/src/actor/router.ts +265 -0
- package/src/actor/schedule.ts +17 -0
- package/src/actor/unstable-react.ts +110 -0
- package/src/actor/utils.ts +102 -0
- package/src/client/actor-common.ts +30 -0
- package/src/client/actor-conn.ts +865 -0
- package/src/client/actor-handle.ts +268 -0
- package/src/client/actor-query.ts +65 -0
- package/src/client/client.ts +554 -0
- package/src/client/config.ts +44 -0
- package/src/client/errors.ts +42 -0
- package/src/client/log.ts +5 -0
- package/src/client/mod.ts +60 -0
- package/src/client/raw-utils.ts +149 -0
- package/src/client/test.ts +44 -0
- package/src/client/utils.ts +152 -0
- package/src/common/eventsource-interface.ts +47 -0
- package/src/common/eventsource.ts +80 -0
- package/src/common/fake-event-source.ts +267 -0
- package/src/common/inline-websocket-adapter2.ts +454 -0
- package/src/common/log-levels.ts +27 -0
- package/src/common/log.ts +214 -0
- package/src/common/logfmt.ts +219 -0
- package/src/common/network.ts +2 -0
- package/src/common/router.ts +80 -0
- package/src/common/utils.ts +336 -0
- package/src/common/versioned-data.ts +95 -0
- package/src/common/websocket-interface.ts +49 -0
- package/src/common/websocket.ts +42 -0
- package/src/driver-helpers/mod.ts +22 -0
- package/src/driver-helpers/utils.ts +17 -0
- package/src/driver-test-suite/log.ts +5 -0
- package/src/driver-test-suite/mod.ts +239 -0
- package/src/driver-test-suite/tests/action-features.ts +136 -0
- package/src/driver-test-suite/tests/actor-conn-state.ts +249 -0
- package/src/driver-test-suite/tests/actor-conn.ts +349 -0
- package/src/driver-test-suite/tests/actor-driver.ts +25 -0
- package/src/driver-test-suite/tests/actor-error-handling.ts +158 -0
- package/src/driver-test-suite/tests/actor-handle.ts +292 -0
- package/src/driver-test-suite/tests/actor-inline-client.ts +152 -0
- package/src/driver-test-suite/tests/actor-inspector.ts +570 -0
- package/src/driver-test-suite/tests/actor-metadata.ts +116 -0
- package/src/driver-test-suite/tests/actor-onstatechange.ts +95 -0
- package/src/driver-test-suite/tests/actor-schedule.ts +108 -0
- package/src/driver-test-suite/tests/actor-sleep.ts +413 -0
- package/src/driver-test-suite/tests/actor-state.ts +54 -0
- package/src/driver-test-suite/tests/actor-vars.ts +93 -0
- package/src/driver-test-suite/tests/manager-driver.ts +367 -0
- package/src/driver-test-suite/tests/raw-http-direct-registry.ts +227 -0
- package/src/driver-test-suite/tests/raw-http-request-properties.ts +414 -0
- package/src/driver-test-suite/tests/raw-http.ts +347 -0
- package/src/driver-test-suite/tests/raw-websocket-direct-registry.ts +393 -0
- package/src/driver-test-suite/tests/raw-websocket.ts +484 -0
- package/src/driver-test-suite/tests/request-access.ts +230 -0
- package/src/driver-test-suite/utils.ts +71 -0
- package/src/drivers/default.ts +34 -0
- package/src/drivers/engine/actor-driver.ts +369 -0
- package/src/drivers/engine/config.ts +31 -0
- package/src/drivers/engine/kv.ts +3 -0
- package/src/drivers/engine/log.ts +5 -0
- package/src/drivers/engine/mod.ts +35 -0
- package/src/drivers/file-system/actor.ts +91 -0
- package/src/drivers/file-system/global-state.ts +686 -0
- package/src/drivers/file-system/log.ts +5 -0
- package/src/drivers/file-system/manager.ts +329 -0
- package/src/drivers/file-system/mod.ts +48 -0
- package/src/drivers/file-system/utils.ts +109 -0
- package/src/globals.d.ts +6 -0
- package/src/inspector/actor.ts +298 -0
- package/src/inspector/config.ts +88 -0
- package/src/inspector/log.ts +5 -0
- package/src/inspector/manager.ts +86 -0
- package/src/inspector/mod.ts +2 -0
- package/src/inspector/protocol/actor.ts +10 -0
- package/src/inspector/protocol/common.ts +196 -0
- package/src/inspector/protocol/manager.ts +10 -0
- package/src/inspector/protocol/mod.ts +2 -0
- package/src/inspector/utils.ts +76 -0
- package/src/manager/driver.ts +88 -0
- package/src/manager/hono-websocket-adapter.ts +342 -0
- package/src/manager/log.ts +5 -0
- package/src/manager/mod.ts +2 -0
- package/src/manager/protocol/mod.ts +24 -0
- package/src/manager/protocol/query.ts +89 -0
- package/src/manager/router.ts +412 -0
- package/src/manager-api/routes/actors-create.ts +16 -0
- package/src/manager-api/routes/actors-delete.ts +4 -0
- package/src/manager-api/routes/actors-get-by-id.ts +7 -0
- package/src/manager-api/routes/actors-get-or-create-by-id.ts +29 -0
- package/src/manager-api/routes/actors-get.ts +7 -0
- package/src/manager-api/routes/common.ts +18 -0
- package/src/mod.ts +18 -0
- package/src/registry/config.ts +32 -0
- package/src/registry/log.ts +5 -0
- package/src/registry/mod.ts +157 -0
- package/src/registry/run-config.ts +52 -0
- package/src/registry/serve.ts +52 -0
- package/src/remote-manager-driver/actor-http-client.ts +72 -0
- package/src/remote-manager-driver/actor-websocket-client.ts +63 -0
- package/src/remote-manager-driver/api-endpoints.ts +79 -0
- package/src/remote-manager-driver/api-utils.ts +43 -0
- package/src/remote-manager-driver/log.ts +5 -0
- package/src/remote-manager-driver/mod.ts +274 -0
- package/src/remote-manager-driver/ws-proxy.ts +180 -0
- package/src/schemas/actor-persist/mod.ts +1 -0
- package/src/schemas/actor-persist/versioned.ts +25 -0
- package/src/schemas/client-protocol/mod.ts +1 -0
- package/src/schemas/client-protocol/versioned.ts +63 -0
- package/src/schemas/file-system-driver/mod.ts +1 -0
- package/src/schemas/file-system-driver/versioned.ts +28 -0
- package/src/serde.ts +90 -0
- package/src/test/config.ts +16 -0
- package/src/test/log.ts +5 -0
- package/src/test/mod.ts +154 -0
- package/src/utils.ts +172 -0
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
import type { Hono } from "hono";
|
|
2
|
+
import { z } from "zod";
|
|
3
|
+
import { getEnvUniversal } from "@/utils";
|
|
4
|
+
|
|
5
|
+
export const ConfigSchema = z
|
|
6
|
+
.object({
|
|
7
|
+
app: z.custom<Hono>().optional(),
|
|
8
|
+
endpoint: z
|
|
9
|
+
.string()
|
|
10
|
+
.default(
|
|
11
|
+
() => getEnvUniversal("RIVET_ENGINE") ?? "http://localhost:6420",
|
|
12
|
+
),
|
|
13
|
+
pegboardEndpoint: z.string().optional(),
|
|
14
|
+
namespace: z
|
|
15
|
+
.string()
|
|
16
|
+
.default(() => getEnvUniversal("RIVET_NAMESPACE") ?? "default"),
|
|
17
|
+
runnerName: z
|
|
18
|
+
.string()
|
|
19
|
+
.default(() => getEnvUniversal("RIVET_RUNNER") ?? "rivetkit"),
|
|
20
|
+
// TODO: Automatically attempt to determine key by common env vars (e.g. k8s pod name)
|
|
21
|
+
runnerKey: z
|
|
22
|
+
.string()
|
|
23
|
+
.default(
|
|
24
|
+
() => getEnvUniversal("RIVET_RUNNER_KEY") ?? crypto.randomUUID(),
|
|
25
|
+
),
|
|
26
|
+
totalSlots: z.number().default(100_000),
|
|
27
|
+
})
|
|
28
|
+
.default({});
|
|
29
|
+
|
|
30
|
+
export type InputConfig = z.input<typeof ConfigSchema>;
|
|
31
|
+
export type Config = z.infer<typeof ConfigSchema>;
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
import type { Client } from "@/client/client";
|
|
2
|
+
import type { ManagerDriver } from "@/manager/driver";
|
|
3
|
+
import type { RegistryConfig } from "@/registry/config";
|
|
4
|
+
import type { DriverConfig, RunConfig } from "@/registry/run-config";
|
|
5
|
+
import { RemoteManagerDriver } from "@/remote-manager-driver/mod";
|
|
6
|
+
import { EngineActorDriver } from "./actor-driver";
|
|
7
|
+
import { ConfigSchema, type InputConfig } from "./config";
|
|
8
|
+
|
|
9
|
+
export { EngineActorDriver } from "./actor-driver";
|
|
10
|
+
export { type Config, ConfigSchema, type InputConfig } from "./config";
|
|
11
|
+
|
|
12
|
+
export function createEngineDriver(inputConfig?: InputConfig): DriverConfig {
|
|
13
|
+
const config = ConfigSchema.parse(inputConfig);
|
|
14
|
+
|
|
15
|
+
return {
|
|
16
|
+
name: "engine",
|
|
17
|
+
manager: (_registryConfig, runConfig) => {
|
|
18
|
+
return new RemoteManagerDriver(runConfig);
|
|
19
|
+
},
|
|
20
|
+
actor: (
|
|
21
|
+
registryConfig: RegistryConfig,
|
|
22
|
+
runConfig: RunConfig,
|
|
23
|
+
managerDriver: ManagerDriver,
|
|
24
|
+
inlineClient: Client<any>,
|
|
25
|
+
) => {
|
|
26
|
+
return new EngineActorDriver(
|
|
27
|
+
registryConfig,
|
|
28
|
+
runConfig,
|
|
29
|
+
managerDriver,
|
|
30
|
+
inlineClient,
|
|
31
|
+
config,
|
|
32
|
+
);
|
|
33
|
+
},
|
|
34
|
+
};
|
|
35
|
+
}
|
|
@@ -0,0 +1,91 @@
|
|
|
1
|
+
import type { GenericConnGlobalState } from "@/actor/generic-conn-driver";
|
|
2
|
+
import { loggerWithoutContext } from "@/actor/log";
|
|
3
|
+
import type { AnyClient } from "@/client/client";
|
|
4
|
+
import type {
|
|
5
|
+
ActorDriver,
|
|
6
|
+
AnyActorInstance,
|
|
7
|
+
ManagerDriver,
|
|
8
|
+
} from "@/driver-helpers/mod";
|
|
9
|
+
import type { RegistryConfig, RunConfig } from "@/mod";
|
|
10
|
+
import { bufferToArrayBuffer } from "@/utils";
|
|
11
|
+
import type { FileSystemGlobalState } from "./global-state";
|
|
12
|
+
|
|
13
|
+
export type ActorDriverContext = Record<never, never>;
|
|
14
|
+
|
|
15
|
+
/**
|
|
16
|
+
* File System implementation of the Actor Driver
|
|
17
|
+
*/
|
|
18
|
+
export class FileSystemActorDriver implements ActorDriver {
|
|
19
|
+
#registryConfig: RegistryConfig;
|
|
20
|
+
#runConfig: RunConfig;
|
|
21
|
+
#managerDriver: ManagerDriver;
|
|
22
|
+
#inlineClient: AnyClient;
|
|
23
|
+
#state: FileSystemGlobalState;
|
|
24
|
+
|
|
25
|
+
constructor(
|
|
26
|
+
registryConfig: RegistryConfig,
|
|
27
|
+
runConfig: RunConfig,
|
|
28
|
+
managerDriver: ManagerDriver,
|
|
29
|
+
inlineClient: AnyClient,
|
|
30
|
+
state: FileSystemGlobalState,
|
|
31
|
+
) {
|
|
32
|
+
this.#registryConfig = registryConfig;
|
|
33
|
+
this.#runConfig = runConfig;
|
|
34
|
+
this.#managerDriver = managerDriver;
|
|
35
|
+
this.#inlineClient = inlineClient;
|
|
36
|
+
this.#state = state;
|
|
37
|
+
}
|
|
38
|
+
|
|
39
|
+
async loadActor(actorId: string): Promise<AnyActorInstance> {
|
|
40
|
+
return this.#state.startActor(
|
|
41
|
+
this.#registryConfig,
|
|
42
|
+
this.#runConfig,
|
|
43
|
+
this.#inlineClient,
|
|
44
|
+
this,
|
|
45
|
+
actorId,
|
|
46
|
+
);
|
|
47
|
+
}
|
|
48
|
+
|
|
49
|
+
getGenericConnGlobalState(actorId: string): GenericConnGlobalState {
|
|
50
|
+
return this.#state.getActorOrError(actorId).genericConnGlobalState;
|
|
51
|
+
}
|
|
52
|
+
|
|
53
|
+
/**
|
|
54
|
+
* Get the current storage directory path
|
|
55
|
+
*/
|
|
56
|
+
get storagePath(): string {
|
|
57
|
+
return this.#state.storagePath;
|
|
58
|
+
}
|
|
59
|
+
|
|
60
|
+
getContext(_actorId: string): ActorDriverContext {
|
|
61
|
+
return {};
|
|
62
|
+
}
|
|
63
|
+
|
|
64
|
+
async readPersistedData(actorId: string): Promise<Uint8Array | undefined> {
|
|
65
|
+
return new Uint8Array(
|
|
66
|
+
(await this.#state.loadActorStateOrError(actorId)).persistedData,
|
|
67
|
+
);
|
|
68
|
+
}
|
|
69
|
+
|
|
70
|
+
async writePersistedData(actorId: string, data: Uint8Array): Promise<void> {
|
|
71
|
+
const state = await this.#state.loadActorStateOrError(actorId);
|
|
72
|
+
|
|
73
|
+
// Save state to disk
|
|
74
|
+
await this.#state.writeActor(actorId, {
|
|
75
|
+
...state,
|
|
76
|
+
persistedData: bufferToArrayBuffer(data),
|
|
77
|
+
});
|
|
78
|
+
}
|
|
79
|
+
|
|
80
|
+
async setAlarm(actor: AnyActorInstance, timestamp: number): Promise<void> {
|
|
81
|
+
await this.#state.setActorAlarm(actor.id, timestamp);
|
|
82
|
+
}
|
|
83
|
+
|
|
84
|
+
getDatabase(actorId: string): Promise<unknown | undefined> {
|
|
85
|
+
return this.#state.createDatabase(actorId);
|
|
86
|
+
}
|
|
87
|
+
|
|
88
|
+
sleep(actorId: string): Promise<void> {
|
|
89
|
+
return this.#state.sleepActor(actorId);
|
|
90
|
+
}
|
|
91
|
+
}
|