Data Fetcher

by qf3l3k
5
4
3
2
1
Score: 55/100

Description

Category: 3rd Party Integrations

The Data Fetcher plugin enables Obsidian users to retrieve and display live data from external sources directly within their notes. It supports various data formats including REST APIs, GraphQL, and RPC-based endpoints, offering flexibility in how data is queried and presented. Users can either write custom queries inline within notes or configure reusable endpoints in the plugin settings. With built-in caching mechanisms, results can be stored and refreshed manually or automatically based on expiration settings, helping reduce redundant calls.

Reviews

No reviews yet.

Stats

21
stars
1,328
downloads
0
forks
394
days
7
days
7
days
8
total PRs
0
open PRs
0
closed PRs
8
merged PRs
7
total issues
0
open issues
7
closed issues
0
commits

Latest Version

8 days ago

Changelog

[1.2.0] - 2026-05-02

Added

  • Added Markdown template output with emplate: for alias and direct JSON queries.
  • Template placeholders support nested dot paths, for example {{owner.login}}.
  • Array responses render one template result per item, joined by new lines.
  • Added Test endpoint action in the endpoint editor to verify an unsaved endpoint draft without writing cache or frontmatter.

README file from

Github

Data Fetcher

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

License

MIT

Similar Plugins

info
• Similar plugins are suggested based on the common tags between the plugins.
API Designer
5 months ago by Ruveyda Yilmaz
A plugin for Obsidian that lets you design and document API endpoints visually without leaving your notes.
APIRequest
3 years ago by rooyca
Obsidian plugin that allows you to integrate API data into your notes with request caching, variable support, and precise JSON extraction.
File Publisher
3 years ago by Devin Sackett
Geocoding Properties
3 years ago by Jose Elias Alvarez
Insert address / location data from geocoding APIs as Obsidian properties.
JSON Importer
4 years ago by farling42
Plug-in for Obsidian.md which will create Notes from JSON files
JSON table
3 years ago by Dario Baumberger
Simply switch between JSON and tables in your Obsidian notes.
Latex Render
2 years ago by jvsteiner
An Obsidian plugin that renders `label` code blocks to `<svg>` for viewing in notes. Make sure to bring your own command!
Linear Integration
7 months ago by casals
Sync Linear (https://linear.app) issues with Obsidian notes. Create, update, and track Linear issues directly from your vault.
Local GraphQL
2 years ago by Hawtian Wang
Local REST API
4 years ago by Adam Coddington
Unlock your automation needs by interacting with your notes in Obsidian over a secure REST API.
Magiedit
a year ago by Matteo Gassend
Media DB Plugin
4 years ago by Moritz Jung
A plugin that can query multiple APIs for movies, series, anime, games, music and wiki articles, and import them into your vault.
Obsidian to Flomo
4 years ago by Xiaoyu Li
Quickly share content to Flomo.
OpenAPI Renderer
2 years ago by Sentiago
Integrate OpenAPI specification management into Obsidian with features for version control, visualization, editing, and easy navigation of API specs.
Oura Ring
5 years ago by Andrew Lombardi
Plugin to process data from Oura Ring
Ridian
a year ago by Michel Nivard
This is Ridian: R in Obsidian
SQLite DB
a year ago by Stefano Frigerio
Unofficial Fabric Integration
2 years ago by Chasebank87
Integrate fabric by danielmiessler/fabric into Obsidian
User Plugins
4 years ago by mnowotnik
Allows user scripts to use plugin API