skills/joplin/SKILL.md
Orchestration guidance for Joplin note, notebook, and tag management tools
npx skillsauth add alondmnt/joplin-mcp joplinInstall this skill globally with one command. Works with Claude Code, Cursor, and Windsurf.
3 of 9 scanners reported clean
Some scanners were skipped, did not run, or reported a non-clean status. Review each row below.
This skill covers non-obvious tool interactions. Tool parameters are already in the tool schemas — don't restate them here.
If Joplin MCP tools (e.g., ping_joplin) aren't available, the server isn't connected. Follow these steps to configure it automatically:
Ask the user for their Joplin API token. Tell them where to find it:
Open Joplin Desktop → Tools → Options → Web Clipper → copy the Authorization token.
Write .mcp.json to the project root with the token. Use the Write tool to create the file:
{
"mcpServers": {
"joplin-mcp": {
"command": "uvx",
"args": ["--from", "joplin-mcp", "joplin-mcp-server"],
"env": {
"JOPLIN_TOKEN": "<paste_token_here>"
}
}
}
}
This file is already covered by .gitignore (.* rule) so it won't be committed.
Tell the user to restart Claude Code. The MCP server is loaded at startup, so a restart is required for the tools to appear.
After restart, call ping_joplin to verify the connection.
edit_note — find/replace, append, prepend. Use this for partial changes.update_note(body=...) — replaces the entire body. Only use when you intend to rewrite the whole note.If you need to change a paragraph, fix a typo, or append a section: always use edit_note.
get_note returns a table of contents (not content) when a note exceeds ~50 lines. To read the actual content:
get_note(note_id) — see the TOC and line countget_note(note_id, section="Section Name") — extract a specific sectionget_note(note_id, start_line=1, line_count=50) — sequential reading by line rangeget_note(note_id, force_full=True) — force full content (large context cost)| Parameter | Accepts |
|-----------|---------|
| note_id | 32-char hex ID only |
| notebook_name | Human-readable name (e.g., "Work") |
| tag_name | Human-readable name (e.g., "important") |
| parent_id | Omit for top-level notebooks, or pass a 32-char hex parent notebook ID only |
Search results return IDs — use those IDs in subsequent calls.
tag_note fails if the tag doesn't exist. Before tagging multiple notes:
create_tag("my-tag") — create it first (idempotent if it already exists)tag_note(note_id, "my-tag") for each noteget_note(id) # see TOC + line count
get_note(id, section="Target") # read the section you need
edit_note(id, old_string="...", new_string="...") # surgical edit
create_notebook("Sub") # top-level notebook: omit parent_name
create_notebook("Sub", parent_name="Projects/Work") # under an existing notebook (by name or path)
create_note("Title", notebook_name="Sub", body="...")
create_tag("project-x") # ensure tag exists first
find_notes("project x") # get note IDs
tag_note(id1, "project-x") # tag each result
tag_note(id2, "project-x")
list_notebooks() # find target notebook ID
update_note(note_id, notebook_id="<target_hex_id>")
tools
Use when work should span one or more detached tasks but still behave like one job with a single owner context. TaskFlow is the durable flow substrate under authoring layers like Lobster, ACPX, plugins, or plain code. Keep conditional logic in the caller; use TaskFlow for flow identity, child-task linkage, waiting state, revision-checked mutations, and user-facing emergence.
tools
# Lobster Lobster executes multi-step workflows with approval checkpoints. Use it when: - User wants a repeatable automation (triage, monitor, sync) - Actions need human approval before executing (send, post, delete) - Multiple tool calls should run as one deterministic operation ## When to use Lobster | User intent | Use Lobster? | | ------------------------------------------------------ | --------------------------
tools
# Lobster Lobster executes multi-step workflows with approval checkpoints. Use it when: - User wants a repeatable automation (triage, monitor, sync) - Actions need human approval before executing (send, post, delete) - Multiple tool calls should run as one deterministic operation ## When to use Lobster | User intent | Use Lobster? | | ------------------------------------------------------ | --------------------------
tools
A CLI tool for making authenticated requests to the X (Twitter) API. Use this skill when you need to post tweets, reply, quote, search, read posts, manage followers, send DMs, upload media, or interact with any X API v2 endpoint.