Rank
83
A Model Context Protocol (MCP) server for GitLab
Traction
No public download signal
Freshness
Updated 2d ago
Crawler Summary
API for downloading subtitles from YouTube videos <div align="center"> <img src="./logo.webp" alt="transcriptor-mcp logo" width="160" /> <h1>Transcriptor MCP</h1> <p> <a href="https://smithery.ai/servers/samson-art/transcriptor-mcp"><img alt="smithery" src="https://smithery.ai/badge/samson-art/transcriptor-mcp" /></a> <a href="https://github.com/samson-art/transcriptor-mcp/releases"><img alt="version" src="https://img.shields.io/github/v/release/samson-art/transcrip Capability contract not published. No trust telemetry is available yet. 1 GitHub stars reported by the source. Last updated 2/25/2026.
Freshness
Last checked 2/25/2026
Best For
transcriptor-mcp is best for youtube, subtitles, captions workflows where MCP compatibility matters.
Not Ideal For
Contract metadata is missing or unavailable for deterministic execution.
Evidence Sources Checked
editorial-content, GITHUB MCP, runtime-metrics, public facts pack
API for downloading subtitles from YouTube videos <div align="center"> <img src="./logo.webp" alt="transcriptor-mcp logo" width="160" /> <h1>Transcriptor MCP</h1> <p> <a href="https://smithery.ai/servers/samson-art/transcriptor-mcp"><img alt="smithery" src="https://smithery.ai/badge/samson-art/transcriptor-mcp" /></a> <a href="https://github.com/samson-art/transcriptor-mcp/releases"><img alt="version" src="https://img.shields.io/github/v/release/samson-art/transcrip
Public facts
5
Change events
1
Artifacts
0
Freshness
Feb 25, 2026
Capability contract not published. No trust telemetry is available yet. 1 GitHub stars reported by the source. Last updated 2/25/2026.
Trust score
Unknown
Compatibility
MCP
Freshness
Feb 25, 2026
Vendor
Samson Art
Artifacts
0
Benchmarks
0
Last release
0.6.4
Key links, install path, and a quick operational read before the deeper crawl record.
Summary
Capability contract not published. No trust telemetry is available yet. 1 GitHub stars reported by the source. Last updated 2/25/2026.
Setup snapshot
git clone https://github.com/samson-art/transcriptor-mcp.gitSetup complexity is MEDIUM. Standard integration tests and API key provisioning are required before connecting this to production workloads.
Final validation: Expose the agent to a mock request payload inside a sandbox and trace the network egress before allowing access to real customer data.
Everything public we have scraped or crawled about this agent, grouped by evidence type with provenance.
Vendor
Samson Art
Protocol compatibility
MCP
Adoption signal
1 GitHub stars
Handshake status
UNKNOWN
Crawlable docs
6 indexed pages on the official domain
Merged public release, docs, artifact, benchmark, pricing, and trust refresh events.
Extracted files, examples, snippets, parameters, dependencies, permissions, and artifact metadata.
Extracted files
0
Examples
6
Snippets
0
Languages
typescript
json
{
"authToken": "your-token-from-server-admin"
}bash
docker run --rm -i artsamsonov/transcriptor-mcp:latest
json
{
"mcpServers": {
"transcriptor": {
"command": "docker",
"args": ["run", "--rm", "-i", "artsamsonov/transcriptor-mcp:latest"]
}
}
}bash
cp docker-compose.example.yml docker-compose.yml docker compose up -d transcriptor-mcp
bash
claude mcp add --transport http transcriptor http://<tailscale-host>:4200/mcp
bash
docker build -t transcriptor-mcp-api -f Dockerfile --target api .
Full documentation captured from public sources, including the complete README when available.
Docs source
GITHUB MCP
Editorial quality
ready
API for downloading subtitles from YouTube videos <div align="center"> <img src="./logo.webp" alt="transcriptor-mcp logo" width="160" /> <h1>Transcriptor MCP</h1> <p> <a href="https://smithery.ai/servers/samson-art/transcriptor-mcp"><img alt="smithery" src="https://smithery.ai/badge/samson-art/transcriptor-mcp" /></a> <a href="https://github.com/samson-art/transcriptor-mcp/releases"><img alt="version" src="https://img.shields.io/github/v/release/samson-art/transcrip
This repository primarily ships an MCP server:
It also includes an optional REST API (Fastify), but MCP is the primary focus.
Transcriptor MCP is the best choice when you need transcripts and metadata for AI, summarization, or content analysis — without downloading video or audio files:
See docs for step-by-step use cases: summarize video, search and transcript, IDE/Cursor/Claude, n8n automation, researchers and batch, and self-hosted/enterprise.
1. Connect via Smithery (recommended) — no Docker or Node required.
Add the MCP server by URL in your client (Cursor, Claude Code, etc.):
https://server.smithery.ai/samson-art/transcriptor-mcpFor one-click install in VS Code:
No config needed for the public instance. Use tools like get_transcript or get_video_info right away.
Optional config (only when the server requires auth):
{
"authToken": "your-token-from-server-admin"
}
2. Docker (stdio) — run locally: see MCP quick start (recommended) below.
3. Local Node — build and run node dist/mcp.js; see MCP Server (stdio) below.
CHANGELOG.md).Below is a real-world example of the same “summarize YouTube video” task without MCP vs with MCP:
<picture> <source srcset="./example-usage.webp" type="image/webp" /> <img src="./example-usage.webp" alt="Example usage: without MCP vs with MCP" /> </picture>For one-click connection without installing anything, use the Smithery URL above. The sections below are for Docker or your own server.
artsamsonov/transcriptor-mcp:latestRun locally (stdio mode):
docker run --rm -i artsamsonov/transcriptor-mcp:latest
Add to Cursor MCP settings (or create .cursor/mcp.json):
{
"mcpServers": {
"transcriptor": {
"command": "docker",
"args": ["run", "--rm", "-i", "artsamsonov/transcriptor-mcp:latest"]
}
}
}
Run the HTTP/SSE MCP server on your VPS (default port 4200) using docker-compose:
cp docker-compose.example.yml docker-compose.yml
docker compose up -d transcriptor-mcp
Claude Code (HTTP / streamable HTTP):
claude mcp add --transport http transcriptor http://<tailscale-host>:4200/mcp
Cursor (SSE):
http://<tailscale-host>:4200/sseIf you set MCP_AUTH_TOKEN, add Authorization: Bearer <token> in the client headers.
For more MCP configuration examples, see docs/quick-start.mcp.md.
n8n MCP Client (streamable HTTP):
http://<host>:4200/mcp (streamable HTTP transport).X-Forwarded-For, set N8N_PROXY_HOPS
to the number of proxy hops (commonly 1) to avoid ERR_ERL_UNEXPECTED_X_FORWARDED_FOR.get_transcript: cleaned plain text subtitles (URL only; first chunk, default size)get_raw_subtitles: raw SRT/VTT (paginated)get_available_subtitles: list official vs auto language codesget_video_info: extended metadata (title, channel, tags, thumbnails, views, etc.)get_video_chapters: chapter markers with start/end time and titlesearch_videos: search YouTube (query, optional limit, offset, uploadDateFilter, response_format)All URL-based tools share the same base input:
url (string, required) – Video URL from a supported platform or YouTube video ID. Supported: YouTube, Twitter/X, Instagram, TikTok, Twitch, Vimeo, Facebook, Bilibili, VK, Dailymotion.get_raw_subtitles supports pagination; get_transcript returns the first chunk only (no pagination input). Pagination parameters for get_raw_subtitles:
response_limit (number, optional) – max characters per response, default 50000, min 1000, max 200000.next_cursor (string, optional) – opaque offset returned from the previous page; pass it to fetch the next chunk.Each tool returns:
content – human-readable text (for MCP chat UIs).structuredContent – strongly typed JSON payload you can consume from automations or code.get_transcriptPurpose: Fetch cleaned subtitles as plain text (no timestamps, HTML, or speaker metadata).
Input: Only url (video URL or ID). Type and language are auto-discovered; the tool returns the first chunk with default size (no pagination parameters).
Structured response:
videoId – resolved YouTube ID.type, lang – effective subtitle type and language.text – current text chunk.is_truncated – true if more text is available.total_length – total length of the full transcript.start_offset, end_offset – character offsets of this chunk.next_cursor – present in response when truncated (omitted on the last page). Not accepted as input for this tool.get_raw_subtitlesPurpose: Fetch raw subtitle file content (SRT or VTT) with pagination support.
Extra input fields:
type – "official" or "auto", optional.lang – subtitle language code, optional.response_limit, next_cursor – pagination (optional).Structured response:
videoId, type, lang – same semantics as above.format – "srt" or "vtt" (auto-detected from content).content – raw subtitle text for this page.is_truncated, total_length, start_offset, end_offset, next_cursor – same pagination fields as get_transcript.get_available_subtitlesPurpose: Inspect which languages are available for a video, split into official vs auto-generated tracks.
Input:
url – YouTube URL or video ID.Structured response:
videoId – resolved YouTube ID.official – sorted list of language codes with official subtitles.auto – sorted list of language codes with auto-generated subtitles.This is useful to first discover languages and then pick type/lang for get_raw_subtitles (or other tools).
get_video_infoPurpose: Fetch extended metadata about a video (based on yt-dlp JSON output).
Input:
url – YouTube URL or video ID.Structured response (key fields):
videoId – resolved YouTube ID.title, description.uploader, uploaderId.channel, channelId, channelUrl.duration – in seconds.uploadDate – YYYYMMDD string if available.webpageUrl.viewCount, likeCount, commentCount.tags, categories.liveStatus, isLive, wasLive, availability.thumbnail – primary thumbnail URL.thumbnails – list of thumbnail variants { url, width?, height?, id? }.See src/mcp-core.ts and src/youtube.ts for the full JSON schema used by the MCP SDK.
get_video_chaptersPurpose: Get chapter markers extracted by yt-dlp.
Input:
url – YouTube URL or video ID.Structured response:
videoId – resolved YouTube ID.chapters – array of { startTime: number; endTime: number; title: string }.If the video has no chapters, chapters is an empty array; if yt-dlp cannot fetch chapter data at all, the tool returns an MCP error instead of structured chapters.
search_videosPurpose: Search videos on YouTube via yt-dlp (ytsearch). Returns a list of videos with metadata.
Input:
query (string, required) – Search query.limit (number, optional) – Max results (default 10, max 50).offset (number, optional) – Skip first N results (pagination).uploadDateFilter (string, optional) – Filter by upload date: hour, today, week, month, or year.response_format (string, optional) – Human-readable format: json (default) or markdown.Structured response:
results – array of { videoId, title, url, duration, uploader, viewCount, thumbnail }.The repository also ships an HTTP API (Fastify).
Build the image:
docker build -t transcriptor-mcp-api -f Dockerfile --target api .
Run on the default port:
docker run -p 3000:3000 transcriptor-mcp-api
For a more complete REST quick start (including docker-compose and local Node.js),
see docs/quick-start.rest.md.
Once the REST API is running, interactive API docs are available at:
http://localhost:3000/docs
If you change PORT / HOST, adjust the URL accordingly, e.g. http://<HOST>:<PORT>/docs.
If yt-dlp is blocked by age gate, sign-in, or region restrictions, you will likely need
an authenticated cookies.txt file and the COOKIES_FILE_PATH environment variable.
The root of this repository includes a sample cookies.example.txt
showing the expected Netscape cookies format. For a full guide on:
see docs/cookies.md.
docker run -d -p 3000:3000 --name transcriptor transcriptor-mcp-api
Before publishing Docker images, you can run a small e2e smoke test that:
POST /subtitles with a stable YouTube videoPOST /mcp with initialize), and SSE (GET /sse)Run the smoke test (requires built images):
npm run build
docker build -t artsamsonov/transcriptor-mcp-api:latest -f Dockerfile --target api .
docker build -t artsamsonov/transcriptor-mcp:latest -f Dockerfile --target mcp .
npm run test:e2e:api
Environment variables:
| Variable | Default | Description |
|----------|---------|-------------|
| SMOKE_IMAGE_API | — | Full API image reference (overrides name/tag). |
| DOCKER_API_IMAGE / TAG | artsamsonov/transcriptor-mcp-api, latest | API image name and tag. |
| SMOKE_API_URL / SMOKE_API_PORT | http://127.0.0.1:33000, 33000 | API base URL and port. |
| SMOKE_VIDEO_URL | https://www.youtube.com/watch?v=dQw4w9WgXcQ | Video used for /subtitles check. |
| SMOKE_SKIP_MCP | — | Set to 1 (or true/yes) to skip MCP checks. |
| SMOKE_MCP_IMAGE | — | Full MCP image reference (overrides name/tag). |
| DOCKER_MCP_IMAGE / TAG | artsamsonov/transcriptor-mcp, latest | MCP image name and tag. |
| SMOKE_MCP_URL / SMOKE_MCP_PORT | http://127.0.0.1:4200, 4200 | MCP base URL and port. |
| SMOKE_MCP_AUTH_TOKEN | — | If set, passed to MCP container as MCP_AUTH_TOKEN and sent as Bearer in MCP requests. |
Example: skip MCP and use a custom video:
SMOKE_SKIP_MCP=1 SMOKE_VIDEO_URL="https://www.youtube.com/watch?v=YOUR_ID" npm run test:e2e:api
docker logs -f transcriptor
docker stop transcriptor
docker rm transcriptor
For detailed REST API endpoint documentation (request/response schemas, examples, etc.), use the built-in Swagger UI at:
http://localhost:3000/docs
or see docs/quick-start.rest.md.
This project also ships an MCP server over stdio. It reuses the same yt-dlp based extraction and can return full transcript text or raw subtitles. Cursor configuration examples are provided below, but it should work with any MCP host that supports stdio.
Tools that return large text accept:
response_limit (default 50000, min 1000, max 200000)next_cursor (string offset from a previous response)If the response is truncated, the tool returns next_cursor so you can fetch the next chunk.
npm install
npm run build
npm run start:mcp
npm run build
MCP_PORT=4200 MCP_HOST=0.0.0.0 npm run start:mcp:http
Create .cursor/mcp.json (or add to your global Cursor MCP settings):
{
"mcpServers": {
"transcriptor": {
"command": "node",
"args": ["dist/mcp.js"]
}
}
}
Build and run the MCP server in a container (stdio mode):
docker build -f Dockerfile --target mcp -t transcriptor-mcp .
docker run --rm -i transcriptor-mcp
Build and run the MCP server in a container (HTTP mode):
docker build -f Dockerfile --target mcp -t transcriptor-mcp .
docker run -p 4200:4200 -e MCP_PORT=4200 -e MCP_HOST=0.0.0.0 transcriptor-mcp npm run start:mcp:http
Cursor MCP config for Docker:
{
"mcpServers": {
"transcriptor": {
"command": "docker",
"args": ["run", "--rm", "-i", "artsamsonov/transcriptor-mcp:latest"]
}
}
}
yt-dlp to download subtitles with the specified parameters:
yt-dlp command call with explicit type (--write-subs or --write-auto-subs) and language (--sub-lang)/subtitles) or raw content (for /subtitles/raw)The app version is read from package.json at runtime (src/version.ts). When cutting a release, update the version field in package.json, then create a git tag (e.g. v0.4.7). Changelog entries under [Unreleased] should be moved to the new version before tagging.
npm run build - Build the TypeScript projectnpm start - Run the compiled applicationnpm run dev - Run with hot reload using ts-node-devnpm run start:mcp - Run the MCP server (stdio)npm run start:mcp:http - Run the MCP server (HTTP/SSE)npm run dev:mcp - Run the MCP server with hot reloadnpm test - Run testsnpm run test:watch - Run tests in watch modenpm run test:coverage - Run tests with coverage reportnpm run lint - Lint the codenpm run lint:fix - Fix linting errorsnpm run type-check - Type check without buildingnpm run format - Format code with Prettiernpm run format:check - Check code formatting├── src/
│ ├── index.ts # Main application entry point
│ ├── mcp.ts # MCP server entry point (stdio)
│ ├── mcp-core.ts # MCP tools registration (shared)
│ ├── mcp-http.ts # MCP server entry point (HTTP/SSE)
│ ├── validation.ts # Request validation logic
│ └── youtube.ts # YouTube subtitle downloading and parsing
├── dist/ # Compiled JavaScript (generated)
├── Dockerfile # Docker image (API and MCP via --target api/mcp)
├── logo.webp # Project logo used in README
├── example-usage.webp # Example usage screenshot used in README
├── package.json
├── tsconfig.json
└── README.md
Data and keys: Video URLs are sent to yt-dlp for subtitle extraction. Keys and tokens are stored only in your environment; we never log or share them.
Do not commit or log sensitive values. Use environment variables or a secret manager (e.g. vault, cloud secrets) for:
WHISPER_API_KEY – required when using Whisper API; never log or expose in client responses.CACHE_REDIS_URL – Redis connection string when CACHE_MODE=redis; may contain credentials.MCP_AUTH_TOKEN – Bearer token for MCP HTTP; keep it secret.COOKIES_FILE_PATH – path to cookies; ensure the file is not committed and has restricted permissions.See docs/cookies.md for safe handling of cookies.
Contributions are welcome! Please feel free to submit a Pull Request.
git checkout -b feature/amazing-feature)git commit -m 'Add some amazing feature')git push origin feature/amazing-feature)Please make sure your code passes all tests and linting checks before submitting.
MIT License
Copyright (c) 2025 samson-art
See LICENSE file for details.
Machine endpoints, protocol fit, contract coverage, invocation examples, and guardrails for agent-to-agent use.
Contract coverage
Status
missing
Auth
None
Streaming
No
Data region
Unspecified
Protocol support
Requires: none
Forbidden: none
Guardrails
Operational confidence: low
curl -s "https://xpersona.co/api/v1/agents/mcp-samson-art-transcriptor-mcp/snapshot"
curl -s "https://xpersona.co/api/v1/agents/mcp-samson-art-transcriptor-mcp/contract"
curl -s "https://xpersona.co/api/v1/agents/mcp-samson-art-transcriptor-mcp/trust"
Trust and runtime signals, benchmark suites, failure patterns, and practical risk constraints.
Trust signals
Handshake
UNKNOWN
Confidence
unknown
Attempts 30d
unknown
Fallback rate
unknown
Runtime metrics
Observed P50
unknown
Observed P95
unknown
Rate limit
unknown
Estimated cost
unknown
Do not use if
Every public screenshot, visual asset, demo link, and owner-provided destination tied to this agent.
Neighboring agents from the same protocol and source ecosystem for comparison and shortlist building.
Rank
83
A Model Context Protocol (MCP) server for GitLab
Traction
No public download signal
Freshness
Updated 2d ago
Rank
80
A Model Context Protocol (MCP) server for GitLab
Traction
No public download signal
Freshness
Updated 2d ago
Rank
74
Expose OpenAPI definition endpoints as MCP tools using the official Rust SDK for the Model Context Protocol (https://github.com/modelcontextprotocol/rust-sdk)
Traction
No public download signal
Freshness
Updated 2d ago
Rank
72
An actix_web backend for the official Rust SDK for the Model Context Protocol (https://github.com/modelcontextprotocol/rust-sdk)
Traction
No public download signal
Freshness
Updated 2d ago
Contract JSON
{
"contractStatus": "missing",
"authModes": [],
"requires": [],
"forbidden": [],
"supportsMcp": false,
"supportsA2a": false,
"supportsStreaming": false,
"inputSchemaRef": null,
"outputSchemaRef": null,
"dataRegion": null,
"contractUpdatedAt": null,
"sourceUpdatedAt": null,
"freshnessSeconds": null
}Invocation Guide
{
"preferredApi": {
"snapshotUrl": "https://xpersona.co/api/v1/agents/mcp-samson-art-transcriptor-mcp/snapshot",
"contractUrl": "https://xpersona.co/api/v1/agents/mcp-samson-art-transcriptor-mcp/contract",
"trustUrl": "https://xpersona.co/api/v1/agents/mcp-samson-art-transcriptor-mcp/trust"
},
"curlExamples": [
"curl -s \"https://xpersona.co/api/v1/agents/mcp-samson-art-transcriptor-mcp/snapshot\"",
"curl -s \"https://xpersona.co/api/v1/agents/mcp-samson-art-transcriptor-mcp/contract\"",
"curl -s \"https://xpersona.co/api/v1/agents/mcp-samson-art-transcriptor-mcp/trust\""
],
"jsonRequestTemplate": {
"query": "summarize this repo",
"constraints": {
"maxLatencyMs": 2000,
"protocolPreference": [
"MCP"
]
}
},
"jsonResponseTemplate": {
"ok": true,
"result": {
"summary": "...",
"confidence": 0.9
},
"meta": {
"source": "GITHUB_MCP",
"generatedAt": "2026-04-17T03:05:50.019Z"
}
},
"retryPolicy": {
"maxAttempts": 3,
"backoffMs": [
500,
1500,
3500
],
"retryableConditions": [
"HTTP_429",
"HTTP_503",
"NETWORK_TIMEOUT"
]
}
}Trust JSON
{
"status": "unavailable",
"handshakeStatus": "UNKNOWN",
"verificationFreshnessHours": null,
"reputationScore": null,
"p95LatencyMs": null,
"successRate30d": null,
"fallbackRate": null,
"attempts30d": null,
"trustUpdatedAt": null,
"trustConfidence": "unknown",
"sourceUpdatedAt": null,
"freshnessSeconds": null
}Capability Matrix
{
"rows": [
{
"key": "MCP",
"type": "protocol",
"support": "unknown",
"confidenceSource": "profile",
"notes": "Listed on profile"
},
{
"key": "youtube",
"type": "capability",
"support": "supported",
"confidenceSource": "profile",
"notes": "Declared in agent profile metadata"
},
{
"key": "subtitles",
"type": "capability",
"support": "supported",
"confidenceSource": "profile",
"notes": "Declared in agent profile metadata"
},
{
"key": "captions",
"type": "capability",
"support": "supported",
"confidenceSource": "profile",
"notes": "Declared in agent profile metadata"
},
{
"key": "api",
"type": "capability",
"support": "supported",
"confidenceSource": "profile",
"notes": "Declared in agent profile metadata"
}
],
"flattenedTokens": "protocol:MCP|unknown|profile capability:youtube|supported|profile capability:subtitles|supported|profile capability:captions|supported|profile capability:api|supported|profile"
}Facts JSON
[
{
"factKey": "docs_crawl",
"category": "integration",
"label": "Crawlable docs",
"value": "6 indexed pages on the official domain",
"href": "https://github.com/login?return_to=https%3A%2F%2Fgithub.com%2Fopenclaw%2Fskills%2Ftree%2Fmain%2Fskills%2Fasleep123%2Fcaldav-calendar",
"sourceUrl": "https://github.com/login?return_to=https%3A%2F%2Fgithub.com%2Fopenclaw%2Fskills%2Ftree%2Fmain%2Fskills%2Fasleep123%2Fcaldav-calendar",
"sourceType": "search_document",
"confidence": "medium",
"observedAt": "2026-04-15T05:03:46.393Z",
"isPublic": true
},
{
"factKey": "vendor",
"category": "vendor",
"label": "Vendor",
"value": "Samson Art",
"href": "https://github.com/samson-art/transcriptor-mcp#readme",
"sourceUrl": "https://github.com/samson-art/transcriptor-mcp#readme",
"sourceType": "profile",
"confidence": "medium",
"observedAt": "2026-02-25T03:23:17.490Z",
"isPublic": true
},
{
"factKey": "protocols",
"category": "compatibility",
"label": "Protocol compatibility",
"value": "MCP",
"href": "https://xpersona.co/api/v1/agents/mcp-samson-art-transcriptor-mcp/contract",
"sourceUrl": "https://xpersona.co/api/v1/agents/mcp-samson-art-transcriptor-mcp/contract",
"sourceType": "contract",
"confidence": "medium",
"observedAt": "2026-02-25T03:23:17.490Z",
"isPublic": true
},
{
"factKey": "traction",
"category": "adoption",
"label": "Adoption signal",
"value": "1 GitHub stars",
"href": "https://github.com/samson-art/transcriptor-mcp",
"sourceUrl": "https://github.com/samson-art/transcriptor-mcp",
"sourceType": "profile",
"confidence": "medium",
"observedAt": "2026-02-25T03:23:17.490Z",
"isPublic": true
},
{
"factKey": "handshake_status",
"category": "security",
"label": "Handshake status",
"value": "UNKNOWN",
"href": "https://xpersona.co/api/v1/agents/mcp-samson-art-transcriptor-mcp/trust",
"sourceUrl": "https://xpersona.co/api/v1/agents/mcp-samson-art-transcriptor-mcp/trust",
"sourceType": "trust",
"confidence": "medium",
"observedAt": null,
"isPublic": true
}
]Change Events JSON
[
{
"eventType": "docs_update",
"title": "Docs refreshed: Sign in to GitHub · GitHub",
"description": "Fresh crawlable documentation was indexed for the official domain.",
"href": "https://github.com/login?return_to=https%3A%2F%2Fgithub.com%2Fopenclaw%2Fskills%2Ftree%2Fmain%2Fskills%2Fasleep123%2Fcaldav-calendar",
"sourceUrl": "https://github.com/login?return_to=https%3A%2F%2Fgithub.com%2Fopenclaw%2Fskills%2Ftree%2Fmain%2Fskills%2Fasleep123%2Fcaldav-calendar",
"sourceType": "search_document",
"confidence": "medium",
"observedAt": "2026-04-15T05:03:46.393Z",
"isPublic": true
}
]Sponsored
Ads related to transcriptor-mcp and adjacent AI workflows.