ClawAudit verdict

wechat-content-studio

45
🟠 Risky
Significant concerns — only install if you understand the risks

The skill provides a one-stop solution for WeChat content creation, but its use of package installation and execution could pose a risk if not properly validated.

⚠ Flagged for review — coarse, uncorroborated signal, not a confirmed exploit. Review the config yourself before installing.

Automated static analysis — not a human review. ClawAudit flags capabilities, not confirmed intent, and can produce false positives. Disagree with this verdict? Use Dispute below.

48
security
100
transparency
100
maintenance

Permission integrity

Installs packages at runtime — transitive dependencies are not auditable

package_install

Findings (7)

Pattern match medium

HTTP request to bare IP address — common in malicious payloads

SKILL.md · prose · downgraded · http://127.0.0.1

Pattern match medium

Accesses OpenClaw config/secrets directly

SKILL.md · prose · downgraded · ~/.openclaw/.env

Pattern match medium

References child_process — can spawn system processes

scripts/extractor/multi_site_bridge.js · prose · downgraded · child_process

Pattern match medium

Dynamic import() — loads module at runtime

scripts/image/generate_cover.js · prose · downgraded · import('

Pattern match low

Popular HTTP library — network access

package-lock.json · prose · downgraded · axios

Pattern match low

Accesses sensitive environment variables

scripts/lib/openclaw_env.js · prose · downgraded · process.env.DASHSCOPE_API_KEY

Pattern match low

POSTs data to external URL

scripts/publisher/api_publish.js · prose · downgraded · .post( `https://

Why the tier is capped

Execution sink present in raw bytes (Hard Floor: class D). Final tier capped at Caution — cannot be lifted by any downgrade, example-payload opt-in, or allowlist.

Permissions & capabilities

No declared permissions — minimal attack surface.

package_install

Is this flag fair?

Check another skill Browse the registry Auditing your own skills or configs? Use the API