Skill flagged — suspicious patterns detected

ClawHub Security flagged this skill as suspicious. Review the scan results before using.

Blog Writing

v2.2.1

Step-by-step SEO blog writing workflow for teams who want full control over every phase. Covers keyword strategy, competitive research, content structure, in...

0· 9·0 current·0 all-time
MIT-0
Download zip
LicenseMIT-0 · Free to use, modify, and redistribute. No attribution required.
Security Scan
VirusTotalVirusTotal
Pending
View report →
OpenClawOpenClaw
Suspicious
medium confidence
Purpose & Capability
The name/description (SEO blog workflow) aligns with instructions for research, outlining, writing, linking, and QA. However, the skill is explicitly tailored to an organization (filomail/* paths) and depends on a separate seo-geo-qa script set that is not included or declared. Asking to read product/brand/internal link maps is plausible for an internal content workflow, but unexpected for a generic public skill.
!
Instruction Scope
The SKILL.md instructs the agent to run shell commands (python QA runners), read multiple local paths under filomail/, and write partial article sections to disk. Critically, it mandates spawning a subagent with security: "full" to bypass exec approval gates — this explicitly requests elevated runtime privileges and the ability to run arbitrary exec commands. The instructions also assume the presence and trustworthiness of scripts at skills/seo-geo-qa/, which are not present in the package.
Install Mechanism
This is instruction-only with no install spec or code files, so nothing will be written to disk by an installer. That lowers supply-chain risk. However, because the instructions call external scripts and python commands, the skill implicitly depends on out-of-band files and tooling not provided here.
!
Credentials
The skill requests no declared environment variables or credentials, but the runtime instructions require reading potentially sensitive local directories (filomail/product/, filomail/brand/, filomail/blog/plan/). Those paths grant access to product facts, brand/voice guidance, and internal link maps that may be sensitive. The SKILL.md does not justify why full exec privileges are needed beyond running QA/link-check scripts, nor does it limit file access to a narrow scope.
!
Persistence & Privilege
The skill does not request always:true, which is good, but it explicitly instructs spawning a subagent with security: "full" to bypass approval gates. Asking to circumvent approval and obtain full exec permissions is a privileged request that increases blast radius and could allow actions beyond the stated blog-writing purpose if misused.
What to consider before installing
This skill appears designed for internal use at filomail and expects local QA/link-check scripts and product/brand files that are not included. Before installing or enabling it: (1) Confirm you trust the skill owner and that this is intended for your organization; (2) don't grant or automate 'security: "full"' for a subagent unless you fully trust the code it will run — prefer manual exec approvals; (3) verify the presence, source, and content of the referenced skills/seo-geo-qa scripts and review them for data exfiltration or network calls; (4) if you must run it, run in an isolated environment or container with limited filesystem access and network egress controls; (5) ask the author to remove hard-coded org file paths or make them configurable and to avoid requiring full, blanket exec privileges — request least-privilege alternatives. If you cannot get these assurances, treat this skill as risky for general use.

Like a lobster shell, security has layers — review code before you run it.

latestvk9799ngwqx7s32dem1khev8ycn845s3k

License

MIT-0
Free to use, modify, and redistribute. No attribution required.

SKILL.md

SEO Blog Writing — Complete Workflow

When to Use

  • Writing any blog article (comparison, how-to, listicle, guide, thought piece)
  • Creating long-form SEO content (2000+ words)
  • Producing content for filomail.com/blog or any website

Execution Model (IMPORTANT)

This skill requires running shell commands (Phase 5 link verification, Phase 6 QA runner). It must be executed in a context with full exec permissions.

Always spawn the writing subagent with security: "full":

sessions_spawn(
  task: "[full article brief]",
  runtime: "subagent",
  security: "full"   ← REQUIRED — without this, exec approval gates block Phase 5 & 6
)

If running in main session directly (fallback only), exec permissions are already sufficient — proceed normally.

Never spawn without security: "full" — the subagent will silently skip QA and deliver an unverified draft.

Failure Recovery Guardrails (Mandatory)

  1. Section-by-section writes — Write each H2 section to disk incrementally. Never hold more than one section only in context.
  2. Inline AI-tell check — After each H2 section, run the 4-point check (see Phase 3) before moving on. Fix inline, don't batch.
  3. QA loop cap — Max 3 QA rounds. Each round fixes only concrete FAIL items from the latest report. Never regenerate passing sections.
  4. Timeout recovery — If interrupted mid-article, write partial output to disk immediately, note the resume section, and continue from there. Do not restart from zero.

Pre-Flight

  1. Read filomail/product/ for current product facts
  2. Read filomail/brand/ for voice and red lines
  3. Check filomail/blog/plan/internal-links-map.md for internal linking targets
  4. Check filomail/blog/plan/content-plan.md for where this article fits in the topic cluster

Phase 1: Research (Before Writing)

Keyword Research

  1. Primary keyword — The exact phrase we want to rank for (e.g., "best AI email apps 2026")
  2. Secondary keywords — Related phrases to include naturally (3-5)
  3. Long-tail variants — Question-form queries for FAQ section

Competitive Analysis

For the primary keyword, search Google and analyze top 5 results:

  • Word count of each
  • H2/H3 structure
  • What they cover that we should cover
  • What they miss that we can fill (content gap)
  • External links they use (authority sources)

Run the QA runner to analyze SERP gaps during research:

python3 skills/seo-geo-qa/scripts/seo_qa_runner.py path/to/draft.md --keyword "best email apps for mac"

Use the lower-level analyzer only when debugging SERP gaps in isolation:

python3 skills/seo-geo-qa/scripts/serp_gap_analyzer.py "best email apps for mac" path/to/draft.md
python3 skills/seo-geo-qa/scripts/serp_gap_analyzer.py "best email apps for mac" path/to/draft.md --urls https://competitor1.com https://competitor2.com

Search Intent Classification

Intent TypeSignalArticle Approach
Informational"what is", "how to"Definitive guide, answer-first
Comparison"best", "vs", "alternatives"Structured comparison, table-heavy
Commercial"review", "pricing"Detailed evaluation, honest pros/cons
Navigationalbrand nameProduct-focused, feature deep-dive

Output: Research Brief

Save to filomail/blog/plan/ before writing:

## Research Brief: [Title]
- Primary keyword: 
- Secondary keywords: 
- Search intent: 
- Target word count: 
- Top 5 competitor URLs + word counts
- Content gaps to exploit
- Internal links to include
- External authority sources identified

Phase 2: Outline

Standard Article Structure

# H1 — Contains primary keyword, under 60 chars

Opening hook (150-200 words)
- Define the problem/question
- Why this matters now
- What this article covers

## Quick Comparison Table (for comparison articles)

## Detailed Reviews / Sections (bulk of article)
### H3 subsections as needed

## How We Tested / Methodology

## How to Choose / Decision Framework

## FAQ (4-6 questions, schema-markup ready)

## Further Reading (internal + external links)

Heading Rules

  • One H1 per article, contains primary keyword
  • H2s match search queries where possible
  • H3s for subsections within H2s
  • Never skip levels (H1 → H3 is wrong)
  • Headings describe content, not for styling

Phase 3: Write

Opening (First 100 Words — Critical)

  • Primary keyword appears in first 100 words
  • Direct answer or clear hook (no throat-clearing)
  • Set expectation for what reader will learn

Body Writing Standards

Word Count by Type:

TypeMinimumTarget
Comparison / Listicle2,5003,000-3,500
How-to Guide1,5002,000-2,500
Thought Piece1,0001,500-2,000
Product Comparison (vs)2,0002,500-3,000

Keyword Density:

  • Primary keyword: 1-2% (natural, never stuffed)
  • Secondary keywords: 0.5-1% each
  • Check: keyword should feel invisible to the reader

Paragraph Structure:

  • Max 3-4 sentences per paragraph
  • One idea per paragraph
  • Short sentences mixed with longer ones
  • Use bullet points and numbered lists for scanability

Readability Target:

  • Flesch Reading Ease: 60-70 (standard/conversational)
  • Grade level: 8-10 (accessible but not dumbed down)
  • Sentence length: average 15-20 words, max 35

Internal Linking Strategy

Word CountInternal Links MinTarget
< 150023-5
1500-250035-8
2500-350058-12
3500+710-15
  • Link with descriptive anchor text (not "click here")
  • Link to related blog posts in the same topic cluster
  • Link to product/feature pages where natural
  • Follow hub-spoke pattern (see internal-links-map)
  • Consult filomail/blog/plan/internal-links-map.md

External Linking Standards (Proportional)

Content TypeExternal Links MinRationale
Comparison / Best-of (8+ products)16-24Each product: official site + 1 authority source
Comparison / Best-of (5-7 products)12-18Same ratio
Alternatives page10-15Each alternative + authority sources
How-to guide5-10Claims need sources, fewer entities
Thought piece3-8Fewer claims, more perspective

The principle: Every entity mentioned gets a link. Every factual claim gets a source. Don't link for the sake of linking.

  • Prefer: official sites > media reviews > research papers
  • Avoid: personal blogs, paywalled content, temporary pages
  • Never link to competitors' comparison articles (link to their product page)
  • All links must be verified (Phase 5)

Authority Signals (GEO/AEO Optimization)

These boost visibility in AI search engines (ChatGPT, Perplexity, Google AI Overviews):

SignalImpactHow
Statistics with sources+37%"According to [Source], X% of users..."
Quotations (expert quotes)+30%"As [Name], [Title] at [Company], notes..."
Authoritative tone+25%Write with demonstrated expertise, not hedge language
Authoritative citations+40%Link to research, not just claims
Clear definitions+20%Definition in first paragraph of each section
FAQ with schema+30-40%Natural Q&A format at bottom
"Last updated" date+freshnessInclude at bottom of article

Evidence sandwich pattern — Structure every major claim as: Claim → Evidence → Interpretation

"Most users prefer [X] [claim]. A 2024 study of 1,000 professionals found Y [evidence]. This means Z for your specific workflow [interpretation]."

Stats without interpretation are noise. Interpretation without evidence is opinion. The sandwich does both and is the format AI systems are most likely to excerpt.

Content Extractability (for AI Citation)

AI systems extract passages, not pages. Each key point should work standalone:

  • Lead every section with a direct answer (don't bury it)
  • Keep key answer passages to 40-60 words
  • Tables beat prose for comparison content
  • Numbered lists beat paragraphs for process content
  • Self-contained answer blocks that work without surrounding context

Platform-Specific GEO

Different AI systems cite differently. Write each major section to satisfy all four:

PlatformWhat it prefersFormat to use
Google AI OverviewsDirect answers, tables, listsLead with 40-60 word direct answer. "X is [definition]. Key points: [numbered list]."
PerplexityEvidence with methodology, attributed data"Research shows [finding] (N=size, method, year)." Front-load sample size and date.
ChatGPTMultiple angles, acknowledged limitations"While X is generally true, Y also matters because..." Cover edge cases.
ClaudeLogical cause-and-effect chains"Because X happens, Y results, leading to Z." Structure reasoning, not just conclusions.

In practice: One well-structured section satisfies all four. Lead with direct answer (Google), follow with sourced evidence (Perplexity), add nuance (ChatGPT), ensure logical flow throughout (Claude).

Comparison Article Specifics

For "Best X" / "X Alternatives" / "X vs Y" articles:

  • Always include a comparison table at the top
  • Each entry needs: Name, Price, Key Feature, Platforms, Best For
  • Be honest about competitors — acknowledge strengths
  • Be honest about our weaknesses — builds trust, ranks better
  • Position Filo first but earn it with real arguments
  • Include anchor IDs for each product section

Inline AI-Tell Check (Run After Each H2 — Not Batched)

After writing each H2 section, check these 4 things before moving to the next section. Fix inline. Do not save the check for Phase 4.

□ Banned words: delve, seamlessly, robust, leverage, revolutionize, holistic, tapestry,
                navigate (metaphor), harness, paradigm, synergy, game-changer, elevate
□ Long sentences: any sentence > 35 words? Split it.
□ Throat-clearing opener: section starts with "It's important to..." / "When it comes to..."?
  Cut it — start with the point.
□ Em-dash density: > 1 em-dash per 200 words? Rewrite as commas, semicolons, or split sentences.

If any box is checked: rewrite only the flagged sentence(s). Then move on. This takes under 30 seconds per section and catches problems at the source rather than in a painful batch rewrite at the end.


Phase 4: Optimize

SEO Checklist (Before Review)

  • H1 contains primary keyword, under 60 chars
  • Meta description drafted: 150-160 chars, includes keyword
  • Primary keyword in first 100 words
  • Primary keyword in at least one H2
  • URL slug is keyword-rich and clean
  • At least one table or list (featured snippet opportunity)
  • FAQ section present (schema markup ready)
  • "Last updated: [Month Year]" at bottom
  • Internal links ≥ 3
  • External links ≥ 10
  • All images have alt text (when applicable)

AI Writing Pattern Avoidance

CRITICAL: Content must not read like AI wrote it.

Common AI patterns to eliminate:

PatternExampleFix
Em-dash overuse"The tool — which is powerful — works well"Use commas or periods instead. Max 3 em-dashes per article.
"Delve into""Let's delve into the features""Here's what it does" / "Let's look at"
"Landscape""In today's email landscape"Cut it. Be specific.
"Leverage""Leverage AI to improve""Use AI to improve"
"Tapestry/Mosaic""A rich tapestry of features"Just describe the features.
"Revolutionize""Revolutionizing how you email""Changes how you email"
"Game-changer""This is a game-changer"Say what it actually changes.
"Seamlessly""Seamlessly integrates""Integrates" or "works with"
"Robust""A robust set of features""A full set of features" or just list them.
"Elevate""Elevate your inbox experience""Improve" or describe the specific improvement.
"Navigate" (metaphor)"Navigate your inbox challenges""Deal with" / "Handle" / "Manage"
"Harness""Harness the power of AI""Use AI to..."
"Paradigm""A paradigm shift"Describe the actual change.
"Synergy""Create synergy between...""Works well with" or describe specifically.
"Holistic""A holistic approach""A complete approach" or be specific.
"At the end of the day"FillerCut it.
"Without further ado""Without further ado, here's..."Just start.
Triple-adjective stacking"Powerful, intuitive, and elegant"Pick one. Prove it.
Rhetorical questions"But what if there was a better way?"State the better way.
"In conclusion" / "In summary""In conclusion, Filo is the best"Just make your point.

Self-check: Read the article out loud. If any sentence sounds like a press release, rewrite it.


Phase 5: Link Verification (MANDATORY)

Never deliver content without verifying every link.

Process

  1. Extract all URLs from the article
  2. Test each with web_fetch or curl -sI
  3. Check for: 404, 403, redirects to wrong content, paywalls
  4. For non-obvious external sources, run a source-quality spot check (AITDK/Ahrefs/search evidence)

Source Quality Spot Check

For external sources that are not obviously authoritative, check whether they are worth citing:

  • AITDK traffic page: https://aitdk.com/traffic/<domain> for traffic / keyword / domain-age hints when accessible
  • Ahrefs Backlink Checker: use as a quick proxy for domain strength / backlink profile
  • Search evidence: site:domain.com, branded query, and recent indexed pages if third-party tools are blocked

Do not require perfect metrics. The goal is to catch weak, stale, spammy, or irrelevant sources before they land in the article.

When Links Fail

  • Search for alternative source supporting the same claim
  • Prioritize: Official sites > Research > Major publications
  • Update surrounding text if needed
  • Document changes:
**Original:** https://broken-link.com (404)
**Replacement:** https://working-link.com
**Reason:** Original returned 404
**Verified:** ✅ Same data confirmed

Quote & Attribution Verification (CRITICAL — learned the hard way)

  • If citing a review → verify the quote exists AND the article's overall tone matches your framing
  • Tone match test: Read the first 3 paragraphs of the source article. Is it positive, negative, or neutral?
    • Source is positive → quote freely
    • Source is negative → either don't quote, or frame honestly: "Even [Source]'s critical review acknowledged..."
    • Source is neutral → quote with accurate framing
  • Don't pull positive fragments from negative reviews — readers click through and lose trust
  • Statistics must match their cited source exactly (number, date, methodology)
  • "According to [Source]" → verify Source actually says that

Phase 6: Automated QA (MANDATORY — runs before human review)

After completing Phase 5, ALWAYS run the QA runner before spawning a review agent or delivering the draft. Do not skip this. Do not ask whether to run it.

python3 skills/seo-geo-qa/scripts/seo_qa_runner.py path/to/article.md --keyword "primary keyword"

What happens automatically

  1. All links verified (liveness + source quality tiering)
  2. Dead links, weak sources, moved links flagged
  3. FAQ count, external link count, SERP gap checked
  4. Markdown + JSON report saved to qa-reports/{slug}/ next to the article
  5. Verdict: PASS or FAIL

If FAIL

  • Fix critical issues (dead links, too many TIER-D sources)
  • Re-run until PASS
  • Max 3 rounds

If PASS

  • Proceed to Phase 7 (human review)
  • Include the QA report link in the review handoff

Phase 7: Review (Auto-Spawn)

Always spawn a review agent after Phase 6 passes. The review agent checks:

Review must check:

  • QA runner verdict is PASS (with report link)
  • SEO checklist complete
  • Brand voice compliance
  • Factual accuracy (pricing, features)
  • AI writing patterns eliminated
  • Readability standards met

File Conventions

Where to Save

  • Research briefs: blog/plan/brief-{slug}.md
  • Article drafts: blog/seo/{slug}.md (SEO) or blog/{slug}.md (general)
  • Article images: handled separately in your CMS or website repo

Slug Format

  • Lowercase, hyphen-separated
  • Match target URL path: /blog/{slug}

Title Year Rules (2026-03-24 决策)

文章类型标题带年份?原因
比较类 (best X, X alternatives)✅ 是年份是搜索关键词的一部分("best email app 2026")
教育型 / How-to❌ 否搜索意图是常青的,年份反而限制文章寿命
场景痛点❌ 否同上
功能发布❌ 否功能不按年份搜索
思想 / 署名文章❌ 否同上
  • 教育类文章的 freshness 信号放在文末 "Last updated: [Month Year]"
  • 比较类文章的年份每年 Q1 集中更新(标题 + 内容 + slug)
  • 参考:Anthropic claude.com/blog 零篇使用年份标题,全靠内容 freshness 信号

Related Skills

  • content-production — Mandatory produce → review → revise workflow
  • content-qa — QA checklist and review agent
  • seo-audit — Technical SEO checks for the whole site
  • seo-geo — GEO optimization for AI search engines
  • competitor-alternatives — Comparison page structure
  • schema-markup — JSON-LD implementation
  • copy-editing — Multi-pass editing framework

Files

1 total
Select a file
Select a file to preview.

Comments

Loading comments…