Search...Search plugins and themes...
⌘K
Sign in
  • Get started
  • Download
  • Pricing
  • Enterprise
  • Account
  • Obsidian
  • Overview
  • Sync
  • Publish
  • Canvas
  • Mobile
  • Web Clipper
  • CLI
  • Learn
  • Help
  • Developers
  • Changelog
  • About
  • Roadmap
  • Blog
  • Resources
  • System status
  • License overview
  • Terms of service
  • Privacy policy
  • Security
  • Community
  • Plugins
  • Join the community
  • Discord
  • Forum / 中文论坛
  • Merch store
  • Brand guidelines
Follow us
DiscordTwitterBlueskyThreadsMastodonYouTubeGitHub
© 2026 Obsidian

Data Fetcher

qf3l3kqf3l3k1k downloads

Fetch data from multiple sources (REST APIs, RPC, gRPC, GraphQL) and insert results into notes

Add to Obsidian
  • Overview
  • Scorecard
  • Updates17

Data Fetcher is an Obsidian plugin that fetches data from external endpoints and renders it directly inside notes.

Use it to query REST APIs, GraphQL endpoints, JSON-RPC APIs, or gRPC-style HTTP proxy endpoints from data-query code blocks. Results can be rendered as JSON, tables, Markdown templates, copied to clipboard, saved into the note, cached, or written into note frontmatter.

Features

  • Query REST, GraphQL, RPC, and gRPC-style HTTP proxy endpoints.
  • Use direct JSON requests or reusable endpoint aliases from plugin settings.
  • Configure custom headers for authenticated APIs.
  • Test endpoint configuration before saving it.
  • Shape output with dot-path selection.
  • Render output as JSON, table, or Markdown template.
  • Write selected values into note frontmatter/properties.
  • Cache responses with configurable expiration.
  • Browse, preview, filter, delete, or clear cached responses.
  • Refresh one rendered block or all data-query blocks in the active note.
  • Copy rendered output or save it as static Markdown in the current note.
  • Import/export endpoint aliases between devices, with headers excluded by default.

Installation

Community Plugins

  1. Open Settings -> Community Plugins in Obsidian.
  2. Search for Data Fetcher.
  3. Install and enable the plugin.

Manual Install

  1. Download manifest.json, main.js, and styles.css from the latest GitHub release.
  2. Copy those files into .obsidian/plugins/data-fetcher in your vault.
  3. Reload Obsidian and enable Data Fetcher.

Quick Start

Create a fenced code block with language data-query:

{
  "type": "rest",
  "url": "https://api.github.com/users/octocat/repos",
  "method": "GET",
  "path": "0",
  "template": "First repo: [{{name}}]({{html_url}})"
}

When the note is rendered, Data Fetcher executes the request, caches the response, and renders the selected output below the block.

Endpoint Aliases

For repeated use, configure endpoints in Settings -> Data Fetcher and reference them by alias.

Example endpoint:

  • Alias: github-repos
  • Type: REST
  • URL: https://api.github.com/users/octocat/repos
  • Method: GET

Then use it in a note:

@github-repos
path: 0
template: First repo: [{{name}}]({{html_url}})

Endpoint settings support:

  • Alias, type, URL, method, and headers.
  • Compact endpoint list with filtering by alias, type, or URL.
  • Edit, duplicate, and delete actions.
  • Endpoint test button in the add/edit dialog.
  • Import/export for moving endpoint lists between devices.

Header exports are disabled by default so API keys and tokens are not accidentally shared.

Query Types

REST

{
  "type": "rest",
  "url": "https://api.example.com/items",
  "method": "GET",
  "headers": {
    "Authorization": "Bearer your-token"
  }
}

REST supports GET, POST, PUT, and DELETE. Use body for request payloads.

GraphQL

{
  "type": "graphql",
  "url": "https://api.example.com/graphql",
  "query": "query($first: Int) { viewer { repositories(first: $first) { nodes { name url } } } }",
  "variables": {
    "first": 5
  },
  "path": "data.viewer.repositories.nodes",
  "format": "table"
}

With an alias, inline variables can be passed at the call site:

@github-api({"first": 5})
query: query($first: Int) { viewer { repositories(first: $first) { nodes { name url } } } }
path: viewer.repositories.nodes
format: table

=@alias({...}) is also supported for inline-style calls.

RPC / JSON-RPC

{
  "type": "rpc",
  "url": "https://rpc.example.com",
  "query": "status",
  "body": {}
}

RPC requests are sent as JSON-RPC-style POST requests. query is used as the RPC method name and body is used as params.

gRPC via HTTP Proxy

{
  "type": "grpc",
  "url": "https://proxy.example.com/my.Service/GetItem",
  "body": {
    "id": "123"
  }
}

Obsidian does not provide native gRPC transport. This mode is intended for gRPC services exposed through an HTTP/JSON proxy.

Output Options

Select Data With path

Use dot notation to select nested response data:

@github-repos
path: 0.owner.login

Paths can include array indexes, for example items.0.name.

Render as JSON

JSON is the default output format:

@github-repos
path: 0
format: json

Render as a Table

Tables work best with arrays of objects:

@github-repos
path: data
format: table

If table rendering cannot find an array of objects, the plugin falls back to JSON output.

Render With a Markdown Template

Templates turn API data into note-ready Markdown:

@github-repos
path: data
template: - [{{name}}]({{html_url}}) by {{owner.login}}

Template rules:

  • {{field}} inserts a field from the selected object.
  • {{owner.login}} supports nested fields.
  • Missing values render as empty strings.
  • Arrays render one template result per item, joined with new lines.
  • Primitive values can be referenced with {{value}}.
  • template takes precedence over format: table.

Write to Frontmatter

Use output: frontmatter to write selected data into note properties:

@github-repos
path: 0.name
output: frontmatter
property: external.firstRepo

Notes:

  • property is required.
  • Dot-path properties are supported, for example external.github.firstRepo.
  • Frontmatter writes use raw selected data, not rendered template text.
  • Cached render results do not write frontmatter; fresh fetches and manual refreshes do.

Rendered Block Actions

Each rendered result includes:

  • Refresh: reruns the query and updates the cache.
  • Copy: copies the rendered output.
  • Save to Note: inserts/replaces static Markdown output in the current note.

Commands

Data Fetcher adds these commands:

  • Refresh data query: refresh all data-query blocks in the active note.
  • Open cache browser: inspect and manage cached responses.

Cache Management

Data Fetcher stores cached responses in .data-fetcher-cache in the vault root.

In settings, you can:

  • Set cache duration in minutes.
  • Clear all cached responses.
  • Open the cache browser.
  • Enable an optional ribbon icon for quick cache browser access.

The cache browser can:

  • List cached entries with alias-aware labels, size, date, type, and URL.
  • Filter entries by alias, hash, type, or URL.
  • Preview cached payloads.
  • Delete individual entries.
  • Clear all entries.

Import and Export

Endpoint configurations can be exported to JSON and imported on another device.

Export behavior:

  • Headers are excluded by default.
  • Enable Include headers only when you intentionally want to export secrets such as Authorization tokens.

Import behavior:

  • Merge updates matching aliases and adds new ones.
  • Replace overwrites the current endpoint list.
  • Invalid or duplicate entries are skipped with a summary.

Troubleshooting

  • Endpoint alias "..." not found: add the alias in settings or fix the alias name in the note.
  • Variables must be valid JSON: use valid JSON, for example {"first": 5}.
  • Path "..." not found: verify the response shape and the selected path.
  • Table format requires an array of objects: point path at an array of objects or use JSON/template output.
  • Blank template placeholders: check field names against the data selected by path.
  • property is required when output: frontmatter is used: add a property value.
  • GraphQL endpoint test fails with missing query: endpoint testing checks the saved endpoint draft; run complete GraphQL queries from a note block.
  • Response too large for this device: reduce payload size, add filters/limits, or use a proxy endpoint.
  • No command refresh happens: make sure the active pane is a Markdown note.

Privacy and Data Disclosure

This plugin communicates with external services and stores response data locally.

  • Network usage: sends HTTP(S) requests to endpoints configured in notes or settings.
  • External dependency: uses Obsidian's built-in requestUrl API.
  • Data sent: URL, method, headers, body, query, and variables you configure.
  • Data stored locally: plugin settings and cached responses in .data-fetcher-cache.
  • Data shared externally: only with endpoints you configure.

Development

Build:

npm install
npm run build

Watch mode:

npm run dev

Test in a vault by linking or copying plugin files to .obsidian/plugins/data-fetcher.

Support

  • Issues and feature requests: GitHub Issues

License

MIT

79%
HealthExcellent
ReviewCaution
About
Run REST, GraphQL, RPC or gRPC-style requests and render responses inline using data-query code blocks. Manage endpoint aliases and headers, cache results with expiration and a cache browser, refresh individual or all queries, and copy or save responses.
DataIntegrationsJSON
Details
Current version
1.2.0
Last updated
Last week
Created
Last year
Updates
17 releases
Downloads
1k
Compatible with
Obsidian 1.8.3+
License
MIT
Report bugRequest featureReport plugin
Sponsor
Buy Me a Coffee
Author
qf3l3kqf3l3k
github.com/qf3l3k
GitHubqf3l3k
  1. Community
  2. Plugins
  3. Data
  4. Data Fetcher

Related plugins

BRAT

Easily install a beta version of a plugin for testing.

Tracker

Track occurrences and numbers in your notes.

Zotero Integration

Insert and import citations, bibliographies, notes, and PDF annotations from Zotero.

Maps

Adds a map layout to bases so you can display notes as an interactive map view.

Smart Composer

AI chat with note context, smart writing assistance, and one-click edits for your vault.

LanguageTool Integration

advanced spell/grammar checks with the help of language-tool.

Readwise Official

Sync highlights from Readwise to your vault.

Datacore

An even faster reactive query engine for the data obsessed.

MCP Tools

Securely connect Claude Desktop to your vault with semantic search, templates, and file management capabilities.

Reminder

Manage Markdown TODOs with reminder.