This is a beta plugin adding features to the Readwise x Obsidian integration.
I use both Readwise (https://readwise.io/) and Obsidian (https://obsidian.md) regularly. When reviewing my daily highlights in Readwise, I'd sometimes want to connect the highlight to something in my Obsidian vault.
Since my vault already has all of my Readwise highlights—and since I personally have each highlight exported as one block (a callout)—this plugin is mostly a matter of finding the block corresponding to some highlight.
This requires a paid subscription to Readwise.
The plugin assumes that the official Readwise integration for Obsidian is installed. We use the official plugin's data for both (1) your Readwise API token and (2) the filename to book ID mapping.
We register a new command, "Add daily review highlights to current note." This gets your Readwise daily review from the API, attempts to locate each highlight in the vault, and presents them in a modal.
We read your Readwise API token from the official plugin's data. I don't know whether this is explicitly forbidden—the developer policy makes no mention of this—but it's at minimum questionable (and undocumented). That said, I built the plugin for my personal use; the plugin makes no attempt to hide this; the command is gated by a user action; and we only make read/GET requests.
Since the request volume is so low and the user is fully in-control, we don't make any attempt to cache responses or rate limit the requests.
The plugin assumes that highlights are stored and formatted the way that my vault stores and formats them. Specifically:
- Each highlight is wrapped in a callout
- The callout has a block reference ID, the string
rw
plus the highlight ID (e.g.,rw0041401448
) - You use
[[Markdown links]]
and not[wiki](links)
.
The plugin will ignore (silently or gracefully, depending on your perspective) highlights that it can't find (because the file was deleted, because there are multiple files with the book's name, etc.).
This project uses:
- bun as a package manager
- vite as a bundler (because bun doesn't support CJS bundling)
- biome for linting and formatting
- hot-reload for simpler development
To develop the project:
- Clone this repo.
- Install bun, if needed.
- Install dependencies with
bun install
. - Start the development server with
bun dev
. - Format and lint (with autofixes) with
bun fix
.
I have not released this plugin and don't plan to. If you're interested in using this plugin, please install it via the excellent and community-maintained BRAT
Issues, PRs, and discussions are welcome.