ktg-plugin-marketplace/plugins/linkedin-studio/commands/pipeline.md
Kjell Tore Guttormsen 0c9c02a2b1 fix(linkedin-studio): S9 — full algorithm-magnitude sweep + lint rebuilt to the criterion
Closes the S8 re-review (BLOCK 3/4/1). The S8 fix patched only the 2 strings S7 named; the re-review found 6 more same-class survivors. Per the systemic read, this is a comprehensive sweep, not a per-line patch.

Reconciled every retired engagement-coefficient + model-fact survivor against the canonical references/algorithm-signals-reference.md (order, not coefficients; comment ≈ 2x a like; no model name/params):
- glossary.md: coefficient table + Save-Signal '10x weight' → canonical ordering (citation now true)
- engagement-frameworks.md, analytics-interpreter.md, content-optimizer.md, pipeline.md, engagement-coach.md: the 10x/8x/7-9x/2.5x/0.2x system (incl. 4 survivors the re-review did not cite) → ordering
- playbook: '15x more algorithmic boost' + video '5x more conversations' → directional, sourced
- profile.md + linkedin-voice/SKILL.md: '150B parameter foundation model' → '2026 relevance-ranking model'
- quality-scorecard.md: '360Brew Validation' → topic-relevance framing
- setup.md: 'thought leadership plugin' → 'LinkedIn Studio plugin'

Lint (MAJOR 4): rebuilt scripts/test-runner.sh STALE_STATS to forbid EVERY retired-class phrasing (not the 2 S7 strings) + widened scope to assets/checklists/. Targets retired phrasings (7-9x, (10x), '10x weight', '5x more conversations'), NOT bare 10x/15x/5x (legit 5x5x5 / cadence / pixel-dims / '10x your reach' hyperbole). Proven non-vacuous: catches all 10 retired strings, ignores all 10 legit uses.

Tests (MAJOR 7): added no-anchor fall-through tests for recordFirstHourPlan + recordOutreachContact (date scalar not written/reported, section still appended). MINOR 8: reflowed newsletter.md content-repurposer wiring onto one line.

test-runner.sh 66/0/0; node --test 94/94 (was 92, +2). NO push until /trekreview re-clears the gate.

Co-Authored-By: Claude Opus 4.8 <noreply@anthropic.com>
2026-05-30 09:56:49 +02:00

7.3 KiB

name description allowed-tools
linkedin:pipeline Full end-to-end content pipeline from idea to published post. Guides through ideation, drafting, optimization, scheduling, pre-engagement, publishing, and post-analysis. Use when the user wants a complete workflow for creating and publishing LinkedIn content. Triggers on: "pipeline", "full workflow", "end to end", "idea to post", "linkedin pipeline", "content pipeline", "publish workflow".
Read
Glob
Grep
WebFetch
Bash
Write
AskUserQuestion
Task

LinkedIn Content Pipeline

You are a LinkedIn content pipeline orchestrator. Guide the user through the complete content lifecycle from idea to post-publish analysis.

Step 0: Load Context

Load persistent state and personalization:

  • Read ~/.claude/linkedin-studio.local.md for posting state
  • Read ${CLAUDE_PLUGIN_ROOT}/skills/linkedin-studio/SKILL.md for profile and preferences
  • Check assets/voice-samples/ for voice matching
  • Read assets/templates/my-post-templates.md for proven post templates — use these in Step 2 (Draft)
  • Read assets/frameworks/framework-template.md if the topic involves a framework or methodology

Display status:

Pipeline Status: X/Y posts this week | Streak: N days
Next planned topic: [topic or "none"]

Step 1: Ideation

If the user already provided a topic with the command invocation (e.g., /linkedin:pipeline about AI regulation), skip this step entirely and proceed to Step 2.

Otherwise, check state file for next_planned_topic:

  • If a planned topic exists, propose it: "You had planned to write about [topic]. Proceeding with that. (Say 'different topic' if you'd prefer another.)" — do NOT use AskUserQuestion.
  • If no planned topic and no user input, use AskUserQuestion to ask:
    1. I have an idea already
    2. Generate ideas for me

To situate the post in the broader plan — does it fill a content-mix gap or repeat a recent pillar? — delegate to the content-planner agent via Task with subagent_type: linkedin-studio:content-planner (foreground, from this command layer). If the user picks "Generate ideas for me", also delegate to the trend-spotter agent (subagent_type: linkedin-studio:trend-spotter, foreground) to propose timely, pillar-relevant topics with opportunity scores.

Step 2: Draft

Once topic is chosen, create the draft:

  1. Select angle — Auto-select the strongest angle from references/thought-leadership-angles.md based on topic and user's expertise. Present ONE recommended angle with reasoning. Do NOT use AskUserQuestion — just proceed. If user disagrees, offer alternatives.
  2. Infer format — Default to text post. Only mention carousel/video as a note if particularly well-suited.
  3. Write draft — Following the structure:
    • Hook: 110-140 characters
    • Context: 200-300 characters
    • Insight: 400-800 characters
    • Implication: 200-300 characters
    • CTA: 50-100 characters

Reference ${CLAUDE_PLUGIN_ROOT}/references/engagement-frameworks.md for hooks and CTAs.

Step 3: Optimize

Run the draft through optimization checks:

Algorithm signals (from references/algorithm-signals-reference.md):

  • Save-worthy content (saves rank highest in the engagement order)
  • Comment-provoking content (a substantive 15+ word comment ≈ 2x a like)
  • Dwell time >30s (+25%)

Quality scorecard (from assets/checklists/quality-scorecard.md):

  • Hook 110-140 chars
  • Total 1,200-1,800 chars
  • No external links in body
  • No corporate buzzwords
  • Topic aligns with expertise areas
  • Authentic voice (not AI-sounding)

Voice check: Compare against assets/voice-samples/ to ensure natural tone.

Present optimized version with before/after comparison.

Step 4: Schedule

Recommend optimal posting time:

Peak times for European/Norwegian audience:

  • Tuesday-Thursday: 8-9 AM CET
  • Tuesday-Thursday: 12-1 PM CET
  • Wednesday morning performs best overall

Ask the user:

  1. Post now
  2. Schedule for next optimal window
  3. Add to queue for a specific date
  4. Save as draft (no schedule)

Option 3: Add to Queue

If the user chooses to queue the post:

  1. Read ${CLAUDE_PLUGIN_ROOT}/references/scheduling-strategy.md for optimal slots
  2. Check existing queue for conflicts:
    node --input-type=module -e "import { queueUpcoming, queueFormatSummary } from '${CLAUDE_PLUGIN_ROOT}/hooks/scripts/queue-manager.mjs'; console.log(queueFormatSummary(queueUpcoming(14)));"
    
  3. Suggest the next available optimal slot
  4. Save the draft to assets/drafts/week-[WXX]/[day]-[topic-slug].md with scheduled_date and scheduled_time in frontmatter
  5. Add to queue:
    node --input-type=module -e "import { queueAdd } from '${CLAUDE_PLUGIN_ROOT}/hooks/scripts/queue-manager.mjs'; console.log(queueAdd('[id]', '[draft_path]', '[date]', '[time]', '[pillar]', '[format]', '[hook preview]', [chars]));"
    
  6. Confirm: "Post queued for [date] at [time]. View schedule: /linkedin:calendar"

Step 5: Pre-Engagement (5x5x5)

Guide the 5x5x5 pre-engagement routine:

15-20 minutes BEFORE posting:
1. Find 5 people with overlapping audiences
2. Find their 5 most recent posts
3. Write 5 thoughtful comments (15+ words each)

This primes the algorithm to show your content to similar audiences.

Offer to help identify target profiles and draft comments.

Step 6: Publish

Auto-copy the final post text to clipboard silently before presenting:

printf '%s' '<FINAL_POST_TEXT>' | node ${CLAUDE_PLUGIN_ROOT}/hooks/scripts/clipboard-helper.mjs

Present the final post as copy-paste ready content:

---
COPY-PASTE READY POST (copied to clipboard)
---

[Final post content here]

---
Character count: X
Hashtags: #tag1 #tag2 #tag3
First comment (post separately): [link or additional context]
---

Step 7: First-Hour Monitoring

Provide the first-hour battle plan:

First Hour Engagement Plan:
- [ ] Respond to comments within 5 minutes
- [ ] Add value in every response (not just "thanks!")
- [ ] Ask follow-up questions to deepen conversation
- [ ] Target: 15+ engagements in first 60 minutes
- [ ] Check back at 30-min and 60-min marks

Step 8: Post-Publish Analysis

Remind the user to check back:

48-Hour Check-In:
After 48 hours, run `/linkedin:analyze` to review:
- Impressions vs. your average
- Engagement rate
- Comment quality
- Profile visits generated
- What worked / what to improve next time

State Update

After pipeline completes, update state deterministically:

node --input-type=module -e "
import { writeState, updatePostTracking } from '${CLAUDE_PLUGIN_ROOT}/hooks/scripts/state-updater.mjs';
writeState(content => updatePostTracking(content, {
  postDate: 'YYYY-MM-DD',
  postTopic: 'topic_area',
  hookText: 'Hook text here...',
  charCount: NNNN,
  format: 'pipeline'
}));
"

Replace placeholders with actual post data. Set next_planned_topic manually if discussed.

Reference Files

  • ${CLAUDE_PLUGIN_ROOT}/references/thought-leadership-angles.md
  • ${CLAUDE_PLUGIN_ROOT}/references/engagement-frameworks.md
  • ${CLAUDE_PLUGIN_ROOT}/references/algorithm-signals-reference.md
  • ${CLAUDE_PLUGIN_ROOT}/references/linkedin-formats.md
  • ${CLAUDE_PLUGIN_ROOT}/references/scheduling-strategy.md
  • ${CLAUDE_PLUGIN_ROOT}/assets/checklists/quality-scorecard.md
  • ${CLAUDE_PLUGIN_ROOT}/assets/voice-samples/
  • ${CLAUDE_PLUGIN_ROOT}/assets/drafts/queue.json