App Legal Pages
/install app-legal-pages
App Legal Pages
Generate a complete legal mini-site for an app:
index.html(legal home)privacy.html(Privacy Policy)terms.html(Terms of Service)styles.css(shared styles)
Workflow
- Collect required legal/product inputs.
- Generate draft legal pages from feature documentation.
- Run strict consistency checker.
- Present generated pages for user review/approval.
- Check Cloudflare deployment auth readiness.
- Ask user to complete auth if missing.
- Auto-deploy to Cloudflare Pages after explicit confirmation.
- Return final public URLs.
1) Collect Inputs
Collect or confirm:
- App name
- Company/entity name (or individual publisher name)
- Contact email
- Governing law jurisdiction (country/region, optional; only if explicitly provided)
- Effective date
- App feature document (markdown/text)
- Data behavior details:
- Analytics events
- Crash/error logs
- Identifiers (device/user IDs)
- Third-party SDKs/services
- Permissions used (camera/location/photos/mic/contacts/tracking/notifications)
If facts are unknown, pause and ask for missing inputs before generation. Do not output placeholder markers (no TODO/TEMP strings in final pages). Never assume jurisdiction, region, analytics/tracking, sharing, or permission usage unless explicitly stated in the input document or user prompt. Generate policy clauses from explicit product claims first (e.g., offline-only, no cloud, no tracking, no analytics), and avoid introducing contradictory generic legal boilerplate.
2) Generate Draft Site
Run:
python3 scripts/generate_legal_site.py \
--input /path/to/app-feature.md \
--out ./out/legal-site \
--app-name "Your App" \
--company "Your Company" \
--base-email "[email protected]" \
--email-tag "quillnest" \
--effective-date "2026-03-03" \
--jurisdiction "California, United States"
Email rule:
- Prefer plus-address derivation from GitHub/base email + app tag.
- Example:
[email protected]+quillnest=>[email protected]. - Use
--emailonly when you explicitly want a fixed address.
Language rule:
- Generate English-only legal pages by default.
- Exclude non-English feature bullets from Feature Context to keep language consistent.
The script auto-detects likely data categories/permissions from the feature text. Manually review and adjust output if app behavior is more specific than heuristic detection.
3) Run Strict Consistency Checker
Run before publishing:
python3 scripts/check_consistency.py \
--feature /path/to/app-feature.md \
--privacy ./out/legal-site/privacy.html \
--terms ./out/legal-site/terms.html
The checker fails on:
- Placeholder tokens (TODO/TEMP/FIXME)
- Contradictions against explicit product claims (offline/no-cloud/no-tracking/no-analytics)
- EXIF mention in feature doc without corresponding privacy disclosure
- Governing-law section in Terms when jurisdiction is not explicitly provided
4) Validate Draft Quality
Check before publishing:
privacy.htmlandterms.htmlboth exist.- App/company/email/effective date are consistent across pages.
- Privacy disclosures match only explicitly stated permissions and data behavior (no inferred tracking/region claims).
- User rights and contact/deletion request path are present.
- No unverifiable legal claims.
- Final pages contain no placeholder markers (forbidden: TODO/TEMP/FIXME).
If the app uses sensitive permissions or SDKs, verify these are explicitly disclosed in Privacy Policy.
5) Review Gate (Mandatory)
Before deployment, share generated files with the user and ask for explicit approval to deploy. Do not deploy automatically without user confirmation.
6) Check Deployment Auth
Run auth readiness check:
python3 scripts/deploy_cloudflare_pages.py --check-auth --site-dir ./out/legal-site --project-name your-project-name --production-branch main
Auth is valid when either:
CLOUDFLARE_API_TOKEN+CLOUDFLARE_ACCOUNT_IDare set, orwrangler whoamisucceeds.
If auth is missing, ask the user to authenticate:
wrangler login
7) Auto-Deploy to Cloudflare Pages
After explicit approval + auth ready:
python3 scripts/deploy_cloudflare_pages.py \
--site-dir ./out/legal-site \
--project-name your-project-name \
--production-branch main
Or use one-shot pipeline:
python3 scripts/run_pipeline.py \
--feature /path/to/app-feature.md \
--out ./out/legal-site \
--app-name "Your App" \
--company "Your Company" \
--base-email "[email protected]" \
--email-tag "yourapp" \
--effective-date "2026-03-05" \
--project-name your-project-name \
--production-branch main \
--confirm-deploy
8) Returnables
Return:
- Cloudflare Pages site URL
- Privacy Policy URL (
\x3Csite>/privacy.html) - Terms of Service URL (
\x3Csite>/terms.html) - Auth mode used (
api-tokenorwrangler-login)
Guardrails
- Do not claim legal compliance guarantees.
- Keep wording plain and readable.
- Keep deterministic page structure for easy future edits.
- Recommend human legal review before production app-store submission.
- 确保已安装 OpenClaw(本地或 Docker 部署)
- 在对话框中输入安装命令:
/install app-legal-pages - 安装完成后,直接呼叫该 Skill 的名称或使用
/app-legal-pages触发 - 根据 Skill 的参数说明提供必要输入,即可获得结构化输出
App Legal Pages 是什么?
Generate and deploy app Privacy Policy and Terms of Service static websites from an app feature document. Use when a user provides app requirements/feature d... 它是一个面向 Claude Code / OpenClaw 的 AI Agent Skill 插件,目前累计下载 429 次。
如何安装 App Legal Pages?
在 OpenClaw 或 Claude Code 对话框中运行命令「/install app-legal-pages」即可一键安装,无需额外配置。
App Legal Pages 是免费的吗?
是的,App Legal Pages 完全免费(开源免费),可自由下载、安装和使用。
App Legal Pages 支持哪些平台?
App Legal Pages 跨平台运行,可在任意部署了 OpenClaw / Claude Code 的环境中使用(cross-platform)。
谁开发了 App Legal Pages?
由 chentuan7963-afk(@chentuan7963-afk)开发并维护,当前版本 v0.1.6。