qf3l3k1k downloadsFetch data from multiple sources (REST APIs, RPC, gRPC, GraphQL) and insert results into notes
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.
data-query blocks in the active note.Settings -> Community Plugins in Obsidian.Data Fetcher.manifest.json, main.js, and styles.css from the latest GitHub release..obsidian/plugins/data-fetcher in your vault.Data Fetcher.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.
For repeated use, configure endpoints in Settings -> Data Fetcher and reference them by alias.
Example endpoint:
github-reposRESThttps://api.github.com/users/octocat/reposGETThen use it in a note:
@github-repos
path: 0
template: First repo: [{{name}}]({{html_url}})
Endpoint settings support:
Header exports are disabled by default so API keys and tokens are not accidentally shared.
{
"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.
{
"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.
{
"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.
{
"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.
pathUse dot notation to select nested response data:
@github-repos
path: 0.owner.login
Paths can include array indexes, for example items.0.name.
JSON is the default output format:
@github-repos
path: 0
format: json
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.
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.{{value}}.template takes precedence over format: table.Use output: frontmatter to write selected data into note properties:
@github-repos
path: 0.name
output: frontmatter
property: external.firstRepo
Notes:
property is required.external.github.firstRepo.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.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.Data Fetcher stores cached responses in .data-fetcher-cache in the vault root.
In settings, you can:
The cache browser can:
Endpoint configurations can be exported to JSON and imported on another device.
Export behavior:
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.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.path.property is required when output: frontmatter is used: add a property value.Response too large for this device: reduce payload size, add filters/limits, or use a proxy endpoint.This plugin communicates with external services and stores response data locally.
requestUrl API..data-fetcher-cache.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.
MIT