@q1k-oss/btree-workflows 0.0.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.
Files changed (203) hide show
  1. package/.claude/settings.local.json +31 -0
  2. package/CLAUDE.md +181 -0
  3. package/LICENSE +21 -0
  4. package/README.md +920 -0
  5. package/behaviour-tree-workflows-landing/index.html +16 -0
  6. package/behaviour-tree-workflows-landing/package-lock.json +2074 -0
  7. package/behaviour-tree-workflows-landing/package.json +31 -0
  8. package/behaviour-tree-workflows-landing/public/favicon.svg +17 -0
  9. package/behaviour-tree-workflows-landing/src/App.css +103 -0
  10. package/behaviour-tree-workflows-landing/src/App.tsx +176 -0
  11. package/behaviour-tree-workflows-landing/src/components/BlackboardInspector.css +89 -0
  12. package/behaviour-tree-workflows-landing/src/components/BlackboardInspector.tsx +64 -0
  13. package/behaviour-tree-workflows-landing/src/components/ExampleSelector.css +64 -0
  14. package/behaviour-tree-workflows-landing/src/components/ExampleSelector.tsx +34 -0
  15. package/behaviour-tree-workflows-landing/src/components/ExecutionLog.css +107 -0
  16. package/behaviour-tree-workflows-landing/src/components/ExecutionLog.tsx +85 -0
  17. package/behaviour-tree-workflows-landing/src/components/Header.css +50 -0
  18. package/behaviour-tree-workflows-landing/src/components/Header.tsx +26 -0
  19. package/behaviour-tree-workflows-landing/src/components/StatusBadge.css +45 -0
  20. package/behaviour-tree-workflows-landing/src/components/StatusBadge.tsx +15 -0
  21. package/behaviour-tree-workflows-landing/src/components/Toolbar.css +74 -0
  22. package/behaviour-tree-workflows-landing/src/components/Toolbar.tsx +53 -0
  23. package/behaviour-tree-workflows-landing/src/components/TreeVisualizer.css +67 -0
  24. package/behaviour-tree-workflows-landing/src/components/TreeVisualizer.tsx +192 -0
  25. package/behaviour-tree-workflows-landing/src/components/YamlEditor.css +18 -0
  26. package/behaviour-tree-workflows-landing/src/components/YamlEditor.tsx +96 -0
  27. package/behaviour-tree-workflows-landing/src/lib/count-nodes.ts +11 -0
  28. package/behaviour-tree-workflows-landing/src/lib/execution-engine.ts +96 -0
  29. package/behaviour-tree-workflows-landing/src/lib/tree-layout.ts +136 -0
  30. package/behaviour-tree-workflows-landing/src/lib/yaml-examples.ts +549 -0
  31. package/behaviour-tree-workflows-landing/src/main.tsx +9 -0
  32. package/behaviour-tree-workflows-landing/src/stubs/activepieces.ts +18 -0
  33. package/behaviour-tree-workflows-landing/src/stubs/fs.ts +24 -0
  34. package/behaviour-tree-workflows-landing/src/stubs/path.ts +16 -0
  35. package/behaviour-tree-workflows-landing/src/stubs/temporal-activity.ts +6 -0
  36. package/behaviour-tree-workflows-landing/src/stubs/temporal-workflow.ts +22 -0
  37. package/behaviour-tree-workflows-landing/tsconfig.json +25 -0
  38. package/behaviour-tree-workflows-landing/vite.config.ts +40 -0
  39. package/demo-google-sheets.ts +181 -0
  40. package/demo-runtime-variables.ts +174 -0
  41. package/demo-template.ts +208 -0
  42. package/docs/ARCHITECTURE_SUMMARY.md +613 -0
  43. package/docs/NODE_REFERENCE.md +504 -0
  44. package/docs/README.md +53 -0
  45. package/docs/custom-nodes-architecture.md +826 -0
  46. package/docs/observability.md +175 -0
  47. package/docs/yaml-specification.md +990 -0
  48. package/examples/temporal/README.md +117 -0
  49. package/examples/temporal/activities.ts +373 -0
  50. package/examples/temporal/client.ts +115 -0
  51. package/examples/temporal/python-worker/activities.py +339 -0
  52. package/examples/temporal/python-worker/requirements.txt +12 -0
  53. package/examples/temporal/python-worker/worker.py +106 -0
  54. package/examples/temporal/worker.ts +66 -0
  55. package/examples/temporal/workflows.ts +6 -0
  56. package/examples/temporal/yaml-workflow-loader.ts +105 -0
  57. package/examples/yaml-test.ts +97 -0
  58. package/examples/yaml-workflows/01-simple-sequence.yaml +25 -0
  59. package/examples/yaml-workflows/02-parallel-timeout.yaml +45 -0
  60. package/examples/yaml-workflows/03-ecommerce-checkout.yaml +94 -0
  61. package/examples/yaml-workflows/04-ai-agent-workflow.yaml +346 -0
  62. package/examples/yaml-workflows/05-order-processing.yaml +146 -0
  63. package/examples/yaml-workflows/06-activity-test.yaml +71 -0
  64. package/examples/yaml-workflows/07-activity-simple-test.yaml +43 -0
  65. package/examples/yaml-workflows/08-file-processing.yaml +141 -0
  66. package/examples/yaml-workflows/09-http-request.yaml +137 -0
  67. package/examples/yaml-workflows/README.md +211 -0
  68. package/package.json +38 -0
  69. package/src/actions/code-execution.schema.ts +27 -0
  70. package/src/actions/code-execution.ts +218 -0
  71. package/src/actions/generate-file.test.ts +516 -0
  72. package/src/actions/generate-file.ts +166 -0
  73. package/src/actions/http-request.test.ts +784 -0
  74. package/src/actions/http-request.ts +228 -0
  75. package/src/actions/index.ts +20 -0
  76. package/src/actions/parse-file.test.ts +448 -0
  77. package/src/actions/parse-file.ts +139 -0
  78. package/src/actions/python-script.test.ts +439 -0
  79. package/src/actions/python-script.ts +154 -0
  80. package/src/base-node.test.ts +511 -0
  81. package/src/base-node.ts +605 -0
  82. package/src/behavior-tree.test.ts +431 -0
  83. package/src/behavior-tree.ts +283 -0
  84. package/src/blackboard.test.ts +222 -0
  85. package/src/blackboard.ts +192 -0
  86. package/src/composites/conditional.schema.ts +19 -0
  87. package/src/composites/conditional.test.ts +309 -0
  88. package/src/composites/conditional.ts +129 -0
  89. package/src/composites/for-each.schema.ts +23 -0
  90. package/src/composites/for-each.test.ts +254 -0
  91. package/src/composites/for-each.ts +132 -0
  92. package/src/composites/index.ts +15 -0
  93. package/src/composites/memory-sequence.schema.ts +19 -0
  94. package/src/composites/memory-sequence.test.ts +223 -0
  95. package/src/composites/memory-sequence.ts +98 -0
  96. package/src/composites/parallel.schema.ts +28 -0
  97. package/src/composites/parallel.test.ts +502 -0
  98. package/src/composites/parallel.ts +157 -0
  99. package/src/composites/reactive-sequence.schema.ts +19 -0
  100. package/src/composites/reactive-sequence.test.ts +170 -0
  101. package/src/composites/reactive-sequence.ts +85 -0
  102. package/src/composites/recovery.schema.ts +19 -0
  103. package/src/composites/recovery.test.ts +366 -0
  104. package/src/composites/recovery.ts +90 -0
  105. package/src/composites/selector.schema.ts +19 -0
  106. package/src/composites/selector.test.ts +387 -0
  107. package/src/composites/selector.ts +85 -0
  108. package/src/composites/sequence.schema.ts +19 -0
  109. package/src/composites/sequence.test.ts +337 -0
  110. package/src/composites/sequence.ts +72 -0
  111. package/src/composites/sub-tree.schema.ts +21 -0
  112. package/src/composites/sub-tree.test.ts +893 -0
  113. package/src/composites/sub-tree.ts +177 -0
  114. package/src/composites/while.schema.ts +24 -0
  115. package/src/composites/while.test.ts +381 -0
  116. package/src/composites/while.ts +149 -0
  117. package/src/data-store/index.ts +10 -0
  118. package/src/data-store/memory-store.ts +161 -0
  119. package/src/data-store/types.ts +94 -0
  120. package/src/debug/breakpoint.test.ts +47 -0
  121. package/src/debug/breakpoint.ts +30 -0
  122. package/src/debug/index.ts +17 -0
  123. package/src/debug/resume-point.test.ts +49 -0
  124. package/src/debug/resume-point.ts +29 -0
  125. package/src/decorators/delay.schema.ts +21 -0
  126. package/src/decorators/delay.test.ts +261 -0
  127. package/src/decorators/delay.ts +140 -0
  128. package/src/decorators/force-result.schema.ts +32 -0
  129. package/src/decorators/force-result.test.ts +133 -0
  130. package/src/decorators/force-result.ts +63 -0
  131. package/src/decorators/index.ts +13 -0
  132. package/src/decorators/invert.schema.ts +19 -0
  133. package/src/decorators/invert.test.ts +135 -0
  134. package/src/decorators/invert.ts +42 -0
  135. package/src/decorators/keep-running.schema.ts +20 -0
  136. package/src/decorators/keep-running.test.ts +105 -0
  137. package/src/decorators/keep-running.ts +49 -0
  138. package/src/decorators/precondition.schema.ts +19 -0
  139. package/src/decorators/precondition.test.ts +351 -0
  140. package/src/decorators/precondition.ts +139 -0
  141. package/src/decorators/repeat.schema.ts +21 -0
  142. package/src/decorators/repeat.test.ts +187 -0
  143. package/src/decorators/repeat.ts +94 -0
  144. package/src/decorators/run-once.schema.ts +19 -0
  145. package/src/decorators/run-once.test.ts +140 -0
  146. package/src/decorators/run-once.ts +61 -0
  147. package/src/decorators/soft-assert.schema.ts +19 -0
  148. package/src/decorators/soft-assert.test.ts +107 -0
  149. package/src/decorators/soft-assert.ts +68 -0
  150. package/src/decorators/timeout.schema.ts +21 -0
  151. package/src/decorators/timeout.test.ts +274 -0
  152. package/src/decorators/timeout.ts +159 -0
  153. package/src/errors.test.ts +63 -0
  154. package/src/errors.ts +34 -0
  155. package/src/events.test.ts +347 -0
  156. package/src/events.ts +183 -0
  157. package/src/index.ts +80 -0
  158. package/src/integrations/index.ts +30 -0
  159. package/src/integrations/integration-action.test.ts +571 -0
  160. package/src/integrations/integration-action.ts +233 -0
  161. package/src/integrations/piece-executor.ts +320 -0
  162. package/src/observability/execution-tracker.ts +320 -0
  163. package/src/observability/index.ts +23 -0
  164. package/src/observability/sinks.ts +138 -0
  165. package/src/observability/types.ts +130 -0
  166. package/src/registry-utils.ts +147 -0
  167. package/src/registry.test.ts +466 -0
  168. package/src/registry.ts +334 -0
  169. package/src/schemas/base.schema.ts +104 -0
  170. package/src/schemas/index.ts +223 -0
  171. package/src/schemas/integration.test.ts +238 -0
  172. package/src/schemas/tree-definition.schema.ts +170 -0
  173. package/src/schemas/validation.test.ts +146 -0
  174. package/src/schemas/validation.ts +122 -0
  175. package/src/scripting/index.ts +22 -0
  176. package/src/templates/template-loader.test.ts +281 -0
  177. package/src/templates/template-loader.ts +152 -0
  178. package/src/temporal-integration.test.ts +213 -0
  179. package/src/test-nodes.ts +259 -0
  180. package/src/types.ts +503 -0
  181. package/src/utilities/index.ts +17 -0
  182. package/src/utilities/log-message.test.ts +275 -0
  183. package/src/utilities/log-message.ts +134 -0
  184. package/src/utilities/regex-extract.test.ts +138 -0
  185. package/src/utilities/regex-extract.ts +108 -0
  186. package/src/utilities/variable-resolver.test.ts +416 -0
  187. package/src/utilities/variable-resolver.ts +318 -0
  188. package/src/utils/error-handler.test.ts +117 -0
  189. package/src/utils/error-handler.ts +48 -0
  190. package/src/utils/signal-check.test.ts +234 -0
  191. package/src/utils/signal-check.ts +140 -0
  192. package/src/yaml/errors.ts +143 -0
  193. package/src/yaml/index.ts +30 -0
  194. package/src/yaml/loader.ts +39 -0
  195. package/src/yaml/parser.ts +286 -0
  196. package/src/yaml/validation/semantic-validator.ts +196 -0
  197. package/templates/google-sheets/insert-row.yaml +76 -0
  198. package/templates/notification-sender.yaml +33 -0
  199. package/templates/order-validation.yaml +44 -0
  200. package/tsconfig.json +24 -0
  201. package/vitest.config.ts +25 -0
  202. package/workflows/order-processor.yaml +59 -0
  203. package/workflows/process-order-workflow.yaml +142 -0
@@ -0,0 +1,31 @@
1
+ {
2
+ "permissions": {
3
+ "allow": [
4
+ "WebFetch(domain:temporal.io)",
5
+ "WebSearch",
6
+ "WebFetch(domain:docs.temporal.io)",
7
+ "Bash(npm run typecheck:*)",
8
+ "Bash(npm install:*)",
9
+ "Bash(node -e:*)",
10
+ "Bash(npm test:*)",
11
+ "Bash(ls:*)",
12
+ "Bash(grep:*)",
13
+ "Bash(npm run type-check:*)",
14
+ "Bash(npm run test:*)",
15
+ "Bash(timeout 30 npm run test:*)",
16
+ "Bash(timeout 10 npx tsx:*)",
17
+ "Bash(npm run build:*)",
18
+ "Bash(npx tsx client.ts)",
19
+ "Bash(mkdir:*)",
20
+ "Bash(cat:*)",
21
+ "Bash(npx tsx:*)",
22
+ "WebFetch(domain:mint.q1k.ai)",
23
+ "Bash(wc:*)",
24
+ "Bash(find:*)",
25
+ "Bash(npx vite build:*)",
26
+ "Bash(npm whoami:*)",
27
+ "Bash(npm org:*)",
28
+ "Bash(npm publish:*)"
29
+ ]
30
+ }
31
+ }
package/CLAUDE.md ADDED
@@ -0,0 +1,181 @@
1
+ # CLAUDE.md
2
+
3
+ This file provides guidance to Claude Code (claude.ai/code) when working with code in this repository.
4
+
5
+ ## Project Overview
6
+
7
+ @wayfarer-ai/btree-workflows is a behavior tree library for TypeScript, designed for AI-native workflows. It provides 30+ production-ready nodes, YAML workflow definitions, native Temporal integration for durable execution, and built-in observability.
8
+
9
+ ## Commands
10
+
11
+ ```bash
12
+ # Development
13
+ npm run dev # Watch mode build (tsup)
14
+ npm run build # Production build (CJS + ESM + types)
15
+ npm run typecheck # TypeScript type checking
16
+ npm run clean # Remove dist/
17
+
18
+ # Testing (534+ tests, 89%+ coverage)
19
+ npm test # Run all tests with coverage (CI=true)
20
+ npm run test:watch # Watch mode
21
+ npm run test:ui # Vitest UI
22
+ ```
23
+
24
+ ## Architecture
25
+
26
+ ### Core Concepts
27
+ - **NodeStatus**: `SUCCESS | FAILURE | RUNNING | IDLE` - every tick returns a status
28
+ - **ScopedBlackboard**: Hierarchical key-value store with scope inheritance
29
+ - **TickEngine**: Executes tree via tick loop with auto exponential backoff
30
+ - **Registry**: Factory for creating nodes from YAML/JSON definitions
31
+ - **ExecutionTracker**: Aggregates events into queryable state (progress, errors, timeline)
32
+
33
+ ### Node Types
34
+ | Category | Count | Examples |
35
+ |----------|-------|----------|
36
+ | Composites | 10 | Sequence, Selector, Parallel, ForEach, While, Conditional, Recovery |
37
+ | Decorators | 10 | Timeout, Delay, Repeat, Invert, ForceSuccess, RunOnce, Precondition |
38
+ | Actions | 9 | PrintAction, CodeExecution, LogMessage, HttpRequest, GenerateFile |
39
+
40
+ ### Directory Structure
41
+ ```
42
+ src/
43
+ ├── base-node.ts # BaseNode abstract class
44
+ ├── behavior-tree.ts # BehaviorTree wrapper with toWorkflow()
45
+ ├── blackboard.ts # ScopedBlackboard implementation
46
+ ├── tick-engine.ts # TickEngine with snapshot support
47
+ ├── registry.ts # Node registry + YAML loading
48
+ ├── events.ts # NodeEventEmitter for lifecycle events
49
+ ├── composites/ # Composite nodes (Sequence, Parallel, etc.)
50
+ ├── decorators/ # Decorator nodes (Timeout, Repeat, etc.)
51
+ ├── actions/ # Activity-based action nodes
52
+ │ ├── code-execution.ts # CodeExecution (JS/Python via Microsandbox)
53
+ │ ├── http-request.ts # HttpRequest (REST API calls)
54
+ │ └── generate-file.ts # GenerateFile (CSV/JSON export)
55
+ ├── data-store/ # DataStore for large payloads
56
+ ├── observability/ # Execution tracking and error capture
57
+ │ ├── types.ts # ExecutionProgress, StructuredError, TimelineEntry
58
+ │ ├── execution-tracker.ts # State aggregation from events
59
+ │ └── sinks.ts # Temporal workflow sink types
60
+ ├── schemas/ # Zod schemas for node props
61
+ ├── yaml/ # YAML loading + validation
62
+ └── utils/ # Shared utilities
63
+ ```
64
+
65
+ ### YAML Workflows
66
+ ```typescript
67
+ import { Registry, registerStandardNodes, loadTreeFromYaml } from '@wayfarer-ai/btree';
68
+
69
+ const registry = new Registry();
70
+ registerStandardNodes(registry); // Registers all 32 built-in nodes
71
+
72
+ const tree = loadTreeFromYaml(`
73
+ type: Sequence
74
+ id: my-workflow
75
+ children:
76
+ - type: PrintAction
77
+ id: hello
78
+ props:
79
+ message: "Hello from YAML!"
80
+ `, registry);
81
+
82
+ await tree.execute();
83
+ ```
84
+
85
+ ### Temporal Integration
86
+ ```typescript
87
+ import { BehaviorTree, Sequence, PrintAction } from '@wayfarer-ai/btree';
88
+
89
+ export async function myWorkflow(args: WorkflowArgs): Promise<WorkflowResult> {
90
+ const root = new Sequence({ id: 'root' });
91
+ root.addChild(new PrintAction({ id: 'step1', message: 'Hello' }));
92
+
93
+ const tree = new BehaviorTree(root);
94
+ return tree.toWorkflow()(args); // Returns Temporal-compatible workflow
95
+ }
96
+ ```
97
+
98
+ ## Key Patterns
99
+
100
+ ### Adding New Nodes
101
+ 1. Create file in `src/composites/` or `src/decorators/`
102
+ 2. Extend `CompositeNode` or `DecoratorNode`
103
+ 3. Implement `executeTick(context)` returning `Promise<NodeStatus>`
104
+ 4. Add Zod schema in `src/schemas/` for YAML validation
105
+ 5. Register in `registerStandardNodes()` or custom registry
106
+ 6. Write tests covering SUCCESS/FAILURE/RUNNING states
107
+
108
+ ### CodeExecution Node
109
+ The CodeExecution node runs JavaScript or Python in a secure sandbox (Microsandbox).
110
+
111
+ **JavaScript Example:**
112
+ ```yaml
113
+ type: CodeExecution
114
+ props:
115
+ language: javascript
116
+ code: |
117
+ const users = getBB('apiUsers');
118
+ const processed = users.map(u => ({ id: u.id, name: u.name }));
119
+ setBB('processedUsers', processed);
120
+ ```
121
+
122
+ **Python Example:**
123
+ ```yaml
124
+ type: CodeExecution
125
+ props:
126
+ language: python
127
+ packages: [pandas]
128
+ code: |
129
+ users = getBB('users')
130
+ setBB('count', len(users))
131
+ ```
132
+
133
+ Available functions: `getBB(key)`, `setBB(key, value)`, `getInput(key)`, `console.log`/`print`.
134
+
135
+ ### Error Handling
136
+ Nodes that fail should set `this._lastError` with descriptive context:
137
+ ```typescript
138
+ catch (error) {
139
+ this._lastError = `Verification failed: expected "${expected}": ${error.message}`;
140
+ return NodeStatus.FAILURE;
141
+ }
142
+ ```
143
+
144
+ ### Execution Snapshots
145
+ ```typescript
146
+ const engine = new TickEngine(tree, { captureSnapshots: true });
147
+ await engine.tick(blackboard);
148
+
149
+ const snapshots = engine.getSnapshots(); // Only captured when state changes
150
+ engine.clearSnapshots(); // Always clear to prevent memory growth
151
+ ```
152
+
153
+ ### Observability
154
+ The library includes an observability module for tracking execution:
155
+
156
+ ```typescript
157
+ import { ExecutionTracker, NodeEventEmitter } from '@wayfarer-ai/btree';
158
+
159
+ const tracker = new ExecutionTracker(totalNodes);
160
+ const eventEmitter = new NodeEventEmitter();
161
+
162
+ // Subscribe to all events
163
+ eventEmitter.onAll((event) => tracker.onNodeEvent(event));
164
+
165
+ // Query state
166
+ tracker.getProgress(); // { totalNodes, completedNodes, failedNodes, status }
167
+ tracker.getErrors(); // Structured errors with blackboard snapshots
168
+ tracker.getTimeline(); // Chronological execution trace
169
+ ```
170
+
171
+ All node types automatically emit ERROR events with:
172
+ - Error message and stack trace
173
+ - Blackboard snapshot at time of error
174
+ - Heuristic-based fix suggestions
175
+
176
+ ## Testing Guidelines
177
+ - Use `describe/it` structure
178
+ - Test all status transitions (SUCCESS, FAILURE, RUNNING)
179
+ - Test edge cases (empty children, null values)
180
+ - Use helper nodes from `src/test-nodes.ts`
181
+ - Tests run with `CI=true` to prevent watch mode in CI
package/LICENSE ADDED
@@ -0,0 +1,21 @@
1
+ MIT License
2
+
3
+ Copyright (c) 2025 wayfarer-ai
4
+
5
+ Permission is hereby granted, free of charge, to any person obtaining a copy
6
+ of this software and associated documentation files (the "Software"), to deal
7
+ in the Software without restriction, including without limitation the rights
8
+ to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
9
+ copies of the Software, and to permit persons to whom the Software is
10
+ furnished to do so, subject to the following conditions:
11
+
12
+ The above copyright notice and this permission notice shall be included in all
13
+ copies or substantial portions of the Software.
14
+
15
+ THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16
+ IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17
+ FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
18
+ AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
19
+ LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
20
+ OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
21
+ SOFTWARE.