@psiclawops/hypercompositor 0.9.0 → 0.9.1

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/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "@psiclawops/hypercompositor",
3
- "version": "0.9.0",
4
- "description": "HyperCompositor context engine plugin for OpenClaw",
3
+ "version": "0.9.1",
4
+ "description": "HyperCompositor \u2014 context engine plugin for OpenClaw",
5
5
  "type": "module",
6
6
  "main": "dist/index.js",
7
7
  "license": "Apache-2.0",
@@ -18,7 +18,7 @@
18
18
  "openclaw": {
19
19
  "plugin": {
20
20
  "id": "hypercompositor",
21
- "name": "HyperCompositor Context Engine",
21
+ "name": "HyperCompositor \u2014 Context Engine",
22
22
  "kind": "context-engine"
23
23
  },
24
24
  "extensions": [
@@ -38,7 +38,7 @@
38
38
  "typecheck": "tsc --noEmit"
39
39
  },
40
40
  "dependencies": {
41
- "@psiclawops/hypermem": "0.9.0",
41
+ "@psiclawops/hypermem": "0.9.1",
42
42
  "zod": "^4.0.0"
43
43
  },
44
44
  "devDependencies": {
package/dist/index.d.ts DELETED
@@ -1,208 +0,0 @@
1
- /**
2
- * hypermem Context Engine Plugin
3
- *
4
- * Implements OpenClaw's ContextEngine interface backed by hypermem's
5
- * four-layer memory architecture:
6
- *
7
- * L1 Cache — SQLite `:memory:` hot session working memory
8
- * L2 Messages — per-agent conversation history (SQLite)
9
- * L3 Vectors — semantic + keyword search (KNN + FTS5)
10
- * L4 Library — facts, knowledge, episodes, preferences
11
- *
12
- * Lifecycle mapping:
13
- * ingest() → record each message into messages.db
14
- * assemble() → compositor builds context from all four layers
15
- * compact() → delegate to runtime (ownsCompaction: false)
16
- * afterTurn() → trigger background indexer (fire-and-forget)
17
- * bootstrap() → warm hot-cache session, register agent in fleet
18
- * dispose() → close hypermem connections
19
- *
20
- * Session key format expected: "agent:<agentId>:<channel>:<name>"
21
- */
22
- import type { NeutralMessage, NeutralToolCall, NeutralToolResult, ComposeRequest, ComposeResult } from '@psiclawops/hypermem';
23
- import { resolveTrimBudgets } from '@psiclawops/hypermem';
24
- export type { NeutralMessage, NeutralToolCall, NeutralToolResult, ComposeRequest, ComposeResult };
25
- type TrimTelemetryPath = 'assemble.normal' | 'assemble.toolLoop' | 'assemble.subagent' | 'reshape' | 'compact.nuclear' | 'compact.history' | 'compact.history2' | 'afterTurn.secondary' | 'warmstart';
26
- type DegradationTelemetryPath = 'compose' | 'toolLoop';
27
- interface DegradationTelemetryFields {
28
- agentId: string;
29
- sessionKey: string;
30
- turnId: string;
31
- path: DegradationTelemetryPath;
32
- toolChainCoEjections?: number;
33
- toolChainStubReplacements?: number;
34
- artifactDegradations?: number;
35
- artifactOversizeThresholdTokens?: number;
36
- replayState?: 'entering' | 'stabilizing' | 'exited';
37
- replayReason?: string;
38
- }
39
- declare function trimTelemetry(fields: {
40
- path: TrimTelemetryPath;
41
- agentId: string;
42
- sessionKey: string;
43
- preTokens: number;
44
- postTokens: number;
45
- removed: number;
46
- cacheInvalidated: boolean;
47
- reason: string;
48
- }): void;
49
- declare function assembleTrace(fields: {
50
- agentId: string;
51
- sessionKey: string;
52
- turnId: string;
53
- path: 'cold' | 'replay' | 'subagent';
54
- toolLoop: boolean;
55
- msgCount: number;
56
- prefixChanged?: boolean;
57
- prefixHash?: string;
58
- rerankerStatus?: string;
59
- rerankerCandidates?: number;
60
- rerankerProvider?: string | null;
61
- slotSpans?: Record<string, {
62
- allocated: number;
63
- filled: number;
64
- overflow: boolean;
65
- }>;
66
- compactionEligibleCount?: number;
67
- compactionEligibleRatio?: number;
68
- compactionProcessedCount?: number;
69
- composeTopicSource?: 'request-topic-id' | 'session-topic-map' | 'none';
70
- composeTopicState?: 'no-active-topic' | 'active-topic-ready' | 'active-topic-missing-stamped-history' | 'history-disabled';
71
- composeTopicMessageCount?: number;
72
- composeTopicStampedMessageCount?: number;
73
- composeTopicTelemetryStatus?: 'emitted' | 'intentionally-omitted';
74
- }): void;
75
- declare function degradationTelemetry(fields: DegradationTelemetryFields): void;
76
- declare function lifecyclePolicyTelemetry(fields: {
77
- path: 'compose.eviction' | 'compose.preRecall' | 'afterTurn.gradient';
78
- agentId: string;
79
- sessionKey: string;
80
- band: string;
81
- pressurePct?: number;
82
- topicShiftConfidence?: number;
83
- trimSoftTarget?: number;
84
- reasons?: string[];
85
- }): void;
86
- declare function nextTurnId(): string;
87
- declare const GUARD_TELEMETRY_REASONS: readonly ["warmstart-pressure-demoted", "reshape-downshift-demoted", "duplicate-claim-suppressed", "afterturn-secondary-demoted", "window-within-budget-skip", "pressure-accounting-anomaly"];
88
- type GuardTelemetryReason = typeof GUARD_TELEMETRY_REASONS[number];
89
- declare function beginTrimOwnerTurn(sessionKey: string, turnId: string): void;
90
- declare function endTrimOwnerTurn(sessionKey: string, turnId: string): void;
91
- /**
92
- * Claim the steady-state trim owner slot for the current turn.
93
- *
94
- * Behavior:
95
- * - compact.* paths are exception-only and pass through without claiming.
96
- * - Non-steady paths (warmstart, reshape, afterTurn.secondary) also pass
97
- * through without claiming. Demoted/no-op sites should normally emit
98
- * via guardTelemetry() instead so they stay visible without contending
99
- * for ownership (sub-tasks 2.2 and 2.3 wire this in).
100
- * - Steady-state paths (assemble.normal, assemble.subagent,
101
- * assemble.toolLoop) claim the single owner slot for the current turn.
102
- * The first such claim succeeds. A second steady-state claim against the
103
- * same turn is a duplicate-turn violation: it throws loudly under
104
- * NODE_ENV='development' and warns in other environments (returning
105
- * false so non-dev runtimes keep working).
106
- *
107
- * Callers should invoke this immediately before the real
108
- * trimHistoryToTokenBudget() call. Guard telemetry does NOT route through
109
- * this helper — it is explicitly excluded from the steady-state invariant.
110
- *
111
- * Returns true when the claim succeeds (or is exempt); false on a swallowed
112
- * duplicate claim in non-development. In development the duplicate throws
113
- * before returning.
114
- */
115
- declare function claimTrimOwner(sessionKey: string, turnId: string, path: TrimTelemetryPath): boolean;
116
- /**
117
- * Non-counting guard / noop telemetry.
118
- *
119
- * Emits a `trim-guard` record on the same JSONL channel as trimTelemetry()
120
- * but with a distinct event name so per-turn reporting (scripts/trim-report.mjs,
121
- * future ownership dashboards) can keep it out of `trimCount`. Used by
122
- * demoted/no-op call sites in 2.2 and 2.3 so their path labels stay visible
123
- * in telemetry without consuming a steady-state owner slot.
124
- *
125
- * Zero-cost when telemetry is off. Never throws.
126
- */
127
- declare function guardTelemetry(fields: {
128
- path: TrimTelemetryPath;
129
- agentId: string;
130
- sessionKey: string;
131
- reason: GuardTelemetryReason;
132
- }): void;
133
- export declare const __telemetryForTests: {
134
- trimTelemetry: typeof trimTelemetry;
135
- assembleTrace: typeof assembleTrace;
136
- degradationTelemetry: typeof degradationTelemetry;
137
- guardTelemetry: typeof guardTelemetry;
138
- lifecyclePolicyTelemetry: typeof lifecyclePolicyTelemetry;
139
- nextTurnId: typeof nextTurnId;
140
- beginTrimOwnerTurn: typeof beginTrimOwnerTurn;
141
- endTrimOwnerTurn: typeof endTrimOwnerTurn;
142
- claimTrimOwner: typeof claimTrimOwner;
143
- TRIM_SOFT_TARGET: number;
144
- TRIM_GROWTH_THRESHOLD: number;
145
- TRIM_HEADROOM_FRACTION: number;
146
- resolveTrimBudgets: typeof resolveTrimBudgets;
147
- reset(): void;
148
- };
149
- export declare const CONTEXT_WINDOW_OVERRIDE_KEY_REGEX: RegExp;
150
- export type ContextWindowOverride = {
151
- contextTokens?: number;
152
- contextWindow?: number;
153
- };
154
- export declare function sanitizeContextWindowOverrides(raw: unknown): {
155
- value: Record<string, ContextWindowOverride>;
156
- warnings: string[];
157
- };
158
- export declare function resolveEffectiveBudget(args: {
159
- tokenBudget?: number;
160
- model?: string;
161
- contextWindowSize: number;
162
- contextWindowReserve: number;
163
- contextWindowOverrides?: Record<string, ContextWindowOverride>;
164
- }): {
165
- budget: number;
166
- source: string;
167
- };
168
- export interface ModelIdentity {
169
- rawModel: string | null;
170
- modelKey: string | null;
171
- provider: string | null;
172
- modelId: string | null;
173
- }
174
- export declare function resolveModelIdentity(model?: string): ModelIdentity;
175
- export declare function diffModelState(previous: {
176
- model?: string;
177
- modelKey?: string | null;
178
- provider?: string | null;
179
- modelId?: string | null;
180
- tokenBudget?: number;
181
- } | null | undefined, current: {
182
- model?: string;
183
- tokenBudget?: number;
184
- }): {
185
- previousIdentity: ModelIdentity;
186
- currentIdentity: ModelIdentity;
187
- modelChanged: boolean;
188
- providerChanged: boolean;
189
- modelIdChanged: boolean;
190
- budgetChanged: boolean;
191
- budgetDownshift: boolean;
192
- budgetUplift: boolean;
193
- };
194
- /**
195
- * Bust the assembly cache for a specific agent+session.
196
- * Call this after writing to identity files (SOUL.md, IDENTITY.md, TOOLS.md,
197
- * USER.md) to ensure the next assemble() runs full compositor, not a replay.
198
- */
199
- export declare function bustAssemblyCache(agentId: string, sessionKey: string): Promise<void>;
200
- declare const _default: {
201
- id: string;
202
- name: string;
203
- description: string;
204
- configSchema: import("openclaw/plugin-sdk").OpenClawPluginConfigSchema;
205
- register: NonNullable<import("openclaw/plugin-sdk/plugin-entry").OpenClawPluginDefinition["register"]>;
206
- } & Pick<import("openclaw/plugin-sdk/plugin-entry").OpenClawPluginDefinition, "kind" | "reload" | "nodeHostCommands" | "securityAuditCollectors">;
207
- export default _default;
208
- //# sourceMappingURL=index.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"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"}