[{"data":1,"prerenderedAt":-1},["ShallowReactive",2],{"extension-skill-nowork-studio-broken-link-checker-zh-CN":3,"guides-for-nowork-studio-broken-link-checker":644,"similar-k17cc99w7n01557h2apwbdd8ah86m479-zh-CN":645},{"_creationTime":4,"_id":5,"children":6,"community":7,"display":9,"evaluation":15,"identity":246,"isFallback":237,"parentExtension":251,"providers":306,"relations":310,"repo":311,"tags":642,"workflow":643},1778694720643.0342,"k17cc99w7n01557h2apwbdd8ah86m479",[],{"reviewCount":8},0,{"description":10,"installMethods":11,"name":13,"sourceUrl":14},"Scans a website to find broken links (404s, 500s). Crawls internal pages,  identifies broken outbound links, and reports source pages for easy fixing. Use this when the user asks to \"check for broken links\", \"find 404s\",  \"audit my links\", or \"is my site healthy\".\n",{"claudeCode":12},"nowork-studio/toprank","broken-link-checker","https://github.com/nowork-studio/toprank",{"_creationTime":16,"_id":17,"extensionId":5,"locale":18,"result":19,"trustSignals":227,"workflow":244},1778694983523.7874,"kn7aqmmdapx44haj1bvzrbw09n86n41m","en",{"checks":20,"evaluatedAt":196,"extensionSummary":197,"features":198,"nonGoals":204,"promptVersionExtension":208,"promptVersionScoring":209,"purpose":210,"rationale":211,"score":212,"summary":213,"tags":214,"targetMarket":220,"tier":221,"useCases":222},[21,26,29,32,36,39,44,48,51,54,58,62,65,69,72,75,78,81,84,87,91,95,99,103,107,110,113,117,121,124,127,130,133,136,139,143,147,151,154,158,161,164,167,170,174,177,180,183,186,189,193],{"category":22,"check":23,"severity":24,"summary":25},"Practical Utility","Problem relevance","pass","The description clearly states the problem of broken links and identifies specific user intents for using the skill.",{"category":22,"check":27,"severity":24,"summary":28},"Unique selling proposition","The skill uniquely addresses the problem of broken links by crawling, identifying, and reporting source pages for fixing, going beyond basic link checking.",{"category":22,"check":30,"severity":24,"summary":31},"Production readiness","The skill is production-ready, with a clear script for scanning and reporting, covering the full lifecycle of identifying and reporting broken links.",{"category":33,"check":34,"severity":24,"summary":35},"Scope","Single responsibility principle","The extension focuses solely on scanning a website for broken links, adhering to a single responsibility.",{"category":33,"check":37,"severity":24,"summary":38},"Description quality","The displayed description accurately reflects the functionality described in the SKILL.md and the script's purpose.",{"category":40,"check":41,"severity":42,"summary":43},"Invocation","Scoped tools","not_applicable","This is a skill, not a tool-based extension with multiple scoped commands.",{"category":45,"check":46,"severity":24,"summary":47},"Documentation","Configuration & parameter reference","The script's arguments (`--url`, `--max-pages`, `--output`) are documented in the command-line help and the SKILL.md frontmatter.",{"category":33,"check":49,"severity":42,"summary":50},"Tool naming","As a skill, it does not expose multiple user-facing tools with distinct names.",{"category":33,"check":52,"severity":24,"summary":53},"Minimal I/O surface","The script accepts specific command-line arguments for input and outputs structured JSON, adhering to a minimal I/O surface.",{"category":55,"check":56,"severity":24,"summary":57},"License","License usability","The extension is licensed under the MIT license, as confirmed by the LICENSE file and the README.",{"category":59,"check":60,"severity":24,"summary":61},"Maintenance","Commit recency","The last commit was on May 10, 2026, which is within the last 3 months.",{"category":59,"check":63,"severity":24,"summary":64},"Dependency Management","The script uses only Python 3.8+ standard library and the 'requests' library, which is a common and safe dependency.",{"category":66,"check":67,"severity":42,"summary":68},"Security","Secret Management","The script does not handle any secrets or sensitive credentials.",{"category":66,"check":70,"severity":24,"summary":71},"Injection","The script treats URLs as data and does not execute arbitrary code or instructions from external sources.",{"category":66,"check":73,"severity":24,"summary":74},"Transitive Supply-Chain Grenades","The script only uses standard libraries and does not fetch external content at runtime or execute remote code.",{"category":66,"check":76,"severity":24,"summary":77},"Sandbox Isolation","The script operates on network requests and local file output (if specified) and does not attempt to modify files outside its designated scope.",{"category":66,"check":79,"severity":24,"summary":80},"Sandbox escape primitives","The script does not use any detached processes or retry loops around denied tool calls.",{"category":66,"check":82,"severity":42,"summary":83},"Data Exfiltration","The script does not handle or submit any confidential data.",{"category":66,"check":85,"severity":24,"summary":86},"Hidden Text Tricks","The bundled content is free of hidden-steering tricks and uses clean printable ASCII.",{"category":88,"check":89,"severity":24,"summary":90},"Hooks","Opaque code execution","The script is written in plain Python 3.8+ and is not obfuscated.",{"category":92,"check":93,"severity":24,"summary":94},"Portability","Structural Assumption","The script assumes standard Python 3.8+ environment and does not make assumptions about user-specific project organization.",{"category":96,"check":97,"severity":24,"summary":98},"Trust","Issues Attention","1 open issue and 4 closed issues in the last 90 days, indicating good maintainer engagement with a closure rate of ~80%.",{"category":100,"check":101,"severity":24,"summary":102},"Versioning","Release Management","The project has a VERSION file and recent commits, indicating active development, and the installation instructions reference a specific version.",{"category":104,"check":105,"severity":24,"summary":106},"Code Execution","Validation","Input arguments are validated via argparse, and URL parsing handles malformed inputs gracefully.",{"category":66,"check":108,"severity":42,"summary":109},"Unguarded Destructive Operations","The script is read-only; it performs scans and does not make any destructive operations.",{"category":104,"check":111,"severity":24,"summary":112},"Error Handling","The script uses try-except blocks to catch various potential errors during URL fetching and parsing, reporting them gracefully.",{"category":104,"check":114,"severity":115,"summary":116},"Logging","info","The script prints progress and errors to stderr, but does not maintain a separate audit log file.",{"category":118,"check":119,"severity":42,"summary":120},"Compliance","GDPR","The script does not handle personal data; it only processes URLs and HTTP responses.",{"category":118,"check":122,"severity":24,"summary":123},"Target market","The extension is a general-purpose web crawling tool and has no regional or jurisdictional restrictions.",{"category":92,"check":125,"severity":24,"summary":126},"Runtime stability","The script requires Python 3.8+ and standard libraries, making it portable across POSIX-compliant systems.",{"category":45,"check":128,"severity":24,"summary":129},"README","The README.md file exists and clearly describes the Toprank project, including its purpose and installation.",{"category":33,"check":131,"severity":42,"summary":132},"Tool surface size","This is a single skill, not an extension with multiple distinct tools/commands.",{"category":40,"check":134,"severity":42,"summary":135},"Overlapping near-synonym tools","This is a single skill, not an extension with multiple tools/commands.",{"category":45,"check":137,"severity":24,"summary":138},"Phantom features","All advertised features of the broken link checker are implemented in the provided script.",{"category":140,"check":141,"severity":24,"summary":142},"Install","Installation instruction","The README provides clear, copy-pasteable installation instructions for Claude Code and manual installation.",{"category":144,"check":145,"severity":24,"summary":146},"Errors","Actionable error messages","Error messages include the cause (e.g., reason for URL error) and attempt to provide context, though explicit remediation steps are limited due to the nature of web errors.",{"category":148,"check":149,"severity":24,"summary":150},"Execution","Pinned dependencies","The script uses Python 3.8+ and standard libraries, with no external dependencies requiring pinning. The shebang is present.",{"category":33,"check":152,"severity":42,"summary":153},"Dry-run preview","The skill is purely analytical and does not perform any state-changing operations or send data outward.",{"category":155,"check":156,"severity":24,"summary":157},"Protocol","Idempotent retry & timeouts","The script includes timeouts for network requests and handles potential errors gracefully, preventing infinite waits.",{"category":118,"check":159,"severity":42,"summary":160},"Telemetry opt-in","The script does not emit any telemetry.",{"category":40,"check":162,"severity":24,"summary":163},"Precise Purpose","The SKILL.md clearly defines the purpose (finding broken links), the target artifact (website), and usage triggers.",{"category":40,"check":165,"severity":24,"summary":166},"Concise Frontmatter","The frontmatter is concise and effectively summarizes the skill's purpose and usage.",{"category":45,"check":168,"severity":24,"summary":169},"Concise Body","The SKILL.md body is concise, under 500 lines, and delegates the script to a separate file.",{"category":171,"check":172,"severity":24,"summary":173},"Context","Progressive Disclosure","The SKILL.md is concise, and the script is in a separate file, following progressive disclosure.",{"category":171,"check":175,"severity":42,"summary":176},"Forked exploration","This skill is a focused task and does not involve deep exploration that would warrant 'context: fork'.",{"category":22,"check":178,"severity":24,"summary":179},"Usage examples","The SKILL.md and README provide clear examples of how to invoke the script and what kind of output to expect.",{"category":22,"check":181,"severity":24,"summary":182},"Edge cases","The script includes handling for common web errors (4xx, 5xx) and network issues, and the SKILL.md outlines reporting steps.",{"category":104,"check":184,"severity":42,"summary":185},"Tool Fallback","This skill does not rely on external MCP servers or tools; it's a standalone script.",{"category":92,"check":187,"severity":24,"summary":188},"Stack assumptions","The script declares Python 3.8+ with a shebang and uses only standard libraries, making its stack assumptions clear.",{"category":190,"check":191,"severity":24,"summary":192},"Safety","Halt on unexpected state","The script exits with non-zero status codes on errors and provides descriptive messages, effectively halting on unexpected states.",{"category":92,"check":194,"severity":42,"summary":195},"Cross-skill coupling","This is a standalone skill and does not implicitly rely on other skills or reference them without explicit linkage.",1778694983013,"This skill scans a website to find broken links (404s and 5xx errors), crawls internal pages, and identifies broken outbound links, reporting the source pages for easy fixing. It uses a Python script for the crawling and checking process.",[199,200,201,202,203],"Crawls internal website pages","Identifies broken outbound links","Reports source pages for broken links","Handles 404 and 5xx errors","Outputs scan results in JSON format",[205,206,207],"This skill does not check for broken images, CSS, or JavaScript.","It does not perform extensive SEO analysis beyond link health.","It does not automatically fix links; it only reports them.","3.0.0","4.4.0","To help users identify and fix broken links on their websites, improving user experience and SEO by ensuring site health.","Excellent documentation and implementation quality with a clear focus on a single problem, with recent commits and good issue management.",98,"A well-documented and robust skill for identifying broken links on websites.",[215,216,217,218,219],"seo","link-checker","auditing","python","web-crawling","global","verified",[223,224,225,226],"Use when asked to 'check for broken links'","Use when asked to 'find 404s'","Use when asked to 'audit my links'","Use when asked 'is my site healthy'",{"codeQuality":228,"collectedAt":230,"documentation":231,"maintenance":234,"security":241,"testCoverage":243},{"hasLockfile":229},false,1778694968154,{"descriptionLength":232,"readmeSize":233},265,18269,{"closedIssues90d":235,"forks":236,"hasChangelog":237,"openIssues90d":238,"pushedAt":239,"stars":240},4,276,true,1,1778438111000,2061,{"hasNpmPackage":229,"license":242,"smitheryVerified":229},"MIT",{"hasCi":229,"hasTests":237},{"updatedAt":245},1778694983523,{"basePath":247,"githubOwner":248,"githubRepo":249,"locale":18,"slug":13,"type":250},"seo/broken-link-checker","nowork-studio","toprank","skill",{"_creationTime":252,"_id":253,"community":254,"display":255,"identity":259,"parentExtension":262,"providers":292,"relations":302,"tags":303,"workflow":304},1778694720643.031,"k17dxqwvvhjw9ft30d5zz356z986my6s",{"reviewCount":8},{"description":256,"installMethods":257,"name":258,"sourceUrl":14},"The official Google Ads + Meta Ads + SEO + GEO plugin from NotFair. SEO analysis, Google Ads management, Meta (Facebook + Instagram) Ads management, keyword research, content optimization, schema markup tools, broken link checker, single-page deep audit, and Generative Engine Optimization (GEO) for AI search engines — powered by Google Search Console, Google Ads, and Meta Marketing APIs.",{"claudeCode":249},"Toprank",{"basePath":260,"githubOwner":248,"githubRepo":249,"locale":18,"slug":249,"type":261},"","plugin",{"_creationTime":263,"_id":264,"community":265,"display":266,"identity":269,"providers":271,"relations":286,"tags":288,"workflow":289},1778694720643.0308,"k17bcx0h1xk1nvah6sf9zj1bsd86n6dq",{"reviewCount":8},{"description":267,"installMethods":268,"name":258,"sourceUrl":14},"The official Google Ads + Meta Ads + SEO + GEO plugin from NotFair. SEO, GEO, Google Ads, and Meta Ads skills for Claude Code.",{"claudeCode":12},{"basePath":260,"githubOwner":248,"githubRepo":249,"locale":18,"slug":249,"type":270},"marketplace",{"evaluate":272,"extract":281},{"promptVersionExtension":273,"promptVersionScoring":209,"score":274,"tags":275,"targetMarket":220,"tier":221},"3.1.0",97,[276,277,215,278,279,280],"google-ads","meta-ads","marketing","automation","analytics",{"commitSha":282,"license":242,"marketplace":283,"plugin":284},"HEAD",{"name":248,"pluginCount":238},{"mcpCount":8,"provider":285,"skillCount":8},"classify",{"repoId":287},"kd74wn8s89tp9hrfsmcra492r586nbrv",[280,279,276,278,277,215],{"evaluatedAt":290,"extractAt":291,"updatedAt":290},1778694741191,1778694720643,{"evaluate":293,"extract":299},{"promptVersionExtension":208,"promptVersionScoring":209,"score":294,"tags":295,"targetMarket":220,"tier":298},75,[276,277,215,296,297,278,280,279],"geo","advertising","community",{"commitSha":282,"license":242,"plugin":300},{"mcpCount":8,"provider":285,"skillCount":301},17,{"parentExtensionId":264,"repoId":287},[297,280,279,296,276,278,277,215],{"evaluatedAt":305,"extractAt":291,"updatedAt":305},1778694758113,{"evaluate":307,"extract":309},{"promptVersionExtension":208,"promptVersionScoring":209,"score":212,"tags":308,"targetMarket":220,"tier":221},[215,216,217,218,219],{"commitSha":282},{"parentExtensionId":253,"repoId":287},{"_creationTime":312,"_id":287,"identity":313,"providers":314,"workflow":638},1778694715657.0981,{"githubOwner":248,"githubRepo":249,"sourceUrl":14},{"classify":315,"discover":625,"github":628},{"commitSha":282,"extensions":316},[317,330,349,357,372,382,392,415,426,442,450,458,466,474,482,489,499,509,525,539,553,599,609,617],{"basePath":260,"description":267,"displayName":248,"installMethods":318,"rationale":319,"selectedPaths":320,"source":329,"sourceLanguage":18,"type":270},{"claudeCode":12},"marketplace.json at .claude-plugin/marketplace.json",[321,324,326],{"path":322,"priority":323},".claude-plugin/marketplace.json","mandatory",{"path":325,"priority":323},"README.md",{"path":327,"priority":328},"LICENSE","high","rule",{"basePath":260,"description":256,"displayName":249,"installMethods":331,"rationale":332,"selectedPaths":333,"source":329,"sourceLanguage":18,"type":261},{"claudeCode":249},"plugin manifest at .claude-plugin/plugin.json",[334,336,337,338,340,343,345,347],{"path":335,"priority":323},".claude-plugin/plugin.json",{"path":325,"priority":323},{"path":327,"priority":328},{"path":339,"priority":323},".mcp.json",{"path":341,"priority":342},"bin/preamble.md","low",{"path":344,"priority":342},"bin/toprank-change-watch",{"path":346,"priority":342},"bin/toprank-config",{"path":348,"priority":342},"bin/toprank-update-check",{"basePath":350,"description":351,"displayName":350,"installMethods":352,"rationale":353,"selectedPaths":354,"source":329,"sourceLanguage":18,"type":250},"gemini","Cross-model second opinion from Google Gemini — a different AI reviewing the same changes, with deep Google ecosystem knowledge. Three modes: review (pass/fail gate for Google Ads campaigns, SEO metadata, or code), challenge (adversarial stress-test that tries to break your changes), and consult (open Q&A with Gemini on Google Ads strategy, SEO best practices, or implementation questions). Use when the user says \"gemini review\", \"ask gemini\", \"gemini challenge\", \"second opinion from gemini\", \"consult gemini\", \"stress test with gemini\", \"what would gemini say\", \"cross-model review\", or \"get another opinion\". Voice aliases: \"gem\", \"gemini check\". Especially useful for Google Ads changes, SEO metadata updates, campaign structure decisions, keyword strategies, and bid/budget changes — Gemini has native Google ecosystem knowledge that complements Claude's analysis.\n",{"claudeCode":12},"SKILL.md frontmatter at gemini/SKILL.md",[355],{"path":356,"priority":323},"SKILL.md",{"basePath":358,"description":359,"displayName":360,"installMethods":361,"rationale":362,"selectedPaths":363,"source":329,"sourceLanguage":18,"type":250},"google-ads/audit","Google Ads account audit and business context setup. Run this first — it gathers business information, analyzes account health, and saves context that all other ads skills reuse. Trigger on \"audit my ads\", \"ads audit\", \"set up my ads\", \"onboard\", \"account overview\", \"how's my account\", \"ads health check\", \"what should I fix in my ads\", or when the user is new to NotFair and hasn't run an audit before. Also trigger proactively when other ads skills detect that business-context.json is missing.","google-ads-audit",{"claudeCode":12},"SKILL.md frontmatter at google-ads/audit/SKILL.md",[364,365,368,370],{"path":356,"priority":323},{"path":366,"priority":367},"references/account-health-scoring.md","medium",{"path":369,"priority":367},"references/business-context.md",{"path":371,"priority":367},"references/persona-discovery.md",{"basePath":373,"description":374,"displayName":375,"installMethods":376,"rationale":377,"selectedPaths":378,"source":329,"sourceLanguage":18,"type":250},"google-ads/copy","Generate and A/B test Google Ads copy. Use when asked to write ad copy, headlines, descriptions, create ad variants, test ad messaging, improve CTR, or generate RSA (Responsive Search Ad) components. Trigger on \"ad copy\", \"write ads\", \"headlines\", \"descriptions\", \"RSA\", \"responsive search ad\", \"ad text\", \"ad creative\", \"improve CTR\", \"ad A/B test\", \"ad variants\", \"write me an ad\", \"ad variation experiment\", or when the user wants to improve click-through rate on existing ads.","google-ads-copy",{"claudeCode":12},"SKILL.md frontmatter at google-ads/copy/SKILL.md",[379,380],{"path":356,"priority":323},{"path":381,"priority":367},"references/rsa-best-practices.md",{"basePath":383,"description":384,"displayName":385,"installMethods":386,"rationale":387,"selectedPaths":388,"source":329,"sourceLanguage":18,"type":250},"google-ads/landing","Score and diagnose Google Ads landing pages. Use when asked to audit a landing page, check landing page quality, diagnose high-CTR but low-conversion-rate ad groups, improve Quality Score's Landing Page Experience component, or compare an ad group's messaging against its landing page. Trigger on \"landing page audit\", \"landing page score\", \"landing page quality\", \"why is my conversion rate low\", \"LPX\", \"landing page experience\", \"ad to page match\", or when `/google-ads-audit` surfaces a high-CTR / low-CVR ad group.","google-ads-landing",{"claudeCode":12},"SKILL.md frontmatter at google-ads/landing/SKILL.md",[389,390],{"path":356,"priority":323},{"path":391,"priority":367},"references/scoring-rubric.md",{"basePath":393,"description":394,"displayName":276,"installMethods":395,"rationale":396,"selectedPaths":397,"source":329,"sourceLanguage":18,"type":250},"google-ads/manage","Manage Google Ads — performance, keywords, bids, budgets, negatives, campaigns, ads, search terms, QS, location targeting, bulk operations, experiments, asset management, portfolio bidding, offline conversions. Use for any mention of Google Ads, CPA, ROAS, ad spend, or campaign settings.",{"claudeCode":12},"SKILL.md frontmatter at google-ads/manage/SKILL.md",[398,399,401,403,405,407,409,411,413],{"path":356,"priority":323},{"path":400,"priority":367},"references/analysis-heuristics.md",{"path":402,"priority":367},"references/bid-strategy-decision-tree.md",{"path":404,"priority":367},"references/campaign-structure-guide.md",{"path":406,"priority":367},"references/change-tracking.md",{"path":408,"priority":367},"references/industry-benchmarks.md",{"path":410,"priority":367},"references/quality-score-framework.md",{"path":412,"priority":367},"references/search-term-analysis-guide.md",{"path":414,"priority":367},"references/session-checks.md",{"basePath":416,"description":417,"displayName":418,"installMethods":419,"rationale":420,"selectedPaths":421,"source":329,"sourceLanguage":18,"type":250},"meta-ads/audit","Meta Ads (Facebook + Instagram) account audit and business context setup. Run this first — it gathers business information, analyzes account health, and saves context that all other Meta ads skills reuse. Trigger on \"audit my Meta ads\", \"audit my Facebook ads\", \"Meta ads audit\", \"set up my Meta ads\", \"onboard Meta\", \"Meta account overview\", \"how's my Meta account\", \"Meta health check\", \"what should I fix in my Facebook ads\", or when the user is new to NotFair Meta and hasn't run an audit before. Also trigger proactively when other Meta ads skills detect that meta business-context.json is missing.","meta-ads-audit",{"claudeCode":12},"SKILL.md frontmatter at meta-ads/audit/SKILL.md",[422,423,424,425],{"path":356,"priority":323},{"path":366,"priority":367},{"path":369,"priority":367},{"path":371,"priority":367},{"basePath":427,"description":428,"displayName":277,"installMethods":429,"rationale":430,"selectedPaths":431,"source":329,"sourceLanguage":18,"type":250},"meta-ads/manage","Manage Meta Ads (Facebook + Instagram) — performance, ROAS, CPM, frequency, audience overlap, learning phase, creative fatigue, budgets, ad sets, campaigns, ads. Use for any mention of Meta Ads, Facebook Ads, Instagram Ads, ROAS, CPM, ad spend, or campaign settings on Meta.",{"claudeCode":12},"SKILL.md frontmatter at meta-ads/manage/SKILL.md",[432,433,434,436,437,439,440],{"path":356,"priority":323},{"path":400,"priority":367},{"path":435,"priority":367},"references/audience-strategy.md",{"path":404,"priority":367},{"path":438,"priority":367},"references/creative-fatigue.md",{"path":408,"priority":367},{"path":441,"priority":367},"references/learning-phase.md",{"basePath":443,"description":444,"displayName":445,"installMethods":446,"rationale":447,"selectedPaths":448,"source":329,"sourceLanguage":18,"type":250},"openclaw/skills/toprank-improve-page","Improve one URL inside a registered site by producing a focused diagnosis, proposal, and verification artifact.","toprank-improve-page",{"claudeCode":12},"SKILL.md frontmatter at openclaw/skills/toprank-improve-page/SKILL.md",[449],{"path":356,"priority":323},{"basePath":451,"description":452,"displayName":453,"installMethods":454,"rationale":455,"selectedPaths":456,"source":329,"sourceLanguage":18,"type":250},"openclaw/skills/toprank-investigate-drop","Investigate an organic traffic drop for one registered site and produce a ranked recovery plan with artifacts.","toprank-investigate-drop",{"claudeCode":12},"SKILL.md frontmatter at openclaw/skills/toprank-investigate-drop/SKILL.md",[457],{"path":356,"priority":323},{"basePath":459,"description":460,"displayName":461,"installMethods":462,"rationale":463,"selectedPaths":464,"source":329,"sourceLanguage":18,"type":250},"openclaw/skills/toprank-portfolio-review","Review all registered websites in the Toprank OpenClaw portfolio and rank which site deserves attention next.","toprank-portfolio-review",{"claudeCode":12},"SKILL.md frontmatter at openclaw/skills/toprank-portfolio-review/SKILL.md",[465],{"path":356,"priority":323},{"basePath":467,"description":468,"displayName":469,"installMethods":470,"rationale":471,"selectedPaths":472,"source":329,"sourceLanguage":18,"type":250},"openclaw/skills/toprank-site-onboard","Register a website in Toprank's OpenClaw adaptive layer and initialize its per-site work folder.","toprank-site-onboard",{"claudeCode":12},"SKILL.md frontmatter at openclaw/skills/toprank-site-onboard/SKILL.md",[473],{"path":356,"priority":323},{"basePath":475,"description":476,"displayName":477,"installMethods":478,"rationale":479,"selectedPaths":480,"source":329,"sourceLanguage":18,"type":250},"openclaw/skills/toprank-weekly-review","Run a weekly SEO review for one registered website, write audit artifacts, and choose the next best safe action.","toprank-weekly-review",{"claudeCode":12},"SKILL.md frontmatter at openclaw/skills/toprank-weekly-review/SKILL.md",[481],{"path":356,"priority":323},{"basePath":247,"description":10,"displayName":13,"installMethods":483,"rationale":484,"selectedPaths":485,"source":329,"sourceLanguage":18,"type":250},{"claudeCode":12},"SKILL.md frontmatter at seo/broken-link-checker/SKILL.md",[486,487],{"path":356,"priority":323},{"path":488,"priority":342},"scripts/checker.py",{"basePath":490,"description":491,"displayName":492,"installMethods":493,"rationale":494,"selectedPaths":495,"source":329,"sourceLanguage":18,"type":250},"seo/content-writer","Write SEO-optimized blog posts, landing pages, and content improvements following Google's E-E-A-T and Helpful Content guidelines. Handles new content creation from a keyword or topic, and improving existing pages. Use when asked to \"write a blog post\", \"create a landing page\", \"improve this page\", \"write content about X\", \"content for keyword X\", \"draft an article\", \"blog post about\", \"landing page for\", \"service page\", \"product page copy\", \"rewrite this page\", \"make this page rank better\", \"content brief\", \"how-to guide\", \"listicle\", or any content creation or improvement task for a website.\n","content-writer",{"claudeCode":12},"SKILL.md frontmatter at seo/content-writer/SKILL.md",[496,497],{"path":356,"priority":323},{"path":498,"priority":367},"references/content-writing.md",{"basePath":500,"description":501,"displayName":502,"installMethods":503,"rationale":504,"selectedPaths":505,"source":329,"sourceLanguage":18,"type":250},"seo/geo-optimizer","Generative Engine Optimization (GEO) — make content rank in AI search answers from ChatGPT, Claude, Perplexity, Gemini, and Google AI Overviews. Audits existing content, rewrites for AI citation, and produces per-engine strategy. Use when asked to \"optimize for AI search\", \"rank in ChatGPT\", \"GEO audit\", \"improve AI citations\", \"rank in Perplexity\", \"AI Overview optimization\", \"AI Overview ranking\", \"LLM SEO\", \"answer engine optimization\", \"AEO\", \"get cited by AI\", \"GEO\", \"generative engine optimization\", \"show up in ChatGPT\", \"appear in AI answers\", \"be cited by Perplexity\", \"SGE optimization\", \"Search Generative Experience\", or \"make my content show up in AI answers\". Distinct from regular SEO — this targets generative engines, not traditional Google rankings.\n","geo-optimizer",{"claudeCode":12},"SKILL.md frontmatter at seo/geo-optimizer/SKILL.md",[506,507],{"path":356,"priority":323},{"path":508,"priority":367},"references/geo-techniques.md",{"basePath":510,"description":511,"displayName":512,"installMethods":513,"rationale":514,"selectedPaths":515,"source":329,"sourceLanguage":18,"type":250},"seo/keyword-research","Discover, analyze, and prioritize keywords for SEO and GEO content strategies. Identifies high-value opportunities based on search volume, competition, intent, and business relevance. Generates topic clusters and content calendars. Use when asked to \"find keywords\", \"keyword research\", \"what should I write about\", \"keyword analysis\", \"find me topics to write\", \"search volume\", \"keyword difficulty\", \"content ideas\", or any keyword discovery task.\n","keyword-research",{"claudeCode":12},"SKILL.md frontmatter at seo/keyword-research/SKILL.md",[516,517,519,521,523],{"path":356,"priority":323},{"path":518,"priority":367},"references/example-report.md",{"path":520,"priority":367},"references/keyword-intent-taxonomy.md",{"path":522,"priority":367},"references/keyword-prioritization-framework.md",{"path":524,"priority":367},"references/topic-cluster-templates.md",{"basePath":526,"description":527,"displayName":528,"installMethods":529,"rationale":530,"selectedPaths":531,"source":329,"sourceLanguage":18,"type":250},"seo/meta-tags-optimizer","Optimize title tags, meta descriptions, Open Graph, and Twitter cards for maximum click-through rate. Generates multiple A/B test variations with character counting and SERP preview. Use when asked to \"optimize title tag\", \"write meta description\", \"improve CTR\", \"Open Graph tags\", \"fix my meta tags\", \"social media preview\", \"my click rate is low\", \"title optimization\", or any meta tag task.\n","meta-tags-optimizer",{"claudeCode":12},"SKILL.md frontmatter at seo/meta-tags-optimizer/SKILL.md",[532,533,535,537],{"path":356,"priority":323},{"path":534,"priority":367},"references/ctr-and-social-reference.md",{"path":536,"priority":367},"references/meta-tag-code-templates.md",{"path":538,"priority":367},"references/meta-tag-formulas.md",{"basePath":540,"description":541,"displayName":542,"installMethods":543,"rationale":544,"selectedPaths":545,"source":329,"sourceLanguage":18,"type":250},"seo/schema-markup-generator","Generate JSON-LD structured data markup for rich results in Google Search. Supports FAQ, HowTo, Article, Product, LocalBusiness, and multi-type schemas. Validates against Google requirements and provides implementation guidance. Use when asked to \"add schema markup\", \"generate structured data\", \"JSON-LD\", \"rich snippets\", \"FAQ schema\", \"product markup\", \"add structured data to my page\", \"how to get rich snippets\", or any structured data task.\n","schema-markup-generator",{"claudeCode":12},"SKILL.md frontmatter at seo/schema-markup-generator/SKILL.md",[546,547,549,551],{"path":356,"priority":323},{"path":548,"priority":367},"references/schema-decision-tree.md",{"path":550,"priority":367},"references/schema-templates.md",{"path":552,"priority":367},"references/validation-guide.md",{"basePath":554,"description":555,"displayName":556,"installMethods":557,"rationale":558,"selectedPaths":559,"source":329,"sourceLanguage":18,"type":250},"seo/seo-analysis","Full SEO audit: Google Search Console data + URL Inspection API + PageSpeed Insights API + technical crawl + keyword research + metadata audit + schema markup audit + search intent analysis + Core Web Vitals monitoring. Feeds real GSC data and PageSpeed metrics into AI to surface quick wins, diagnose traffic drops, find content gaps, identify metadata mismatches, detect schema gaps, monitor page performance, and produce an actionable 30-day plan. Use this skill whenever the user asks about SEO, search rankings, organic traffic, Google Search Console, keyword performance, traffic drops, content gaps, search visibility, technical SEO, meta tags, schema markup, structured data, URL indexing, keyword research, indexing issues, page speed, performance, Core Web Vitals, LCP, INP, CLS, or Lighthouse scores. Also trigger on: \"why is my traffic down\", \"what keywords am I ranking for\", \"improve my rankings\", \"check my search console\", \"SEO audit\", \"analyze my SEO\", \"technical SEO\", \"meta tags\", \"indexing issues\", \"crawl errors\", \"content strategy\", \"keyword cannibalization\", \"search intent\", \"schema markup\", \"structured data\", \"URL inspection\", \"page speed\", \"performance score\", \"core web vitals\", \"lighthouse\", or any organic search question. If in doubt, trigger. This skill handles everything from quick GSC checks to deep technical audits with performance monitoring.\n","seo-analysis",{"claudeCode":12},"SKILL.md frontmatter at seo/seo-analysis/SKILL.md",[560,561,563,565,567,569,571,573,575,577,579,581,583,585,587,589,591,593,595,597],{"path":356,"priority":323},{"path":562,"priority":367},"references/gsc_setup.md",{"path":564,"priority":342},"scripts/_uid.py",{"path":566,"priority":342},"scripts/analyze_gsc.py",{"path":568,"priority":342},"scripts/cms_detect.py",{"path":570,"priority":342},"scripts/fetch_contentful_content.py",{"path":572,"priority":342},"scripts/fetch_ghost_content.py",{"path":574,"priority":342},"scripts/fetch_strapi_content.py",{"path":576,"priority":342},"scripts/fetch_wordpress_content.py",{"path":578,"priority":342},"scripts/list_gsc_sites.py",{"path":580,"priority":342},"scripts/pagespeed.py",{"path":582,"priority":342},"scripts/preflight.py",{"path":584,"priority":342},"scripts/preflight_contentful.py",{"path":586,"priority":342},"scripts/preflight_ghost.py",{"path":588,"priority":342},"scripts/preflight_strapi.py",{"path":590,"priority":342},"scripts/preflight_wordpress.py",{"path":592,"priority":342},"scripts/push_strapi_seo.py",{"path":594,"priority":342},"scripts/show_gsc.py",{"path":596,"priority":342},"scripts/show_pagespeed.py",{"path":598,"priority":342},"scripts/url_inspection.py",{"basePath":600,"description":601,"displayName":602,"installMethods":603,"rationale":604,"selectedPaths":605,"source":329,"sourceLanguage":18,"type":250},"seo/seo-page","Single-page SEO audit: deep content quality evaluation using Google's E-E-A-T framework, Helpful Content guidelines, on-page SEO factors, search intent alignment, technical signals, and readability analysis. Fetches GSC performance data for that specific page, crawls the live HTML, evaluates metadata, schema markup, internal linking, content depth, and produces a scored report with actionable fixes. Use this skill whenever the user wants to analyze a specific page or URL — not the whole site. Trigger on: \"analyze this page\", \"audit this URL\", \"how is this page doing\", \"evaluate my blog post\", \"check this landing page\", \"page SEO\", \"content quality check\", \"is this page good enough\", \"review this page's SEO\", \"what's wrong with this page\", \"how can I improve this page\", \"page analysis\", \"single page audit\", \"content audit for [URL]\", or any request that names a specific URL/page for SEO evaluation. If the user provides a specific URL (not just a domain), this is likely the right skill — use /seo-analysis for full-site audits instead.\n","seo-page",{"claudeCode":12},"SKILL.md frontmatter at seo/seo-page/SKILL.md",[606,607],{"path":356,"priority":323},{"path":608,"priority":367},"references/content-quality-framework.md",{"basePath":610,"description":611,"displayName":612,"installMethods":613,"rationale":614,"selectedPaths":615,"source":329,"sourceLanguage":18,"type":250},"seo/setup-cms","Connect a CMS to toprank SEO tools. Guides users through configuring WordPress, Strapi, Contentful, or Ghost — tests the connection, and writes credentials to .env.local. Once set up, seo-analysis automatically cross- references CMS content against Google Search Console data. Use whenever the user says \"connect my CMS\", \"set up WordPress\", \"configure Strapi\", \"add Contentful\", \"connect Ghost\", or \"CMS setup\". Also trigger if the user asks why no CMS data appears in a seo-analysis report.\n","setup-cms",{"claudeCode":12},"SKILL.md frontmatter at seo/setup-cms/SKILL.md",[616],{"path":356,"priority":323},{"basePath":618,"description":619,"displayName":620,"installMethods":621,"rationale":622,"selectedPaths":623,"source":329,"sourceLanguage":18,"type":250},"toprank-upgrade-skill","Upgrade toprank plugin to the latest version. Updates the marketplace repo, installs the new version to the plugin cache, and updates installed_plugins.json. Use when asked to \"upgrade toprank\", \"update toprank\", or \"get latest version\". Also handles inline upgrade prompts when a skill detects UPGRADE_AVAILABLE at startup.\n","toprank-upgrade",{"claudeCode":12},"SKILL.md frontmatter at toprank-upgrade-skill/SKILL.md",[624],{"path":356,"priority":323},{"sources":626},[627],"manual",{"closedIssues90d":235,"description":629,"forks":236,"homepage":630,"license":242,"openIssues90d":238,"pushedAt":239,"readmeSize":233,"stars":240,"topics":631},"Open-source Claude Code skills for SEO, GEO, Google Ads, Meta Ads","https://notfair.co/",[632,633,296,634,635,636,215,637],"claude-code-plugin","claude-skills","googleads","mcp","metaads","googleadsmcp",{"classifiedAt":639,"discoverAt":640,"extractAt":641,"githubAt":641,"updatedAt":639},1778694720337,1778694715657,1778694717962,[217,216,218,215,219],{"evaluatedAt":245,"extractAt":291,"updatedAt":245},[],[646,663,693,721,743,775],{"_creationTime":647,"_id":648,"community":649,"display":650,"identity":653,"providers":654,"relations":659,"tags":660,"workflow":661},1778694720643.034,"k175824bv0hy06y0gygd192pgd86nceh",{"reviewCount":8},{"description":476,"installMethods":651,"name":652,"sourceUrl":14},{"claudeCode":12},"Toprank Weekly Review",{"basePath":475,"githubOwner":248,"githubRepo":249,"locale":18,"slug":477,"type":250},{"evaluate":655,"extract":658},{"promptVersionExtension":208,"promptVersionScoring":209,"score":656,"tags":657,"targetMarket":220,"tier":221},100,[215,276,277,217,279],{"commitSha":282,"license":242},{"repoId":287},[217,279,276,277,215],{"evaluatedAt":662,"extractAt":291,"updatedAt":662},1778694967711,{"_creationTime":664,"_id":665,"community":666,"display":667,"identity":673,"providers":677,"relations":686,"tags":689,"workflow":690},1778695548458.3718,"k175vfqr247swcyt62e6v08a4x86mtf1",{"reviewCount":8},{"description":668,"installMethods":669,"name":671,"sourceUrl":672},"Investigate root causes and manage CAPAs (Corrective and Preventive Actions) for compliance deviations. Covers investigation method selection (5-Why, fishbone, fault tree), structured root cause analysis, corrective vs preventive action design, effectiveness verification, and trend analysis. Use when an audit finding requires a CAPA, when a deviation or incident occurs in a validated system, when a regulatory observation needs a formal response, when a data integrity anomaly requires investigation, or when recurring issues suggest a systemic root cause.\n",{"claudeCode":670},"pjt222/agent-almanac","investigate-capa-root-cause","https://github.com/pjt222/agent-almanac",{"basePath":674,"githubOwner":675,"githubRepo":676,"locale":18,"slug":671,"type":250},"skills/investigate-capa-root-cause","pjt222","agent-almanac",{"evaluate":678,"extract":685},{"promptVersionExtension":208,"promptVersionScoring":209,"score":656,"tags":679,"targetMarket":220,"tier":221},[680,681,682,683,684,217],"compliance","capa","investigation","root-cause-analysis","gxp",{"commitSha":282},{"parentExtensionId":687,"repoId":688},"k170h0janaa9kwn7cfgfz2ykss86mmh9","kd7aryv63z61j39n2td1aeqkvh86mh12",[217,681,680,684,682,683],{"evaluatedAt":691,"extractAt":692,"updatedAt":691},1778699030088,1778695548458,{"_creationTime":694,"_id":695,"community":696,"display":697,"identity":703,"providers":707,"relations":715,"tags":717,"workflow":718},1778695753353.633,"k17fxb9fnez7bhk0sy8znxzx8n86m48r",{"reviewCount":8},{"description":698,"installMethods":699,"name":701,"sourceUrl":702},"Drift detection + baseline integrity guard for agent workspace files with automatic alerting support",{"claudeCode":700},"prompt-security/clawsec","soul-guardian","https://github.com/prompt-security/clawsec",{"basePath":704,"githubOwner":705,"githubRepo":706,"locale":18,"slug":701,"type":250},"skills/soul-guardian","prompt-security","clawsec",{"evaluate":708,"extract":714},{"promptVersionExtension":208,"promptVersionScoring":209,"score":656,"tags":709,"targetMarket":220,"tier":221},[710,711,217,712,713],"security","integrity","file-guard","workspace",{"commitSha":282},{"repoId":716},"kd72phsqkbk8w57ctvf7ac9nqs86n9t4",[217,712,711,710,713],{"evaluatedAt":719,"extractAt":720,"updatedAt":719},1778696065248,1778695753353,{"_creationTime":722,"_id":723,"community":724,"display":725,"identity":729,"providers":731,"relations":739,"tags":740,"workflow":741},1778695548458.3328,"k17cyw0d6mk1vdgew2xmncx1f186npdm",{"reviewCount":8},{"description":726,"installMethods":727,"name":728,"sourceUrl":672},"Audit project dependencies for version staleness, security vulnerabilities, and compatibility issues. Covers lock file analysis, upgrade path planning, and breaking change assessment. Use before a release to ensure dependencies are current and secure, during periodic maintenance reviews, after receiving a security advisory, when upgrading to a new language version, before submitting to CRAN or npm, or when inheriting a project to assess its dependency health.\n",{"claudeCode":670},"audit-dependency-versions",{"basePath":730,"githubOwner":675,"githubRepo":676,"locale":18,"slug":728,"type":250},"skills/audit-dependency-versions",{"evaluate":732,"extract":738},{"promptVersionExtension":208,"promptVersionScoring":209,"score":656,"tags":733,"targetMarket":220,"tier":221},[734,217,710,735,736,737],"dependencies","upgrades","versioning","maintenance",{"commitSha":282},{"parentExtensionId":687,"repoId":688},[217,734,737,710,735,736],{"evaluatedAt":742,"extractAt":692,"updatedAt":742},1778696062378,{"_creationTime":744,"_id":745,"community":746,"display":747,"identity":753,"providers":758,"relations":766,"tags":770,"workflow":771},1778692169475.437,"k172w1s4pv9xgb31fp2vrtv04186n44y",{"reviewCount":8},{"description":748,"installMethods":749,"name":751,"sourceUrl":752},"显示每个技能消耗的上下文窗口令牌数量。当用户询问有关令牌成本、上下文预算、技能大小，或希望了解哪些技能浪费了最多的上下文空间时使用。",{"claudeCode":750},"khendzel/skills-janitor","janitor-tokens","https://github.com/khendzel/skills-janitor",{"basePath":754,"githubOwner":755,"githubRepo":756,"locale":757,"slug":751,"type":250},"skills/janitor-tokens","khendzel","skills-janitor","zh-CN",{"evaluate":759,"extract":765},{"promptVersionExtension":208,"promptVersionScoring":209,"score":656,"tags":760,"targetMarket":220,"tier":221},[761,762,763,764,217],"skills-management","code-analysis","cost-optimization","token-usage",{"commitSha":282},{"parentExtensionId":767,"repoId":768,"translatedFrom":769},"k173y287h96a0x42zvrvymzvgn86nq38","kd722xn3d2v8ze2vwgebvzgpv986mj48","k17epektyn71reavpa0hvxmvch86mxwf",[217,762,763,761,764],{"evaluatedAt":772,"extractAt":773,"updatedAt":774},1778692064277,1778691884319,1778692169475,{"_creationTime":776,"_id":777,"community":778,"display":779,"identity":783,"providers":785,"relations":792,"tags":794,"workflow":795},1778692149990.924,"k1784mxj5rt2pfmfdqhc36xnys86nnwc",{"reviewCount":8},{"description":780,"installMethods":781,"name":782,"sourceUrl":752},"一个完整的报告，用于检查所有技能的健康状况。当用户想要检查错误、查找重复项、检测损坏的技能或获取技能健康状况的完整概览时使用。",{"claudeCode":750},"janitor-report",{"basePath":784,"githubOwner":755,"githubRepo":756,"locale":757,"slug":782,"type":250},"skills/janitor-report",{"evaluate":786,"extract":791},{"promptVersionExtension":208,"promptVersionScoring":209,"score":656,"tags":787,"targetMarket":220,"tier":221},[788,789,217,737,790],"skills","management","developer-tools",{"commitSha":282},{"parentExtensionId":767,"repoId":768,"translatedFrom":793},"k177wxk7zzyaycd3t6ads36e7586mkcw",[217,790,737,789,788],{"evaluatedAt":796,"extractAt":773,"updatedAt":797},1778692022779,1778692149990]