swarm-mail 0.1.3 → 0.1.4

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (45) hide show
  1. package/README.md +4 -0
  2. package/dist/beads/adapter.d.ts +38 -0
  3. package/dist/beads/adapter.d.ts.map +1 -0
  4. package/dist/beads/blocked-cache.d.ts +21 -0
  5. package/dist/beads/blocked-cache.d.ts.map +1 -0
  6. package/dist/beads/comments.d.ts +21 -0
  7. package/dist/beads/comments.d.ts.map +1 -0
  8. package/dist/beads/dependencies.d.ts +58 -0
  9. package/dist/beads/dependencies.d.ts.map +1 -0
  10. package/dist/beads/events.d.ts +163 -0
  11. package/dist/beads/events.d.ts.map +1 -0
  12. package/dist/beads/flush-manager.d.ts +71 -0
  13. package/dist/beads/flush-manager.d.ts.map +1 -0
  14. package/dist/beads/index.d.ts +25 -0
  15. package/dist/beads/index.d.ts.map +1 -0
  16. package/dist/beads/jsonl.d.ts +103 -0
  17. package/dist/beads/jsonl.d.ts.map +1 -0
  18. package/dist/beads/labels.d.ts +21 -0
  19. package/dist/beads/labels.d.ts.map +1 -0
  20. package/dist/beads/merge.d.ts +99 -0
  21. package/dist/beads/merge.d.ts.map +1 -0
  22. package/dist/beads/migrations.d.ts +41 -0
  23. package/dist/beads/migrations.d.ts.map +1 -0
  24. package/dist/beads/operations.d.ts +56 -0
  25. package/dist/beads/operations.d.ts.map +1 -0
  26. package/dist/beads/projections.d.ts +103 -0
  27. package/dist/beads/projections.d.ts.map +1 -0
  28. package/dist/beads/queries.d.ts +77 -0
  29. package/dist/beads/queries.d.ts.map +1 -0
  30. package/dist/beads/store.d.ts +98 -0
  31. package/dist/beads/store.d.ts.map +1 -0
  32. package/dist/beads/validation.d.ts +75 -0
  33. package/dist/beads/validation.d.ts.map +1 -0
  34. package/dist/index.d.ts +1 -0
  35. package/dist/index.d.ts.map +1 -1
  36. package/dist/index.js +1957 -39
  37. package/dist/pglite.d.ts +9 -1
  38. package/dist/pglite.d.ts.map +1 -1
  39. package/dist/streams/debug.d.ts.map +1 -1
  40. package/dist/streams/migrations.d.ts +1 -1
  41. package/dist/streams/migrations.d.ts.map +1 -1
  42. package/dist/streams/store.d.ts.map +1 -1
  43. package/dist/types/beads-adapter.d.ts +397 -0
  44. package/dist/types/beads-adapter.d.ts.map +1 -0
  45. package/package.json +1 -1
package/README.md CHANGED
@@ -30,6 +30,8 @@
30
30
 
31
31
  Event sourcing primitives for multi-agent coordination. Local-first, no external servers.
32
32
 
33
+ **[🌐 swarmtools.ai](https://swarmtools.ai)** | **[📖 Full Documentation](https://swarmtools.ai/docs)**
34
+
33
35
  ```
34
36
  ┌─────────────────────────────────────────────────────────────┐
35
37
  │ SWARM MAIL STACK │
@@ -190,6 +192,8 @@ Materialized views derived from events:
190
192
 
191
193
  ## API Reference
192
194
 
195
+ For complete API documentation, see [swarmtools.ai/docs](https://swarmtools.ai/docs).
196
+
193
197
  ### SwarmMailAdapter
194
198
 
195
199
  ```typescript
@@ -0,0 +1,38 @@
1
+ /**
2
+ * Beads Adapter - Factory for creating BeadsAdapter instances
3
+ *
4
+ * This file implements the adapter pattern for beads event sourcing,
5
+ * enabling dependency injection of the database.
6
+ *
7
+ * ## Design Pattern
8
+ * - Accept DatabaseAdapter via factory parameter
9
+ * - Return BeadsAdapter interface
10
+ * - Delegate to store.ts for event operations
11
+ * - Delegate to projections.ts for queries
12
+ * - No direct database access (all via adapter)
13
+ *
14
+ * ## Usage
15
+ * ```typescript
16
+ * import { wrapPGlite } from '@opencode/swarm-mail/pglite';
17
+ * import { createBeadsAdapter } from '@opencode/swarm-mail/beads';
18
+ *
19
+ * const pglite = new PGlite('./streams.db');
20
+ * const db = wrapPGlite(pglite);
21
+ * const beads = createBeadsAdapter(db, '/path/to/project');
22
+ *
23
+ * // Use the adapter
24
+ * await beads.createBead(projectKey, { title: "Task", type: "task", priority: 2 });
25
+ * const bead = await beads.getBead(projectKey, "bd-123");
26
+ * ```
27
+ */
28
+ import type { DatabaseAdapter } from "../types/database.js";
29
+ import type { BeadsAdapter } from "../types/beads-adapter.js";
30
+ /**
31
+ * Create a BeadsAdapter instance
32
+ *
33
+ * @param db - DatabaseAdapter instance (PGLite, SQLite, PostgreSQL, etc.)
34
+ * @param projectKey - Project identifier (typically the project path)
35
+ * @returns BeadsAdapter interface
36
+ */
37
+ export declare function createBeadsAdapter(db: DatabaseAdapter, projectKey: string): BeadsAdapter;
38
+ //# sourceMappingURL=adapter.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"adapter.d.ts","sourceRoot":"","sources":["../../src/beads/adapter.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;;;;;;;;;;GA0BG;AAEH,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,sBAAsB,CAAC;AAC5D,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,2BAA2B,CAAC;AA6B9D;;;;;;GAMG;AACH,wBAAgB,kBAAkB,CAChC,EAAE,EAAE,eAAe,EACnB,UAAU,EAAE,MAAM,GACjB,YAAY,CAkiBd"}
@@ -0,0 +1,21 @@
1
+ /**
2
+ * Blocked Beads Cache Management
3
+ *
4
+ * Convenience re-exports for blocked cache operations.
5
+ * The actual implementation is in dependencies.ts to avoid circular dependencies.
6
+ *
7
+ * ## Cache Strategy
8
+ * - blocked_beads_cache table stores bead_id → blocker_ids[]
9
+ * - Rebuilt when dependencies change or bead status changes
10
+ * - Enables fast "ready work" queries without recursive CTEs
11
+ *
12
+ * ## Performance
13
+ * - Cache rebuild: <50ms for typical projects
14
+ * - Ready work query: 25x faster with cache (752ms → 29ms on 10K beads)
15
+ *
16
+ * Reference: steveyegge/beads/internal/storage/sqlite/blocked_cache.go
17
+ *
18
+ * @module beads/blocked-cache
19
+ */
20
+ export { rebuildBeadBlockedCache, rebuildAllBlockedCaches, invalidateBlockedCache, } from "./dependencies.js";
21
+ //# sourceMappingURL=blocked-cache.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"blocked-cache.d.ts","sourceRoot":"","sources":["../../src/beads/blocked-cache.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;;GAkBG;AAEH,OAAO,EACL,uBAAuB,EACvB,uBAAuB,EACvB,sBAAsB,GACvB,MAAM,mBAAmB,CAAC"}
@@ -0,0 +1,21 @@
1
+ /**
2
+ * Comment Operations
3
+ *
4
+ * Comment management with threading support.
5
+ * Comments can have parent_id for nested discussions.
6
+ *
7
+ * Reference: steveyegge/beads/internal/storage/sqlite/comments.go
8
+ *
9
+ * @module beads/comments
10
+ */
11
+ import type { DatabaseAdapter } from "../types/database.js";
12
+ import type { BeadComment } from "../types/beads-adapter.js";
13
+ /**
14
+ * Get a specific comment by ID
15
+ */
16
+ export declare function getCommentById(db: DatabaseAdapter, commentId: number): Promise<BeadComment | null>;
17
+ /**
18
+ * Get comment thread (comment + all replies)
19
+ */
20
+ export declare function getCommentThread(db: DatabaseAdapter, rootCommentId: number): Promise<BeadComment[]>;
21
+ //# sourceMappingURL=comments.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"comments.d.ts","sourceRoot":"","sources":["../../src/beads/comments.ts"],"names":[],"mappings":"AAAA;;;;;;;;;GASG;AAEH,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,sBAAsB,CAAC;AAC5D,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,2BAA2B,CAAC;AAE7D;;GAEG;AACH,wBAAsB,cAAc,CAClC,EAAE,EAAE,eAAe,EACnB,SAAS,EAAE,MAAM,GAChB,OAAO,CAAC,WAAW,GAAG,IAAI,CAAC,CAM7B;AAED;;GAEG;AACH,wBAAsB,gBAAgB,CACpC,EAAE,EAAE,eAAe,EACnB,aAAa,EAAE,MAAM,GACpB,OAAO,CAAC,WAAW,EAAE,CAAC,CAgBxB"}
@@ -0,0 +1,58 @@
1
+ /**
2
+ * Dependency Graph Operations
3
+ *
4
+ * Provides dependency management with cycle detection and blocked bead tracking.
5
+ *
6
+ * ## Dependency Types
7
+ * - **blocks**: Hard dependency - target must be closed before source can start
8
+ * - **blocked-by**: Inverse of blocks (computed, not stored)
9
+ * - **related**: Soft relationship - doesn't affect ready state
10
+ * - **discovered-from**: Tracking relationship - found while working on another bead
11
+ *
12
+ * ## Cycle Prevention
13
+ * All dependency types are checked for cycles to maintain a DAG (Directed Acyclic Graph).
14
+ * This ensures:
15
+ * - Ready work calculation works correctly
16
+ * - Dependency traversal doesn't loop
17
+ * - Semantic clarity (no circular dependencies)
18
+ *
19
+ * Reference: steveyegge/beads/internal/storage/sqlite/dependencies.go
20
+ *
21
+ * @module beads/dependencies
22
+ */
23
+ import type { DatabaseAdapter } from "../types/database.js";
24
+ /**
25
+ * Check if adding a dependency would create a cycle
26
+ *
27
+ * Uses recursive CTE to traverse from dependsOnId to see if we can reach beadId.
28
+ * If yes, adding "beadId depends on dependsOnId" would complete a cycle.
29
+ */
30
+ export declare function wouldCreateCycle(db: DatabaseAdapter, beadId: string, dependsOnId: string): Promise<boolean>;
31
+ /**
32
+ * Get all open blockers for a bead (including transitive)
33
+ *
34
+ * Returns bead IDs of all beads blocking this one that aren't closed.
35
+ * Only considers "blocks" relationship type.
36
+ */
37
+ export declare function getOpenBlockers(db: DatabaseAdapter, projectKey: string, beadId: string): Promise<string[]>;
38
+ /**
39
+ * Rebuild blocked cache for a specific bead
40
+ *
41
+ * Finds all open blockers and updates the cache.
42
+ * If no open blockers, removes from cache (bead is unblocked).
43
+ */
44
+ export declare function rebuildBeadBlockedCache(db: DatabaseAdapter, projectKey: string, beadId: string): Promise<void>;
45
+ /**
46
+ * Rebuild blocked cache for all beads in a project
47
+ *
48
+ * Used after bulk operations or status changes that affect blocking.
49
+ */
50
+ export declare function rebuildAllBlockedCaches(db: DatabaseAdapter, projectKey: string): Promise<void>;
51
+ /**
52
+ * Invalidate blocked cache when dependencies change
53
+ *
54
+ * Marks beads as needing cache rebuild.
55
+ * In this simple implementation, we just rebuild immediately.
56
+ */
57
+ export declare function invalidateBlockedCache(db: DatabaseAdapter, projectKey: string, beadId: string): Promise<void>;
58
+ //# sourceMappingURL=dependencies.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"dependencies.d.ts","sourceRoot":"","sources":["../../src/beads/dependencies.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;;;;;GAqBG;AAEH,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,sBAAsB,CAAC;AAI5D;;;;;GAKG;AACH,wBAAsB,gBAAgB,CACpC,EAAE,EAAE,eAAe,EACnB,MAAM,EAAE,MAAM,EACd,WAAW,EAAE,MAAM,GAClB,OAAO,CAAC,OAAO,CAAC,CA6BlB;AAED;;;;;GAKG;AACH,wBAAsB,eAAe,CACnC,EAAE,EAAE,eAAe,EACnB,UAAU,EAAE,MAAM,EAClB,MAAM,EAAE,MAAM,GACb,OAAO,CAAC,MAAM,EAAE,CAAC,CAwBnB;AAED;;;;;GAKG;AACH,wBAAsB,uBAAuB,CAC3C,EAAE,EAAE,eAAe,EACnB,UAAU,EAAE,MAAM,EAClB,MAAM,EAAE,MAAM,GACb,OAAO,CAAC,IAAI,CAAC,CAmBf;AAED;;;;GAIG;AACH,wBAAsB,uBAAuB,CAC3C,EAAE,EAAE,eAAe,EACnB,UAAU,EAAE,MAAM,GACjB,OAAO,CAAC,IAAI,CAAC,CAaf;AAED;;;;;GAKG;AACH,wBAAsB,sBAAsB,CAC1C,EAAE,EAAE,eAAe,EACnB,UAAU,EAAE,MAAM,EAClB,MAAM,EAAE,MAAM,GACb,OAAO,CAAC,IAAI,CAAC,CAYf"}
@@ -0,0 +1,163 @@
1
+ /**
2
+ * Bead Event Types - Minimal type definitions for swarm-mail
3
+ *
4
+ * These are simplified type definitions that match the bead-events from
5
+ * opencode-swarm-plugin but avoid cross-package TypeScript imports.
6
+ *
7
+ * The actual event schemas with Zod validation live in:
8
+ * packages/opencode-swarm-plugin/src/schemas/bead-events.ts
9
+ *
10
+ * This file provides just enough type information for the store to work.
11
+ */
12
+ /**
13
+ * Base bead event (all events extend this)
14
+ */
15
+ export interface BaseBeadEvent {
16
+ id?: number;
17
+ type: string;
18
+ project_key: string;
19
+ bead_id: string;
20
+ timestamp: number;
21
+ sequence?: number;
22
+ }
23
+ /**
24
+ * Union of all bead event types
25
+ *
26
+ * This matches the discriminated union in bead-events.ts but as pure TypeScript
27
+ */
28
+ export type BeadEvent = BeadCreatedEvent | BeadUpdatedEvent | BeadStatusChangedEvent | BeadClosedEvent | BeadReopenedEvent | BeadDeletedEvent | BeadDependencyAddedEvent | BeadDependencyRemovedEvent | BeadLabelAddedEvent | BeadLabelRemovedEvent | BeadCommentAddedEvent | BeadCommentUpdatedEvent | BeadCommentDeletedEvent | BeadEpicChildAddedEvent | BeadEpicChildRemovedEvent | BeadEpicClosureEligibleEvent | BeadAssignedEvent | BeadWorkStartedEvent | BeadCompactedEvent;
29
+ export interface BeadCreatedEvent extends BaseBeadEvent {
30
+ type: "bead_created";
31
+ title: string;
32
+ description?: string;
33
+ issue_type: "bug" | "feature" | "task" | "epic" | "chore";
34
+ priority: number;
35
+ parent_id?: string;
36
+ created_by?: string;
37
+ metadata?: Record<string, unknown>;
38
+ }
39
+ export interface BeadUpdatedEvent extends BaseBeadEvent {
40
+ type: "bead_updated";
41
+ updated_by?: string;
42
+ changes: {
43
+ title?: {
44
+ old: string;
45
+ new: string;
46
+ };
47
+ description?: {
48
+ old: string;
49
+ new: string;
50
+ };
51
+ priority?: {
52
+ old: number;
53
+ new: number;
54
+ };
55
+ };
56
+ }
57
+ export interface BeadStatusChangedEvent extends BaseBeadEvent {
58
+ type: "bead_status_changed";
59
+ from_status: "open" | "in_progress" | "blocked" | "closed" | "tombstone";
60
+ to_status: "open" | "in_progress" | "blocked" | "closed" | "tombstone";
61
+ changed_by?: string;
62
+ reason?: string;
63
+ }
64
+ export interface BeadClosedEvent extends BaseBeadEvent {
65
+ type: "bead_closed";
66
+ reason: string;
67
+ closed_by?: string;
68
+ files_touched?: string[];
69
+ duration_ms?: number;
70
+ }
71
+ export interface BeadReopenedEvent extends BaseBeadEvent {
72
+ type: "bead_reopened";
73
+ reason?: string;
74
+ reopened_by?: string;
75
+ }
76
+ export interface BeadDeletedEvent extends BaseBeadEvent {
77
+ type: "bead_deleted";
78
+ reason?: string;
79
+ deleted_by?: string;
80
+ }
81
+ export interface BeadDependencyAddedEvent extends BaseBeadEvent {
82
+ type: "bead_dependency_added";
83
+ dependency: {
84
+ target: string;
85
+ type: "blocks" | "blocked-by" | "related" | "discovered-from";
86
+ };
87
+ added_by?: string;
88
+ reason?: string;
89
+ }
90
+ export interface BeadDependencyRemovedEvent extends BaseBeadEvent {
91
+ type: "bead_dependency_removed";
92
+ dependency: {
93
+ target: string;
94
+ type: "blocks" | "blocked-by" | "related" | "discovered-from";
95
+ };
96
+ removed_by?: string;
97
+ reason?: string;
98
+ }
99
+ export interface BeadLabelAddedEvent extends BaseBeadEvent {
100
+ type: "bead_label_added";
101
+ label: string;
102
+ added_by?: string;
103
+ }
104
+ export interface BeadLabelRemovedEvent extends BaseBeadEvent {
105
+ type: "bead_label_removed";
106
+ label: string;
107
+ removed_by?: string;
108
+ }
109
+ export interface BeadCommentAddedEvent extends BaseBeadEvent {
110
+ type: "bead_comment_added";
111
+ comment_id?: number;
112
+ author: string;
113
+ body: string;
114
+ parent_comment_id?: number;
115
+ metadata?: Record<string, unknown>;
116
+ }
117
+ export interface BeadCommentUpdatedEvent extends BaseBeadEvent {
118
+ type: "bead_comment_updated";
119
+ comment_id: number;
120
+ old_body: string;
121
+ new_body: string;
122
+ updated_by: string;
123
+ }
124
+ export interface BeadCommentDeletedEvent extends BaseBeadEvent {
125
+ type: "bead_comment_deleted";
126
+ comment_id: number;
127
+ deleted_by: string;
128
+ reason?: string;
129
+ }
130
+ export interface BeadEpicChildAddedEvent extends BaseBeadEvent {
131
+ type: "bead_epic_child_added";
132
+ child_id: string;
133
+ child_index?: number;
134
+ added_by?: string;
135
+ }
136
+ export interface BeadEpicChildRemovedEvent extends BaseBeadEvent {
137
+ type: "bead_epic_child_removed";
138
+ child_id: string;
139
+ removed_by?: string;
140
+ reason?: string;
141
+ }
142
+ export interface BeadEpicClosureEligibleEvent extends BaseBeadEvent {
143
+ type: "bead_epic_closure_eligible";
144
+ child_ids: string[];
145
+ total_duration_ms?: number;
146
+ all_files_touched?: string[];
147
+ }
148
+ export interface BeadAssignedEvent extends BaseBeadEvent {
149
+ type: "bead_assigned";
150
+ agent_name: string;
151
+ task_description?: string;
152
+ }
153
+ export interface BeadWorkStartedEvent extends BaseBeadEvent {
154
+ type: "bead_work_started";
155
+ agent_name: string;
156
+ reserved_files?: string[];
157
+ }
158
+ export interface BeadCompactedEvent extends BaseBeadEvent {
159
+ type: "bead_compacted";
160
+ events_archived: number;
161
+ new_start_sequence: number;
162
+ }
163
+ //# sourceMappingURL=events.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"events.d.ts","sourceRoot":"","sources":["../../src/beads/events.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,71 @@
1
+ /**
2
+ * FlushManager - Debounced JSONL export to file
3
+ *
4
+ * Automatically exports dirty beads to a JSONL file on a debounced timer.
5
+ * Prevents excessive writes while ensuring changes are persisted.
6
+ *
7
+ * Based on steveyegge/beads flush_manager.go
8
+ *
9
+ * @module beads/flush-manager
10
+ */
11
+ import type { BeadsAdapter } from "../types/beads-adapter.js";
12
+ export interface FlushManagerOptions {
13
+ adapter: BeadsAdapter;
14
+ projectKey: string;
15
+ outputPath: string;
16
+ debounceMs?: number;
17
+ onFlush?: (result: FlushResult) => void;
18
+ }
19
+ export interface FlushResult {
20
+ beadsExported: number;
21
+ bytesWritten: number;
22
+ duration: number;
23
+ }
24
+ /**
25
+ * FlushManager handles debounced export of dirty beads to JSONL
26
+ *
27
+ * Usage:
28
+ * ```ts
29
+ * const manager = new FlushManager({
30
+ * adapter,
31
+ * projectKey: "/path/to/project",
32
+ * outputPath: ".beads/issues.jsonl",
33
+ * debounceMs: 30000,
34
+ * });
35
+ *
36
+ * // Schedule flushes as beads change
37
+ * manager.scheduleFlush();
38
+ *
39
+ * // Clean up
40
+ * manager.stop();
41
+ * ```
42
+ */
43
+ export declare class FlushManager {
44
+ private adapter;
45
+ private projectKey;
46
+ private outputPath;
47
+ private debounceMs;
48
+ private onFlush?;
49
+ private timer;
50
+ private flushing;
51
+ constructor(options: FlushManagerOptions);
52
+ /**
53
+ * Schedule a flush (debounced)
54
+ *
55
+ * If a flush is already scheduled, resets the timer.
56
+ */
57
+ scheduleFlush(): void;
58
+ /**
59
+ * Force immediate flush
60
+ *
61
+ * Exports all dirty beads to the output file.
62
+ */
63
+ flush(): Promise<FlushResult>;
64
+ /**
65
+ * Stop the flush manager
66
+ *
67
+ * Clears any pending timers. Does NOT flush pending changes.
68
+ */
69
+ stop(): void;
70
+ }
71
+ //# sourceMappingURL=flush-manager.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"flush-manager.d.ts","sourceRoot":"","sources":["../../src/beads/flush-manager.ts"],"names":[],"mappings":"AAAA;;;;;;;;;GASG;AAGH,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,2BAA2B,CAAC;AAI9D,MAAM,WAAW,mBAAmB;IAClC,OAAO,EAAE,YAAY,CAAC;IACtB,UAAU,EAAE,MAAM,CAAC;IACnB,UAAU,EAAE,MAAM,CAAC;IACnB,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,OAAO,CAAC,EAAE,CAAC,MAAM,EAAE,WAAW,KAAK,IAAI,CAAC;CACzC;AAED,MAAM,WAAW,WAAW;IAC1B,aAAa,EAAE,MAAM,CAAC;IACtB,YAAY,EAAE,MAAM,CAAC;IACrB,QAAQ,EAAE,MAAM,CAAC;CAClB;AAED;;;;;;;;;;;;;;;;;;GAkBG;AACH,qBAAa,YAAY;IACvB,OAAO,CAAC,OAAO,CAAe;IAC9B,OAAO,CAAC,UAAU,CAAS;IAC3B,OAAO,CAAC,UAAU,CAAS;IAC3B,OAAO,CAAC,UAAU,CAAS;IAC3B,OAAO,CAAC,OAAO,CAAC,CAAgC;IAChD,OAAO,CAAC,KAAK,CAA+B;IAC5C,OAAO,CAAC,QAAQ,CAAS;gBAEb,OAAO,EAAE,mBAAmB;IAQxC;;;;OAIG;IACH,aAAa,IAAI,IAAI;IAcrB;;;;OAIG;IACG,KAAK,IAAI,OAAO,CAAC,WAAW,CAAC;IA8DnC;;;;OAIG;IACH,IAAI,IAAI,IAAI;CAMb"}
@@ -0,0 +1,25 @@
1
+ /**
2
+ * Beads Module - Event-sourced issue tracking
3
+ *
4
+ * Exports:
5
+ * - BeadsAdapter interface and types
6
+ * - Migration definitions
7
+ * - Projection functions
8
+ * - Store operations (append, read, replay)
9
+ * - Event type definitions
10
+ *
11
+ * @module beads
12
+ */
13
+ export type { Bead, BeadAdapter, BeadComment, BeadDependency, BeadLabel, BeadsAdapter, BeadsAdapterFactory, BeadsSchemaAdapter, BeadStatus, BeadType, CommentAdapter, CreateBeadOptions, DependencyAdapter, DependencyRelationship, EpicAdapter, LabelAdapter, QueryAdapter, QueryBeadsOptions, UpdateBeadOptions, } from "../types/beads-adapter.js";
14
+ export type { BeadEvent, BaseBeadEvent, BeadCreatedEvent, BeadUpdatedEvent, BeadStatusChangedEvent, BeadClosedEvent, BeadReopenedEvent, BeadDeletedEvent, BeadDependencyAddedEvent, BeadDependencyRemovedEvent, BeadLabelAddedEvent, BeadLabelRemovedEvent, BeadCommentAddedEvent, BeadCommentUpdatedEvent, BeadCommentDeletedEvent, BeadEpicChildAddedEvent, BeadEpicChildRemovedEvent, BeadEpicClosureEligibleEvent, BeadAssignedEvent, BeadWorkStartedEvent, BeadCompactedEvent, } from "./events.js";
15
+ export { createBeadsAdapter } from "./adapter.js";
16
+ export { beadsMigration, beadsMigrations } from "./migrations.js";
17
+ export { appendBeadEvent, readBeadEvents, replayBeadEvents, type ReadBeadEventsOptions, } from "./store.js";
18
+ export { clearAllDirtyBeads, clearDirtyBead, getBead, getBlockedBeads, getBlockers, getComments, getDependencies, getDependents, getDirtyBeads, getInProgressBeads, getLabels, getNextReadyBead, isBlocked, markBeadDirty, queryBeads, updateProjections, } from "./projections.js";
19
+ export { wouldCreateCycle, getOpenBlockers, rebuildBeadBlockedCache, rebuildAllBlockedCaches, invalidateBlockedCache, } from "./dependencies.js";
20
+ export { getBeadsByLabel, getAllLabels, } from "./labels.js";
21
+ export { getCommentById, getCommentThread, } from "./comments.js";
22
+ export { exportToJSONL, exportDirtyBeads, importFromJSONL, parseJSONL, serializeToJSONL, computeContentHash, type BeadExport, type ExportOptions, type ImportOptions, type ImportResult, } from "./jsonl.js";
23
+ export { FlushManager, type FlushManagerOptions, type FlushResult, } from "./flush-manager.js";
24
+ export { merge3Way, mergeJsonl, isTombstone, isExpiredTombstone, DEFAULT_TOMBSTONE_TTL_MS, MIN_TOMBSTONE_TTL_MS, CLOCK_SKEW_GRACE_MS, STATUS_TOMBSTONE, type IssueKey, type MergeResult, type MergeOptions, } from "./merge.js";
25
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/beads/index.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;GAWG;AAGH,YAAY,EACV,IAAI,EACJ,WAAW,EACX,WAAW,EACX,cAAc,EACd,SAAS,EACT,YAAY,EACZ,mBAAmB,EACnB,kBAAkB,EAClB,UAAU,EACV,QAAQ,EACR,cAAc,EACd,iBAAiB,EACjB,iBAAiB,EACjB,sBAAsB,EACtB,WAAW,EACX,YAAY,EACZ,YAAY,EACZ,iBAAiB,EACjB,iBAAiB,GAClB,MAAM,2BAA2B,CAAC;AAGnC,YAAY,EACV,SAAS,EACT,aAAa,EACb,gBAAgB,EAChB,gBAAgB,EAChB,sBAAsB,EACtB,eAAe,EACf,iBAAiB,EACjB,gBAAgB,EAChB,wBAAwB,EACxB,0BAA0B,EAC1B,mBAAmB,EACnB,qBAAqB,EACrB,qBAAqB,EACrB,uBAAuB,EACvB,uBAAuB,EACvB,uBAAuB,EACvB,yBAAyB,EACzB,4BAA4B,EAC5B,iBAAiB,EACjB,oBAAoB,EACpB,kBAAkB,GACnB,MAAM,aAAa,CAAC;AAGrB,OAAO,EAAE,kBAAkB,EAAE,MAAM,cAAc,CAAC;AAGlD,OAAO,EAAE,cAAc,EAAE,eAAe,EAAE,MAAM,iBAAiB,CAAC;AAGlE,OAAO,EACL,eAAe,EACf,cAAc,EACd,gBAAgB,EAChB,KAAK,qBAAqB,GAC3B,MAAM,YAAY,CAAC;AAGpB,OAAO,EACL,kBAAkB,EAClB,cAAc,EACd,OAAO,EACP,eAAe,EACf,WAAW,EACX,WAAW,EACX,eAAe,EACf,aAAa,EACb,aAAa,EACb,kBAAkB,EAClB,SAAS,EACT,gBAAgB,EAChB,SAAS,EACT,aAAa,EACb,UAAU,EACV,iBAAiB,GAClB,MAAM,kBAAkB,CAAC;AAG1B,OAAO,EACL,gBAAgB,EAChB,eAAe,EACf,uBAAuB,EACvB,uBAAuB,EACvB,sBAAsB,GACvB,MAAM,mBAAmB,CAAC;AAG3B,OAAO,EACL,eAAe,EACf,YAAY,GACb,MAAM,aAAa,CAAC;AAGrB,OAAO,EACL,cAAc,EACd,gBAAgB,GACjB,MAAM,eAAe,CAAC;AAGvB,OAAO,EACL,aAAa,EACb,gBAAgB,EAChB,eAAe,EACf,UAAU,EACV,gBAAgB,EAChB,kBAAkB,EAClB,KAAK,UAAU,EACf,KAAK,aAAa,EAClB,KAAK,aAAa,EAClB,KAAK,YAAY,GAClB,MAAM,YAAY,CAAC;AAGpB,OAAO,EACL,YAAY,EACZ,KAAK,mBAAmB,EACxB,KAAK,WAAW,GACjB,MAAM,oBAAoB,CAAC;AAG5B,OAAO,EACL,SAAS,EACT,UAAU,EACV,WAAW,EACX,kBAAkB,EAClB,wBAAwB,EACxB,oBAAoB,EACpB,mBAAmB,EACnB,gBAAgB,EAChB,KAAK,QAAQ,EACb,KAAK,WAAW,EAChB,KAAK,YAAY,GAClB,MAAM,YAAY,CAAC"}
@@ -0,0 +1,103 @@
1
+ /**
2
+ * JSONL Export/Import for Beads
3
+ *
4
+ * Implements git sync via JSONL format compatible with steveyegge/beads.
5
+ * Features:
6
+ * - Full export to JSONL string
7
+ * - Incremental dirty bead export
8
+ * - Import with hash-based deduplication
9
+ * - Parse/serialize individual lines
10
+ *
11
+ * @module beads/jsonl
12
+ */
13
+ import type { BeadsAdapter } from "../types/beads-adapter.js";
14
+ /**
15
+ * JSONL export format matching steveyegge/beads
16
+ *
17
+ * One JSON object per line. Field names match the Go struct tags.
18
+ */
19
+ export interface BeadExport {
20
+ id: string;
21
+ title: string;
22
+ description?: string;
23
+ status: "open" | "in_progress" | "blocked" | "closed" | "tombstone";
24
+ priority: number;
25
+ issue_type: "bug" | "feature" | "task" | "epic" | "chore";
26
+ created_at: string;
27
+ updated_at: string;
28
+ closed_at?: string;
29
+ assignee?: string;
30
+ parent_id?: string;
31
+ dependencies: Array<{
32
+ depends_on_id: string;
33
+ type: string;
34
+ }>;
35
+ labels: string[];
36
+ comments: Array<{
37
+ author: string;
38
+ text: string;
39
+ }>;
40
+ }
41
+ export interface ExportOptions {
42
+ includeDeleted?: boolean;
43
+ beadIds?: string[];
44
+ }
45
+ export interface ImportOptions {
46
+ dryRun?: boolean;
47
+ skipExisting?: boolean;
48
+ }
49
+ export interface ImportResult {
50
+ created: number;
51
+ updated: number;
52
+ skipped: number;
53
+ errors: Array<{
54
+ beadId: string;
55
+ error: string;
56
+ }>;
57
+ }
58
+ /**
59
+ * Serialize a bead to a JSONL line
60
+ */
61
+ export declare function serializeToJSONL(bead: BeadExport): string;
62
+ /**
63
+ * Parse JSONL string to bead exports
64
+ *
65
+ * Skips empty lines. Throws on invalid JSON.
66
+ */
67
+ export declare function parseJSONL(jsonl: string): BeadExport[];
68
+ /**
69
+ * Compute SHA-256 content hash for deduplication
70
+ *
71
+ * Uses canonical JSON encoding (sorted keys) for stability.
72
+ * Includes timestamps to detect any change.
73
+ */
74
+ export declare function computeContentHash(bead: BeadExport): string;
75
+ /**
76
+ * Export all beads to JSONL string
77
+ *
78
+ * By default excludes deleted beads (tombstones).
79
+ * Includes dependencies, labels, and comments.
80
+ */
81
+ export declare function exportToJSONL(adapter: BeadsAdapter, projectKey: string, options?: ExportOptions): Promise<string>;
82
+ /**
83
+ * Export only dirty beads (incremental)
84
+ *
85
+ * Returns JSONL and list of bead IDs that were exported.
86
+ */
87
+ export declare function exportDirtyBeads(adapter: BeadsAdapter, projectKey: string): Promise<{
88
+ jsonl: string;
89
+ beadIds: string[];
90
+ }>;
91
+ /**
92
+ * Import beads from JSONL string
93
+ *
94
+ * Features:
95
+ * - Creates new beads
96
+ * - Updates existing beads
97
+ * - Hash-based deduplication (skips if content unchanged)
98
+ * - Imports dependencies, labels, comments
99
+ * - Dry run mode for preview
100
+ * - Skip existing mode
101
+ */
102
+ export declare function importFromJSONL(adapter: BeadsAdapter, projectKey: string, jsonl: string, options?: ImportOptions): Promise<ImportResult>;
103
+ //# sourceMappingURL=jsonl.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"jsonl.d.ts","sourceRoot":"","sources":["../../src/beads/jsonl.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;GAWG;AAGH,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,2BAA2B,CAAC;AAa9D;;;;GAIG;AACH,MAAM,WAAW,UAAU;IACzB,EAAE,EAAE,MAAM,CAAC;IACX,KAAK,EAAE,MAAM,CAAC;IACd,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,MAAM,EAAE,MAAM,GAAG,aAAa,GAAG,SAAS,GAAG,QAAQ,GAAG,WAAW,CAAC;IACpE,QAAQ,EAAE,MAAM,CAAC;IACjB,UAAU,EAAE,KAAK,GAAG,SAAS,GAAG,MAAM,GAAG,MAAM,GAAG,OAAO,CAAC;IAC1D,UAAU,EAAE,MAAM,CAAC;IACnB,UAAU,EAAE,MAAM,CAAC;IACnB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,YAAY,EAAE,KAAK,CAAC;QAClB,aAAa,EAAE,MAAM,CAAC;QACtB,IAAI,EAAE,MAAM,CAAC;KACd,CAAC,CAAC;IACH,MAAM,EAAE,MAAM,EAAE,CAAC;IACjB,QAAQ,EAAE,KAAK,CAAC;QACd,MAAM,EAAE,MAAM,CAAC;QACf,IAAI,EAAE,MAAM,CAAC;KACd,CAAC,CAAC;CACJ;AAED,MAAM,WAAW,aAAa;IAC5B,cAAc,CAAC,EAAE,OAAO,CAAC;IACzB,OAAO,CAAC,EAAE,MAAM,EAAE,CAAC;CACpB;AAED,MAAM,WAAW,aAAa;IAC5B,MAAM,CAAC,EAAE,OAAO,CAAC;IACjB,YAAY,CAAC,EAAE,OAAO,CAAC;CACxB;AAED,MAAM,WAAW,YAAY;IAC3B,OAAO,EAAE,MAAM,CAAC;IAChB,OAAO,EAAE,MAAM,CAAC;IAChB,OAAO,EAAE,MAAM,CAAC;IAChB,MAAM,EAAE,KAAK,CAAC;QAAE,MAAM,EAAE,MAAM,CAAC;QAAC,KAAK,EAAE,MAAM,CAAA;KAAE,CAAC,CAAC;CAClD;AAMD;;GAEG;AACH,wBAAgB,gBAAgB,CAAC,IAAI,EAAE,UAAU,GAAG,MAAM,CAEzD;AAED;;;;GAIG;AACH,wBAAgB,UAAU,CAAC,KAAK,EAAE,MAAM,GAAG,UAAU,EAAE,CAyBtD;AAMD;;;;;GAKG;AACH,wBAAgB,kBAAkB,CAAC,IAAI,EAAE,UAAU,GAAG,MAAM,CAI3D;AAMD;;;;;GAKG;AACH,wBAAsB,aAAa,CACjC,OAAO,EAAE,YAAY,EACrB,UAAU,EAAE,MAAM,EAClB,OAAO,GAAE,aAAkB,GAC1B,OAAO,CAAC,MAAM,CAAC,CA2EjB;AAED;;;;GAIG;AACH,wBAAsB,gBAAgB,CACpC,OAAO,EAAE,YAAY,EACrB,UAAU,EAAE,MAAM,GACjB,OAAO,CAAC;IAAE,KAAK,EAAE,MAAM,CAAC;IAAC,OAAO,EAAE,MAAM,EAAE,CAAA;CAAE,CAAC,CAa/C;AAMD;;;;;;;;;;GAUG;AACH,wBAAsB,eAAe,CACnC,OAAO,EAAE,YAAY,EACrB,UAAU,EAAE,MAAM,EAClB,KAAK,EAAE,MAAM,EACb,OAAO,GAAE,aAAkB,GAC1B,OAAO,CAAC,YAAY,CAAC,CAqBvB"}
@@ -0,0 +1,21 @@
1
+ /**
2
+ * Label Operations
3
+ *
4
+ * Simple label management for categorizing beads.
5
+ * Labels are string tags that can be queried for grouping and filtering.
6
+ *
7
+ * Reference: steveyegge/beads/internal/storage/sqlite/labels.go
8
+ *
9
+ * @module beads/labels
10
+ */
11
+ import type { DatabaseAdapter } from "../types/database.js";
12
+ import type { Bead } from "../types/beads-adapter.js";
13
+ /**
14
+ * Get all beads with a specific label
15
+ */
16
+ export declare function getBeadsByLabel(db: DatabaseAdapter, projectKey: string, label: string): Promise<Bead[]>;
17
+ /**
18
+ * Get all unique labels for a project
19
+ */
20
+ export declare function getAllLabels(db: DatabaseAdapter, projectKey: string): Promise<string[]>;
21
+ //# sourceMappingURL=labels.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"labels.d.ts","sourceRoot":"","sources":["../../src/beads/labels.ts"],"names":[],"mappings":"AAAA;;;;;;;;;GASG;AAEH,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,sBAAsB,CAAC;AAC5D,OAAO,KAAK,EAAE,IAAI,EAAE,MAAM,2BAA2B,CAAC;AAEtD;;GAEG;AACH,wBAAsB,eAAe,CACnC,EAAE,EAAE,eAAe,EACnB,UAAU,EAAE,MAAM,EAClB,KAAK,EAAE,MAAM,GACZ,OAAO,CAAC,IAAI,EAAE,CAAC,CASjB;AAED;;GAEG;AACH,wBAAsB,YAAY,CAChC,EAAE,EAAE,eAAe,EACnB,UAAU,EAAE,MAAM,GACjB,OAAO,CAAC,MAAM,EAAE,CAAC,CASnB"}