develop-userscripts

tarafından xixu-me

Tarayıcı kullanıcı betiklerini Tampermonkey veya ScriptCat için oluştururken, hata ayıklarken, paketlerken veya yayınlarken kullanılır; GM API'leri, meta veri blokları, izin sorunları, @match/@grant/@connect kurulumu, ScriptCat arka plan veya zamanlanmış betikleri, UserConfig blokları veya abonelik iş akışları dahil.

npx skills add https://github.com/xixu-me/skills --skill develop-userscripts

Userscript work usually breaks at the runtime and metadata boundary, not in the page logic. Choose the runtime first, declare the minimum permissions up front, then debug in the environment where the script actually runs.

When to Use

Use this skill for:

  • writing or fixing a Tampermonkey or ScriptCat userscript
  • debugging injection timing, missing permissions, CSP workarounds, update checks, or GM_* behavior
  • deciding between a portable foreground script and ScriptCat-only @background or @crontab
  • adding config UI with ==UserConfig==
  • packaging a ScriptCat ==UserSubscribe== bundle or preparing a CloudCat-compatible script

Do not use this skill for full browser extension development or general browser automation outside userscript managers.

Runtime Selection

digraph userscript_runtime {
    "Need page DOM or page context?" [shape=diamond];
    "Need persistent or scheduled work?" [shape=diamond];
    "Need to install many scripts as one package?" [shape=diamond];
    "Portable foreground script" [shape=box];
    "ScriptCat background or crontab script" [shape=box];
    "ScriptCat subscription package" [shape=box];

    "Need page DOM or page context?" -> "Portable foreground script" [label="yes"];
    "Need page DOM or page context?" -> "Need persistent or scheduled work?" [label="no"];
    "Need persistent or scheduled work?" -> "ScriptCat background or crontab script" [label="yes"];
    "Need persistent or scheduled work?" -> "Need to install many scripts as one package?" [label="no"];
    "Need to install many scripts as one package?" -> "ScriptCat subscription package" [label="yes"];
    "Need to install many scripts as one package?" -> "Portable foreground script" [label="no"];
}

Preflight

  • Confirm the manager and browser. On Manifest V3 browsers, ScriptCat may require Allow User Scripts or browser developer mode before scripts run.
  • Decide page script versus background script before writing code. ScriptCat background scripts cannot touch the DOM.
  • Start with metadata, not implementation: @match, @grant, @connect, @run-at, and any update URLs.
  • Prefer portable ==UserScript== patterns for ordinary page scripts. Only switch to ScriptCat-only headers when the requested behavior actually needs them.

Workflow

  1. Choose the runtime and metadata first.
  2. Declare the smallest permission surface that fits the task.
  3. Implement against the runtime you chose.
  4. Debug where the code really runs.
    • Foreground scripts: page console plus manager logs.
    • ScriptCat background scripts: run log first, then background.html for real-environment debugging.
  5. Publish with the right update model.
    • Normal scripts: keep @version accurate and add @updateURL or @downloadURL only when needed.
    • Subscription bundles: use ==UserSubscribe==, HTTPS URLs, and subscription-level @connect.

Quick Reference

IntentDefault choiceWatch for
Page UI, DOM scraping, page patchingPortable ==UserScript==@match, @grant, @run-at, CSP-sensitive injection
Cross-origin API accessGM_xmlhttpRequest with explicit @connectMissing hosts, cookie behavior differences, user authorization
Long-running workerScriptCat @backgroundNo DOM, must return Promise for async work
Scheduled taskScriptCat @crontabOnly first @crontab counts, prefer 5-field cron, avoid interval overlap
User-editable settings==UserConfig== plus GM_getValueBlock placement and group.key naming
Silent bundle install and updates==UserSubscribe==HTTPS, user.sub.js, subscription connect overrides child scripts

Common Mistakes

  • Missing @grant for APIs the script actually uses.
  • Missing @connect for hosts used by GM_xmlhttpRequest or GM_cookie.
  • Treating @include as a better default than @match for ordinary host targeting.
  • Using DOM APIs inside ScriptCat background or cron scripts.
  • Returning from a ScriptCat background script before async GM work is truly finished.
  • Mixing ==UserScript== and ==UserSubscribe== packaging concepts.
  • Putting ==UserConfig== in the wrong place or reading config keys without the group.key name.
  • Assuming Tampermonkey and ScriptCat storage, notification, or request behavior is identical.

References

xixu-me tarafından daha fazla skill

github-actions-docs
xixu-me
Kullanıcılar GitHub Actions iş akışlarını yazma, açıklama, özelleştirme, taşıma, güvenliğini sağlama veya sorun giderme; iş akışı sözdizimi, tetikleyiciler, matrisler, çalıştırıcılar, yeniden kullanılabilir iş akışları, yapıtlar, önbellekleme, sırlar, OIDC, dağıtımlar, özel eylemler veya Actions Runner Controller hakkında soru sorduğunda, özellikle resmi GitHub dokümantasyonu, tam bağlantılar veya dokümantasyon tabanlı YAML rehberliğine ihtiyaç duyduklarında kullanın.
developmentdevopsdocument
use-my-browser
xixu-me
Kullanıcının canlı tarayıcı oturumuna veya statik getirmelerden ziyade görünür işlenmiş duruma bağlı olduğu durumlarda, özellikle tarayıcı hata ayıklama bağlamları veya DevTools tarafından seçilen öğeler veya istekler, oturum açılmış panolar veya CMS akışları, localhost uygulamaları, formlar, yüklemeler, indirmeler, medya incelemesi, DOM veya iframe incelemesi, Shadow DOM veya yumuşak 404'ler, kimlik doğrulama duvarları, bot karşıtı kontroller veya hız sınırlamaları gibi görünen tarayıcı hataları için kullanın.
browser-automationweb-scrapingtesting
readme-i18n
xixu-me
Kullanıcı bir depo README'sini çevirmek, depoyu çok dilli hale getirmek, belgeleri yerelleştirmek, dil değiştirici eklemek, README'yi uluslararasılaştırmak veya GitHub tarzı bir depoda yerelleştirilmiş README varyantlarını güncellemek istediğinde kullanılır.
documentdevelopmentapi
openclaw-secure-linux-cloud
xixu-me
Kendi OpenClaw sunucunuzu bir bulut sunucusunda barındırırken, uzak bir OpenClaw ağ geçidini güçlendirirken, SSH tünelleme, Tailscale veya ters proxy maruziyeti arasında seçim yaparken veya güvenli bir kişisel dağıtım için Podman, eşleştirme, sanal alan, token kimlik doğrulaması ve araç-izin varsayılanlarını gözden geçirirken kullanın.
devopssecurity
secure-linux-web-hosting
xixu-me
Kendin barındırma için bir bulut sunucusu kurarken, güvenliğini sağlarken veya gözden geçirirken kullanılır; buna DNS, SSH, güvenlik duvarları, Nginx, statik site barındırma, bir uygulamaya ters proxy yapma, Let's Encrypt veya ACME istemcileriyle HTTPS, güvenli HTTP'den HTTPS'ye yönlendirmeler veya isteğe bağlı olarak BBR gibi yayın sonrası ağ ayarları dahildir.
devopssecurityaws
opensource-guide-coach
xixu-me
Bir kullanıcı açık kaynak projesine başlama, katkıda bulunma, büyütme, yönetme, fonlama, güvenliğini sağlama veya sürdürme konularında rehberlik istediğinde ya da katkıda bulunanları işe alım, topluluk sağlığı, bakımcı tükenmişliği, davranış kuralları, metrikler, yasal temeller veya açık kaynak proje benimsenmesi hakkında sorular sorduğunda kullanılır.
developmentresearch
running-claude-code-via-litellm-copilot
xixu-me
Claude Code'u yerel bir LiteLLM proxy'si üzerinden GitHub Copilot'a yönlendirirken, doğrudan Anthropic harcamasını azaltmak, ANTHROPIC_BASE_URL veya ANTHROPIC_MODEL geçersiz kılmalarını yapılandırmak veya model-bulunamadı, localhost trafiği yok veya GitHub 401/403 kimlik doğrulama hataları gibi Copilot proxy kurulum başarısızlıklarını gidermek için kullanılır.
developmentapidevops
skills-cli
xixu-me
Use when users ask to discover, install, list, check, update, remove, back up, restore, sync, or initialize Agent Skills, mention `bunx skills`, `npx skills`, `skills.sh`, or `skills-lock.json`, ask "find a skill for X", or want help extending agent capabilities with installable skills.
developmentapiproductivity