my-pi 0.0.3 → 0.0.4
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +24 -5
- package/dist/api-B6KnhtN9.js +1893 -0
- package/dist/api-B6KnhtN9.js.map +1 -0
- package/dist/api.js +1 -49
- package/dist/index.js +2 -2
- package/dist/index.js.map +1 -1
- package/package.json +2 -1
- package/src/extensions/config.test.ts +88 -0
- package/src/extensions/config.ts +189 -0
- package/src/extensions/extensions.ts +366 -0
- package/src/extensions/skills.ts +496 -75
- package/src/skills/importer.test.ts +301 -0
- package/src/skills/importer.ts +221 -0
- package/src/skills/manager.ts +129 -30
- package/src/skills/scanner.ts +172 -72
- package/dist/api.js.map +0 -1
package/README.md
CHANGED
|
@@ -63,8 +63,12 @@ my-pi -e ./ext/damage-control.ts -e ./ext/tool-counter.ts
|
|
|
63
63
|
my-pi --no-builtin -e ./ext/custom.ts "do something"
|
|
64
64
|
```
|
|
65
65
|
|
|
66
|
-
Stack arbitrary Pi extensions via `-e`. Use `--no-builtin` to skip
|
|
67
|
-
built-in
|
|
66
|
+
Stack arbitrary Pi extensions via `-e`. Use `--no-builtin` to skip all
|
|
67
|
+
built-in extensions.
|
|
68
|
+
|
|
69
|
+
Built-in extension choices can also be saved interactively with
|
|
70
|
+
`/extensions`. Startup flags like `--no-recall` and `--no-skills`
|
|
71
|
+
still force-disable those extensions for the current process only.
|
|
68
72
|
|
|
69
73
|
### Stdin piping
|
|
70
74
|
|
|
@@ -142,8 +146,18 @@ In interactive mode:
|
|
|
142
146
|
- `/mcp list` — show connected servers and tool counts
|
|
143
147
|
- `/mcp enable <server>` — enable a disabled server's tools
|
|
144
148
|
- `/mcp disable <server>` — disable a server's tools
|
|
145
|
-
- `/
|
|
146
|
-
- `/
|
|
149
|
+
- `/extensions` — open the built-in extensions manager
|
|
150
|
+
- `/extensions list` — print built-in extensions with saved/effective
|
|
151
|
+
state
|
|
152
|
+
- `/extensions enable <key>` / `/extensions disable <key>` — toggle a
|
|
153
|
+
built-in extension
|
|
154
|
+
- `/skills` — open the interactive skills manager (unified list with
|
|
155
|
+
managed and importable sections, checkbox batch-import)
|
|
156
|
+
- `/skills import <key|name>` — import an external skill from the
|
|
157
|
+
command line
|
|
158
|
+
- `/skills sync <key|name>` — sync an imported skill to its upstream
|
|
159
|
+
- `/skills refresh` — rescan skill directories
|
|
160
|
+
- `/skills defaults <all-enabled|all-disabled>` — set default policy
|
|
147
161
|
|
|
148
162
|
### How it works
|
|
149
163
|
|
|
@@ -154,7 +168,9 @@ In interactive mode:
|
|
|
154
168
|
5. Registers each tool via `pi.registerTool()` as
|
|
155
169
|
`mcp__<server>__<tool>`
|
|
156
170
|
6. `/mcp enable/disable` toggles tools via `pi.setActiveTools()`
|
|
157
|
-
7.
|
|
171
|
+
7. Built-in extension state can be managed via `/extensions` and is
|
|
172
|
+
persisted in `~/.config/my-pi/extensions.json`
|
|
173
|
+
8. Cleanup on `session_shutdown`
|
|
158
174
|
|
|
159
175
|
## Agent Chains
|
|
160
176
|
|
|
@@ -214,11 +230,14 @@ src/
|
|
|
214
230
|
index.ts CLI entry point (citty + pi SDK)
|
|
215
231
|
api.ts Programmatic API (create_my_pi + re-exports)
|
|
216
232
|
extensions/
|
|
233
|
+
config.ts Persistent built-in extension config
|
|
234
|
+
extensions.ts Built-in extension manager (/extensions)
|
|
217
235
|
mcp.ts MCP server integration
|
|
218
236
|
skills.ts Skill discovery and toggle
|
|
219
237
|
chain.ts Agent chain pipelines
|
|
220
238
|
filter-output.ts Secret redaction in tool output
|
|
221
239
|
handoff.ts Session context export
|
|
240
|
+
recall.ts Past session recall guidance
|
|
222
241
|
mcp/
|
|
223
242
|
client.ts Minimal MCP stdio client (JSON-RPC 2.0)
|
|
224
243
|
config.ts Loads and merges mcp.json configs
|