# Obsidian Community Plugins & Themes Scraper (`crawlerbros/obsidian-plugin-scraper`) Actor

Scrape all Obsidian community plugins and CSS themes from the official obsidian-releases repository. Includes download stats, latest version, GitHub links, and more for 1700+ plugins.

- **URL**: https://apify.com/crawlerbros/obsidian-plugin-scraper.md
- **Developed by:** [Crawler Bros](https://apify.com/crawlerbros) (community)
- **Categories:** Automation, Developer tools
- **Stats:** 2 total users, 1 monthly users, 100.0% runs succeeded, NaN bookmarks
- **User rating**: No ratings yet

## Pricing

from $3.00 / 1,000 results

This Actor is paid per event and usage. You are charged both the fixed price for specific events and for Apify platform usage.
Since this Actor supports Apify Store discounts, the price gets lower the higher subscription plan you have.

Learn more: https://docs.apify.com/platform/actors/running/actors-in-store#pay-per-event

## What's an Apify Actor?

Actors are a software tools running on the Apify platform, for all kinds of web data extraction and automation use cases.
In Batch mode, an Actor accepts a well-defined JSON input, performs an action which can take anything from a few seconds to a few hours,
and optionally produces a well-defined JSON output, datasets with results, or files in key-value store.
In Standby mode, an Actor provides a web server which can be used as a website, API, or an MCP server.
Actors are written with capital "A".

## How to integrate an Actor?

If asked about integration, you help developers integrate Actors into their projects.
You adapt to their stack and deliver integrations that are safe, well-documented, and production-ready.
The best way to integrate Actors is as follows.

In JavaScript/TypeScript projects, use official [JavaScript/TypeScript client](https://docs.apify.com/api/client/js.md):

```bash
npm install apify-client
```

In Python projects, use official [Python client library](https://docs.apify.com/api/client/python.md):

```bash
pip install apify-client
```

In shell scripts, use [Apify CLI](https://docs.apify.com/cli/docs.md):

````bash
# MacOS / Linux
curl -fsSL https://apify.com/install-cli.sh | bash
# Windows
irm https://apify.com/install-cli.ps1 | iex
```bash

In AI frameworks, you might use the [Apify MCP server](https://docs.apify.com/platform/integrations/mcp.md).

If your project is in a different language, use the [REST API](https://docs.apify.com/api/v2.md).

For usage examples, see the [API](#api) section below.

For more details, see Apify documentation as [Markdown index](https://docs.apify.com/llms.txt) and [Markdown full-text](https://docs.apify.com/llms-full.txt).


# README

## Obsidian Community Plugins & Themes Scraper

Extract data on every community plugin and CSS theme from the official [Obsidian](https://obsidian.md/) releases repository. Get plugin names, authors, descriptions, total download counts, latest versions, GitHub links, and Obsidian marketplace URLs — all from a single actor run.

No authentication or API keys required. Data is sourced from the publicly available [obsidian-releases](https://github.com/obsidianmd/obsidian-releases) repository maintained by the Obsidian team.

### What you get

- **1,700+ community plugins** with download statistics, version history, and GitHub links
- **300+ community CSS themes** with screenshot URLs and supported color modes
- Clean, structured JSON output ready for analysis, dashboards, or integrations
- Optional text filtering and minimum-download thresholds

### Output fields

#### Plugins mode (default)

| Field | Type | Description |
|-------|------|-------------|
| `plugin_id` | string | Unique plugin identifier, e.g. `"obsidian-tasks-group"` |
| `name` | string | Display name, e.g. `"Tasks"` |
| `author` | string | Plugin author name |
| `description` | string | Short description of what the plugin does |
| `github_repo` | string | GitHub repository in `author/repo` format |
| `github_url` | string | Full GitHub URL, e.g. `https://github.com/obsidian-tasks-group/obsidian-tasks` |
| `total_downloads` | integer | Sum of all version download counts |
| `latest_version` | string | Most recently published version, e.g. `"7.0.1"` |
| `obsidian_url` | string | Obsidian marketplace URL, e.g. `https://obsidian.md/plugins?id=obsidian-tasks-group` |

#### Themes mode

| Field | Type | Description |
|-------|------|-------------|
| `name` | string | Theme display name |
| `author` | string | Theme author name |
| `github_repo` | string | GitHub repository in `author/repo` format |
| `github_url` | string | Full GitHub URL |
| `screenshot_url` | string | Direct URL to the theme screenshot image |
| `supported_modes` | array | Color modes supported, e.g. `["light", "dark"]` |

### Input options

| Field | Type | Default | Description |
|-------|------|---------|-------------|
| `mode` | select | `plugins` | What to scrape: `"plugins"` or `"themes"` |
| `query` | string | — | Case-insensitive text filter applied to name, description, and author |
| `minDownloads` | integer | — | Minimum total downloads required (plugins mode only) |
| `maxItems` | integer | `500` | Maximum number of records to return |

### Example inputs

**Get the top 50 most-downloaded plugins:**
```json
{
  "mode": "plugins",
  "minDownloads": 100000,
  "maxItems": 50
}
````

**Search for all task-management plugins:**

```json
{
  "mode": "plugins",
  "query": "task",
  "maxItems": 100
}
```

**Get all community themes:**

```json
{
  "mode": "themes",
  "maxItems": 500
}
```

**Get all dark themes:**

```json
{
  "mode": "themes",
  "query": "dark",
  "maxItems": 200
}
```

### Example output (plugins mode)

```json
{
  "plugin_id": "obsidian-tasks-group",
  "name": "Tasks",
  "author": "Clare Macrae and Ilya Paranin",
  "description": "Track tasks across your entire vault. Query them and mark them done.",
  "github_repo": "obsidian-tasks-group/obsidian-tasks",
  "github_url": "https://github.com/obsidian-tasks-group/obsidian-tasks",
  "total_downloads": 2150000,
  "latest_version": "7.0.1",
  "obsidian_url": "https://obsidian.md/plugins?id=obsidian-tasks-group",
  "recordType": "plugin",
  "scrapedAt": "2026-01-15T10:30:00+00:00"
}
```

### Use cases

- **Plugin discovery** — Find the most popular or niche plugins for a specific workflow
- **Download trend tracking** — Monitor which plugins are gaining traction
- **Developer research** — Identify feature gaps or competitive landscape in the plugin ecosystem
- **Documentation and blogs** — Build curated plugin lists or "best of" articles
- **Obsidian-based products** — Power recommendation engines or plugin directories
- **Data analysis** — Analyze the Obsidian ecosystem, author productivity, and version release cadence

### Data source

All data comes from the official [obsidian-releases](https://github.com/obsidianmd/obsidian-releases) GitHub repository maintained by Obsidian, Inc. This repository is the single source of truth for community plugins and themes listed in the in-app Community Plugins browser.

- Plugin list: `community-plugins.json`
- Download statistics: `community-plugin-stats.json`
- Theme list: `community-css-themes.json`

Data is publicly accessible with no authentication, rate limits, or terms-of-service restrictions beyond GitHub's standard acceptable use policy.

### FAQ

**How current is the data?**
The actor fetches data directly from GitHub on every run, so results always reflect the latest published state of the repository. Obsidian's team typically updates the files within hours of a plugin approval or stats refresh.

**How are total downloads calculated?**
Total downloads are computed by summing all per-version download counts from the stats file. The special `"latest"` key (which is a version alias, not a separate count) is excluded from the sum.

**Why is `latest_version` missing for some plugins?**
A small number of plugins appear in the plugin list but have no entry in the stats file (usually very newly added plugins). For these, `latest_version` is omitted from the output rather than populated with a null value.

**Can I filter by author or specific plugin ID?**
Use the `query` field to filter by any text appearing in the plugin name, description, or author name. For example, `"query": "blacksmithgu"` returns all plugins by that author.

**What is the maximum number of results?**
The `maxItems` field accepts up to 10,000. The full plugin catalog is approximately 1,700–1,800 entries; set `maxItems` to 2000 to ensure you get everything.

**Does this actor require a proxy or cookies?**
No. GitHub raw content is publicly accessible with standard HTTP requests. No proxy, cookies, or API keys are needed.

# Actor input Schema

## `mode` (type: `string`):

What to fetch: community plugins (with download stats) or community CSS themes.

## `query` (type: `string`):

Case-insensitive substring filter applied to plugin/theme name and description. Leave blank to return all.

## `minDownloads` (type: `integer`):

Only return plugins with at least this many total downloads. Ignored in themes mode.

## `maxItems` (type: `integer`):

Hard cap on the number of records returned.

## Actor input object example

```json
{
  "mode": "plugins",
  "maxItems": 500
}
```

# Actor output Schema

## `results` (type: `string`):

Dataset containing all scraped Obsidian community plugins or themes.

# API

You can run this Actor programmatically using our API. Below are code examples in JavaScript, Python, and CLI, as well as the OpenAPI specification and MCP server setup.

## JavaScript example

```javascript
import { ApifyClient } from 'apify-client';

// Initialize the ApifyClient with your Apify API token
// Replace the '<YOUR_API_TOKEN>' with your token
const client = new ApifyClient({
    token: '<YOUR_API_TOKEN>',
});

// Prepare Actor input
const input = {
    "mode": "plugins",
    "maxItems": 500
};

// Run the Actor and wait for it to finish
const run = await client.actor("crawlerbros/obsidian-plugin-scraper").call(input);

// Fetch and print Actor results from the run's dataset (if any)
console.log('Results from dataset');
console.log(`💾 Check your data here: https://console.apify.com/storage/datasets/${run.defaultDatasetId}`);
const { items } = await client.dataset(run.defaultDatasetId).listItems();
items.forEach((item) => {
    console.dir(item);
});

// 📚 Want to learn more 📖? Go to → https://docs.apify.com/api/client/js/docs

```

## Python example

```python
from apify_client import ApifyClient

# Initialize the ApifyClient with your Apify API token
# Replace '<YOUR_API_TOKEN>' with your token.
client = ApifyClient("<YOUR_API_TOKEN>")

# Prepare the Actor input
run_input = {
    "mode": "plugins",
    "maxItems": 500,
}

# Run the Actor and wait for it to finish
run = client.actor("crawlerbros/obsidian-plugin-scraper").call(run_input=run_input)

# Fetch and print Actor results from the run's dataset (if there are any)
print("💾 Check your data here: https://console.apify.com/storage/datasets/" + run["defaultDatasetId"])
for item in client.dataset(run["defaultDatasetId"]).iterate_items():
    print(item)

# 📚 Want to learn more 📖? Go to → https://docs.apify.com/api/client/python/docs/quick-start

```

## CLI example

```bash
echo '{
  "mode": "plugins",
  "maxItems": 500
}' |
apify call crawlerbros/obsidian-plugin-scraper --silent --output-dataset

```

## MCP server setup

```json
{
    "mcpServers": {
        "apify": {
            "command": "npx",
            "args": [
                "mcp-remote",
                "https://mcp.apify.com/?tools=crawlerbros/obsidian-plugin-scraper",
                "--header",
                "Authorization: Bearer <YOUR_API_TOKEN>"
            ]
        }
    }
}

```

## OpenAPI specification

```json
{
    "openapi": "3.0.1",
    "info": {
        "title": "Obsidian Community Plugins & Themes Scraper",
        "description": "Scrape all Obsidian community plugins and CSS themes from the official obsidian-releases repository. Includes download stats, latest version, GitHub links, and more for 1700+ plugins.",
        "version": "1.0",
        "x-build-id": "5SoBrejHKZKYaVXLX"
    },
    "servers": [
        {
            "url": "https://api.apify.com/v2"
        }
    ],
    "paths": {
        "/acts/crawlerbros~obsidian-plugin-scraper/run-sync-get-dataset-items": {
            "post": {
                "operationId": "run-sync-get-dataset-items-crawlerbros-obsidian-plugin-scraper",
                "x-openai-isConsequential": false,
                "summary": "Executes an Actor, waits for its completion, and returns Actor's dataset items in response.",
                "tags": [
                    "Run Actor"
                ],
                "requestBody": {
                    "required": true,
                    "content": {
                        "application/json": {
                            "schema": {
                                "$ref": "#/components/schemas/inputSchema"
                            }
                        }
                    }
                },
                "parameters": [
                    {
                        "name": "token",
                        "in": "query",
                        "required": true,
                        "schema": {
                            "type": "string"
                        },
                        "description": "Enter your Apify token here"
                    }
                ],
                "responses": {
                    "200": {
                        "description": "OK"
                    }
                }
            }
        },
        "/acts/crawlerbros~obsidian-plugin-scraper/runs": {
            "post": {
                "operationId": "runs-sync-crawlerbros-obsidian-plugin-scraper",
                "x-openai-isConsequential": false,
                "summary": "Executes an Actor and returns information about the initiated run in response.",
                "tags": [
                    "Run Actor"
                ],
                "requestBody": {
                    "required": true,
                    "content": {
                        "application/json": {
                            "schema": {
                                "$ref": "#/components/schemas/inputSchema"
                            }
                        }
                    }
                },
                "parameters": [
                    {
                        "name": "token",
                        "in": "query",
                        "required": true,
                        "schema": {
                            "type": "string"
                        },
                        "description": "Enter your Apify token here"
                    }
                ],
                "responses": {
                    "200": {
                        "description": "OK",
                        "content": {
                            "application/json": {
                                "schema": {
                                    "$ref": "#/components/schemas/runsResponseSchema"
                                }
                            }
                        }
                    }
                }
            }
        },
        "/acts/crawlerbros~obsidian-plugin-scraper/run-sync": {
            "post": {
                "operationId": "run-sync-crawlerbros-obsidian-plugin-scraper",
                "x-openai-isConsequential": false,
                "summary": "Executes an Actor, waits for completion, and returns the OUTPUT from Key-value store in response.",
                "tags": [
                    "Run Actor"
                ],
                "requestBody": {
                    "required": true,
                    "content": {
                        "application/json": {
                            "schema": {
                                "$ref": "#/components/schemas/inputSchema"
                            }
                        }
                    }
                },
                "parameters": [
                    {
                        "name": "token",
                        "in": "query",
                        "required": true,
                        "schema": {
                            "type": "string"
                        },
                        "description": "Enter your Apify token here"
                    }
                ],
                "responses": {
                    "200": {
                        "description": "OK"
                    }
                }
            }
        }
    },
    "components": {
        "schemas": {
            "inputSchema": {
                "type": "object",
                "required": [
                    "mode"
                ],
                "properties": {
                    "mode": {
                        "title": "Mode",
                        "enum": [
                            "plugins",
                            "themes"
                        ],
                        "type": "string",
                        "description": "What to fetch: community plugins (with download stats) or community CSS themes.",
                        "default": "plugins"
                    },
                    "query": {
                        "title": "Filter query",
                        "type": "string",
                        "description": "Case-insensitive substring filter applied to plugin/theme name and description. Leave blank to return all."
                    },
                    "minDownloads": {
                        "title": "Min total downloads (plugins only)",
                        "minimum": 0,
                        "maximum": 100000000,
                        "type": "integer",
                        "description": "Only return plugins with at least this many total downloads. Ignored in themes mode."
                    },
                    "maxItems": {
                        "title": "Max items",
                        "minimum": 1,
                        "maximum": 10000,
                        "type": "integer",
                        "description": "Hard cap on the number of records returned.",
                        "default": 500
                    }
                }
            },
            "runsResponseSchema": {
                "type": "object",
                "properties": {
                    "data": {
                        "type": "object",
                        "properties": {
                            "id": {
                                "type": "string"
                            },
                            "actId": {
                                "type": "string"
                            },
                            "userId": {
                                "type": "string"
                            },
                            "startedAt": {
                                "type": "string",
                                "format": "date-time",
                                "example": "2025-01-08T00:00:00.000Z"
                            },
                            "finishedAt": {
                                "type": "string",
                                "format": "date-time",
                                "example": "2025-01-08T00:00:00.000Z"
                            },
                            "status": {
                                "type": "string",
                                "example": "READY"
                            },
                            "meta": {
                                "type": "object",
                                "properties": {
                                    "origin": {
                                        "type": "string",
                                        "example": "API"
                                    },
                                    "userAgent": {
                                        "type": "string"
                                    }
                                }
                            },
                            "stats": {
                                "type": "object",
                                "properties": {
                                    "inputBodyLen": {
                                        "type": "integer",
                                        "example": 2000
                                    },
                                    "rebootCount": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "restartCount": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "resurrectCount": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "computeUnits": {
                                        "type": "integer",
                                        "example": 0
                                    }
                                }
                            },
                            "options": {
                                "type": "object",
                                "properties": {
                                    "build": {
                                        "type": "string",
                                        "example": "latest"
                                    },
                                    "timeoutSecs": {
                                        "type": "integer",
                                        "example": 300
                                    },
                                    "memoryMbytes": {
                                        "type": "integer",
                                        "example": 1024
                                    },
                                    "diskMbytes": {
                                        "type": "integer",
                                        "example": 2048
                                    }
                                }
                            },
                            "buildId": {
                                "type": "string"
                            },
                            "defaultKeyValueStoreId": {
                                "type": "string"
                            },
                            "defaultDatasetId": {
                                "type": "string"
                            },
                            "defaultRequestQueueId": {
                                "type": "string"
                            },
                            "buildNumber": {
                                "type": "string",
                                "example": "1.0.0"
                            },
                            "containerUrl": {
                                "type": "string"
                            },
                            "usage": {
                                "type": "object",
                                "properties": {
                                    "ACTOR_COMPUTE_UNITS": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "DATASET_READS": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "DATASET_WRITES": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "KEY_VALUE_STORE_READS": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "KEY_VALUE_STORE_WRITES": {
                                        "type": "integer",
                                        "example": 1
                                    },
                                    "KEY_VALUE_STORE_LISTS": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "REQUEST_QUEUE_READS": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "REQUEST_QUEUE_WRITES": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "DATA_TRANSFER_INTERNAL_GBYTES": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "DATA_TRANSFER_EXTERNAL_GBYTES": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "PROXY_RESIDENTIAL_TRANSFER_GBYTES": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "PROXY_SERPS": {
                                        "type": "integer",
                                        "example": 0
                                    }
                                }
                            },
                            "usageTotalUsd": {
                                "type": "number",
                                "example": 0.00005
                            },
                            "usageUsd": {
                                "type": "object",
                                "properties": {
                                    "ACTOR_COMPUTE_UNITS": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "DATASET_READS": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "DATASET_WRITES": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "KEY_VALUE_STORE_READS": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "KEY_VALUE_STORE_WRITES": {
                                        "type": "number",
                                        "example": 0.00005
                                    },
                                    "KEY_VALUE_STORE_LISTS": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "REQUEST_QUEUE_READS": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "REQUEST_QUEUE_WRITES": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "DATA_TRANSFER_INTERNAL_GBYTES": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "DATA_TRANSFER_EXTERNAL_GBYTES": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "PROXY_RESIDENTIAL_TRANSFER_GBYTES": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "PROXY_SERPS": {
                                        "type": "integer",
                                        "example": 0
                                    }
                                }
                            }
                        }
                    }
                }
            }
        }
    }
}
```
