asonas13 downloadsLocal AI editor that reviews your writing using Claude Code CLI.
An Obsidian plugin that runs your notes through Claude Code and shows the feedback inline. The name comes from 赤入れ, the red-pen marks Japanese editors leave on a manuscript.
I wanted a writing reviewer that lives inside Obsidian instead of a separate tab or chat window. Open a note, run a command, read comments next to the paragraphs they apply to.
Claude only, via the Claude Code CLI. The actual model is whatever Claude Code is configured to use (set with claude --model ... or through Claude Code's own config). Other providers are not planned right now because the plugin reads Claude Code's streaming JSON output format directly.
claude on your PATH..textlintrc.json that enables textlint-rule-preset-ja-technical-writing, so you also need that preset installed where your textlint binary can resolve it (e.g. npm i -g textlint textlint-rule-preset-ja-technical-writing). If your vault already has its own .textlintrc upward from the note, that one is used instead.The plugin is not yet listed in the Obsidian community plugin browser. For now you can install it manually:
manifest.json, main.js, styles.css, and .textlintrc.json from a release.<your-vault>/.obsidian/plugins/akaire/.Open a note and run one of these from the command palette (the commands are listed under "Akaire" in the palette):
Review whole note reviews the entire note.Review changed paragraphs reviews only the paragraphs that changed since the last review.Open sidebar shows the comment sidebar.You can give Claude per-note instructions in the frontmatter:
---
editor_prompt: "Blog tone, です・ます調, annotate jargon"
---
If you drop a .editor.md file inside a directory, its contents are appended to the prompt for every note under that directory. Set editor_prompt_inherit: false in a note's frontmatter to opt out of that inheritance.
Comment anchors are stored under .editor-state/ at the root of your vault. Add it to your vault's .gitignore if you sync the vault with git.
Akaire itself does not make any network requests. The plugin spawns the claude CLI as a subprocess, and Claude Code in turn talks to Anthropic's servers (api.anthropic.com) to produce the review. The text of the note you are reviewing is sent to Anthropic as part of that request. The optional textlint integration runs entirely locally and does not use the network.
Authentication is handled by Claude Code, not by Akaire. You log in once with claude (or configure an Anthropic API key) and Akaire piggy-backs on that session. Akaire never reads, stores, or transmits your credentials, and it does not include any telemetry or auto-update mechanism.
The Obsidian community directory flags two capabilities that Akaire uses by design. Both are required for the plugin to function, and what they are used for is described below.
child_process): Akaire spawns the claude CLI (and, when configured, the textlint CLI) as child processes to perform reviews. No other shell commands are executed. Command-line arguments are constructed from configuration values and the path of the file being reviewed; the note body is passed through stdin rather than through the shell.fs): Akaire reads and writes a small set of files using the Node.js fs module rather than the Obsidian Vault API. Specifically, it writes per-note anchor state under .editor-state/ at the vault root, reads .editor.md files for prompt inheritance, and resolves a project-local .textlintrc(.json) walked up from the note's directory. All of these paths sit inside the vault tree. Direct filesystem access is used because the Vault API does not cover dotfiles outside of data.json, and because the claude and textlint CLIs themselves need real filesystem paths to operate on. Akaire does not read or modify any file outside the vault tree.npm install
npm run dev # esbuild in watch mode
npm test # vitest
npm run build # production build into dist/
The source layout:
src/core/: prompt resolution, the Claude and textlint runners, anchor storage, the review session.src/editor/: CodeMirror anchor matching and decoration.src/ui/: sidebar view and comment cards.src/util/: paragraph hashing, vault filesystem helpers, JSON extraction.The fixtures under test/fixtures/ simulate the Claude Code CLI so the runner can be tested without calling the real binary.
MIT. See LICENSE.