opencode-graphiti 0.0.0-development
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/LICENSE +21 -0
- package/README.md +358 -0
- package/esm/_dnt.polyfills.d.ts +166 -0
- package/esm/_dnt.polyfills.d.ts.map +1 -0
- package/esm/_dnt.polyfills.js +177 -0
- package/esm/_dnt.shims.d.ts +6 -0
- package/esm/_dnt.shims.d.ts.map +1 -0
- package/esm/_dnt.shims.js +61 -0
- package/esm/deno.d.ts +45 -0
- package/esm/deno.d.ts.map +1 -0
- package/esm/deno.js +39 -0
- package/esm/mod.d.ts +3 -0
- package/esm/mod.d.ts.map +1 -0
- package/esm/mod.js +2 -0
- package/esm/package.json +3 -0
- package/esm/src/config.d.ts +20 -0
- package/esm/src/config.d.ts.map +1 -0
- package/esm/src/config.js +246 -0
- package/esm/src/handlers/chat.d.ts +14 -0
- package/esm/src/handlers/chat.d.ts.map +1 -0
- package/esm/src/handlers/chat.js +60 -0
- package/esm/src/handlers/compacting.d.ts +9 -0
- package/esm/src/handlers/compacting.d.ts.map +1 -0
- package/esm/src/handlers/compacting.js +30 -0
- package/esm/src/handlers/event.d.ts +22 -0
- package/esm/src/handlers/event.d.ts.map +1 -0
- package/esm/src/handlers/event.js +287 -0
- package/esm/src/handlers/messages.d.ts +9 -0
- package/esm/src/handlers/messages.d.ts.map +1 -0
- package/esm/src/handlers/messages.js +93 -0
- package/esm/src/index.d.ts +5 -0
- package/esm/src/index.d.ts.map +1 -0
- package/esm/src/index.js +153 -0
- package/esm/src/services/batch-drain.d.ts +23 -0
- package/esm/src/services/batch-drain.d.ts.map +1 -0
- package/esm/src/services/batch-drain.js +217 -0
- package/esm/src/services/connection-manager.d.ts +104 -0
- package/esm/src/services/connection-manager.d.ts.map +1 -0
- package/esm/src/services/connection-manager.js +621 -0
- package/esm/src/services/constants.d.ts +7 -0
- package/esm/src/services/constants.d.ts.map +1 -0
- package/esm/src/services/constants.js +6 -0
- package/esm/src/services/context-limit.d.ts +3 -0
- package/esm/src/services/context-limit.d.ts.map +1 -0
- package/esm/src/services/context-limit.js +44 -0
- package/esm/src/services/event-extractor.d.ts +29 -0
- package/esm/src/services/event-extractor.d.ts.map +1 -0
- package/esm/src/services/event-extractor.js +659 -0
- package/esm/src/services/graphiti-async.d.ts +22 -0
- package/esm/src/services/graphiti-async.d.ts.map +1 -0
- package/esm/src/services/graphiti-async.js +219 -0
- package/esm/src/services/graphiti-mcp.d.ts +57 -0
- package/esm/src/services/graphiti-mcp.d.ts.map +1 -0
- package/esm/src/services/graphiti-mcp.js +194 -0
- package/esm/src/services/logger.d.ts +9 -0
- package/esm/src/services/logger.d.ts.map +1 -0
- package/esm/src/services/logger.js +104 -0
- package/esm/src/services/opencode-warning.d.ts +8 -0
- package/esm/src/services/opencode-warning.d.ts.map +1 -0
- package/esm/src/services/opencode-warning.js +104 -0
- package/esm/src/services/redis-cache.d.ts +27 -0
- package/esm/src/services/redis-cache.d.ts.map +1 -0
- package/esm/src/services/redis-cache.js +215 -0
- package/esm/src/services/redis-client.d.ts +89 -0
- package/esm/src/services/redis-client.d.ts.map +1 -0
- package/esm/src/services/redis-client.js +906 -0
- package/esm/src/services/redis-events.d.ts +46 -0
- package/esm/src/services/redis-events.d.ts.map +1 -0
- package/esm/src/services/redis-events.js +517 -0
- package/esm/src/services/redis-snapshot.d.ts +16 -0
- package/esm/src/services/redis-snapshot.d.ts.map +1 -0
- package/esm/src/services/redis-snapshot.js +184 -0
- package/esm/src/services/render-utils.d.ts +23 -0
- package/esm/src/services/render-utils.d.ts.map +1 -0
- package/esm/src/services/render-utils.js +149 -0
- package/esm/src/services/runtime-teardown.d.ts +23 -0
- package/esm/src/services/runtime-teardown.d.ts.map +1 -0
- package/esm/src/services/runtime-teardown.js +119 -0
- package/esm/src/services/sdk-normalize.d.ts +55 -0
- package/esm/src/services/sdk-normalize.d.ts.map +1 -0
- package/esm/src/services/sdk-normalize.js +61 -0
- package/esm/src/session.d.ts +74 -0
- package/esm/src/session.d.ts.map +1 -0
- package/esm/src/session.js +694 -0
- package/esm/src/types/index.d.ts +120 -0
- package/esm/src/types/index.d.ts.map +1 -0
- package/esm/src/types/index.js +28 -0
- package/esm/src/utils.d.ts +27 -0
- package/esm/src/utils.d.ts.map +1 -0
- package/esm/src/utils.js +76 -0
- package/package.json +59 -0
- package/script/_dnt.polyfills.d.ts +166 -0
- package/script/_dnt.polyfills.d.ts.map +1 -0
- package/script/_dnt.polyfills.js +180 -0
- package/script/_dnt.shims.d.ts +6 -0
- package/script/_dnt.shims.d.ts.map +1 -0
- package/script/_dnt.shims.js +65 -0
- package/script/deno.d.ts +45 -0
- package/script/deno.d.ts.map +1 -0
- package/script/deno.js +41 -0
- package/script/mod.d.ts +3 -0
- package/script/mod.d.ts.map +1 -0
- package/script/mod.js +6 -0
- package/script/package.json +3 -0
- package/script/src/config.d.ts +20 -0
- package/script/src/config.d.ts.map +1 -0
- package/script/src/config.js +256 -0
- package/script/src/handlers/chat.d.ts +14 -0
- package/script/src/handlers/chat.d.ts.map +1 -0
- package/script/src/handlers/chat.js +63 -0
- package/script/src/handlers/compacting.d.ts +9 -0
- package/script/src/handlers/compacting.d.ts.map +1 -0
- package/script/src/handlers/compacting.js +33 -0
- package/script/src/handlers/event.d.ts +22 -0
- package/script/src/handlers/event.d.ts.map +1 -0
- package/script/src/handlers/event.js +290 -0
- package/script/src/handlers/messages.d.ts +9 -0
- package/script/src/handlers/messages.d.ts.map +1 -0
- package/script/src/handlers/messages.js +96 -0
- package/script/src/index.d.ts +5 -0
- package/script/src/index.d.ts.map +1 -0
- package/script/src/index.js +159 -0
- package/script/src/services/batch-drain.d.ts +23 -0
- package/script/src/services/batch-drain.d.ts.map +1 -0
- package/script/src/services/batch-drain.js +221 -0
- package/script/src/services/connection-manager.d.ts +104 -0
- package/script/src/services/connection-manager.d.ts.map +1 -0
- package/script/src/services/connection-manager.js +635 -0
- package/script/src/services/constants.d.ts +7 -0
- package/script/src/services/constants.d.ts.map +1 -0
- package/script/src/services/constants.js +9 -0
- package/script/src/services/context-limit.d.ts +3 -0
- package/script/src/services/context-limit.d.ts.map +1 -0
- package/script/src/services/context-limit.js +47 -0
- package/script/src/services/event-extractor.d.ts +29 -0
- package/script/src/services/event-extractor.d.ts.map +1 -0
- package/script/src/services/event-extractor.js +669 -0
- package/script/src/services/graphiti-async.d.ts +22 -0
- package/script/src/services/graphiti-async.d.ts.map +1 -0
- package/script/src/services/graphiti-async.js +223 -0
- package/script/src/services/graphiti-mcp.d.ts +57 -0
- package/script/src/services/graphiti-mcp.d.ts.map +1 -0
- package/script/src/services/graphiti-mcp.js +198 -0
- package/script/src/services/logger.d.ts +9 -0
- package/script/src/services/logger.d.ts.map +1 -0
- package/script/src/services/logger.js +142 -0
- package/script/src/services/opencode-warning.d.ts +8 -0
- package/script/src/services/opencode-warning.d.ts.map +1 -0
- package/script/src/services/opencode-warning.js +114 -0
- package/script/src/services/redis-cache.d.ts +27 -0
- package/script/src/services/redis-cache.d.ts.map +1 -0
- package/script/src/services/redis-cache.js +219 -0
- package/script/src/services/redis-client.d.ts +89 -0
- package/script/src/services/redis-client.d.ts.map +1 -0
- package/script/src/services/redis-client.js +943 -0
- package/script/src/services/redis-events.d.ts +46 -0
- package/script/src/services/redis-events.d.ts.map +1 -0
- package/script/src/services/redis-events.js +535 -0
- package/script/src/services/redis-snapshot.d.ts +16 -0
- package/script/src/services/redis-snapshot.d.ts.map +1 -0
- package/script/src/services/redis-snapshot.js +189 -0
- package/script/src/services/render-utils.d.ts +23 -0
- package/script/src/services/render-utils.d.ts.map +1 -0
- package/script/src/services/render-utils.js +165 -0
- package/script/src/services/runtime-teardown.d.ts +23 -0
- package/script/src/services/runtime-teardown.d.ts.map +1 -0
- package/script/src/services/runtime-teardown.js +155 -0
- package/script/src/services/sdk-normalize.d.ts +55 -0
- package/script/src/services/sdk-normalize.d.ts.map +1 -0
- package/script/src/services/sdk-normalize.js +67 -0
- package/script/src/session.d.ts +74 -0
- package/script/src/session.d.ts.map +1 -0
- package/script/src/session.js +698 -0
- package/script/src/types/index.d.ts +120 -0
- package/script/src/types/index.d.ts.map +1 -0
- package/script/src/types/index.js +33 -0
- package/script/src/utils.d.ts +27 -0
- package/script/src/utils.d.ts.map +1 -0
- package/script/src/utils.js +87 -0
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"_dnt.shims.d.ts","sourceRoot":"","sources":["../src/_dnt.shims.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,IAAI,EAAE,MAAM,iBAAiB,CAAC;AACvC,OAAO,EAAE,IAAI,EAAE,MAAM,iBAAiB,CAAC;AAKvC,eAAO,MAAM,aAAa;;CAA2C,CAAC"}
|
|
@@ -0,0 +1,65 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.dntGlobalThis = exports.Deno = void 0;
|
|
4
|
+
const shim_deno_1 = require("@deno/shim-deno");
|
|
5
|
+
var shim_deno_2 = require("@deno/shim-deno");
|
|
6
|
+
Object.defineProperty(exports, "Deno", { enumerable: true, get: function () { return shim_deno_2.Deno; } });
|
|
7
|
+
const dntGlobals = {
|
|
8
|
+
Deno: shim_deno_1.Deno,
|
|
9
|
+
};
|
|
10
|
+
exports.dntGlobalThis = createMergeProxy(globalThis, dntGlobals);
|
|
11
|
+
function createMergeProxy(baseObj, extObj) {
|
|
12
|
+
return new Proxy(baseObj, {
|
|
13
|
+
get(_target, prop, _receiver) {
|
|
14
|
+
if (prop in extObj) {
|
|
15
|
+
return extObj[prop];
|
|
16
|
+
}
|
|
17
|
+
else {
|
|
18
|
+
return baseObj[prop];
|
|
19
|
+
}
|
|
20
|
+
},
|
|
21
|
+
set(_target, prop, value) {
|
|
22
|
+
if (prop in extObj) {
|
|
23
|
+
delete extObj[prop];
|
|
24
|
+
}
|
|
25
|
+
baseObj[prop] = value;
|
|
26
|
+
return true;
|
|
27
|
+
},
|
|
28
|
+
deleteProperty(_target, prop) {
|
|
29
|
+
let success = false;
|
|
30
|
+
if (prop in extObj) {
|
|
31
|
+
delete extObj[prop];
|
|
32
|
+
success = true;
|
|
33
|
+
}
|
|
34
|
+
if (prop in baseObj) {
|
|
35
|
+
delete baseObj[prop];
|
|
36
|
+
success = true;
|
|
37
|
+
}
|
|
38
|
+
return success;
|
|
39
|
+
},
|
|
40
|
+
ownKeys(_target) {
|
|
41
|
+
const baseKeys = Reflect.ownKeys(baseObj);
|
|
42
|
+
const extKeys = Reflect.ownKeys(extObj);
|
|
43
|
+
const extKeysSet = new Set(extKeys);
|
|
44
|
+
return [...baseKeys.filter((k) => !extKeysSet.has(k)), ...extKeys];
|
|
45
|
+
},
|
|
46
|
+
defineProperty(_target, prop, desc) {
|
|
47
|
+
if (prop in extObj) {
|
|
48
|
+
delete extObj[prop];
|
|
49
|
+
}
|
|
50
|
+
Reflect.defineProperty(baseObj, prop, desc);
|
|
51
|
+
return true;
|
|
52
|
+
},
|
|
53
|
+
getOwnPropertyDescriptor(_target, prop) {
|
|
54
|
+
if (prop in extObj) {
|
|
55
|
+
return Reflect.getOwnPropertyDescriptor(extObj, prop);
|
|
56
|
+
}
|
|
57
|
+
else {
|
|
58
|
+
return Reflect.getOwnPropertyDescriptor(baseObj, prop);
|
|
59
|
+
}
|
|
60
|
+
},
|
|
61
|
+
has(_target, prop) {
|
|
62
|
+
return prop in extObj || prop in baseObj;
|
|
63
|
+
},
|
|
64
|
+
});
|
|
65
|
+
}
|
package/script/deno.d.ts
ADDED
|
@@ -0,0 +1,45 @@
|
|
|
1
|
+
declare namespace _default {
|
|
2
|
+
export let name: string;
|
|
3
|
+
export let description: string;
|
|
4
|
+
export let version: string;
|
|
5
|
+
export let license: string;
|
|
6
|
+
export namespace tasks {
|
|
7
|
+
let build: string;
|
|
8
|
+
let check: string;
|
|
9
|
+
let deploy: string;
|
|
10
|
+
let dev: string;
|
|
11
|
+
let lint: string;
|
|
12
|
+
let fmt: string;
|
|
13
|
+
}
|
|
14
|
+
export namespace lint_1 {
|
|
15
|
+
let exclude: string[];
|
|
16
|
+
namespace rules {
|
|
17
|
+
let exclude_1: string[];
|
|
18
|
+
export { exclude_1 as exclude };
|
|
19
|
+
}
|
|
20
|
+
}
|
|
21
|
+
export { lint_1 as lint };
|
|
22
|
+
export namespace fmt_1 {
|
|
23
|
+
let exclude_2: string[];
|
|
24
|
+
export { exclude_2 as exclude };
|
|
25
|
+
}
|
|
26
|
+
export { fmt_1 as fmt };
|
|
27
|
+
export namespace compilerOptions {
|
|
28
|
+
let strict: boolean;
|
|
29
|
+
let lib: string[];
|
|
30
|
+
}
|
|
31
|
+
export let nodeModulesDir: string;
|
|
32
|
+
export let imports: {
|
|
33
|
+
"@modelcontextprotocol/sdk": string;
|
|
34
|
+
"@opencode-ai/plugin": string;
|
|
35
|
+
"@opencode-ai/sdk": string;
|
|
36
|
+
cosmiconfig: string;
|
|
37
|
+
ioredis: string;
|
|
38
|
+
zod: string;
|
|
39
|
+
};
|
|
40
|
+
export let exports: {
|
|
41
|
+
".": string;
|
|
42
|
+
};
|
|
43
|
+
}
|
|
44
|
+
export default _default;
|
|
45
|
+
//# sourceMappingURL=deno.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"deno.d.ts","sourceRoot":"","sources":["../src/deno.js"],"names":[],"mappings":""}
|
package/script/deno.js
ADDED
|
@@ -0,0 +1,41 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.default = {
|
|
4
|
+
"name": "opencode-graphiti",
|
|
5
|
+
"description": "OpenCode plugin for persistent memory via Graphiti knowledge graph",
|
|
6
|
+
"version": "0.0.0-development",
|
|
7
|
+
"license": "MIT",
|
|
8
|
+
"tasks": {
|
|
9
|
+
"build": "deno run -A dnt.ts",
|
|
10
|
+
"check": "deno check src/index.ts",
|
|
11
|
+
"deploy": "deno eval \"throw new Error('Manual publish is disabled. Use the GitHub Actions publish workflow for releases.')\"",
|
|
12
|
+
"dev": "deno run --allow-all src/index.ts",
|
|
13
|
+
"lint": "deno lint",
|
|
14
|
+
"fmt": "deno fmt"
|
|
15
|
+
},
|
|
16
|
+
"lint": {
|
|
17
|
+
"exclude": ["dist/"],
|
|
18
|
+
"rules": {
|
|
19
|
+
"exclude": ["no-import-prefix"]
|
|
20
|
+
}
|
|
21
|
+
},
|
|
22
|
+
"fmt": {
|
|
23
|
+
"exclude": ["dist/"]
|
|
24
|
+
},
|
|
25
|
+
"compilerOptions": {
|
|
26
|
+
"strict": true,
|
|
27
|
+
"lib": ["deno.ns", "dom", "esnext"]
|
|
28
|
+
},
|
|
29
|
+
"nodeModulesDir": "auto",
|
|
30
|
+
"imports": {
|
|
31
|
+
"@modelcontextprotocol/sdk": "npm:@modelcontextprotocol/sdk@^1.25.2",
|
|
32
|
+
"@opencode-ai/plugin": "npm:@opencode-ai/plugin@1.2.26",
|
|
33
|
+
"@opencode-ai/sdk": "npm:@opencode-ai/sdk@1.2.26",
|
|
34
|
+
"cosmiconfig": "npm:cosmiconfig@9.0.0",
|
|
35
|
+
"ioredis": "npm:ioredis@^5.7.0",
|
|
36
|
+
"zod": "npm:zod@4.3.6"
|
|
37
|
+
},
|
|
38
|
+
"exports": {
|
|
39
|
+
".": "./mod.ts"
|
|
40
|
+
}
|
|
41
|
+
};
|
package/script/mod.d.ts
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"mod.d.ts","sourceRoot":"","sources":["../src/mod.ts"],"names":[],"mappings":"AAAA,OAAO,qBAAqB,CAAC;AAC7B,OAAO,EAAE,QAAQ,EAAE,MAAM,gBAAgB,CAAC"}
|
package/script/mod.js
ADDED
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.graphiti = void 0;
|
|
4
|
+
require("./_dnt.polyfills.js");
|
|
5
|
+
var index_js_1 = require("./src/index.js");
|
|
6
|
+
Object.defineProperty(exports, "graphiti", { enumerable: true, get: function () { return index_js_1.graphiti; } });
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import type { GraphitiConfig } from "./types/index.js";
|
|
2
|
+
type ConfigLoadResult = {
|
|
3
|
+
config: unknown;
|
|
4
|
+
} | null;
|
|
5
|
+
export declare class ConfigLoadError extends Error {
|
|
6
|
+
cause: unknown;
|
|
7
|
+
constructor(message: string, options?: {
|
|
8
|
+
cause?: unknown;
|
|
9
|
+
});
|
|
10
|
+
}
|
|
11
|
+
export interface ConfigExplorerAdapter {
|
|
12
|
+
search(from?: string): ConfigLoadResult;
|
|
13
|
+
load(filePath: string): ConfigLoadResult;
|
|
14
|
+
}
|
|
15
|
+
type ConfigExplorerFactory = () => ConfigExplorerAdapter;
|
|
16
|
+
export declare const setConfigExplorerAdapterForTesting: (factory: ConfigExplorerFactory) => void;
|
|
17
|
+
export declare const resetConfigExplorerAdapterForTesting: () => void;
|
|
18
|
+
export declare function loadConfig(directory?: string): GraphitiConfig;
|
|
19
|
+
export {};
|
|
20
|
+
//# sourceMappingURL=config.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"config.d.ts","sourceRoot":"","sources":["../../src/src/config.ts"],"names":[],"mappings":"AAGA,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,kBAAkB,CAAC;AA8BvD,KAAK,gBAAgB,GAAG;IAAE,MAAM,EAAE,OAAO,CAAA;CAAE,GAAG,IAAI,CAAC;AAMnD,qBAAa,eAAgB,SAAQ,KAAK;IAC/B,KAAK,EAAE,OAAO,CAAC;gBAEZ,OAAO,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE;QAAE,KAAK,CAAC,EAAE,OAAO,CAAA;KAAE;CAK3D;AAED,MAAM,WAAW,qBAAqB;IACpC,MAAM,CAAC,IAAI,CAAC,EAAE,MAAM,GAAG,gBAAgB,CAAC;IACxC,IAAI,CAAC,QAAQ,EAAE,MAAM,GAAG,gBAAgB,CAAC;CAC1C;AAED,KAAK,qBAAqB,GAAG,MAAM,qBAAqB,CAAC;AAmNzD,eAAO,MAAM,kCAAkC,GAC7C,SAAS,qBAAqB,KAC7B,IAEF,CAAC;AAEF,eAAO,MAAM,oCAAoC,QAAO,IAEvD,CAAC;AAuEF,wBAAgB,UAAU,CAAC,SAAS,CAAC,EAAE,MAAM,GAAG,cAAc,CAO7D"}
|
|
@@ -0,0 +1,256 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
exports.resetConfigExplorerAdapterForTesting = exports.setConfigExplorerAdapterForTesting = exports.ConfigLoadError = void 0;
|
|
7
|
+
exports.loadConfig = loadConfig;
|
|
8
|
+
const node_os_1 = __importDefault(require("node:os"));
|
|
9
|
+
const node_module_1 = require("node:module");
|
|
10
|
+
const node_path_1 = require("node:path");
|
|
11
|
+
const DEFAULT_CONFIG = {
|
|
12
|
+
redis: {
|
|
13
|
+
endpoint: "redis://localhost:6379",
|
|
14
|
+
batchSize: 20,
|
|
15
|
+
batchMaxBytes: 51_200,
|
|
16
|
+
sessionTtlSeconds: 86_400,
|
|
17
|
+
cacheTtlSeconds: 600,
|
|
18
|
+
drainRetryMax: 3,
|
|
19
|
+
},
|
|
20
|
+
graphiti: {
|
|
21
|
+
endpoint: "http://localhost:8000/mcp",
|
|
22
|
+
groupIdPrefix: "opencode",
|
|
23
|
+
driftThreshold: 0.5,
|
|
24
|
+
},
|
|
25
|
+
endpoint: "http://localhost:8000/mcp",
|
|
26
|
+
groupIdPrefix: "opencode",
|
|
27
|
+
driftThreshold: 0.5,
|
|
28
|
+
};
|
|
29
|
+
class ConfigLoadError extends Error {
|
|
30
|
+
constructor(message, options) {
|
|
31
|
+
super(message);
|
|
32
|
+
Object.defineProperty(this, "cause", {
|
|
33
|
+
enumerable: true,
|
|
34
|
+
configurable: true,
|
|
35
|
+
writable: true,
|
|
36
|
+
value: void 0
|
|
37
|
+
});
|
|
38
|
+
this.name = "ConfigLoadError";
|
|
39
|
+
this.cause = options?.cause;
|
|
40
|
+
}
|
|
41
|
+
}
|
|
42
|
+
exports.ConfigLoadError = ConfigLoadError;
|
|
43
|
+
const require = (0, node_module_1.createRequire)(globalThis[Symbol.for("import-meta-ponyfill-commonjs")](require, module).url);
|
|
44
|
+
const isRecord = (value) => !!value && typeof value === "object" && !Array.isArray(value);
|
|
45
|
+
const readString = (value, key) => typeof value[key] === "string" ? value[key] : undefined;
|
|
46
|
+
const readNumber = (value, key) => typeof value[key] === "number" ? value[key] : undefined;
|
|
47
|
+
const normalizeConfig = (value) => {
|
|
48
|
+
if (!isRecord(value))
|
|
49
|
+
return {};
|
|
50
|
+
const compact = (input) => Object.fromEntries(Object.entries(input).filter(([_, entry]) => entry !== undefined));
|
|
51
|
+
const config = {
|
|
52
|
+
endpoint: readString(value, "endpoint"),
|
|
53
|
+
groupIdPrefix: readString(value, "groupIdPrefix"),
|
|
54
|
+
driftThreshold: readNumber(value, "driftThreshold"),
|
|
55
|
+
};
|
|
56
|
+
if (isRecord(value.redis)) {
|
|
57
|
+
config.redis = compact({
|
|
58
|
+
endpoint: readString(value.redis, "endpoint"),
|
|
59
|
+
batchSize: readNumber(value.redis, "batchSize"),
|
|
60
|
+
batchMaxBytes: readNumber(value.redis, "batchMaxBytes"),
|
|
61
|
+
sessionTtlSeconds: readNumber(value.redis, "sessionTtlSeconds"),
|
|
62
|
+
cacheTtlSeconds: readNumber(value.redis, "cacheTtlSeconds"),
|
|
63
|
+
drainRetryMax: readNumber(value.redis, "drainRetryMax"),
|
|
64
|
+
});
|
|
65
|
+
}
|
|
66
|
+
if (isRecord(value.falkordb)) {
|
|
67
|
+
config.falkordb = compact({
|
|
68
|
+
redisEndpoint: readString(value.falkordb, "redisEndpoint"),
|
|
69
|
+
batchSize: readNumber(value.falkordb, "batchSize"),
|
|
70
|
+
batchMaxBytes: readNumber(value.falkordb, "batchMaxBytes"),
|
|
71
|
+
sessionTtlSeconds: readNumber(value.falkordb, "sessionTtlSeconds"),
|
|
72
|
+
cacheTtlSeconds: readNumber(value.falkordb, "cacheTtlSeconds"),
|
|
73
|
+
drainRetryMax: readNumber(value.falkordb, "drainRetryMax"),
|
|
74
|
+
});
|
|
75
|
+
}
|
|
76
|
+
if (isRecord(value.graphiti)) {
|
|
77
|
+
config.graphiti = compact({
|
|
78
|
+
endpoint: readString(value.graphiti, "endpoint"),
|
|
79
|
+
groupIdPrefix: readString(value.graphiti, "groupIdPrefix"),
|
|
80
|
+
driftThreshold: readNumber(value.graphiti, "driftThreshold"),
|
|
81
|
+
});
|
|
82
|
+
}
|
|
83
|
+
return config;
|
|
84
|
+
};
|
|
85
|
+
const isPositiveInteger = (value) => typeof value === "number" && Number.isInteger(value) && value > 0;
|
|
86
|
+
const isUnitInterval = (value) => typeof value === "number" && Number.isFinite(value) && value >= 0 &&
|
|
87
|
+
value <= 1;
|
|
88
|
+
const isValidUrlString = (value) => {
|
|
89
|
+
if (!value?.trim())
|
|
90
|
+
return false;
|
|
91
|
+
try {
|
|
92
|
+
new URL(value);
|
|
93
|
+
return true;
|
|
94
|
+
}
|
|
95
|
+
catch {
|
|
96
|
+
return false;
|
|
97
|
+
}
|
|
98
|
+
};
|
|
99
|
+
const assertExplicitUrl = (value, fieldName) => {
|
|
100
|
+
if (value === undefined)
|
|
101
|
+
return;
|
|
102
|
+
if (isValidUrlString(value))
|
|
103
|
+
return;
|
|
104
|
+
throw new ConfigLoadError(`Invalid Graphiti config value for ${fieldName}: expected a valid URL`);
|
|
105
|
+
};
|
|
106
|
+
const validateExplicitConfig = (value) => {
|
|
107
|
+
if (!value)
|
|
108
|
+
return;
|
|
109
|
+
assertExplicitUrl(value.endpoint, "endpoint");
|
|
110
|
+
assertExplicitUrl(value.graphiti?.endpoint, "graphiti.endpoint");
|
|
111
|
+
assertExplicitUrl(value.redis?.endpoint, "redis.endpoint");
|
|
112
|
+
assertExplicitUrl(value.falkordb?.redisEndpoint, "falkordb.redisEndpoint");
|
|
113
|
+
};
|
|
114
|
+
const resolveNumber = (...candidates) => candidates.find((value) => value !== undefined);
|
|
115
|
+
const resolveConfig = (value) => {
|
|
116
|
+
const raw = value ?? {};
|
|
117
|
+
const resolvedRedisEndpoint = raw.redis?.endpoint ??
|
|
118
|
+
raw.falkordb?.redisEndpoint ??
|
|
119
|
+
DEFAULT_CONFIG.redis.endpoint;
|
|
120
|
+
const resolvedBatchSize = resolveNumber(raw.redis?.batchSize, raw.falkordb?.batchSize);
|
|
121
|
+
const resolvedBatchMaxBytes = resolveNumber(raw.redis?.batchMaxBytes, raw.falkordb?.batchMaxBytes);
|
|
122
|
+
const resolvedSessionTtlSeconds = resolveNumber(raw.redis?.sessionTtlSeconds, raw.falkordb?.sessionTtlSeconds);
|
|
123
|
+
const resolvedCacheTtlSeconds = resolveNumber(raw.redis?.cacheTtlSeconds, raw.falkordb?.cacheTtlSeconds);
|
|
124
|
+
const resolvedDrainRetryMax = resolveNumber(raw.redis?.drainRetryMax, raw.falkordb?.drainRetryMax);
|
|
125
|
+
const requestedGraphitiEndpoint = raw.graphiti?.endpoint ?? raw.endpoint;
|
|
126
|
+
const resolvedGraphitiEndpoint = isValidUrlString(requestedGraphitiEndpoint)
|
|
127
|
+
? requestedGraphitiEndpoint
|
|
128
|
+
: DEFAULT_CONFIG.graphiti.endpoint;
|
|
129
|
+
const resolvedGroupIdPrefix = raw.graphiti?.groupIdPrefix ??
|
|
130
|
+
raw.groupIdPrefix ??
|
|
131
|
+
DEFAULT_CONFIG.graphiti.groupIdPrefix;
|
|
132
|
+
const resolvedDriftThreshold = resolveNumber(raw.graphiti?.driftThreshold, raw.driftThreshold);
|
|
133
|
+
const redis = {
|
|
134
|
+
endpoint: resolvedRedisEndpoint,
|
|
135
|
+
batchSize: isPositiveInteger(resolvedBatchSize)
|
|
136
|
+
? resolvedBatchSize
|
|
137
|
+
: DEFAULT_CONFIG.redis.batchSize,
|
|
138
|
+
batchMaxBytes: isPositiveInteger(resolvedBatchMaxBytes)
|
|
139
|
+
? resolvedBatchMaxBytes
|
|
140
|
+
: DEFAULT_CONFIG.redis.batchMaxBytes,
|
|
141
|
+
sessionTtlSeconds: isPositiveInteger(resolvedSessionTtlSeconds)
|
|
142
|
+
? resolvedSessionTtlSeconds
|
|
143
|
+
: DEFAULT_CONFIG.redis.sessionTtlSeconds,
|
|
144
|
+
cacheTtlSeconds: isPositiveInteger(resolvedCacheTtlSeconds)
|
|
145
|
+
? resolvedCacheTtlSeconds
|
|
146
|
+
: DEFAULT_CONFIG.redis.cacheTtlSeconds,
|
|
147
|
+
drainRetryMax: isPositiveInteger(resolvedDrainRetryMax)
|
|
148
|
+
? resolvedDrainRetryMax
|
|
149
|
+
: DEFAULT_CONFIG.redis.drainRetryMax,
|
|
150
|
+
};
|
|
151
|
+
const falkordb = {
|
|
152
|
+
redisEndpoint: redis.endpoint,
|
|
153
|
+
batchSize: redis.batchSize,
|
|
154
|
+
batchMaxBytes: redis.batchMaxBytes,
|
|
155
|
+
sessionTtlSeconds: redis.sessionTtlSeconds,
|
|
156
|
+
cacheTtlSeconds: redis.cacheTtlSeconds,
|
|
157
|
+
drainRetryMax: redis.drainRetryMax,
|
|
158
|
+
};
|
|
159
|
+
const graphiti = {
|
|
160
|
+
endpoint: resolvedGraphitiEndpoint,
|
|
161
|
+
groupIdPrefix: resolvedGroupIdPrefix,
|
|
162
|
+
driftThreshold: isUnitInterval(resolvedDriftThreshold)
|
|
163
|
+
? resolvedDriftThreshold
|
|
164
|
+
: DEFAULT_CONFIG.graphiti.driftThreshold,
|
|
165
|
+
};
|
|
166
|
+
return {
|
|
167
|
+
redis,
|
|
168
|
+
falkordb,
|
|
169
|
+
graphiti,
|
|
170
|
+
endpoint: graphiti.endpoint,
|
|
171
|
+
groupIdPrefix: graphiti.groupIdPrefix,
|
|
172
|
+
driftThreshold: graphiti.driftThreshold,
|
|
173
|
+
};
|
|
174
|
+
};
|
|
175
|
+
const createCosmiconfigAdapter = () => {
|
|
176
|
+
const { cosmiconfigSync } = require("cosmiconfig");
|
|
177
|
+
const explorer = cosmiconfigSync("graphiti", { searchStrategy: "global" });
|
|
178
|
+
return {
|
|
179
|
+
search(from) {
|
|
180
|
+
return explorer.search(from);
|
|
181
|
+
},
|
|
182
|
+
load(filePath) {
|
|
183
|
+
return explorer.load(filePath);
|
|
184
|
+
},
|
|
185
|
+
};
|
|
186
|
+
};
|
|
187
|
+
let configExplorerFactory = createCosmiconfigAdapter;
|
|
188
|
+
const setConfigExplorerAdapterForTesting = (factory) => {
|
|
189
|
+
configExplorerFactory = factory;
|
|
190
|
+
};
|
|
191
|
+
exports.setConfigExplorerAdapterForTesting = setConfigExplorerAdapterForTesting;
|
|
192
|
+
const resetConfigExplorerAdapterForTesting = () => {
|
|
193
|
+
configExplorerFactory = createCosmiconfigAdapter;
|
|
194
|
+
};
|
|
195
|
+
exports.resetConfigExplorerAdapterForTesting = resetConfigExplorerAdapterForTesting;
|
|
196
|
+
const getConfigExplorerAdapter = () => {
|
|
197
|
+
try {
|
|
198
|
+
return configExplorerFactory();
|
|
199
|
+
}
|
|
200
|
+
catch (err) {
|
|
201
|
+
throw new ConfigLoadError("Unable to initialize Graphiti config discovery", { cause: err });
|
|
202
|
+
}
|
|
203
|
+
};
|
|
204
|
+
const loadConfigFile = (adapter, filePath) => {
|
|
205
|
+
try {
|
|
206
|
+
const loaded = adapter?.load(filePath);
|
|
207
|
+
const normalized = loaded ? normalizeConfig(loaded.config) : null;
|
|
208
|
+
validateExplicitConfig(normalized);
|
|
209
|
+
return normalized;
|
|
210
|
+
}
|
|
211
|
+
catch (err) {
|
|
212
|
+
if (err instanceof ConfigLoadError)
|
|
213
|
+
throw err;
|
|
214
|
+
throw new ConfigLoadError(`Unable to load Graphiti config file: ${filePath}`, { cause: err });
|
|
215
|
+
}
|
|
216
|
+
};
|
|
217
|
+
const getHomeDir = () => {
|
|
218
|
+
try {
|
|
219
|
+
return node_os_1.default.homedir();
|
|
220
|
+
}
|
|
221
|
+
catch {
|
|
222
|
+
return undefined;
|
|
223
|
+
}
|
|
224
|
+
};
|
|
225
|
+
const searchConfig = (adapter, directory) => {
|
|
226
|
+
try {
|
|
227
|
+
const loaded = adapter.search(directory);
|
|
228
|
+
const normalized = loaded ? normalizeConfig(loaded.config) : null;
|
|
229
|
+
validateExplicitConfig(normalized);
|
|
230
|
+
return {
|
|
231
|
+
ok: true,
|
|
232
|
+
config: normalized,
|
|
233
|
+
};
|
|
234
|
+
}
|
|
235
|
+
catch (err) {
|
|
236
|
+
if (err instanceof ConfigLoadError)
|
|
237
|
+
throw err;
|
|
238
|
+
throw new ConfigLoadError("Unable to discover Graphiti config", {
|
|
239
|
+
cause: err,
|
|
240
|
+
});
|
|
241
|
+
}
|
|
242
|
+
};
|
|
243
|
+
const loadLegacyConfig = (adapter) => {
|
|
244
|
+
const homeDir = getHomeDir();
|
|
245
|
+
if (!homeDir)
|
|
246
|
+
return null;
|
|
247
|
+
return loadConfigFile(adapter, (0, node_path_1.join)(homeDir, ".config", "opencode", ".graphitirc"));
|
|
248
|
+
};
|
|
249
|
+
function loadConfig(directory) {
|
|
250
|
+
const adapter = getConfigExplorerAdapter();
|
|
251
|
+
const searched = searchConfig(adapter, directory);
|
|
252
|
+
const loaded = searched.ok ? searched.config : null;
|
|
253
|
+
const resolved = loaded ?? loadLegacyConfig(adapter);
|
|
254
|
+
validateExplicitConfig(resolved);
|
|
255
|
+
return resolveConfig(resolved);
|
|
256
|
+
}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import type { Hooks } from "@opencode-ai/plugin";
|
|
2
|
+
import type { GraphitiAsyncService } from "../services/graphiti-async.js";
|
|
3
|
+
import type { RedisEventsService } from "../services/redis-events.js";
|
|
4
|
+
import type { SessionManager } from "../session.js";
|
|
5
|
+
type ChatMessageHook = NonNullable<Hooks["chat.message"]>;
|
|
6
|
+
export interface ChatHandlerDeps {
|
|
7
|
+
sessionManager: SessionManager;
|
|
8
|
+
redisEvents: RedisEventsService;
|
|
9
|
+
graphitiAsync: GraphitiAsyncService;
|
|
10
|
+
drainTriggerSize: number;
|
|
11
|
+
}
|
|
12
|
+
export declare function createChatHandler(deps: ChatHandlerDeps): ChatMessageHook;
|
|
13
|
+
export {};
|
|
14
|
+
//# sourceMappingURL=chat.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"chat.d.ts","sourceRoot":"","sources":["../../../src/src/handlers/chat.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,KAAK,EAAE,MAAM,qBAAqB,CAAC;AACjD,OAAO,KAAK,EAAE,oBAAoB,EAAE,MAAM,+BAA+B,CAAC;AAE1E,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,6BAA6B,CAAC;AAGtE,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,eAAe,CAAC;AAGpD,KAAK,eAAe,GAAG,WAAW,CAAC,KAAK,CAAC,cAAc,CAAC,CAAC,CAAC;AAI1D,MAAM,WAAW,eAAe;IAC9B,cAAc,EAAE,cAAc,CAAC;IAC/B,WAAW,EAAE,kBAAkB,CAAC;IAChC,aAAa,EAAE,oBAAoB,CAAC;IACpC,gBAAgB,EAAE,MAAM,CAAC;CAC1B;AAED,wBAAgB,iBAAiB,CAAC,IAAI,EAAE,eAAe,GAAG,eAAe,CAmExE"}
|
|
@@ -0,0 +1,63 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.createChatHandler = createChatHandler;
|
|
4
|
+
const event_extractor_js_1 = require("../services/event-extractor.js");
|
|
5
|
+
const logger_js_1 = require("../services/logger.js");
|
|
6
|
+
const render_utils_js_1 = require("../services/render-utils.js");
|
|
7
|
+
const utils_js_1 = require("../utils.js");
|
|
8
|
+
function createChatHandler(deps) {
|
|
9
|
+
const { sessionManager, redisEvents, graphitiAsync, drainTriggerSize } = deps;
|
|
10
|
+
return async ({ sessionID }, output) => {
|
|
11
|
+
try {
|
|
12
|
+
sessionManager.markSessionActive(sessionID);
|
|
13
|
+
const { state, resolved, canonicalSessionId } = await sessionManager
|
|
14
|
+
.resolveSessionState(sessionID);
|
|
15
|
+
if (!resolved || !state?.isMain)
|
|
16
|
+
return;
|
|
17
|
+
if (!canonicalSessionId)
|
|
18
|
+
return;
|
|
19
|
+
sessionManager.markResolvedSessionActive(sessionID, canonicalSessionId);
|
|
20
|
+
const messageText = (0, utils_js_1.extractTextFromParts)(output.parts);
|
|
21
|
+
if (!messageText)
|
|
22
|
+
return;
|
|
23
|
+
const sanitizedMessageText = (0, render_utils_js_1.sanitizeMemoryInput)(messageText);
|
|
24
|
+
if (!sanitizedMessageText)
|
|
25
|
+
return;
|
|
26
|
+
state.messageCount += 1;
|
|
27
|
+
state.latestUserRequest = sanitizedMessageText;
|
|
28
|
+
state.latestRefreshQuery = sanitizedMessageText;
|
|
29
|
+
let queueLength = 0;
|
|
30
|
+
for (const event of (0, event_extractor_js_1.extractStructuredEvents)({
|
|
31
|
+
eventType: "chat.message",
|
|
32
|
+
sessionId: sessionID,
|
|
33
|
+
messageText: sanitizedMessageText,
|
|
34
|
+
messageCount: state.messageCount,
|
|
35
|
+
role: "user",
|
|
36
|
+
})) {
|
|
37
|
+
queueLength = await redisEvents.recordEvent(canonicalSessionId, state.groupId, event);
|
|
38
|
+
}
|
|
39
|
+
const prepared = await sessionManager.prepareInjection(canonicalSessionId, sanitizedMessageText);
|
|
40
|
+
if (prepared) {
|
|
41
|
+
state.injectedMemories = true;
|
|
42
|
+
}
|
|
43
|
+
logger_js_1.logger.info("Prepared local session memory for chat transform", {
|
|
44
|
+
sessionID: canonicalSessionId,
|
|
45
|
+
sourceSessionID: sessionID,
|
|
46
|
+
hotTierReady: state.hotTierReady,
|
|
47
|
+
refreshClassification: prepared?.refreshDecision.classification,
|
|
48
|
+
});
|
|
49
|
+
if (prepared && prepared.refreshDecision.shouldRefresh) {
|
|
50
|
+
graphitiAsync.scheduleCacheRefresh(state.groupId, sanitizedMessageText);
|
|
51
|
+
}
|
|
52
|
+
if (queueLength >= drainTriggerSize) {
|
|
53
|
+
graphitiAsync.scheduleDrain(state.groupId);
|
|
54
|
+
}
|
|
55
|
+
}
|
|
56
|
+
catch (error) {
|
|
57
|
+
logger_js_1.logger.warn("Unable to prepare local session memory for chat transform", {
|
|
58
|
+
sessionID,
|
|
59
|
+
error,
|
|
60
|
+
});
|
|
61
|
+
}
|
|
62
|
+
};
|
|
63
|
+
}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import type { Hooks } from "@opencode-ai/plugin";
|
|
2
|
+
import type { SessionManager } from "../session.js";
|
|
3
|
+
type CompactingHook = NonNullable<Hooks["experimental.session.compacting"]>;
|
|
4
|
+
export interface CompactingHandlerDeps {
|
|
5
|
+
sessionManager: SessionManager;
|
|
6
|
+
}
|
|
7
|
+
export declare function createCompactingHandler(deps: CompactingHandlerDeps): CompactingHook;
|
|
8
|
+
export {};
|
|
9
|
+
//# sourceMappingURL=compacting.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"compacting.d.ts","sourceRoot":"","sources":["../../../src/src/handlers/compacting.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,KAAK,EAAE,MAAM,qBAAqB,CAAC;AAEjD,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,eAAe,CAAC;AAEpD,KAAK,cAAc,GAAG,WAAW,CAAC,KAAK,CAAC,iCAAiC,CAAC,CAAC,CAAC;AAI5E,MAAM,WAAW,qBAAqB;IACpC,cAAc,EAAE,cAAc,CAAC;CAChC;AAED,wBAAgB,uBAAuB,CACrC,IAAI,EAAE,qBAAqB,GAC1B,cAAc,CAmChB"}
|
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.createCompactingHandler = createCompactingHandler;
|
|
4
|
+
const logger_js_1 = require("../services/logger.js");
|
|
5
|
+
function createCompactingHandler(deps) {
|
|
6
|
+
const { sessionManager } = deps;
|
|
7
|
+
return async ({ sessionID }, output) => {
|
|
8
|
+
try {
|
|
9
|
+
const { state, resolved, canonicalSessionId, } = await sessionManager.resolveSessionState(sessionID);
|
|
10
|
+
if (!resolved || !canonicalSessionId)
|
|
11
|
+
return;
|
|
12
|
+
if (!state?.isMain)
|
|
13
|
+
return;
|
|
14
|
+
sessionManager.markResolvedSessionActive(sessionID, canonicalSessionId);
|
|
15
|
+
const prepared = await sessionManager.prepareInjection(canonicalSessionId);
|
|
16
|
+
if (!prepared?.envelope)
|
|
17
|
+
return;
|
|
18
|
+
output.context.push(prepared.envelope);
|
|
19
|
+
sessionManager.clearPendingInjection(state, prepared);
|
|
20
|
+
logger_js_1.logger.info("Injected local session_memory into compaction context", {
|
|
21
|
+
sessionID: canonicalSessionId,
|
|
22
|
+
sourceSessionID: sessionID,
|
|
23
|
+
hotTierReady: state.hotTierReady,
|
|
24
|
+
});
|
|
25
|
+
}
|
|
26
|
+
catch (error) {
|
|
27
|
+
logger_js_1.logger.warn("Unable to prepare local session memory for compaction", {
|
|
28
|
+
sessionID,
|
|
29
|
+
error,
|
|
30
|
+
});
|
|
31
|
+
}
|
|
32
|
+
};
|
|
33
|
+
}
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
import type { Hooks } from "@opencode-ai/plugin";
|
|
2
|
+
import type { OpencodeClient } from "@opencode-ai/sdk";
|
|
3
|
+
import type { GraphitiAsyncService } from "../services/graphiti-async.js";
|
|
4
|
+
import type { RedisCacheService } from "../services/redis-cache.js";
|
|
5
|
+
import type { RedisEventsService } from "../services/redis-events.js";
|
|
6
|
+
import type { RedisSnapshotService } from "../services/redis-snapshot.js";
|
|
7
|
+
import type { SessionManager } from "../session.js";
|
|
8
|
+
type EventHook = NonNullable<Hooks["event"]>;
|
|
9
|
+
export interface EventHandlerDeps {
|
|
10
|
+
sessionManager: SessionManager;
|
|
11
|
+
redisEvents: RedisEventsService;
|
|
12
|
+
redisCache: RedisCacheService;
|
|
13
|
+
redisSnapshot: RedisSnapshotService;
|
|
14
|
+
graphitiAsync: GraphitiAsyncService;
|
|
15
|
+
defaultGroupId: string;
|
|
16
|
+
defaultUserGroupId: string;
|
|
17
|
+
sdkClient: OpencodeClient;
|
|
18
|
+
directory: string;
|
|
19
|
+
}
|
|
20
|
+
export declare function createEventHandler(deps: EventHandlerDeps): EventHook;
|
|
21
|
+
export {};
|
|
22
|
+
//# sourceMappingURL=event.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"event.d.ts","sourceRoot":"","sources":["../../../src/src/handlers/event.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,KAAK,EAAE,MAAM,qBAAqB,CAAC;AACjD,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,kBAAkB,CAAC;AAGvD,OAAO,KAAK,EAAE,oBAAoB,EAAE,MAAM,+BAA+B,CAAC;AAC1E,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,4BAA4B,CAAC;AACpE,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,6BAA6B,CAAC;AACtE,OAAO,KAAK,EAAE,oBAAoB,EAAE,MAAM,+BAA+B,CAAC;AAE1E,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,eAAe,CAAC;AAGpD,KAAK,SAAS,GAAG,WAAW,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC;AAG7C,MAAM,WAAW,gBAAgB;IAC/B,cAAc,EAAE,cAAc,CAAC;IAC/B,WAAW,EAAE,kBAAkB,CAAC;IAChC,UAAU,EAAE,iBAAiB,CAAC;IAC9B,aAAa,EAAE,oBAAoB,CAAC;IACpC,aAAa,EAAE,oBAAoB,CAAC;IACpC,cAAc,EAAE,MAAM,CAAC;IACvB,kBAAkB,EAAE,MAAM,CAAC;IAC3B,SAAS,EAAE,cAAc,CAAC;IAC1B,SAAS,EAAE,MAAM,CAAC;CACnB;AAmDD,wBAAgB,kBAAkB,CAAC,IAAI,EAAE,gBAAgB,GAAG,SAAS,CAoXpE"}
|