mirror of
https://github.com/anthropics/claude-plugins-official.git
synced 2026-06-17 14:53:28 +00:00
Compare commits
202 Commits
add-langfu
...
macos-altp
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
66a63f2c43 | ||
|
|
ad34eb0fa6 | ||
|
|
6ff128bdcc | ||
|
|
0ea860bff1 | ||
|
|
c6335cc27b | ||
|
|
2d25650f94 | ||
|
|
1e37280cf9 | ||
|
|
75c62a9197 | ||
|
|
999e8e0c57 | ||
|
|
00667be766 | ||
|
|
41fc10261c | ||
|
|
2cba8f077a | ||
|
|
ce64e6bf3c | ||
|
|
554d4cb80e | ||
|
|
e5f6c09bcb | ||
|
|
658af9f960 | ||
|
|
e2debd8290 | ||
|
|
25ceefbdb5 | ||
|
|
ea6c6c54bf | ||
|
|
8796a01308 | ||
|
|
ff082f171c | ||
|
|
de0381871c | ||
|
|
9738aaa20d | ||
|
|
2f345cc812 | ||
|
|
0df7ab970a | ||
|
|
0fceb8daac | ||
|
|
be6628629b | ||
|
|
17452b1f98 | ||
|
|
8bc9295a04 | ||
|
|
eb3de173b5 | ||
|
|
c386685e3f | ||
|
|
7a0e1d4465 | ||
|
|
ed419734e6 | ||
|
|
e5cf040923 | ||
|
|
795a4fe72a | ||
|
|
be88f154f6 | ||
|
|
54045e575d | ||
|
|
914872e672 | ||
|
|
5f010ddcaa | ||
|
|
f5c23eb5b2 | ||
|
|
d55675f380 | ||
|
|
093e3563c3 | ||
|
|
ed282ece77 | ||
|
|
d029127f7d | ||
|
|
ac1881863e | ||
|
|
b1b442f791 | ||
|
|
be167462cc | ||
|
|
e23bff59eb | ||
|
|
0154872782 | ||
|
|
055f924478 | ||
|
|
2ab3fbe4c8 | ||
|
|
19bf5d5c3c | ||
|
|
8de280a576 | ||
|
|
aa310d1d9c | ||
|
|
3134d2866d | ||
|
|
2b8b2c33a0 | ||
|
|
5ec330764a | ||
|
|
3d2f32464d | ||
|
|
f1adf52e8c | ||
|
|
24d9c6d418 | ||
|
|
9e279a304e | ||
|
|
58259dd01d | ||
|
|
f8f51e7aa1 | ||
|
|
f2a86b756c | ||
|
|
dd3df95e96 | ||
|
|
fcea04d3c2 | ||
|
|
7562bf611d | ||
|
|
057071a55c | ||
|
|
b27e8e4ba5 | ||
|
|
580329d98a | ||
|
|
ac16ffafcd | ||
|
|
fffaefee8e | ||
|
|
8738e640b2 | ||
|
|
de665302a9 | ||
|
|
00cc11a4db | ||
|
|
16685443cd | ||
|
|
92b8b3b1a4 | ||
|
|
2abc0187cc | ||
|
|
e845d1fc75 | ||
|
|
cb551fda9d | ||
|
|
980f770293 | ||
|
|
b309b87f4a | ||
|
|
39b572829e | ||
|
|
eb35b09fcc | ||
|
|
b4817997ae | ||
|
|
fa8b8dcca9 | ||
|
|
a3ccf58c9c | ||
|
|
eb1510e138 | ||
|
|
3da3a87d3a | ||
|
|
30c7e63900 | ||
|
|
92335cde51 | ||
|
|
0093cc4c19 | ||
|
|
0838a1dc8b | ||
|
|
3d211b8c96 | ||
|
|
631285244a | ||
|
|
b7b93b44b5 | ||
|
|
b0fc21d5e9 | ||
|
|
3d52574103 | ||
|
|
722a3a3135 | ||
|
|
b424b366c1 | ||
|
|
22b1d01458 | ||
|
|
9fcd733451 | ||
|
|
911a4a4948 | ||
|
|
bb1dbb72c2 | ||
|
|
91af1ec414 | ||
|
|
b00b3adfc4 | ||
|
|
ff5936621d | ||
|
|
fec0d03aa8 | ||
|
|
e8cb4b220b | ||
|
|
ab689eaaa3 | ||
|
|
2392bfb536 | ||
|
|
8b2d46e39f | ||
|
|
a8498e96ec | ||
|
|
fe68bbd4cb | ||
|
|
29a9b7821b | ||
|
|
3055453674 | ||
|
|
df202fe49d | ||
|
|
13c87c4343 | ||
|
|
578a1e0424 | ||
|
|
9a0431c4e2 | ||
|
|
811f8ad60f | ||
|
|
15097484e3 | ||
|
|
6c54d520d9 | ||
|
|
fd1fb9b605 | ||
|
|
2e51a286e1 | ||
|
|
ddee31c6d0 | ||
|
|
f509ef5619 | ||
|
|
b86cb16f46 | ||
|
|
3ca32ef77d | ||
|
|
a32fc1e5ee | ||
|
|
13ca790298 | ||
|
|
60b0b15e99 | ||
|
|
cbe3b82009 | ||
|
|
fbf287b7b1 | ||
|
|
4e56d19dd8 | ||
|
|
1a0964045f | ||
|
|
96468b2393 | ||
|
|
3746985ced | ||
|
|
a4b32dc171 | ||
|
|
e7fe15d9ba | ||
|
|
e97f9a40b9 | ||
|
|
78fa3df8d6 | ||
|
|
56fd6abb97 | ||
|
|
c9b8f92b53 | ||
|
|
7279412e77 | ||
|
|
484653886e | ||
|
|
c7af5e02bc | ||
|
|
8ea0761c82 | ||
|
|
600c99b404 | ||
|
|
d28241b7ef | ||
|
|
46c72e981f | ||
|
|
3f8fc630b8 | ||
|
|
fbd57be8e5 | ||
|
|
413d293096 | ||
|
|
e4a454a7eb | ||
|
|
d30ef44d74 | ||
|
|
6ee4f1e1df | ||
|
|
c4b91a6e24 | ||
|
|
e656f87725 | ||
|
|
eaa69c48cb | ||
|
|
46dc6920be | ||
|
|
92954b1b92 | ||
|
|
0784122e63 | ||
|
|
7465bdcc27 | ||
|
|
7209a2ca09 | ||
|
|
71941bb301 | ||
|
|
eeb3316d51 | ||
|
|
66bca6b6f6 | ||
|
|
be8b438e1a | ||
|
|
43297b9419 | ||
|
|
b110a96045 | ||
|
|
9087f2c348 | ||
|
|
9277728768 | ||
|
|
5518e4b87d | ||
|
|
2bf67d3cfd | ||
|
|
c5fd33161c | ||
|
|
2b58efffc3 | ||
|
|
f4cf218b9b | ||
|
|
db5b3d5999 | ||
|
|
5316ced830 | ||
|
|
13ac3cb075 | ||
|
|
5a20d10780 | ||
|
|
9eae436aa2 | ||
|
|
ee7ce490f9 | ||
|
|
460bc2b3a4 | ||
|
|
1a7db730cb | ||
|
|
3ebb9c7a85 | ||
|
|
9ef08d32aa | ||
|
|
b8e4462957 | ||
|
|
2f9c3234ab | ||
|
|
c5660ed060 | ||
|
|
9ecfe41bdd | ||
|
|
d5265b0377 | ||
|
|
c7f3eb4b8f | ||
|
|
3b46b04964 | ||
|
|
a379ddd580 | ||
|
|
8a0797c1eb | ||
|
|
447aef7de0 | ||
|
|
7e9d5e46d1 | ||
|
|
14e6461b03 | ||
|
|
634ea8dfdf | ||
|
|
43fcf6d513 |
@@ -19,7 +19,7 @@
|
||||
"url": "https://github.com/42Crunch-AI/claude-plugins.git",
|
||||
"path": "plugins/api-security-testing",
|
||||
"ref": "v1.5.5",
|
||||
"sha": "b7e131e30ff033be2176faf796c94c151a68c63a"
|
||||
"sha": "bc781f96be8ce17a2972e8a9a3ef38b1ca7e8cc4"
|
||||
},
|
||||
"homepage": "https://42crunch.com"
|
||||
},
|
||||
@@ -35,7 +35,7 @@
|
||||
"url": "https://github.com/adobe/skills.git",
|
||||
"path": "plugins/creative-cloud/adobe-for-creativity",
|
||||
"ref": "main",
|
||||
"sha": "253f56901e058800ccb97ffd5bf1e3329d5f2e00"
|
||||
"sha": "c467bf831064ebda26f39dd30c02d7cce03eb26c"
|
||||
},
|
||||
"homepage": "https://github.com/adobe/skills/tree/main/plugins/creative-cloud/adobe-for-creativity"
|
||||
},
|
||||
@@ -77,7 +77,7 @@
|
||||
"source": {
|
||||
"source": "url",
|
||||
"url": "https://github.com/AikidoSec/aikido-claude-plugin.git",
|
||||
"sha": "79ac524f87c9faa9a356ff3d495b8a5b77e01bbd"
|
||||
"sha": "01e8cf542500e579cff948a0fa0365e4f819d7b4"
|
||||
},
|
||||
"homepage": "https://github.com/AikidoSec/aikido-claude-plugin"
|
||||
},
|
||||
@@ -109,7 +109,7 @@
|
||||
"url": "https://github.com/airwallex/airwallex-marketplace.git",
|
||||
"path": "plugins/airwallex",
|
||||
"ref": "master",
|
||||
"sha": "a49ef1ec801fd776adc4db9f2bb4a78463981bc9"
|
||||
"sha": "683a7536f9445c07439d087607b44b0383b8c41d"
|
||||
},
|
||||
"homepage": "https://www.airwallex.com/docs"
|
||||
},
|
||||
@@ -150,7 +150,7 @@
|
||||
"url": "https://github.com/awslabs/agent-plugins.git",
|
||||
"path": "plugins/amazon-location-service",
|
||||
"ref": "main",
|
||||
"sha": "f985fddc69953f103d9c16fa9e97096d2bc29b02"
|
||||
"sha": "7a17df718d26f07414b876e77a7480fa25089b08"
|
||||
},
|
||||
"homepage": "https://github.com/awslabs/agent-plugins"
|
||||
},
|
||||
@@ -161,7 +161,7 @@
|
||||
"url": "https://github.com/amplitude/mcp-marketplace.git",
|
||||
"path": "plugins/amplitude",
|
||||
"ref": "main",
|
||||
"sha": "e9b4e15193666e1b513b5652ded23fab160bdc4e"
|
||||
"sha": "fb22979da93d27dcb17b832dbd473e6b0caf2ca8"
|
||||
},
|
||||
"description": "Use Amplitude as an expert analyst — instrument Amplitude, discover product opportunities, analyze charts, create dashboards, manage experiments, and understand users and accounts.",
|
||||
"category": "monitoring",
|
||||
@@ -233,7 +233,7 @@
|
||||
"source": {
|
||||
"source": "url",
|
||||
"url": "https://github.com/atlanhq/agent-toolkit.git",
|
||||
"sha": "789507c02d2495235240d10d67aaac8b2051023a"
|
||||
"sha": "86bb1ad27f80e189b328333d2271b360ae579f2b"
|
||||
},
|
||||
"homepage": "https://docs.atlan.com/"
|
||||
},
|
||||
@@ -256,7 +256,7 @@
|
||||
"source": "url",
|
||||
"url": "https://github.com/BrainBlend-AI/atomic-agents.git",
|
||||
"path": "claude-plugin/atomic-agents",
|
||||
"sha": "324399402b9b5965313de6a34ea09d6bb149a200"
|
||||
"sha": "94220182f88df0292a8b59d01b61170ff6c61fd4"
|
||||
},
|
||||
"homepage": "https://github.com/BrainBlend-AI/atomic-agents",
|
||||
"tags": [
|
||||
@@ -275,7 +275,7 @@
|
||||
"url": "https://github.com/auth0/agent-skills.git",
|
||||
"path": "plugins/auth0",
|
||||
"ref": "main",
|
||||
"sha": "bdf0dc23f8b17446b2c94bc9f2e5a58d3f1bc114"
|
||||
"sha": "b595bdb9b574569e864eef86c3d48c06e2cf414c"
|
||||
},
|
||||
"homepage": "https://auth0.com/docs/quickstart/agent-skills"
|
||||
},
|
||||
@@ -291,7 +291,7 @@
|
||||
"url": "https://github.com/aws/agent-toolkit-for-aws.git",
|
||||
"path": "plugins/aws-agents",
|
||||
"ref": "main",
|
||||
"sha": "c0991f463b54ac94af32a730d6d13293dcff98cf"
|
||||
"sha": "a9d1c70fe7442a97678e82b62c7c61bcb0deeaea"
|
||||
},
|
||||
"homepage": "https://github.com/aws/agent-toolkit-for-aws"
|
||||
},
|
||||
@@ -304,7 +304,7 @@
|
||||
"url": "https://github.com/awslabs/agent-plugins.git",
|
||||
"path": "plugins/aws-amplify",
|
||||
"ref": "main",
|
||||
"sha": "f985fddc69953f103d9c16fa9e97096d2bc29b02"
|
||||
"sha": "7a17df718d26f07414b876e77a7480fa25089b08"
|
||||
},
|
||||
"homepage": "https://github.com/awslabs/agent-plugins"
|
||||
},
|
||||
@@ -320,7 +320,7 @@
|
||||
"url": "https://github.com/aws/agent-toolkit-for-aws.git",
|
||||
"path": "plugins/aws-core",
|
||||
"ref": "main",
|
||||
"sha": "c0991f463b54ac94af32a730d6d13293dcff98cf"
|
||||
"sha": "a9d1c70fe7442a97678e82b62c7c61bcb0deeaea"
|
||||
},
|
||||
"homepage": "https://github.com/aws/agent-toolkit-for-aws"
|
||||
},
|
||||
@@ -336,7 +336,7 @@
|
||||
"url": "https://github.com/aws/agent-toolkit-for-aws.git",
|
||||
"path": "plugins/aws-data-analytics",
|
||||
"ref": "main",
|
||||
"sha": "c0991f463b54ac94af32a730d6d13293dcff98cf"
|
||||
"sha": "a9d1c70fe7442a97678e82b62c7c61bcb0deeaea"
|
||||
},
|
||||
"homepage": "https://github.com/aws/agent-toolkit-for-aws"
|
||||
},
|
||||
@@ -365,7 +365,7 @@
|
||||
"url": "https://github.com/awslabs/agent-plugins.git",
|
||||
"path": "plugins/aws-serverless",
|
||||
"ref": "main",
|
||||
"sha": "f985fddc69953f103d9c16fa9e97096d2bc29b02"
|
||||
"sha": "7a17df718d26f07414b876e77a7480fa25089b08"
|
||||
},
|
||||
"homepage": "https://github.com/awslabs/agent-plugins"
|
||||
},
|
||||
@@ -381,7 +381,7 @@
|
||||
"url": "https://github.com/awslabs/startups.git",
|
||||
"path": "advisor/plugins/aws-startup-advisor",
|
||||
"ref": "main",
|
||||
"sha": "3c5d6a7deb24c3318be8b78ef75545539ab1bbcd"
|
||||
"sha": "3eae13125da8cc923f010b19321137efd0e69a66"
|
||||
},
|
||||
"homepage": "https://github.com/awslabs/startups"
|
||||
},
|
||||
@@ -392,7 +392,7 @@
|
||||
"source": {
|
||||
"source": "url",
|
||||
"url": "https://github.com/microsoft/azure-skills.git",
|
||||
"sha": "966330ee4fc61978b6e324993687e917125a1f36"
|
||||
"sha": "82492494405b948c8422766ddae390714bbd78ed"
|
||||
},
|
||||
"homepage": "https://github.com/microsoft/azure-skills"
|
||||
},
|
||||
@@ -430,7 +430,7 @@
|
||||
"url": "https://github.com/Bigdata-com/bigdata-plugins-marketplace.git",
|
||||
"path": "plugins/bigdata-com",
|
||||
"ref": "main",
|
||||
"sha": "67c30be97a0a3f46bc6e8d56df449ae108eda9c5"
|
||||
"sha": "76a043a08c0a10eb73756d04031a613568017067"
|
||||
},
|
||||
"homepage": "https://docs.bigdata.com"
|
||||
},
|
||||
@@ -472,7 +472,7 @@
|
||||
"source": {
|
||||
"source": "url",
|
||||
"url": "https://github.com/brightdata/skills.git",
|
||||
"sha": "bd5bd76bc889f54b744bab3db3cbd42751a1e5b0"
|
||||
"sha": "8d427e9871566efe3f0a1c8888f98b6fe8288831"
|
||||
},
|
||||
"homepage": "https://docs.brightdata.com"
|
||||
},
|
||||
@@ -486,7 +486,7 @@
|
||||
"source": {
|
||||
"source": "url",
|
||||
"url": "https://github.com/buildkite/skills.git",
|
||||
"sha": "a43e944f2017146d0a6b7d8ea2bf21b02484e1d3"
|
||||
"sha": "e6c7784f46a2c070fdf7e6fe1b61cd3ca0e20166"
|
||||
},
|
||||
"homepage": "https://buildkite.com"
|
||||
},
|
||||
@@ -502,7 +502,7 @@
|
||||
"url": "https://github.com/carta/plugins.git",
|
||||
"path": "plugins/carta-cap-table",
|
||||
"ref": "main",
|
||||
"sha": "4b5796517b62c4aeaac1a0bb6ccdaebeb73475a5"
|
||||
"sha": "5e119d7848e1f495092df4e41ac43e609e3293d1"
|
||||
},
|
||||
"homepage": "https://carta.com"
|
||||
},
|
||||
@@ -518,7 +518,7 @@
|
||||
"url": "https://github.com/carta/plugins.git",
|
||||
"path": "plugins/carta-crm",
|
||||
"ref": "main",
|
||||
"sha": "4b5796517b62c4aeaac1a0bb6ccdaebeb73475a5"
|
||||
"sha": "5e119d7848e1f495092df4e41ac43e609e3293d1"
|
||||
},
|
||||
"homepage": "https://carta.com"
|
||||
},
|
||||
@@ -534,7 +534,7 @@
|
||||
"url": "https://github.com/carta/plugins.git",
|
||||
"path": "plugins/carta-investors",
|
||||
"ref": "main",
|
||||
"sha": "4b5796517b62c4aeaac1a0bb6ccdaebeb73475a5"
|
||||
"sha": "5e119d7848e1f495092df4e41ac43e609e3293d1"
|
||||
},
|
||||
"homepage": "https://carta.com"
|
||||
},
|
||||
@@ -561,7 +561,7 @@
|
||||
"source": {
|
||||
"source": "url",
|
||||
"url": "https://github.com/ChromeDevTools/chrome-devtools-mcp.git",
|
||||
"sha": "4f8eb7ad6beecc58f56ec383f9ff43549a5604d4"
|
||||
"sha": "ed02047ae90f25c4c15adb8fd7e224b963f43135"
|
||||
},
|
||||
"homepage": "https://github.com/ChromeDevTools/chrome-devtools-mcp"
|
||||
},
|
||||
@@ -720,7 +720,7 @@
|
||||
"source": {
|
||||
"source": "url",
|
||||
"url": "https://github.com/cloudflare/skills.git",
|
||||
"sha": "c5b7b06b073fa0b4abbd63964630f97d81da69c4"
|
||||
"sha": "8ff55f2a574f498bbf89675279d92b7a61f4d521"
|
||||
},
|
||||
"description": "Skills for the Cloudflare developer platform: Workers, Durable Objects, Agents SDK, MCP servers, Wrangler CLI, and web performance.",
|
||||
"category": "deployment",
|
||||
@@ -804,7 +804,7 @@
|
||||
"source": {
|
||||
"source": "url",
|
||||
"url": "https://github.com/CodSpeedHQ/codspeed.git",
|
||||
"sha": "7e86f11b2e0dee673f621c80271d8dae4893df73"
|
||||
"sha": "9e21a9c0415c848d1c6d7e66c221f7524433899d"
|
||||
},
|
||||
"homepage": "https://codspeed.io"
|
||||
},
|
||||
@@ -841,7 +841,7 @@
|
||||
"source": {
|
||||
"source": "url",
|
||||
"url": "https://github.com/get-convex/convex-backend-skill.git",
|
||||
"sha": "002f9c834cdb834ddef1e4867d87cb6e80f0acba"
|
||||
"sha": "d184f54776d20dd834218b11b83feb42d5e2a065"
|
||||
},
|
||||
"homepage": "https://github.com/get-convex/convex-backend-skill",
|
||||
"keywords": [
|
||||
@@ -872,7 +872,7 @@
|
||||
"source": {
|
||||
"source": "url",
|
||||
"url": "https://github.com/CrowdStrike/foundry-skills.git",
|
||||
"sha": "57ae73b4a0e228ef2a2258513847dc6afa0e6131"
|
||||
"sha": "a7e6a75ad2d9aa4093771e8c07d455c1ce39aae1"
|
||||
},
|
||||
"homepage": "https://github.com/CrowdStrike/foundry-skills"
|
||||
},
|
||||
@@ -918,7 +918,7 @@
|
||||
"source": {
|
||||
"source": "url",
|
||||
"url": "https://github.com/dash0hq/dash0-agent-plugin.git",
|
||||
"sha": "37fd498b0775d98fcd27ff3c0fe3f68e412482a4"
|
||||
"sha": "e1a46f085171787382465b7148070da36127119f"
|
||||
},
|
||||
"homepage": "https://dash0.com/"
|
||||
},
|
||||
@@ -943,7 +943,7 @@
|
||||
"source": {
|
||||
"source": "url",
|
||||
"url": "https://github.com/gemini-cli-extensions/data-agent-kit-starter-pack.git",
|
||||
"sha": "c125eaea039b9440b306b428ee2068d79123ddb7"
|
||||
"sha": "65a480a04dc09fe51fab66fde61b1a2baa443741"
|
||||
},
|
||||
"homepage": "https://github.com/gemini-cli-extensions/data-agent-kit-starter-pack"
|
||||
},
|
||||
@@ -966,7 +966,7 @@
|
||||
"url": "https://github.com/awslabs/agent-plugins.git",
|
||||
"path": "plugins/databases-on-aws",
|
||||
"ref": "main",
|
||||
"sha": "b13ce7f008c52be10c3fcccce25d64ec614e76be"
|
||||
"sha": "7a17df718d26f07414b876e77a7480fa25089b08"
|
||||
},
|
||||
"homepage": "https://github.com/awslabs/agent-plugins"
|
||||
},
|
||||
@@ -1022,7 +1022,7 @@
|
||||
"source": {
|
||||
"source": "url",
|
||||
"url": "https://github.com/datarobot-oss/datarobot-agent-skills.git",
|
||||
"sha": "ec2ecdd49d54ef490b344a850cff1feb1230c409"
|
||||
"sha": "6937e65a4f652ecc08b8b53bd7e79f6e3d1f69b3"
|
||||
},
|
||||
"homepage": "https://datarobot.com"
|
||||
},
|
||||
@@ -1035,7 +1035,7 @@
|
||||
"url": "https://github.com/microsoft/Dataverse-skills.git",
|
||||
"path": ".github/plugins/dataverse",
|
||||
"ref": "main",
|
||||
"sha": "2c37394346be1afc1db12cc5b89f5dee3617c45c"
|
||||
"sha": "1175021761a2f135ea7505208f074ed0fae45255"
|
||||
},
|
||||
"homepage": "https://github.com/microsoft/Dataverse-skills"
|
||||
},
|
||||
@@ -1048,7 +1048,7 @@
|
||||
"url": "https://github.com/awslabs/agent-plugins.git",
|
||||
"path": "plugins/deploy-on-aws",
|
||||
"ref": "main",
|
||||
"sha": "b13ce7f008c52be10c3fcccce25d64ec614e76be"
|
||||
"sha": "7a17df718d26f07414b876e77a7480fa25089b08"
|
||||
},
|
||||
"homepage": "https://github.com/awslabs/agent-plugins"
|
||||
},
|
||||
@@ -1150,7 +1150,7 @@
|
||||
"url": "https://github.com/expo/skills.git",
|
||||
"path": "plugins/expo",
|
||||
"ref": "main",
|
||||
"sha": "1a5693e0acc95a0829ff1656b4426fee2f2c1167"
|
||||
"sha": "39d50f0caeacec8a17588534bb32aa962c677a3d"
|
||||
},
|
||||
"homepage": "https://github.com/expo/skills/blob/main/plugins/expo/README.md"
|
||||
},
|
||||
@@ -1230,7 +1230,7 @@
|
||||
"source": {
|
||||
"source": "url",
|
||||
"url": "https://github.com/gemini-cli-extensions/firestore-native.git",
|
||||
"sha": "f88103bd0ccfe9e1e7a3a7d849de26d197978c9a"
|
||||
"sha": "d151daf6a5fde7f46fde824292828ab630220282"
|
||||
},
|
||||
"homepage": "https://github.com/gemini-cli-extensions/firestore-native"
|
||||
},
|
||||
@@ -1333,7 +1333,7 @@
|
||||
"source": {
|
||||
"source": "url",
|
||||
"url": "https://github.com/huggingface/skills.git",
|
||||
"sha": "d7223848c3895fbd447faf2aec73e0a6cdd7fdcd"
|
||||
"sha": "c68f1b08d9eb3af22cdc1d3fb60e9cdb78522556"
|
||||
},
|
||||
"homepage": "https://github.com/huggingface/skills.git"
|
||||
},
|
||||
@@ -1361,7 +1361,7 @@
|
||||
"source": {
|
||||
"source": "url",
|
||||
"url": "https://github.com/heygen-com/hyperframes.git",
|
||||
"sha": "8fcbb63a371752932027f3495dbc6ae6b5daf0f7"
|
||||
"sha": "3b3ece81d1a0b36038e67e58d9ca620e4a3122e9"
|
||||
},
|
||||
"homepage": "https://hyperframes.heygen.com"
|
||||
},
|
||||
@@ -1429,7 +1429,7 @@
|
||||
"source": {
|
||||
"source": "url",
|
||||
"url": "https://github.com/gemini-cli-extensions/knowledge-catalog.git",
|
||||
"sha": "317e96fdd12aa61778b950192aff627efdc21099"
|
||||
"sha": "fe4e94035824fa41f7d06426531bbed7bec2520c"
|
||||
},
|
||||
"homepage": "https://github.com/gemini-cli-extensions/knowledge-catalog"
|
||||
},
|
||||
@@ -1458,6 +1458,20 @@
|
||||
}
|
||||
}
|
||||
},
|
||||
{
|
||||
"name": "langfuse-observability",
|
||||
"description": "The Langfuse x Claude Code Observability Plugin",
|
||||
"author": {
|
||||
"name": "Langfuse"
|
||||
},
|
||||
"category": "monitoring",
|
||||
"source": {
|
||||
"source": "url",
|
||||
"url": "https://github.com/langfuse/claude-observability-plugin.git",
|
||||
"sha": "597af67d6c6b369f3e55db6cfa2ebe444f1af46c"
|
||||
},
|
||||
"homepage": "https://langfuse.com/integrations/other/claude-code"
|
||||
},
|
||||
{
|
||||
"name": "laravel-boost",
|
||||
"description": "Laravel development toolkit MCP server. Provides intelligent assistance for Laravel applications including Artisan commands, Eloquent queries, routing, migrations, and framework-specific code generation.",
|
||||
@@ -1554,10 +1568,24 @@
|
||||
"source": {
|
||||
"source": "url",
|
||||
"url": "https://github.com/gemini-cli-extensions/looker.git",
|
||||
"sha": "e912c0342f1bfd436e9236aaef7cc732239c80f7"
|
||||
"sha": "ef38964514c9b6634ac9a211d3987222bb36bf6e"
|
||||
},
|
||||
"homepage": "https://github.com/gemini-cli-extensions/looker"
|
||||
},
|
||||
{
|
||||
"name": "lovable",
|
||||
"description": "Build, iterate on, deploy, and manage Lovable apps from Claude Code. Bundles the official Lovable MCP server (remote, OAuth 2.1) and adds focused commands for the common build/iterate/database workflows, with credit- and publish-safety prompts.",
|
||||
"author": {
|
||||
"name": "Lovable"
|
||||
},
|
||||
"category": "development",
|
||||
"source": {
|
||||
"source": "url",
|
||||
"url": "https://github.com/lovablelabs/mcp.git",
|
||||
"sha": "9321737a737cf719db44c8124507f75e0bd0d270"
|
||||
},
|
||||
"homepage": "https://lovable.dev"
|
||||
},
|
||||
{
|
||||
"name": "lua-lsp",
|
||||
"description": "Lua language server for code intelligence",
|
||||
@@ -1602,7 +1630,7 @@
|
||||
"source": {
|
||||
"source": "url",
|
||||
"url": "https://github.com/lusha-oss/lusha-mcp-plugin.git",
|
||||
"sha": "8fc71d5473ea40e01a92001787f0f3caaf5ca30e"
|
||||
"sha": "affbc76b03c1a46c0dffc5b7a374cf7af17b26e8"
|
||||
},
|
||||
"homepage": "https://www.lusha.com"
|
||||
},
|
||||
@@ -1708,7 +1736,7 @@
|
||||
"url": "https://github.com/awslabs/startups.git",
|
||||
"path": "migrate/plugins/migration-to-aws",
|
||||
"ref": "main",
|
||||
"sha": "3c5d6a7deb24c3318be8b78ef75545539ab1bbcd"
|
||||
"sha": "3eae13125da8cc923f010b19321137efd0e69a66"
|
||||
},
|
||||
"homepage": "https://github.com/awslabs/startups"
|
||||
},
|
||||
@@ -1759,7 +1787,7 @@
|
||||
"url": "https://github.com/neondatabase/agent-skills.git",
|
||||
"path": "plugins/neon-postgres",
|
||||
"ref": "main",
|
||||
"sha": "58b84dfb0815cca6dbb2f40bfdb23ddf934d2b5f"
|
||||
"sha": "e09dafdc62a11fc8a20134afcb70dc2aab2feb88"
|
||||
},
|
||||
"homepage": "https://github.com/neondatabase/agent-skills/tree/main/plugins/neon-postgres"
|
||||
},
|
||||
@@ -1770,7 +1798,7 @@
|
||||
"source": {
|
||||
"source": "url",
|
||||
"url": "https://github.com/netlify/context-and-tools.git",
|
||||
"sha": "22025ef6c9dc9ef88d0c9c047980c10cacb178ee"
|
||||
"sha": "ab80a6ed2b6c4933a3f964101c82b45cab847b5b"
|
||||
},
|
||||
"homepage": "https://github.com/netlify/context-and-tools"
|
||||
},
|
||||
@@ -1802,7 +1830,7 @@
|
||||
"source": {
|
||||
"source": "url",
|
||||
"url": "https://github.com/nvsecurity/nightvision-skills.git",
|
||||
"sha": "7d7a3f342bbf4d02b6e012279800cf91ff0c1c97"
|
||||
"sha": "a510be06ca7fb2a0b1ffe38d4163f56dbc3b9e93"
|
||||
},
|
||||
"homepage": "https://github.com/nvsecurity/nightvision-skills"
|
||||
},
|
||||
@@ -1812,7 +1840,7 @@
|
||||
"source": {
|
||||
"source": "url",
|
||||
"url": "https://github.com/Nimbleway/agent-skills.git",
|
||||
"sha": "9736dfc757f5ed4f05da0480b202af09e93a27de"
|
||||
"sha": "e72345e283f977d4f7bb4d6d415b5964a385bdf1"
|
||||
},
|
||||
"homepage": "https://docs.nimbleway.com/integrations/agent-skills/plugin-installation"
|
||||
},
|
||||
@@ -1839,7 +1867,7 @@
|
||||
"url": "https://github.com/NVIDIA/skills.git",
|
||||
"path": "plugins/nvidia-skills",
|
||||
"ref": "main",
|
||||
"sha": "24806dbdb4f45b9d8c476c0e7a9b223b8c9e7197"
|
||||
"sha": "b0c4c9abca3e0b493d96a1574c9678daf086c4b5"
|
||||
},
|
||||
"homepage": "https://github.com/NVIDIA/skills"
|
||||
},
|
||||
@@ -1855,7 +1883,7 @@
|
||||
"url": "https://github.com/oracle-samples/oracle-aidp-samples.git",
|
||||
"path": "ai/claude-code-plugins/oracle-ai-data-platform-workbench-spark-connectors",
|
||||
"ref": "main",
|
||||
"sha": "00cedef34c99d642d969f87965736768de01cbd6"
|
||||
"sha": "fd54df54076da5fa95fdb4a63398d2edb8724edb"
|
||||
},
|
||||
"homepage": "https://docs.oracle.com/en/cloud/paas/ai-data-platform/index.html"
|
||||
},
|
||||
@@ -1885,7 +1913,7 @@
|
||||
"url": "https://github.com/growthxai/output.git",
|
||||
"path": "coding_assistants/claude/plugins/outputai",
|
||||
"ref": "main",
|
||||
"sha": "f8d698eaf501aeeec1329266b254d44aef556658"
|
||||
"sha": "bd6bd4960b00f340c1e345620a8eb42d6c696e5f"
|
||||
},
|
||||
"homepage": "https://output.ai"
|
||||
},
|
||||
@@ -1995,7 +2023,7 @@
|
||||
"source": {
|
||||
"source": "url",
|
||||
"url": "https://github.com/PostHog/ai-plugin.git",
|
||||
"sha": "f674efefafeff7152294642f8559906eed885210"
|
||||
"sha": "071b9b841a987aa93409d4db1499237a5120bc63"
|
||||
},
|
||||
"homepage": "https://posthog.com/docs/model-context-protocol"
|
||||
},
|
||||
@@ -2016,7 +2044,7 @@
|
||||
"source": {
|
||||
"source": "url",
|
||||
"url": "https://github.com/Postman-Devrel/postman-claude-code-plugin.git",
|
||||
"sha": "812678b3d1d1956815252d8f25e3ccc10d1bca8f"
|
||||
"sha": "cb8e002ec9b94d84e1d247bcb3e854dec4de0ace"
|
||||
},
|
||||
"homepage": "https://learning.postman.com/docs/developer/postman-mcp-server/"
|
||||
},
|
||||
@@ -2088,7 +2116,7 @@
|
||||
"source": {
|
||||
"source": "url",
|
||||
"url": "https://github.com/qdrant/skills.git",
|
||||
"sha": "0814a0875db7a31bf29e46821668ef1b07f9f696"
|
||||
"sha": "80f1980d126039c762664a3fe660bbad2eb1ec11"
|
||||
},
|
||||
"homepage": "https://skills.qdrant.tech"
|
||||
},
|
||||
@@ -2127,7 +2155,7 @@
|
||||
"source": {
|
||||
"source": "url",
|
||||
"url": "https://github.com/quarkusio/quarkus-agent-mcp.git",
|
||||
"sha": "f5c0dd4c4387531a1d5fcc2717030f2c5f41db85"
|
||||
"sha": "bcab0174a0f3a076a265958d9017da15c1f87d01"
|
||||
},
|
||||
"homepage": "https://quarkus.io"
|
||||
},
|
||||
@@ -2140,7 +2168,7 @@
|
||||
"url": "https://github.com/railwayapp/railway-skills.git",
|
||||
"path": "plugins/railway",
|
||||
"ref": "main",
|
||||
"sha": "72299c62ad19a5b1e7646262f3ba9cdd96d6e2a3"
|
||||
"sha": "aa1e055b0f18d13787232b164cfb7416b553bd03"
|
||||
},
|
||||
"homepage": "https://docs.railway.com/ai/claude-code-plugin"
|
||||
},
|
||||
@@ -2163,7 +2191,7 @@
|
||||
"source": "url",
|
||||
"url": "https://github.com/RevenueCat/rc-claude-code-plugin.git",
|
||||
"path": "revenuecat",
|
||||
"sha": "473fd504bf13d25e76bf4a0267b42be3794f6266"
|
||||
"sha": "e0470e8f5413decb0dc67156057b4b5cfc6df447"
|
||||
},
|
||||
"homepage": "https://www.revenuecat.com"
|
||||
},
|
||||
@@ -2215,7 +2243,7 @@
|
||||
"source": "url",
|
||||
"url": "https://github.com/RevenueCat/rc-claude-code-plugin.git",
|
||||
"path": "revenuecat",
|
||||
"sha": "473fd504bf13d25e76bf4a0267b42be3794f6266"
|
||||
"sha": "e0470e8f5413decb0dc67156057b4b5cfc6df447"
|
||||
},
|
||||
"homepage": "https://www.revenuecat.com"
|
||||
},
|
||||
@@ -2300,7 +2328,7 @@
|
||||
"url": "https://github.com/awslabs/agent-plugins.git",
|
||||
"path": "plugins/sagemaker-ai",
|
||||
"ref": "main",
|
||||
"sha": "f985fddc69953f103d9c16fa9e97096d2bc29b02"
|
||||
"sha": "7a17df718d26f07414b876e77a7480fa25089b08"
|
||||
},
|
||||
"homepage": "https://github.com/awslabs/agent-plugins"
|
||||
},
|
||||
@@ -2314,7 +2342,7 @@
|
||||
"source": {
|
||||
"source": "url",
|
||||
"url": "https://github.com/sanity-io/agent-toolkit.git",
|
||||
"sha": "be762f2fc6c82432ff7e4e5d6f27becfc7a95b06"
|
||||
"sha": "2d7b7c08a31a6e5b613e33a9edc76456e4d7c052"
|
||||
},
|
||||
"homepage": "https://www.sanity.io"
|
||||
},
|
||||
@@ -2348,7 +2376,7 @@
|
||||
"url": "https://github.com/SAP/open-ux-tools.git",
|
||||
"path": "packages/fiori-mcp-server",
|
||||
"ref": "main",
|
||||
"sha": "67ad23a4670a26c0fb0e1560601e8eb6ddcb43ad"
|
||||
"sha": "384fb88f5b4662ec0f7e1ac81689ebccaa9d7cb8"
|
||||
},
|
||||
"homepage": "https://github.com/SAP/open-ux-tools/tree/main/packages/fiori-mcp-server"
|
||||
},
|
||||
@@ -2387,7 +2415,7 @@
|
||||
{
|
||||
"name": "security-guidance",
|
||||
"description": "Security review for Claude-generated code. Pattern-based warnings on edits, LLM-powered diff review on Stop, and an agentic commit reviewer that catches injection, XSS, SSRF, hardcoded secrets, and 25+ other vulnerability classes.",
|
||||
"version": "2.0.3",
|
||||
"version": "2.0.7",
|
||||
"author": {
|
||||
"name": "Anthropic",
|
||||
"email": "support@anthropic.com"
|
||||
@@ -2415,7 +2443,7 @@
|
||||
"source": {
|
||||
"source": "url",
|
||||
"url": "https://github.com/getsentry/sentry-for-claude.git",
|
||||
"sha": "9780bfc111f97b359893169e79c33d1e393891e5"
|
||||
"sha": "765cca4683e77271900fdf3521a555a04528baaf"
|
||||
},
|
||||
"homepage": "https://github.com/getsentry/sentry-for-claude/tree/main"
|
||||
},
|
||||
@@ -2431,7 +2459,7 @@
|
||||
"url": "https://github.com/getsentry/cli.git",
|
||||
"path": "plugins/sentry-cli",
|
||||
"ref": "main",
|
||||
"sha": "a5f26c3398ddfa458e32e2f139eb80ee3d9a8abf"
|
||||
"sha": "4fda3dc169b914a8dec53c18d127ccbe67dbbf3e"
|
||||
},
|
||||
"homepage": "https://sentry.io"
|
||||
},
|
||||
@@ -2534,7 +2562,7 @@
|
||||
"url": "https://github.com/Snowflake-Labs/snowflake-ai-kit.git",
|
||||
"path": "plugins/cortex-code",
|
||||
"ref": "main",
|
||||
"sha": "7d2c7e7e0788e255019a64a8690aa5f85d073a2c"
|
||||
"sha": "5a8f277f623394838ee76399261f4704c19eaba7"
|
||||
},
|
||||
"homepage": "https://docs.snowflake.com/en/user-guide/cortex-code"
|
||||
},
|
||||
@@ -2548,7 +2576,7 @@
|
||||
"source": {
|
||||
"source": "url",
|
||||
"url": "https://github.com/SonarSource/sonarqube-agent-plugins.git",
|
||||
"sha": "8c46904b2c21eb98d827c185e15ef5f6dd820312"
|
||||
"sha": "25460dd53961fb4dba3c4b9026b29dfbbd3d87e0"
|
||||
},
|
||||
"homepage": "https://www.sonarsource.com"
|
||||
},
|
||||
@@ -2608,7 +2636,7 @@
|
||||
"url": "https://github.com/stripe/ai.git",
|
||||
"path": "providers/claude/plugin",
|
||||
"ref": "main",
|
||||
"sha": "d076d0558c3b3d86149c2dddc84054fe9c6dd3e0"
|
||||
"sha": "7e7f72eb42e06f79e7bc75f86e9395f4c8232c00"
|
||||
},
|
||||
"homepage": "https://github.com/stripe/ai/tree/main/providers/claude/plugin"
|
||||
},
|
||||
@@ -2620,7 +2648,7 @@
|
||||
"source": "url",
|
||||
"url": "https://github.com/sumup/sumup-skills.git",
|
||||
"path": "providers/claude/plugin",
|
||||
"sha": "5b9b2d72c63fefd9038db0a9c571d3d64ff6353c"
|
||||
"sha": "b69ff6f5afcd5934af70529e529c0dd8abe46cbe"
|
||||
},
|
||||
"homepage": "https://www.sumup.com/"
|
||||
},
|
||||
@@ -2676,7 +2704,7 @@
|
||||
"source": {
|
||||
"source": "url",
|
||||
"url": "https://github.com/JetBrains/teamcity-cli.git",
|
||||
"sha": "67e21f0be908daa7ca1e04c8016d1bc81750baee"
|
||||
"sha": "4865b1b75e77889355393a46dc56a0363ce3330d"
|
||||
},
|
||||
"homepage": "https://www.jetbrains.com/teamcity/"
|
||||
},
|
||||
@@ -2769,7 +2797,7 @@
|
||||
"url": "https://github.com/UI5/plugins-coding-agents.git",
|
||||
"path": "plugins/ui5",
|
||||
"ref": "main",
|
||||
"sha": "6d72751f0b2983c379aaa457fe4c7cf4a075a66d"
|
||||
"sha": "80f2d93287054f9d30dd990e842e15bcfca581c9"
|
||||
},
|
||||
"homepage": "https://github.com/UI5/plugins-coding-agents"
|
||||
},
|
||||
@@ -2803,7 +2831,7 @@
|
||||
"url": "https://github.com/val-town/plugins.git",
|
||||
"path": "plugin",
|
||||
"ref": "main",
|
||||
"sha": "02631f998eda9b88d73d699703b062db059d506b"
|
||||
"sha": "1f7928397349f2ccb228302d8b062c7f20745871"
|
||||
},
|
||||
"homepage": "https://val.town"
|
||||
},
|
||||
@@ -2842,7 +2870,7 @@
|
||||
"source": {
|
||||
"source": "url",
|
||||
"url": "https://github.com/vercel/vercel-plugin.git",
|
||||
"sha": "6e51924cb249e2941de005d59f1ac6f768477b98"
|
||||
"sha": "b73bc95636c4f4d749ea242b669e0f78f5e72751"
|
||||
},
|
||||
"homepage": "https://github.com/vercel/vercel-plugin"
|
||||
},
|
||||
@@ -2856,7 +2884,7 @@
|
||||
"source": {
|
||||
"source": "url",
|
||||
"url": "https://github.com/explorium-ai/vibeprospecting-plugin.git",
|
||||
"sha": "aa5903f52d79e7f2a5f9c324c6fff7d5a5d92631"
|
||||
"sha": "14cb2971a99661382f5a56a9caa7c2d526c4e444"
|
||||
},
|
||||
"homepage": "https://www.vibeprospecting.ai/product/claude-plugin"
|
||||
},
|
||||
@@ -2881,7 +2909,7 @@
|
||||
"source": {
|
||||
"source": "url",
|
||||
"url": "https://github.com/wix/skills.git",
|
||||
"sha": "cda44c29c9155f6e7b3440f953969721aed246be"
|
||||
"sha": "561315d22a49544d6518d3a753973d3a95dfafcc"
|
||||
},
|
||||
"homepage": "https://dev.wix.com/docs/wix-cli/guides/development/about-wix-skills"
|
||||
},
|
||||
@@ -2934,7 +2962,7 @@
|
||||
"url": "https://github.com/zapier/zapier-mcp.git",
|
||||
"path": "plugins/zapier",
|
||||
"ref": "main",
|
||||
"sha": "770167c572deaf74c588b45d88003ddf2145d608"
|
||||
"sha": "ea8ed6b4de66e9bb46c12b3a38da8286e3770ad9"
|
||||
},
|
||||
"homepage": "https://github.com/zapier/zapier-mcp/tree/main/plugins/zapier"
|
||||
},
|
||||
@@ -2988,7 +3016,7 @@
|
||||
"source": {
|
||||
"source": "url",
|
||||
"url": "https://github.com/zscaler/zscaler-mcp-server.git",
|
||||
"sha": "f84ce4f0ed48047614a4202ac311cbdf00ea9a10"
|
||||
"sha": "a2162c384e1ffb68b3bf14783ea9a1a762c85ff5"
|
||||
},
|
||||
"homepage": "https://github.com/zscaler/zscaler-mcp-server"
|
||||
}
|
||||
|
||||
177
plugins/frontend-design/skills/frontend-design/LICENSE.txt
Normal file
177
plugins/frontend-design/skills/frontend-design/LICENSE.txt
Normal file
@@ -0,0 +1,177 @@
|
||||
|
||||
Apache License
|
||||
Version 2.0, January 2004
|
||||
http://www.apache.org/licenses/
|
||||
|
||||
TERMS AND CONDITIONS FOR USE, REPRODUCTION, AND DISTRIBUTION
|
||||
|
||||
1. Definitions.
|
||||
|
||||
"License" shall mean the terms and conditions for use, reproduction,
|
||||
and distribution as defined by Sections 1 through 9 of this document.
|
||||
|
||||
"Licensor" shall mean the copyright owner or entity authorized by
|
||||
the copyright owner that is granting the License.
|
||||
|
||||
"Legal Entity" shall mean the union of the acting entity and all
|
||||
other entities that control, are controlled by, or are under common
|
||||
control with that entity. For the purposes of this definition,
|
||||
"control" means (i) the power, direct or indirect, to cause the
|
||||
direction or management of such entity, whether by contract or
|
||||
otherwise, or (ii) ownership of fifty percent (50%) or more of the
|
||||
outstanding shares, or (iii) beneficial ownership of such entity.
|
||||
|
||||
"You" (or "Your") shall mean an individual or Legal Entity
|
||||
exercising permissions granted by this License.
|
||||
|
||||
"Source" form shall mean the preferred form for making modifications,
|
||||
including but not limited to software source code, documentation
|
||||
source, and configuration files.
|
||||
|
||||
"Object" form shall mean any form resulting from mechanical
|
||||
transformation or translation of a Source form, including but
|
||||
not limited to compiled object code, generated documentation,
|
||||
and conversions to other media types.
|
||||
|
||||
"Work" shall mean the work of authorship, whether in Source or
|
||||
Object form, made available under the License, as indicated by a
|
||||
copyright notice that is included in or attached to the work
|
||||
(an example is provided in the Appendix below).
|
||||
|
||||
"Derivative Works" shall mean any work, whether in Source or Object
|
||||
form, that is based on (or derived from) the Work and for which the
|
||||
editorial revisions, annotations, elaborations, or other modifications
|
||||
represent, as a whole, an original work of authorship. For the purposes
|
||||
of this License, Derivative Works shall not include works that remain
|
||||
separable from, or merely link (or bind by name) to the interfaces of,
|
||||
the Work and Derivative Works thereof.
|
||||
|
||||
"Contribution" shall mean any work of authorship, including
|
||||
the original version of the Work and any modifications or additions
|
||||
to that Work or Derivative Works thereof, that is intentionally
|
||||
submitted to Licensor for inclusion in the Work by the copyright owner
|
||||
or by an individual or Legal Entity authorized to submit on behalf of
|
||||
the copyright owner. For the purposes of this definition, "submitted"
|
||||
means any form of electronic, verbal, or written communication sent
|
||||
to the Licensor or its representatives, including but not limited to
|
||||
communication on electronic mailing lists, source code control systems,
|
||||
and issue tracking systems that are managed by, or on behalf of, the
|
||||
Licensor for the purpose of discussing and improving the Work, but
|
||||
excluding communication that is conspicuously marked or otherwise
|
||||
designated in writing by the copyright owner as "Not a Contribution."
|
||||
|
||||
"Contributor" shall mean Licensor and any individual or Legal Entity
|
||||
on behalf of whom a Contribution has been received by Licensor and
|
||||
subsequently incorporated within the Work.
|
||||
|
||||
2. Grant of Copyright License. Subject to the terms and conditions of
|
||||
this License, each Contributor hereby grants to You a perpetual,
|
||||
worldwide, non-exclusive, no-charge, royalty-free, irrevocable
|
||||
copyright license to reproduce, prepare Derivative Works of,
|
||||
publicly display, publicly perform, sublicense, and distribute the
|
||||
Work and such Derivative Works in Source or Object form.
|
||||
|
||||
3. Grant of Patent License. Subject to the terms and conditions of
|
||||
this License, each Contributor hereby grants to You a perpetual,
|
||||
worldwide, non-exclusive, no-charge, royalty-free, irrevocable
|
||||
(except as stated in this section) patent license to make, have made,
|
||||
use, offer to sell, sell, import, and otherwise transfer the Work,
|
||||
where such license applies only to those patent claims licensable
|
||||
by such Contributor that are necessarily infringed by their
|
||||
Contribution(s) alone or by combination of their Contribution(s)
|
||||
with the Work to which such Contribution(s) was submitted. If You
|
||||
institute patent litigation against any entity (including a
|
||||
cross-claim or counterclaim in a lawsuit) alleging that the Work
|
||||
or a Contribution incorporated within the Work constitutes direct
|
||||
or contributory patent infringement, then any patent licenses
|
||||
granted to You under this License for that Work shall terminate
|
||||
as of the date such litigation is filed.
|
||||
|
||||
4. Redistribution. You may reproduce and distribute copies of the
|
||||
Work or Derivative Works thereof in any medium, with or without
|
||||
modifications, and in Source or Object form, provided that You
|
||||
meet the following conditions:
|
||||
|
||||
(a) You must give any other recipients of the Work or
|
||||
Derivative Works a copy of this License; and
|
||||
|
||||
(b) You must cause any modified files to carry prominent notices
|
||||
stating that You changed the files; and
|
||||
|
||||
(c) You must retain, in the Source form of any Derivative Works
|
||||
that You distribute, all copyright, patent, trademark, and
|
||||
attribution notices from the Source form of the Work,
|
||||
excluding those notices that do not pertain to any part of
|
||||
the Derivative Works; and
|
||||
|
||||
(d) If the Work includes a "NOTICE" text file as part of its
|
||||
distribution, then any Derivative Works that You distribute must
|
||||
include a readable copy of the attribution notices contained
|
||||
within such NOTICE file, excluding those notices that do not
|
||||
pertain to any part of the Derivative Works, in at least one
|
||||
of the following places: within a NOTICE text file distributed
|
||||
as part of the Derivative Works; within the Source form or
|
||||
documentation, if provided along with the Derivative Works; or,
|
||||
within a display generated by the Derivative Works, if and
|
||||
wherever such third-party notices normally appear. The contents
|
||||
of the NOTICE file are for informational purposes only and
|
||||
do not modify the License. You may add Your own attribution
|
||||
notices within Derivative Works that You distribute, alongside
|
||||
or as an addendum to the NOTICE text from the Work, provided
|
||||
that such additional attribution notices cannot be construed
|
||||
as modifying the License.
|
||||
|
||||
You may add Your own copyright statement to Your modifications and
|
||||
may provide additional or different license terms and conditions
|
||||
for use, reproduction, or distribution of Your modifications, or
|
||||
for any such Derivative Works as a whole, provided Your use,
|
||||
reproduction, and distribution of the Work otherwise complies with
|
||||
the conditions stated in this License.
|
||||
|
||||
5. Submission of Contributions. Unless You explicitly state otherwise,
|
||||
any Contribution intentionally submitted for inclusion in the Work
|
||||
by You to the Licensor shall be under the terms and conditions of
|
||||
this License, without any additional terms or conditions.
|
||||
Notwithstanding the above, nothing herein shall supersede or modify
|
||||
the terms of any separate license agreement you may have executed
|
||||
with Licensor regarding such Contributions.
|
||||
|
||||
6. Trademarks. This License does not grant permission to use the trade
|
||||
names, trademarks, service marks, or product names of the Licensor,
|
||||
except as required for reasonable and customary use in describing the
|
||||
origin of the Work and reproducing the content of the NOTICE file.
|
||||
|
||||
7. Disclaimer of Warranty. Unless required by applicable law or
|
||||
agreed to in writing, Licensor provides the Work (and each
|
||||
Contributor provides its Contributions) on an "AS IS" BASIS,
|
||||
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
|
||||
implied, including, without limitation, any warranties or conditions
|
||||
of TITLE, NON-INFRINGEMENT, MERCHANTABILITY, or FITNESS FOR A
|
||||
PARTICULAR PURPOSE. You are solely responsible for determining the
|
||||
appropriateness of using or redistributing the Work and assume any
|
||||
risks associated with Your exercise of permissions under this License.
|
||||
|
||||
8. Limitation of Liability. In no event and under no legal theory,
|
||||
whether in tort (including negligence), contract, or otherwise,
|
||||
unless required by applicable law (such as deliberate and grossly
|
||||
negligent acts) or agreed to in writing, shall any Contributor be
|
||||
liable to You for damages, including any direct, indirect, special,
|
||||
incidental, or consequential damages of any character arising as a
|
||||
result of this License or out of the use or inability to use the
|
||||
Work (including but not limited to damages for loss of goodwill,
|
||||
work stoppage, computer failure or malfunction, or any and all
|
||||
other commercial damages or losses), even if such Contributor
|
||||
has been advised of the possibility of such damages.
|
||||
|
||||
9. Accepting Warranty or Additional Liability. While redistributing
|
||||
the Work or Derivative Works thereof, You may choose to offer,
|
||||
and charge a fee for, acceptance of support, warranty, indemnity,
|
||||
or other liability obligations and/or rights consistent with this
|
||||
License. However, in accepting such obligations, You may act only
|
||||
on Your own behalf and on Your sole responsibility, not on behalf
|
||||
of any other Contributor, and only if You agree to indemnify,
|
||||
defend, and hold each Contributor harmless for any liability
|
||||
incurred by, or claims asserted against, such Contributor by reason
|
||||
of your accepting any such warranty or additional liability.
|
||||
|
||||
END OF TERMS AND CONDITIONS
|
||||
@@ -1,42 +1,55 @@
|
||||
---
|
||||
name: frontend-design
|
||||
description: Create distinctive, production-grade frontend interfaces with high design quality. Use this skill when the user asks to build web components, pages, or applications. Generates creative, polished code that avoids generic AI aesthetics.
|
||||
description: Guidance for distinctive, intentional visual design when building new UI or reshaping an existing one. Helps with aesthetic direction, typography, and making choices that don't read as templated defaults.
|
||||
license: Complete terms in LICENSE.txt
|
||||
---
|
||||
|
||||
This skill guides creation of distinctive, production-grade frontend interfaces that avoid generic "AI slop" aesthetics. Implement real working code with exceptional attention to aesthetic details and creative choices.
|
||||
# Frontend Design
|
||||
|
||||
The user provides frontend requirements: a component, page, application, or interface to build. They may include context about the purpose, audience, or technical constraints.
|
||||
Approach this as the design lead at a small studio known for giving every client a visual identity that could not be mistaken for anyone else's. This client has already rejected proposals that felt templated, and is paying for a distinctive point of view: make deliberate, opinionated choices about palette, typography, and layout that are specific to this brief, and take one real aesthetic risk you can justify.
|
||||
|
||||
## Design Thinking
|
||||
## Ground it in the subject
|
||||
|
||||
Before coding, understand the context and commit to a BOLD aesthetic direction:
|
||||
- **Purpose**: What problem does this interface solve? Who uses it?
|
||||
- **Tone**: Pick an extreme: brutally minimal, maximalist chaos, retro-futuristic, organic/natural, luxury/refined, playful/toy-like, editorial/magazine, brutalist/raw, art deco/geometric, soft/pastel, industrial/utilitarian, etc. There are so many flavors to choose from. Use these for inspiration but design one that is true to the aesthetic direction.
|
||||
- **Constraints**: Technical requirements (framework, performance, accessibility).
|
||||
- **Differentiation**: What makes this UNFORGETTABLE? What's the one thing someone will remember?
|
||||
If the brief does not pin down what the product or subject is, pin it yourself before designing: name one concrete subject, its audience, and the page's single job, and state your choice. If there's any information in your memory about the human's preferences, context about what they're building, or designs you've made before – use that as a hint. The subject's own world, its materials, instruments, artifacts, and vernacular, is where distinctive choices come from. Build with the brief's real content and subject matter throughout.
|
||||
|
||||
**CRITICAL**: Choose a clear conceptual direction and execute it with precision. Bold maximalism and refined minimalism both work - the key is intentionality, not intensity.
|
||||
## Design principles
|
||||
|
||||
Then implement working code (HTML/CSS/JS, React, Vue, etc.) that is:
|
||||
- Production-grade and functional
|
||||
- Visually striking and memorable
|
||||
- Cohesive with a clear aesthetic point-of-view
|
||||
- Meticulously refined in every detail
|
||||
For web designs, the hero is a thesis. Open with the most characteristic thing in the subject's world, in whatever form makes sense for it: a headline, an image, an animation, a live demo, an interactive moment. Be deliberate with your choice: a big number with a small label, supporting stats, and a gradient accent is the template answer, only use if that's truly the best option.
|
||||
|
||||
## Frontend Aesthetics Guidelines
|
||||
Typography carries the personality of the page. Pair the display and body faces deliberately, not the same families you would reach for on any other project, and set a clear type scale with intentional weights, widths, and spacing. Make the type treatment itself a memorable part of the design, not a neutral delivery vehicle for the content.
|
||||
|
||||
Focus on:
|
||||
- **Typography**: Choose fonts that are beautiful, unique, and interesting. Avoid generic fonts like Arial and Inter; opt instead for distinctive choices that elevate the frontend's aesthetics; unexpected, characterful font choices. Pair a distinctive display font with a refined body font.
|
||||
- **Color & Theme**: Commit to a cohesive aesthetic. Use CSS variables for consistency. Dominant colors with sharp accents outperform timid, evenly-distributed palettes.
|
||||
- **Motion**: Use animations for effects and micro-interactions. Prioritize CSS-only solutions for HTML. Use Motion library for React when available. Focus on high-impact moments: one well-orchestrated page load with staggered reveals (animation-delay) creates more delight than scattered micro-interactions. Use scroll-triggering and hover states that surprise.
|
||||
- **Spatial Composition**: Unexpected layouts. Asymmetry. Overlap. Diagonal flow. Grid-breaking elements. Generous negative space OR controlled density.
|
||||
- **Backgrounds & Visual Details**: Create atmosphere and depth rather than defaulting to solid colors. Add contextual effects and textures that match the overall aesthetic. Apply creative forms like gradient meshes, noise textures, geometric patterns, layered transparencies, dramatic shadows, decorative borders, custom cursors, and grain overlays.
|
||||
Structure is information. Structural devices, numbering, eyebrows, dividers, labels, should encode something true about the content, not decorate it. Many generic designs use numbered markers (01 / 02 / 03), but that's only appropriate if the content actually is a sequence - like a real process or a typed timeline where order carries information the reader needs. Question if choices like numbered markers actually make sense before incorporating them.
|
||||
|
||||
NEVER use generic AI-generated aesthetics like overused font families (Inter, Roboto, Arial, system fonts), cliched color schemes (particularly purple gradients on white backgrounds), predictable layouts and component patterns, and cookie-cutter design that lacks context-specific character.
|
||||
Leverage motion deliberately. Think about where and if animation can serve the subject: a page-load sequence, a scroll-triggered reveal, hover micro-interactions, ambient atmosphere. An orchestrated moment usually lands harder than scattered effects; choose what the direction calls for. However, sometimes less is more, and extra animation contributes to the feeling that the design is AI-generated.
|
||||
|
||||
Interpret creatively and make unexpected choices that feel genuinely designed for the context. No design should be the same. Vary between light and dark themes, different fonts, different aesthetics. NEVER converge on common choices (Space Grotesk, for example) across generations.
|
||||
Match complexity to the vision. Maximalist directions need elaborate execution; minimal directions need precision in spacing, type, and detail. Elegance is executing the chosen vision well.
|
||||
|
||||
**IMPORTANT**: Match implementation complexity to the aesthetic vision. Maximalist designs need elaborate code with extensive animations and effects. Minimalist or refined designs need restraint, precision, and careful attention to spacing, typography, and subtle details. Elegance comes from executing the vision well.
|
||||
Consider written content carefully. Often a design brief may not contain real content, and it's up to you to come up with copy. Copy can make a design feel as templated as the design itself. See the below section on writing for more guidance.
|
||||
|
||||
Remember: Claude is capable of extraordinary creative work. Don't hold back, show what can truly be created when thinking outside the box and committing fully to a distinctive vision.
|
||||
## Process: brainstorm, explore, plan, critique, build, critique again
|
||||
|
||||
For calibration: AI-generated design right now clusters around three looks: (1) a warm cream background (near #F4F1EA) with a high-contrast serif display and a terracotta accent; (2) a near-black background with a single bright acid-green or vermilion accent; (3) a broadsheet-style layout with hairline rules, zero border-radius, and dense newspaper-like columns. All three are legitimate for some briefs, but they are defaults rather than choices, and they appear regardless of subject. Where the brief pins down a visual direction, follow it exactly — the brief's own words always win, including when it asks for one of these looks. Where it leaves an axis free, don't spend that freedom on one of these defaults. Just like a human designer who's hired, there's often a careful balance between doing what you're good at and taking each project as a chance to experiment and learn.
|
||||
|
||||
Work in two passes. First, brainstorm a short design plan based on the human's design brief: create a compact token system with color, type, layout, and signature. Color: describe the palette as 4–6 named hex values. Type: the typefaces for 2+ roles (a characterful display face that's used with restraint, a complementary body face, and a utility face for captions or data if needed). Layout: a layout concept, using one-sentence prose descriptions and ASCII wireframes to ideate and compare. Signature: the single unique element this page will be remembered by that embodies the brief in an appropriate way.
|
||||
|
||||
Then review that plan against the brief before building: if any part of it reads like the generic default you would produce for any similar page (work through a similar prompt to see if you arrive somewhere similar) rather than a choice made for this specific brief — revise that part, say what you changed and why. Only after you've confirmed the relative uniqueness of your design plan should you start to write the code, following the revised plan exactly and deriving every color and type decision from it.
|
||||
|
||||
When writing the code, be careful of structuring your CSS selector specificities. It's easy to generate CSS classes that cancel each other out (especially with a type-based selector like .section and a element-based selector like .cta). This can happen often with paddings/margins between sections.
|
||||
|
||||
Try to do a lot of this planning and iteration in your thinking, and only show ideas to the user when you have higher confidence it'll delight them.
|
||||
|
||||
## Restraint and self-critique
|
||||
|
||||
Spend your boldness in one place. Let the signature element be the one memorable thing, keep everything around it quiet and disciplined, and cut any decoration that does not serve the brief. Not taking a risk can be a risk itself! Build to a quality floor without announcing it: responsive down to mobile, visible keyboard focus, reduced motion respected. Critique your own work as you build, taking screenshots if your environment supports it – a picture is worth 1000 tokens. Consider Chanel's advice: before leaving the house, take a look in the mirror and remove one accessory. Human creators have memory and always try to do something new, so if you have a space to quickly jot down notes about what you've tried, it can help you in future passes.
|
||||
|
||||
## More on writing in design
|
||||
|
||||
Words appear in a design for one reason: to make it easier to understand, and therefore easier to use. They are design material, not decoration. Bring the same intentionality to copy that you would bring to spacing and color. Before writing anything, ask what the design needs to say, and how it can best be said to help the person navigate the experience.
|
||||
|
||||
Write from the end user's side of the screen. Name things by what people control and recognize, never by how the system is built. A person manages notifications, not webhook config. Describe what something does in plain terms rather than selling it. Being specific is always better than being clever.
|
||||
|
||||
Use active voice as default. A control should say exactly what happens when it's used: "Save changes," not "Submit." An action keeps the same name through the whole flow, so the button that says "Publish" produces a toast that says "Published." The vocabulary of an interface is the signposting for someone navigating the product. Cohesion and consistency are how people learn their way around.
|
||||
|
||||
Treat failure and emptiness as moments for direction, not mood. Explain what went wrong and how to fix it, in the interface's voice rather than a person's. Errors don't apologize, and they are never vague about what happened. An empty screen is an invitation to act.
|
||||
|
||||
Keep the register conversational and tuned: plain verbs, sentence case, no filler, with tone matched to the brand and the audience. Let each element do exactly one job. A label labels, an example demonstrates, and nothing quietly does double duty.
|
||||
|
||||
@@ -1,6 +1,6 @@
|
||||
{
|
||||
"name": "security-guidance",
|
||||
"version": "2.0.3",
|
||||
"version": "2.0.7",
|
||||
"description": "Security review for Claude-generated code. Pattern-based warnings on edits, LLM-powered diff review on Stop, and an agentic commit reviewer that catches injection, XSS, SSRF, hardcoded secrets, and 25+ other vulnerability classes.",
|
||||
"author": {
|
||||
"name": "David Dworken",
|
||||
|
||||
@@ -40,6 +40,26 @@ BUILD_FAILED = 3 # venv create or pip install raised/timed out
|
||||
SKIP_SENTINEL = 5 # another SessionStart is currently building
|
||||
HOOK_PY_INCOMPATIBLE = 6 # hook interpreter is <3.10 — SDK syntax can't load
|
||||
# here no matter how the venv was built. See #2071.
|
||||
# --target fallback: when `python -m venv` can't bootstrap pip (ensurepip
|
||||
# missing — Debian python3-venv not installed, or a python.org/pyenv build
|
||||
# without ensurepip), fall back to `pip install --target <dir>` which needs
|
||||
# only the system pip, not venv/ensurepip. Telemetry (v2.0.4 sdk_has_pip
|
||||
# probe) confirmed ~95% of venv_ensurepip_fail users HAVE pip, so this
|
||||
# recovers the agentic reviewer for them instead of degrading to pattern +
|
||||
# single-shot review. See #2154 follow-up.
|
||||
BUILT_TARGET = 7 # venv ensurepip failed → SDK pip-installed via --target
|
||||
NOOP_TARGET = 8 # --target libs already present and importable
|
||||
SKIP_COOLDOWN = 9 # a recent build was signal-killed (memory pressure) — not
|
||||
# retrying this session to avoid burning the user's
|
||||
# memory/CPU on a build that keeps getting killed. CCR
|
||||
# repro confirmed the dominant Linux BUILD_FAILED is a
|
||||
# SIGKILL/SIGSEGV of the memory-heavy venv+pip subprocess
|
||||
# (rc<0, empty streams). See #2154 follow-up.
|
||||
|
||||
# How long to skip rebuilds after a signal kill. Retries at most once per
|
||||
# window so a machine whose memory frees up still recovers (just not every
|
||||
# session). Keyed by marker mtime.
|
||||
SIGNAL_KILL_COOLDOWN_SEC = 24 * 3600
|
||||
|
||||
|
||||
# Phase + err-kind integer encoding for sdk_bootstrap_phase / sdk_bootstrap_err.
|
||||
@@ -63,6 +83,7 @@ SDK_BOOTSTRAP_PHASE_CODES = {
|
||||
"venv": 2, # python -m venv --clear
|
||||
"pip": 3, # pip install
|
||||
"main": 4, # uncaught exception above main()
|
||||
"pip_target": 5, # `pip install --target` fallback (venv ensurepip failed)
|
||||
}
|
||||
SDK_BOOTSTRAP_ERR_CODES = {
|
||||
"pip_no_match": 1,
|
||||
@@ -75,6 +96,11 @@ SDK_BOOTSTRAP_ERR_CODES = {
|
||||
"proxy_auth": 8,
|
||||
"stderr_timeout": 9, # pip stderr containing "timeout"/"timed out"
|
||||
"subprocess_timeout": 10, # subprocess.TimeoutExpired (>120s)
|
||||
"signal_killed": 16, # venv/pip subprocess killed by a signal
|
||||
# (rc<0 or 128+sig) — OOM-killer SIGKILL /
|
||||
# RLIMIT_AS SIGSEGV, empty streams. The
|
||||
# actual rc rides in sdk_bootstrap_rc. This
|
||||
# is the dominant Linux failure (CCR repro).
|
||||
# Venv-stage specific categories added after PR #2112 telemetry surfaced
|
||||
# 2,406 phase=2/err=99 sessions in the first 3h of v2.0.1 — venv phase
|
||||
# failing in ways the original pip-flavored patterns didn't catch. These
|
||||
@@ -102,6 +128,41 @@ SDK_BOOTSTRAP_ERR_CODES = {
|
||||
"_uncategorized": 99,
|
||||
}
|
||||
|
||||
# Exception-type encoding for the "exc:<TypeName>" err_kinds (the generic
|
||||
# `except Exception` path — venv/pip raised a Python exception rather than
|
||||
# a CalledProcessError with categorizable stderr).
|
||||
#
|
||||
# #2154 telemetry surfaced that the dominant remaining venv BUILD_FAILED
|
||||
# bucket (phase=venv, err=99) is ~99% `exc:` with stderr_sig=NULL — i.e.
|
||||
# exceptions, not stderr-bearing subprocess failures — so the stderr_sig
|
||||
# hash couldn't distinguish them. This maps the exception TYPE to a stable
|
||||
# code so BQ can tell FileNotFoundError (python/venv binary missing) from
|
||||
# PermissionError (read-only home) from a bare OSError, etc.
|
||||
#
|
||||
# All the FileNotFoundError/PermissionError/etc. entries are OSError
|
||||
# subclasses, so they ALSO carry an errno (see _encode_errno) — the type
|
||||
# code gives the Python class, errno gives the OS-level cause. APPEND-ONLY.
|
||||
SDK_BOOTSTRAP_EXC_CODES = {
|
||||
"FileNotFoundError": 1, # interpreter/venv path component missing
|
||||
"PermissionError": 2, # read-only home, sandboxed FS
|
||||
"NotADirectoryError": 3,
|
||||
"IsADirectoryError": 4,
|
||||
"FileExistsError": 5, # (sentinel race is handled separately; this
|
||||
# is FileExistsError from elsewhere in venv)
|
||||
"OSError": 6, # bare OSError — errno carries the real cause
|
||||
"BlockingIOError": 7,
|
||||
"BrokenPipeError": 8,
|
||||
"ConnectionError": 9,
|
||||
"TimeoutError": 10, # distinct from subprocess.TimeoutExpired
|
||||
"InterruptedError": 11,
|
||||
"MemoryError": 12,
|
||||
"UnicodeDecodeError": 13,
|
||||
"ValueError": 14,
|
||||
"RuntimeError": 15,
|
||||
# 16–98 reserved; APPEND-ONLY.
|
||||
"_other_exc": 99, # an exception type not in this map
|
||||
}
|
||||
|
||||
|
||||
def _encode_phase(s):
|
||||
"""Map err_phase string to its telemetry integer code, or 0 if unset.
|
||||
@@ -120,6 +181,10 @@ def _encode_err_kind(s):
|
||||
return 0
|
||||
if s in SDK_BOOTSTRAP_ERR_CODES:
|
||||
return SDK_BOOTSTRAP_ERR_CODES[s]
|
||||
# "signal_killed:<rc>" carries the returncode in sdk_bootstrap_rc; the
|
||||
# category maps to the signal_killed code.
|
||||
if s.startswith("signal_killed"):
|
||||
return SDK_BOOTSTRAP_ERR_CODES["signal_killed"]
|
||||
# Prefix matches for the catch-all categories
|
||||
if s.startswith("exc:") or s.startswith("other:") or s == "other":
|
||||
return SDK_BOOTSTRAP_ERR_CODES["_uncategorized"]
|
||||
@@ -127,6 +192,52 @@ def _encode_err_kind(s):
|
||||
return SDK_BOOTSTRAP_ERR_CODES["_uncategorized"]
|
||||
|
||||
|
||||
def _encode_rc(err_kind):
|
||||
"""Extract the subprocess returncode embedded in a 'signal_killed:<rc>'
|
||||
err_kind (e.g. -11 SIGSEGV / -9 SIGKILL / 139 shell-wrapped). Emitted as
|
||||
sdk_bootstrap_rc so BQ can tell OOM-killer (-9) from RLIMIT_AS (-11).
|
||||
Returns 0 when absent/non-numeric."""
|
||||
if not err_kind or not err_kind.startswith("signal_killed:"):
|
||||
return 0
|
||||
try:
|
||||
return int(err_kind.split(":", 1)[1])
|
||||
except (ValueError, IndexError):
|
||||
return 0
|
||||
|
||||
|
||||
def _is_signal_kill(returncode) -> bool:
|
||||
"""A subprocess killed by a signal rather than a clean non-zero exit.
|
||||
subprocess.run (no shell, as used here) reports negative rc = -signum
|
||||
(SIGKILL→-9 OOM-killer, SIGSEGV→-11 RLIMIT_AS, SIGABRT→-6). The 128+sig
|
||||
forms (134/137/139) are defensive for any shell-wrapped path. Paired with
|
||||
empty stdout+stderr this is the memory-kill signature (CCR repro)."""
|
||||
if returncode is None:
|
||||
return False
|
||||
return returncode < 0 or returncode in (134, 137, 139)
|
||||
|
||||
|
||||
def _cooldown_remaining(state_dir) -> float:
|
||||
"""Seconds left in the signal-kill cooldown (0 if none/expired). Reads the
|
||||
marker's mtime; a missing/unreadable marker means not in cooldown."""
|
||||
marker = Path(state_dir) / "agent-sdk-venv.cooldown"
|
||||
try:
|
||||
age = time.time() - marker.stat().st_mtime
|
||||
except OSError:
|
||||
return 0.0
|
||||
return max(0.0, SIGNAL_KILL_COOLDOWN_SEC - age)
|
||||
|
||||
|
||||
def _write_cooldown(state_dir) -> None:
|
||||
"""Start/refresh the signal-kill cooldown so we stop re-attempting a build
|
||||
that keeps getting killed every session. Best-effort."""
|
||||
try:
|
||||
Path(state_dir).mkdir(parents=True, exist_ok=True)
|
||||
(Path(state_dir) / "agent-sdk-venv.cooldown").write_text(
|
||||
time.strftime("%Y-%m-%dT%H:%M:%SZ", time.gmtime()))
|
||||
except OSError:
|
||||
pass
|
||||
|
||||
|
||||
def _encode_stderr_sig(err_kind):
|
||||
"""Bounded integer hash of the stderr tail captured in "other:<tail>"
|
||||
err_kinds. Lets us distinguish patterns INSIDE the _uncategorized
|
||||
@@ -158,6 +269,190 @@ def _encode_stderr_sig(err_kind):
|
||||
return int.from_bytes(h[:2], "big") % 1000
|
||||
|
||||
|
||||
def _encode_exc_kind(err_kind):
|
||||
"""Map an "exc:<TypeName>[:errno]" err_kind to its exception-type code
|
||||
(SDK_BOOTSTRAP_EXC_CODES). Returns 0 for non-exc err_kinds (so the
|
||||
sdk_bootstrap_exc field auto-omits on stderr/categorized failures).
|
||||
Unmapped exception types → 99 (_other_exc)."""
|
||||
if not err_kind or not err_kind.startswith("exc:"):
|
||||
return 0
|
||||
# "exc:OSError:28" → "OSError"; "exc:RuntimeError" → "RuntimeError"
|
||||
name = err_kind[len("exc:"):].split(":", 1)[0].strip()
|
||||
if not name:
|
||||
return 0
|
||||
return SDK_BOOTSTRAP_EXC_CODES.get(name, SDK_BOOTSTRAP_EXC_CODES["_other_exc"])
|
||||
|
||||
|
||||
def _encode_errno(err_kind):
|
||||
"""Extract the OS errno from an "exc:<TypeName>:<errno>" err_kind.
|
||||
OSError-family exceptions embed their errno (ENOENT=2, EACCES=13,
|
||||
ENOSPC=28, …) — the OS-level cause is far more actionable than the
|
||||
Python class alone. Returns 0 when absent/non-numeric (field omitted)."""
|
||||
if not err_kind or not err_kind.startswith("exc:"):
|
||||
return 0
|
||||
parts = err_kind.split(":")
|
||||
if len(parts) < 3:
|
||||
return 0
|
||||
try:
|
||||
return int(parts[2])
|
||||
except (ValueError, IndexError):
|
||||
return 0
|
||||
|
||||
|
||||
def _probe_has_pip() -> bool:
|
||||
"""True iff the current interpreter can run pip (`-m pip --version`).
|
||||
|
||||
Probed only on the venv_ensurepip_fail path (see __main__), NOT on the
|
||||
happy path — it's an extra subprocess we only want when diagnosing a
|
||||
failure. The result decides whether a `pip install --target` fallback
|
||||
(Option A) is even viable for this machine: ensurepip/venv missing but
|
||||
pip present → --target would work; pip also missing → it wouldn't, and
|
||||
the user needs a system package (python3-venv / a complete Python)."""
|
||||
try:
|
||||
r = subprocess.run(
|
||||
[sys.executable, "-m", "pip", "--version"],
|
||||
capture_output=True, timeout=10,
|
||||
)
|
||||
return r.returncode == 0
|
||||
except Exception:
|
||||
return False
|
||||
|
||||
|
||||
def _probe_alt_python() -> int:
|
||||
"""When the hook interpreter is <3.10 (HOOK_PY_INCOMPATIBLE), look for a
|
||||
3.10+ interpreter at well-known install locations that aren't necessarily
|
||||
on the hook's PATH — Homebrew (/opt/homebrew, /usr/local), python.org
|
||||
framework builds, and the `py`/distro layouts. Returns the HIGHEST version
|
||||
found encoded as major*100+minor (e.g. 312), or 0 if none.
|
||||
|
||||
Purpose (telemetry only, for now): size how many of the macOS Python-3.9
|
||||
cohort actually HAVE a newer interpreter that sg-python.sh's PATH probe
|
||||
missed — i.e. how many are RECOVERABLE by an explicit-path search vs.
|
||||
genuinely 3.9-only. Emitted as sdk_alt_py. Existence-checks the versioned
|
||||
binaries (cheap); a later explicit-path search would version-verify before
|
||||
exec'ing. Probed only on the incompatible path, so healthy sessions never
|
||||
pay for it."""
|
||||
candidates = []
|
||||
for minor in (14, 13, 12, 11, 10):
|
||||
candidates += [
|
||||
f"/opt/homebrew/bin/python3.{minor}", # Apple-Silicon Homebrew
|
||||
f"/usr/local/bin/python3.{minor}", # Intel Homebrew / python.org shim
|
||||
f"/Library/Frameworks/Python.framework/Versions/3.{minor}/bin/python3", # python.org
|
||||
f"/usr/bin/python3.{minor}", # distro-managed (Linux)
|
||||
]
|
||||
best = 0
|
||||
for path in candidates:
|
||||
try:
|
||||
if os.access(path, os.X_OK):
|
||||
# path name encodes the minor; parse it back to a code
|
||||
base = os.path.basename(path)
|
||||
minor = None
|
||||
if base.startswith("python3."):
|
||||
minor = int(base.split(".")[1])
|
||||
elif "/Versions/3." in path:
|
||||
minor = int(path.split("/Versions/3.")[1].split("/")[0])
|
||||
if minor is not None:
|
||||
best = max(best, 300 + minor)
|
||||
except (OSError, ValueError, IndexError):
|
||||
continue
|
||||
return best
|
||||
|
||||
|
||||
def _pip_err_from_stderr(stderr_b):
|
||||
"""Categorize a pip-install stderr into a known err_kind (the pip subset
|
||||
of SDK_BOOTSTRAP_ERR_CODES). Used by the --target fallback; mirrors the
|
||||
pip branches of main()'s inline categorizer. Kept as a sibling rather
|
||||
than extracting main()'s chain (which also has venv-phase branches) to
|
||||
avoid disturbing the working venv categorization."""
|
||||
if isinstance(stderr_b, bytes):
|
||||
s = stderr_b.decode("utf-8", errors="replace")
|
||||
else:
|
||||
s = str(stderr_b or "")
|
||||
low = s.lower()
|
||||
if "no matching distribution" in low or "could not find a version" in low:
|
||||
return "pip_no_match"
|
||||
if ("name or service not known" in low or "name resolution" in low
|
||||
or "nodename nor servname" in low or "temporary failure in name" in low):
|
||||
return "dns_fail"
|
||||
if "connection refused" in low or "connection reset" in low:
|
||||
return "conn_refused"
|
||||
if "ssl" in low and ("verify" in low or "certificate" in low):
|
||||
return "ssl_verify"
|
||||
if "permission denied" in low or "read-only file system" in low:
|
||||
return "perm_denied"
|
||||
if "no module named pip" in low or "no module named ensurepip" in low:
|
||||
return "no_pip"
|
||||
if "no space left" in low or "disk quota" in low:
|
||||
return "disk_full"
|
||||
if "proxy" in low and ("authent" in low or "tunnel" in low or "407" in low):
|
||||
return "proxy_auth"
|
||||
if "timeout" in low or "timed out" in low:
|
||||
return "stderr_timeout"
|
||||
tail = next((ln.strip() for ln in reversed(s.splitlines()) if ln.strip()), "")[:60]
|
||||
return f"other:{tail}" if tail else "other"
|
||||
|
||||
|
||||
def _target_dir(state_dir) -> Path:
|
||||
return Path(state_dir) / "agent-sdk-libs"
|
||||
|
||||
|
||||
def _target_sdk_importable(state_dir) -> bool:
|
||||
"""True iff the --target libs dir has an importable claude_agent_sdk,
|
||||
probed with THIS interpreter (the one llm.py will import it from) and the
|
||||
target dir prepended to sys.path. Cheap dir-check first to avoid a
|
||||
subprocess on the common no-target path."""
|
||||
target = _target_dir(state_dir)
|
||||
if not (target / "claude_agent_sdk").is_dir():
|
||||
return False
|
||||
try:
|
||||
r = subprocess.run(
|
||||
[sys.executable, "-c",
|
||||
"import sys; sys.path.insert(0, sys.argv[1]); import claude_agent_sdk",
|
||||
str(target)],
|
||||
capture_output=True, timeout=10,
|
||||
)
|
||||
return r.returncode == 0
|
||||
except Exception:
|
||||
return False
|
||||
|
||||
|
||||
def _build_via_target(state_dir) -> tuple[int, str, str]:
|
||||
"""Fallback install when `python -m venv` can't bootstrap pip (ensurepip
|
||||
missing — Debian python3-venv absent, or a python.org/pyenv build without
|
||||
ensurepip). `pip install --target <dir>` needs only the system pip, not
|
||||
venv/ensurepip. v2.0.4 telemetry (sdk_has_pip) confirmed ~95% of
|
||||
venv_ensurepip_fail users have pip. The consumer (llm.py) adds this flat
|
||||
dir to sys.path. Returns (outcome, err_phase, err_kind).
|
||||
|
||||
--upgrade so a stale/partial target dir from a prior failed attempt
|
||||
doesn't make pip refuse; --prefer-binary mirrors the venv path's wheel
|
||||
preference (ARM64 Windows cryptography)."""
|
||||
target = _target_dir(state_dir)
|
||||
try:
|
||||
subprocess.run(
|
||||
[sys.executable, "-m", "pip", "install",
|
||||
"--target", str(target), "--upgrade",
|
||||
"--disable-pip-version-check", "--prefer-binary", "--no-cache-dir",
|
||||
"claude-agent-sdk"],
|
||||
capture_output=True, timeout=120, check=True,
|
||||
)
|
||||
return BUILT_TARGET, "", ""
|
||||
except subprocess.CalledProcessError as e:
|
||||
# A --target pip install is also memory-heavy, so it too can be
|
||||
# signal-killed under memory pressure — cool down, same as the venv path.
|
||||
if _is_signal_kill(e.returncode):
|
||||
_write_cooldown(state_dir)
|
||||
return BUILD_FAILED, "pip_target", f"signal_killed:{e.returncode}"
|
||||
return BUILD_FAILED, "pip_target", _pip_err_from_stderr(e.stderr)
|
||||
except subprocess.TimeoutExpired:
|
||||
return BUILD_FAILED, "pip_target", "subprocess_timeout"
|
||||
except Exception as e:
|
||||
errno = getattr(e, "errno", None)
|
||||
if isinstance(errno, int):
|
||||
return BUILD_FAILED, "pip_target", f"exc:{type(e).__name__}:{errno}"
|
||||
return BUILD_FAILED, "pip_target", f"exc:{type(e).__name__}"
|
||||
|
||||
|
||||
def _sdk_on_syspath() -> bool:
|
||||
# find_spec is ~10ms; actually importing the SDK pulls in
|
||||
# transitive deps and costs ~800ms — too heavy for a
|
||||
@@ -246,6 +541,20 @@ def main() -> tuple[int, str, str]:
|
||||
except Exception:
|
||||
pass # broken venv; rebuild below
|
||||
|
||||
# If a prior run installed the SDK via the --target fallback (ensurepip
|
||||
# path), reuse it. Only reached when there's no working venv, so healthy
|
||||
# NOOP_VENV users never pay for this probe.
|
||||
if _target_sdk_importable(state_dir):
|
||||
return NOOP_TARGET, "", ""
|
||||
|
||||
# If a recent build was signal-killed (memory pressure), don't re-attempt
|
||||
# this session — the memory-heavy venv+pip just gets killed again, burning
|
||||
# the user's resources. Retry at most once per cooldown window. Reached
|
||||
# only after all no-op probes, so a machine that later gets the SDK via
|
||||
# system/venv/target still short-circuits above.
|
||||
if _cooldown_remaining(state_dir) > 0:
|
||||
return SKIP_COOLDOWN, "", ""
|
||||
|
||||
err_phase = ""
|
||||
err_kind = ""
|
||||
we_own_sentinel = False
|
||||
@@ -278,14 +587,25 @@ def main() -> tuple[int, str, str]:
|
||||
# --prefer-binary tells pip to pick it. Cross-platform safe: no-op
|
||||
# on platforms where the latest version already has a wheel.
|
||||
err_phase = "pip"
|
||||
# --no-cache-dir trims pip's peak memory (no cache read/write/unpack
|
||||
# buffering) — helps marginal low-memory machines get under the OOM
|
||||
# threshold that kills the dominant Linux builds (CCR repro).
|
||||
subprocess.run(
|
||||
[str(venv_py), "-m", "pip", "install", "--quiet",
|
||||
"--disable-pip-version-check", "--prefer-binary",
|
||||
"--disable-pip-version-check", "--prefer-binary", "--no-cache-dir",
|
||||
"claude-agent-sdk"],
|
||||
capture_output=True, timeout=120, check=True,
|
||||
)
|
||||
return BUILT, "", ""
|
||||
except subprocess.CalledProcessError as e:
|
||||
# Signal kill (OOM-killer SIGKILL / RLIMIT_AS SIGSEGV) — rc<0, empty
|
||||
# streams. The dominant Linux failure. Record the rc, start a cooldown
|
||||
# so we stop retry-storming a build that keeps getting killed, and
|
||||
# skip the stderr categorization (there's nothing in stderr). err_phase
|
||||
# says whether it died creating the venv or installing via pip.
|
||||
if _is_signal_kill(e.returncode):
|
||||
_write_cooldown(state_dir)
|
||||
return BUILD_FAILED, err_phase, f"signal_killed:{e.returncode}"
|
||||
# Capture a stderr fingerprint so telemetry can split BUILD_FAILED by
|
||||
# root cause (no-network, package-not-found, dns-fail, etc.).
|
||||
# Categorize first, then keep a short raw tail for the long tail of
|
||||
@@ -360,10 +680,27 @@ def main() -> tuple[int, str, str]:
|
||||
"",
|
||||
)[:60]
|
||||
err_kind = f"other:{tail}" if tail else "other"
|
||||
# venv couldn't bootstrap pip (ensurepip missing) but pip itself may
|
||||
# work — fall back to a flat `pip install --target`. Only this one
|
||||
# category falls through; every other venv/pip failure is terminal.
|
||||
# The finally block unlinks our sentinel first (so the target build
|
||||
# isn't blocked by it); _build_via_target does the target install.
|
||||
if err_kind == "venv_ensurepip_fail":
|
||||
if we_own_sentinel:
|
||||
sentinel.unlink(missing_ok=True)
|
||||
we_own_sentinel = False
|
||||
return _build_via_target(state_dir)
|
||||
return BUILD_FAILED, err_phase, err_kind
|
||||
except subprocess.TimeoutExpired:
|
||||
return BUILD_FAILED, err_phase, "subprocess_timeout"
|
||||
except Exception as e:
|
||||
# Embed errno for OSError-family exceptions ("exc:OSError:28") so
|
||||
# telemetry can decode the OS-level cause (ENOENT/EACCES/ENOSPC/…),
|
||||
# not just the Python class. #2154 follow-up: this is the dominant
|
||||
# remaining venv BUILD_FAILED bucket. See _encode_exc_kind/_encode_errno.
|
||||
errno = getattr(e, "errno", None)
|
||||
if isinstance(errno, int):
|
||||
return BUILD_FAILED, err_phase, f"exc:{type(e).__name__}:{errno}"
|
||||
return BUILD_FAILED, err_phase, f"exc:{type(e).__name__}"
|
||||
finally:
|
||||
# Only remove the sentinel if THIS process created it. The
|
||||
@@ -467,6 +804,44 @@ if __name__ == "__main__":
|
||||
sig = _encode_stderr_sig(err_kind)
|
||||
if sig:
|
||||
metrics["sdk_bootstrap_stderr_sig"] = sig
|
||||
# Exception-type + errno for the "exc:" bucket (the dominant
|
||||
# remaining venv BUILD_FAILED mode per #2154 telemetry). Both
|
||||
# auto-omit (0) on stderr/categorized failures.
|
||||
exc = _encode_exc_kind(err_kind)
|
||||
if exc:
|
||||
metrics["sdk_bootstrap_exc"] = exc
|
||||
exc_errno = _encode_errno(err_kind)
|
||||
if exc_errno:
|
||||
metrics["sdk_bootstrap_errno"] = exc_errno
|
||||
# Subprocess returncode for signal kills (-9 OOM-killer / -11
|
||||
# RLIMIT_AS / -6 abort). Confirms in prod which signal dominates the
|
||||
# Linux memory-kill bucket. 0 (omitted) for non-signal failures.
|
||||
rc = _encode_rc(err_kind)
|
||||
if rc:
|
||||
metrics["sdk_bootstrap_rc"] = rc
|
||||
# venv_ensurepip_fail (code 11) is the top categorizable venv
|
||||
# failure, and telemetry shows it's NOT just Debian — macOS has the
|
||||
# most distinct affected users. Probe whether this interpreter has
|
||||
# pip so we know if a `pip install --target` fallback (Option A)
|
||||
# would actually help, vs the user needing a system package. Probed
|
||||
# only here (not on the happy path) to avoid an extra subprocess
|
||||
# per healthy session.
|
||||
if _encode_err_kind(err_kind) == 11:
|
||||
metrics["sdk_has_pip"] = _probe_has_pip()
|
||||
# When the hook interpreter is <3.10 (HOOK_PY_INCOMPATIBLE), probe for a
|
||||
# 3.10+ interpreter at known non-PATH locations. Non-zero sdk_alt_py =
|
||||
# this user is RECOVERABLE by an explicit-path search in sg-python.sh; 0 =
|
||||
# genuinely 3.9-only (needs a user install). Sizes the macOS Py-3.9 cohort
|
||||
# (~13.6% of macOS sessions) before we build the search. Incompatible path
|
||||
# only — healthy sessions never run it.
|
||||
if outcome == HOOK_PY_INCOMPATIBLE:
|
||||
metrics["sdk_alt_py"] = _probe_alt_python()
|
||||
# Interpreter version (major*100 + minor, e.g. 309 / 312), emitted on
|
||||
# every bootstrap. Disambiguates the macOS cohort (Apple 3.9 vs a 3.10+
|
||||
# with broken ensurepip) for both venv_ensurepip_fail AND
|
||||
# HOOK_PY_INCOMPATIBLE (whose "py_3.9" err_kind otherwise collapses to
|
||||
# err=99, losing the version). Cheap — no subprocess, just sys.version_info.
|
||||
metrics["sdk_hook_py"] = sys.version_info[0] * 100 + sys.version_info[1]
|
||||
pv = _plugin_version_int()
|
||||
if pv:
|
||||
metrics["pv"] = pv
|
||||
|
||||
@@ -55,6 +55,12 @@ def _inject_agent_sdk_venv_into_syspath(state_dir):
|
||||
candidates = (
|
||||
glob.glob(os.path.join(venv_root, "lib", "python*", "site-packages"))
|
||||
+ glob.glob(os.path.join(venv_root, "Lib", "site-packages"))
|
||||
# `pip install --target` fallback (ensure_agent_sdk BUILT_TARGET, used
|
||||
# when venv can't bootstrap pip): a FLAT layout — packages sit directly
|
||||
# in agent-sdk-libs/, not under a site-packages subdir. See #2154
|
||||
# follow-up. The pywin32 .pth bootstrap below applies here too (target
|
||||
# installs don't process .pth at runtime, same as a manual venv insert).
|
||||
+ [os.path.join(state_dir, "agent-sdk-libs")]
|
||||
)
|
||||
added = False
|
||||
for sp in candidates:
|
||||
|
||||
Reference in New Issue
Block a user