@hasna/prompts 0.3.2 → 0.3.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/dist/mcp/index.js +77 -1
- package/package.json +1 -1
package/dist/mcp/index.js
CHANGED
|
@@ -5413,7 +5413,31 @@ server.registerTool("prompts_render", {
|
|
|
5413
5413
|
}, async ({ id, vars, agent }) => {
|
|
5414
5414
|
try {
|
|
5415
5415
|
const prompt = usePrompt(id);
|
|
5416
|
-
const
|
|
5416
|
+
const autoFilled = {};
|
|
5417
|
+
if (agent) {
|
|
5418
|
+
const CONTEXT_VARS = {
|
|
5419
|
+
agent_name: () => agent,
|
|
5420
|
+
agent_id: () => agent,
|
|
5421
|
+
project_id: () => process.env.TODOS_PROJECT_ID || process.env.PROJECT_ID,
|
|
5422
|
+
org_id: () => process.env.ORG_ID,
|
|
5423
|
+
session_id: () => process.env.SESSION_ID,
|
|
5424
|
+
cwd: () => process.cwd(),
|
|
5425
|
+
date: () => new Date().toISOString().split("T")[0],
|
|
5426
|
+
datetime: () => new Date().toISOString()
|
|
5427
|
+
};
|
|
5428
|
+
for (const [key, getter] of Object.entries(CONTEXT_VARS)) {
|
|
5429
|
+
if (!(key in vars)) {
|
|
5430
|
+
const val = getter();
|
|
5431
|
+
if (val)
|
|
5432
|
+
autoFilled[key] = val;
|
|
5433
|
+
}
|
|
5434
|
+
}
|
|
5435
|
+
}
|
|
5436
|
+
const mergedVars = { ...autoFilled, ...vars };
|
|
5437
|
+
const result = renderTemplate(prompt.body, mergedVars);
|
|
5438
|
+
if (Object.keys(autoFilled).length > 0) {
|
|
5439
|
+
result.auto_filled = autoFilled;
|
|
5440
|
+
}
|
|
5417
5441
|
await maybeSaveMemento({ slug: prompt.slug, body: prompt.body, rendered: result.rendered, agentId: agent });
|
|
5418
5442
|
return ok(result);
|
|
5419
5443
|
} catch (e) {
|
|
@@ -5547,6 +5571,58 @@ server.registerTool("prompts_import", {
|
|
|
5547
5571
|
const results = importFromJson(prompts, changed_by);
|
|
5548
5572
|
return ok(results);
|
|
5549
5573
|
});
|
|
5574
|
+
server.registerTool("prompts_export_as_skills", {
|
|
5575
|
+
description: "Export prompts as Claude Code SKILL.md files in ~/.claude/skills/ so they become /slug slash commands. Each prompt slug becomes an invocable skill.",
|
|
5576
|
+
inputSchema: {
|
|
5577
|
+
collection: exports_external.string().optional().describe("Only export prompts from this collection"),
|
|
5578
|
+
slugs: exports_external.array(exports_external.string()).optional().describe("Specific prompt slugs to export"),
|
|
5579
|
+
target_dir: exports_external.string().optional().describe("Target skills directory (default: ~/.claude/skills)"),
|
|
5580
|
+
overwrite: exports_external.boolean().optional().describe("Overwrite existing skill files (default: false)")
|
|
5581
|
+
}
|
|
5582
|
+
}, async ({ collection, slugs, target_dir, overwrite }) => {
|
|
5583
|
+
try {
|
|
5584
|
+
const { mkdirSync: mkdirSync2, writeFileSync, existsSync: existsSync2 } = await import("fs");
|
|
5585
|
+
const { join: join2 } = await import("path");
|
|
5586
|
+
const { homedir } = await import("os");
|
|
5587
|
+
const skillsDir = target_dir ?? join2(homedir(), ".claude", "skills");
|
|
5588
|
+
mkdirSync2(skillsDir, { recursive: true });
|
|
5589
|
+
const filter = collection ? { collection } : {};
|
|
5590
|
+
const allPrompts = listPrompts(filter);
|
|
5591
|
+
const toExport = slugs ? allPrompts.filter((p) => slugs.includes(p.slug)) : allPrompts;
|
|
5592
|
+
const exported = [];
|
|
5593
|
+
const skipped = [];
|
|
5594
|
+
for (const prompt of toExport) {
|
|
5595
|
+
const skillDir = join2(skillsDir, `skill-${prompt.slug}`);
|
|
5596
|
+
const skillFile = join2(skillDir, "SKILL.md");
|
|
5597
|
+
if (!overwrite && existsSync2(skillFile)) {
|
|
5598
|
+
skipped.push(prompt.slug);
|
|
5599
|
+
continue;
|
|
5600
|
+
}
|
|
5601
|
+
mkdirSync2(skillDir, { recursive: true });
|
|
5602
|
+
const skillContent = [
|
|
5603
|
+
"---",
|
|
5604
|
+
`name: skill-${prompt.slug}`,
|
|
5605
|
+
`description: ${prompt.description || prompt.title}`,
|
|
5606
|
+
"user_invocable: true",
|
|
5607
|
+
"---",
|
|
5608
|
+
"",
|
|
5609
|
+
prompt.body
|
|
5610
|
+
].join(`
|
|
5611
|
+
`);
|
|
5612
|
+
writeFileSync(skillFile, skillContent, "utf-8");
|
|
5613
|
+
exported.push(prompt.slug);
|
|
5614
|
+
}
|
|
5615
|
+
return ok({
|
|
5616
|
+
exported: exported.length,
|
|
5617
|
+
skipped: skipped.length,
|
|
5618
|
+
skills_dir: skillsDir,
|
|
5619
|
+
exported_slugs: exported,
|
|
5620
|
+
message: `Exported ${exported.length} prompt(s) as skills. Use /skill-{slug} to invoke them.`
|
|
5621
|
+
});
|
|
5622
|
+
} catch (e) {
|
|
5623
|
+
return err(e instanceof Error ? e.message : String(e));
|
|
5624
|
+
}
|
|
5625
|
+
});
|
|
5550
5626
|
server.registerTool("prompts_import_slash_commands", {
|
|
5551
5627
|
description: "Auto-scan .claude/commands, .codex/skills, .gemini/extensions (both project and home dir) and import all .md files as prompts.",
|
|
5552
5628
|
inputSchema: {
|