mirror of
https://github.com/anthropics/claude-plugins-official.git
synced 2026-04-21 00:24:09 +00:00
Compare commits
1 Commits
dickson/ba
...
add-ui5-pl
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
1f978f586a |
@@ -53,7 +53,7 @@
|
||||
},
|
||||
{
|
||||
"name": "aikido",
|
||||
"description": "Aikido Security scanning for Claude Code — SAST, secrets, and IaC vulnerability detection powered by the Aikido MCP server.",
|
||||
"description": "Aikido Security scanning for Claude Code \u2014 SAST, secrets, and IaC vulnerability detection powered by the Aikido MCP server.",
|
||||
"source": {
|
||||
"source": "url",
|
||||
"url": "https://github.com/AikidoSec/aikido-claude-plugin.git",
|
||||
@@ -243,7 +243,7 @@
|
||||
},
|
||||
{
|
||||
"name": "cockroachdb",
|
||||
"description": "CockroachDB plugin for Claude Code — explore schemas, write optimized SQL, debug queries, and manage distributed database clusters directly from your AI coding agent.",
|
||||
"description": "CockroachDB plugin for Claude Code \u2014 explore schemas, write optimized SQL, debug queries, and manage distributed database clusters directly from your AI coding agent.",
|
||||
"source": {
|
||||
"source": "url",
|
||||
"url": "https://github.com/cockroachdb/claude-plugin.git",
|
||||
@@ -275,7 +275,7 @@
|
||||
},
|
||||
{
|
||||
"name": "coderabbit",
|
||||
"description": "Your code review partner. CodeRabbit provides external validation using a specialized AI architecture and 40+ integrated static analyzers—offering a different perspective that catches bugs, security vulnerabilities, logic errors, and edge cases. Context-aware analysis via AST parsing and codegraph relationships. Automatically incorporates CLAUDE.md and project coding guidelines into reviews. Useful after writing or modifying code, before commits, when implementing complex or security-sensitive logic, or when a second opinion would increase confidence in the changes. Returns specific findings with suggested fixes that can be applied immediately. Free to use.",
|
||||
"description": "Your code review partner. CodeRabbit provides external validation using a specialized AI architecture and 40+ integrated static analyzers\u2014offering a different perspective that catches bugs, security vulnerabilities, logic errors, and edge cases. Context-aware analysis via AST parsing and codegraph relationships. Automatically incorporates CLAUDE.md and project coding guidelines into reviews. Useful after writing or modifying code, before commits, when implementing complex or security-sensitive logic, or when a second opinion would increase confidence in the changes. Returns specific findings with suggested fixes that can be applied immediately. Free to use.",
|
||||
"category": "productivity",
|
||||
"source": {
|
||||
"source": "url",
|
||||
@@ -365,7 +365,7 @@
|
||||
},
|
||||
{
|
||||
"name": "elixir-ls-lsp",
|
||||
"description": "Elixir language server (ElixirLS) for Claude Code — provides code intelligence and diagnostics for .ex, .exs, and .heex files.",
|
||||
"description": "Elixir language server (ElixirLS) for Claude Code \u2014 provides code intelligence and diagnostics for .ex, .exs, and .heex files.",
|
||||
"source": {
|
||||
"source": "url",
|
||||
"url": "https://github.com/MikaelFangel/claude-elixir-ls-lsp.git",
|
||||
@@ -542,7 +542,7 @@
|
||||
},
|
||||
{
|
||||
"name": "helius",
|
||||
"description": "Build on Solana with Helius — live blockchain tools, expert coding patterns, and autonomous account signup",
|
||||
"description": "Build on Solana with Helius \u2014 live blockchain tools, expert coding patterns, and autonomous account signup",
|
||||
"source": {
|
||||
"source": "git-subdir",
|
||||
"url": "helius-labs/core-ai",
|
||||
@@ -753,7 +753,7 @@
|
||||
},
|
||||
{
|
||||
"name": "netlify-skills",
|
||||
"description": "Netlify platform skills for Claude Code — functions, edge functions, blobs, database, image CDN, forms, config, CLI, frameworks, caching, AI gateway, and deployment.",
|
||||
"description": "Netlify platform skills for Claude Code \u2014 functions, edge functions, blobs, database, image CDN, forms, config, CLI, frameworks, caching, AI gateway, and deployment.",
|
||||
"category": "development",
|
||||
"source": {
|
||||
"source": "url",
|
||||
@@ -773,7 +773,7 @@
|
||||
},
|
||||
{
|
||||
"name": "nimble",
|
||||
"description": "Nimble web data toolkit — search, extract, map, crawl the web and work with structured data agents",
|
||||
"description": "Nimble web data toolkit \u2014 search, extract, map, crawl the web and work with structured data agents",
|
||||
"source": {
|
||||
"source": "url",
|
||||
"url": "https://github.com/Nimbleway/agent-skills.git",
|
||||
@@ -793,7 +793,7 @@
|
||||
},
|
||||
{
|
||||
"name": "opsera-devsecops",
|
||||
"description": "Opsera DevSecOps Agent — AI-powered architecture analysis, security scanning, compliance auditing, and SQL security for your codebase. Free trial included.",
|
||||
"description": "Opsera DevSecOps Agent \u2014 AI-powered architecture analysis, security scanning, compliance auditing, and SQL security for your codebase. Free trial included.",
|
||||
"source": {
|
||||
"source": "url",
|
||||
"url": "https://github.com/opsera-agents/opsera-devsecops.git",
|
||||
@@ -803,7 +803,7 @@
|
||||
},
|
||||
{
|
||||
"name": "optibot",
|
||||
"description": "AI code review that catches production-breaking bugs, business logic issues, and security vulnerabilities — directly in Claude Code.",
|
||||
"description": "AI code review that catches production-breaking bugs, business logic issues, and security vulnerabilities \u2014 directly in Claude Code.",
|
||||
"source": {
|
||||
"source": "url",
|
||||
"url": "https://github.com/Optimal-AI/optibot-skill.git",
|
||||
@@ -868,7 +868,7 @@
|
||||
},
|
||||
{
|
||||
"name": "playground",
|
||||
"description": "Creates interactive HTML playgrounds — self-contained single-file explorers with visual controls, live preview, and prompt output with copy button. Includes templates for design playgrounds, data explorers, concept maps, and document critique.",
|
||||
"description": "Creates interactive HTML playgrounds \u2014 self-contained single-file explorers with visual controls, live preview, and prompt output with copy button. Includes templates for design playgrounds, data explorers, concept maps, and document critique.",
|
||||
"author": {
|
||||
"name": "Anthropic",
|
||||
"email": "support@anthropic.com"
|
||||
@@ -950,7 +950,7 @@
|
||||
},
|
||||
{
|
||||
"name": "product-tracking-skills",
|
||||
"description": "AI agent skills that make SaaS products data-ready for product analytics — from codebase scan to tracking plan to working instrumentation code.",
|
||||
"description": "AI agent skills that make SaaS products data-ready for product analytics \u2014 from codebase scan to tracking plan to working instrumentation code.",
|
||||
"source": {
|
||||
"source": "url",
|
||||
"url": "https://github.com/Accoil/product-tracking-skills.git",
|
||||
@@ -984,7 +984,7 @@
|
||||
},
|
||||
{
|
||||
"name": "qodo-skills",
|
||||
"description": "Qodo Skills provides a curated library of reusable AI agent capabilities that extend Claude's functionality for software development workflows. Each skill is designed to integrate seamlessly into your development process, enabling tasks like code quality checks, automated testing, security scanning, and compliance validation. Skills operate across your entire SDLC—from IDE to CI/CD—ensuring consistent standards and catching issues early.",
|
||||
"description": "Qodo Skills provides a curated library of reusable AI agent capabilities that extend Claude's functionality for software development workflows. Each skill is designed to integrate seamlessly into your development process, enabling tasks like code quality checks, automated testing, security scanning, and compliance validation. Skills operate across your entire SDLC\u2014from IDE to CI/CD\u2014ensuring consistent standards and catching issues early.",
|
||||
"category": "development",
|
||||
"source": {
|
||||
"source": "url",
|
||||
@@ -1108,7 +1108,7 @@
|
||||
},
|
||||
{
|
||||
"name": "searchfit-seo",
|
||||
"description": "Free AI-powered SEO toolkit — audit websites, plan content strategy, optimize pages, generate schema markup, cluster keywords, and track AI visibility. Works with any website or codebase.",
|
||||
"description": "Free AI-powered SEO toolkit \u2014 audit websites, plan content strategy, optimize pages, generate schema markup, cluster keywords, and track AI visibility. Works with any website or codebase.",
|
||||
"source": {
|
||||
"source": "url",
|
||||
"url": "https://github.com/searchfit/searchfit-seo.git",
|
||||
@@ -1331,6 +1331,32 @@
|
||||
}
|
||||
}
|
||||
},
|
||||
{
|
||||
"name": "ui5",
|
||||
"description": "SAPUI5 / OpenUI5 plugin for Claude. Create and validate UI5 projects, access API documentation, run UI5 linter, get development guidelines and best practices for UI5 development.",
|
||||
"category": "development",
|
||||
"source": {
|
||||
"source": "git-subdir",
|
||||
"url": "UI5/plugins-claude",
|
||||
"path": "plugins/ui5",
|
||||
"ref": "main",
|
||||
"sha": "5070dfc1cef711d6efad40beb43750027039d71f"
|
||||
},
|
||||
"homepage": "https://github.com/UI5/plugins-claude"
|
||||
},
|
||||
{
|
||||
"name": "ui5-typescript-conversion",
|
||||
"description": "SAPUI5 / OpenUI5 plugin for Claude. Convert JavaScript based UI5 projects to TypeScript.",
|
||||
"category": "development",
|
||||
"source": {
|
||||
"source": "git-subdir",
|
||||
"url": "UI5/plugins-claude",
|
||||
"path": "plugins/ui5-typescript-conversion",
|
||||
"ref": "main",
|
||||
"sha": "5070dfc1cef711d6efad40beb43750027039d71f"
|
||||
},
|
||||
"homepage": "https://github.com/UI5/plugins-claude"
|
||||
},
|
||||
{
|
||||
"name": "vercel",
|
||||
"description": "Vercel deployment platform integration. Manage deployments, check build status, access logs, configure domains, and control your frontend infrastructure directly from Claude Code.",
|
||||
|
||||
@@ -76,7 +76,7 @@ Quick reference: IDs are **handle addresses** (`+15551234567` or `someone@icloud
|
||||
| Tool | Purpose |
|
||||
| --- | --- |
|
||||
| `reply` | Send to a chat. `chat_id` + `text`, optional `files` (absolute paths). Auto-chunks text; files send as separate messages. |
|
||||
| `chat_messages` | Fetch recent history as conversation threads. Each thread is labelled **DM** or **Group** with its participant list, then timestamped messages (oldest-first). Omit `chat_guid` to see every allowlisted chat at once, or pass one to drill in. Default 100 messages per chat. Reads `chat.db` directly — full native history. |
|
||||
| `chat_messages` | Fetch recent history from a chat (oldest-first). Reads `chat.db` directly — full native history. Scoped to allowlisted chats. |
|
||||
|
||||
## What you don't get
|
||||
|
||||
|
||||
@@ -33,8 +33,7 @@ import { join, basename, sep } from 'path'
|
||||
const STATIC = process.env.IMESSAGE_ACCESS_MODE === 'static'
|
||||
const APPEND_SIGNATURE = process.env.IMESSAGE_APPEND_SIGNATURE !== 'false'
|
||||
const SIGNATURE = '\nSent by Claude'
|
||||
const CHAT_DB =
|
||||
process.env.IMESSAGE_DB_PATH ?? join(homedir(), 'Library', 'Messages', 'chat.db')
|
||||
const CHAT_DB = join(homedir(), 'Library', 'Messages', 'chat.db')
|
||||
|
||||
const STATE_DIR = process.env.IMESSAGE_STATE_DIR ?? join(homedir(), '.claude', 'channels', 'imessage')
|
||||
const ACCESS_FILE = join(STATE_DIR, 'access.json')
|
||||
@@ -142,21 +141,6 @@ const qChatsForHandle = db.query<{ guid: string }, [string]>(`
|
||||
WHERE c.style = 45 AND LOWER(h.id) = ?
|
||||
`)
|
||||
|
||||
// Participants of a chat (other than yourself). For DMs this is one handle;
|
||||
// for groups it's everyone in chat_handle_join.
|
||||
const qChatParticipants = db.query<{ id: string }, [string]>(`
|
||||
SELECT DISTINCT h.id FROM handle h
|
||||
JOIN chat_handle_join chj ON chj.handle_id = h.ROWID
|
||||
JOIN chat c ON c.ROWID = chj.chat_id
|
||||
WHERE c.guid = ?
|
||||
`)
|
||||
|
||||
// Group-chat display name and style. display_name is NULL for DMs and
|
||||
// unnamed groups; populated when the user has named the group in Messages.
|
||||
const qChatInfo = db.query<{ display_name: string | null; style: number }, [string]>(`
|
||||
SELECT display_name, style FROM chat WHERE guid = ?
|
||||
`)
|
||||
|
||||
type AttRow = { filename: string | null; mime_type: string | null; transfer_name: string | null }
|
||||
const qAttachments = db.query<AttRow, [number]>(`
|
||||
SELECT a.filename, a.mime_type, a.transfer_name
|
||||
@@ -492,43 +476,15 @@ function messageText(r: Row): string {
|
||||
return r.text ?? parseAttributedBody(r.attributedBody) ?? ''
|
||||
}
|
||||
|
||||
// Build a human-readable header for one conversation. Labels DM vs group and
|
||||
// lists participants so the assistant can tell threads apart at a glance.
|
||||
function conversationHeader(guid: string): string {
|
||||
const info = qChatInfo.get(guid)
|
||||
const participants = qChatParticipants.all(guid).map(p => p.id)
|
||||
const who = participants.length > 0 ? participants.join(', ') : guid
|
||||
if (info?.style === 43) {
|
||||
const name = info.display_name ? `"${info.display_name}" ` : ''
|
||||
return `=== Group ${name}(${who}) ===`
|
||||
}
|
||||
return `=== DM with ${who} ===`
|
||||
}
|
||||
|
||||
// Render one chat's messages as a conversation block: header, then one line
|
||||
// per message with a local-time stamp. A date line is inserted whenever the
|
||||
// calendar day rolls over so long histories stay readable without repeating
|
||||
// the full date on every row.
|
||||
function renderConversation(guid: string, rows: Row[]): string {
|
||||
const lines: string[] = [conversationHeader(guid)]
|
||||
let lastDay = ''
|
||||
for (const r of rows) {
|
||||
const d = appleDate(r.date)
|
||||
const day = d.toDateString()
|
||||
if (day !== lastDay) {
|
||||
lines.push(`-- ${day} --`)
|
||||
lastDay = day
|
||||
}
|
||||
const hhmm = d.toTimeString().slice(0, 5)
|
||||
const who = r.is_from_me ? 'me' : (r.handle_id ?? 'unknown')
|
||||
const atts = r.cache_has_attachments ? ' [attachment]' : ''
|
||||
// Tool results are newline-joined; a multi-line message would forge
|
||||
// adjacent rows. chat_messages is allowlist-scoped, but a configured group
|
||||
// can still have untrusted members.
|
||||
const text = messageText(r).replace(/[\r\n]+/g, ' ⏎ ')
|
||||
lines.push(`[${hhmm}] ${who}: ${text}${atts}`)
|
||||
}
|
||||
return lines.join('\n')
|
||||
function renderMsg(r: Row): string {
|
||||
const who = r.is_from_me ? 'me' : (r.handle_id ?? 'unknown')
|
||||
const ts = appleDate(r.date).toISOString()
|
||||
const atts = r.cache_has_attachments ? ' +att' : ''
|
||||
// Tool results are newline-joined; a multi-line message would forge
|
||||
// adjacent rows. chat_messages is allowlist-scoped, but a configured group
|
||||
// can still have untrusted members.
|
||||
const text = messageText(r).replace(/[\r\n]+/g, ' ⏎ ')
|
||||
return `[${ts}] ${who}: ${text} (id: ${r.guid}${atts})`
|
||||
}
|
||||
|
||||
// --- mcp ---------------------------------------------------------------------
|
||||
@@ -628,19 +584,14 @@ mcp.setRequestHandler(ListToolsRequestSchema, async () => ({
|
||||
{
|
||||
name: 'chat_messages',
|
||||
description:
|
||||
'Fetch recent iMessage history as readable conversation threads. Each thread is labelled DM or Group with its participant list, followed by timestamped messages. Omit chat_guid to see all allowlisted chats at once; pass a specific chat_guid to drill into one thread. Reads chat.db directly — full native history, scoped to allowlisted chats only.',
|
||||
'Fetch recent messages from an iMessage chat. Reads chat.db directly — full native history. Scoped to allowlisted chats only.',
|
||||
inputSchema: {
|
||||
type: 'object',
|
||||
properties: {
|
||||
chat_guid: {
|
||||
type: 'string',
|
||||
description: 'A specific chat_id to read. Omit to read from every allowlisted chat.',
|
||||
},
|
||||
limit: {
|
||||
type: 'number',
|
||||
description: 'Max messages per chat (default 100, max 500).',
|
||||
},
|
||||
chat_guid: { type: 'string', description: 'The chat_id from the inbound message.' },
|
||||
limit: { type: 'number', description: 'Max messages (default 20).' },
|
||||
},
|
||||
required: ['chat_guid'],
|
||||
},
|
||||
},
|
||||
],
|
||||
@@ -688,25 +639,13 @@ mcp.setRequestHandler(CallToolRequestSchema, async req => {
|
||||
return { content: [{ type: 'text', text: sent === 1 ? 'sent' : `sent ${sent} parts` }] }
|
||||
}
|
||||
case 'chat_messages': {
|
||||
const guid = args.chat_guid as string | undefined
|
||||
const limit = Math.min((args.limit as number) ?? 100, 500)
|
||||
const allowed = allowedChatGuids()
|
||||
const targets = guid == null ? [...allowed] : [guid]
|
||||
if (guid != null && !allowed.has(guid)) {
|
||||
const guid = args.chat_guid as string
|
||||
const limit = (args.limit as number) ?? 20
|
||||
if (!allowedChatGuids().has(guid)) {
|
||||
throw new Error(`chat ${guid} is not allowlisted — add via /imessage:access`)
|
||||
}
|
||||
if (targets.length === 0) {
|
||||
return { content: [{ type: 'text', text: '(no allowlisted chats — configure via /imessage:access)' }] }
|
||||
}
|
||||
const blocks: string[] = []
|
||||
for (const g of targets) {
|
||||
const rows = qHistory.all(g, limit).reverse()
|
||||
if (rows.length === 0 && guid == null) continue
|
||||
blocks.push(rows.length === 0
|
||||
? `${conversationHeader(g)}\n(no messages)`
|
||||
: renderConversation(g, rows))
|
||||
}
|
||||
const out = blocks.length === 0 ? '(no messages)' : blocks.join('\n\n')
|
||||
const rows = qHistory.all(guid, limit).reverse()
|
||||
const out = rows.length === 0 ? '(no messages)' : rows.map(renderMsg).join('\n')
|
||||
return { content: [{ type: 'text', text: out }] }
|
||||
}
|
||||
default:
|
||||
|
||||
@@ -1,6 +1,5 @@
|
||||
{
|
||||
"name": "explanatory-output-style",
|
||||
"version": "1.0.0",
|
||||
"description": "Adds educational insights about implementation choices and codebase patterns (mimics the deprecated Explanatory output style)",
|
||||
"author": {
|
||||
"name": "Anthropic",
|
||||
|
||||
@@ -6,7 +6,7 @@
|
||||
"hooks": [
|
||||
{
|
||||
"type": "command",
|
||||
"command": "bash \"${CLAUDE_PLUGIN_ROOT}/hooks-handlers/session-start.sh\""
|
||||
"command": "${CLAUDE_PLUGIN_ROOT}/hooks-handlers/session-start.sh"
|
||||
}
|
||||
]
|
||||
}
|
||||
|
||||
@@ -1,6 +1,5 @@
|
||||
{
|
||||
"name": "learning-output-style",
|
||||
"version": "1.0.0",
|
||||
"description": "Interactive learning mode that requests meaningful code contributions at decision points (mimics the unshipped Learning output style)",
|
||||
"author": {
|
||||
"name": "Anthropic",
|
||||
|
||||
@@ -6,7 +6,7 @@
|
||||
"hooks": [
|
||||
{
|
||||
"type": "command",
|
||||
"command": "bash \"${CLAUDE_PLUGIN_ROOT}/hooks-handlers/session-start.sh\""
|
||||
"command": "${CLAUDE_PLUGIN_ROOT}/hooks-handlers/session-start.sh"
|
||||
}
|
||||
]
|
||||
}
|
||||
|
||||
@@ -1,6 +1,5 @@
|
||||
{
|
||||
"name": "ralph-loop",
|
||||
"version": "1.0.0",
|
||||
"description": "Continuous self-referential AI loops for interactive iterative development, implementing the Ralph Wiggum technique. Run Claude in a while-true loop with the same prompt until task completion.",
|
||||
"author": {
|
||||
"name": "Anthropic",
|
||||
|
||||
@@ -6,7 +6,7 @@
|
||||
"hooks": [
|
||||
{
|
||||
"type": "command",
|
||||
"command": "bash \"${CLAUDE_PLUGIN_ROOT}/hooks/stop-hook.sh\""
|
||||
"command": "${CLAUDE_PLUGIN_ROOT}/hooks/stop-hook.sh"
|
||||
}
|
||||
]
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user