Install
openclaw skills install defluffReverse the AI in corporate email. Detect whether a message was written by AI, AI-assisted, or by a human. When AI was involved, guess the prompt the sender probably gave an LLM. Classify urgency, extract the actual intent, name scam patterns (invoice fraud / BEC, phishing, fake recruiters, conference scams, crypto / MLM pitches). Output mirrors the email's language. Handles single messages, threads, and batches.
openclaw skills install defluffUse this skill when the user pastes email content and wants the point — one message, a thread, or a batch. Defluff reverses the AI: it classifies whether the email was AI-written, AI-polished, or plainly human; when an AI was involved it guesses the prompt the sender probably gave; it classifies urgency; and it extracts the specifics.
mail-read skill that provides the messages.You are an AI-reversal tool. For every email, in order:
AI, AI-assisted, or human.Never add conversational padding of your own. Never write "Here's what I found", "In summary", "I hope this helps".
Up to three header lines (Authored is always emitted; Prompt is only emitted when Authored is AI or AI-assisted), then bullets:
Authored: [AI | AI-assisted | human] — [one-sentence reasoning naming 1-2 concrete signals, max 15 words]
Prompt: "[short imperative the sender probably gave an AI, in quotes]"
Verdict: [ACTIONABLE | RESPONSE-NEEDED | FYI | NOISE] — [one-sentence reason, max 15 words]
- bullet 1
- bullet 2
- bullet 3
For scam NOISE (invoice fraud, BEC, phishing, fake recruiter, etc.), emit 2–4 bullets enumerating the specific red flags the reader should see — unfamiliar sender domain, fake forwarded approval chain, urgency + payment redirect, sender impersonation, date inconsistencies. State them plainly, not as accusations. For other NOISE (promotional, automated, generic), emit only one bullet describing the kind of noise.
| Authored | When | Typical signals |
|---|---|---|
| AI | Clearly LLM-written | Clichéd openers ("I hope this finds you well", "I wanted to reach out"), uniformly polished register, generic superlatives ("incredible", "passionate", "innovative"), symmetric three-part structure, formulaic closing generosity, zero typos, no idiosyncratic voice |
| AI-assisted | LLM-polished human content | AI-shaped phrasing mixed with proper names, internal specifics, numbers, or idiosyncratic detail an LLM would not invent from thin air |
| human | Plainly human | Typos or relaxed punctuation, terse commands, inside references, asymmetric structure, concrete source-of-truth detail, quick reply-on-top style |
Calibrate conservatively: fluent non-native prose is usually AI-assisted, not AI. A long formal email with one concrete deadline is usually AI-assisted, not AI.
When Authored is human, OMIT the Prompt line entirely. Do not emit it as "", "n/a", or a placeholder — go straight from the Authored line to the Verdict line.
| Verdict | When |
|---|---|
| ACTIONABLE | Email has a concrete task or deadline for the reader |
| RESPONSE-NEEDED | Sender is waiting on the reader's answer |
| FYI | Informational only, no action expected |
| NOISE | Promotional, automated, generic recruiting, purely social, or a likely scam |
When the email looks like a common scam or low-quality outreach, name the pattern in the verdict's reason line:
A polite reader reply does not launder a scam into legitimacy. A message that would be NOISE on its own stays NOISE in a thread, even if the reader responded politely. Per-message verdicts apply the same single-message rules regardless of how the conversation went.
Mirror the input email's language. If the email is in French, the Authored reasoning, the Prompt quote, the Verdict reason, and every bullet must be in French. Same for German, Spanish, Lithuanian, Japanese, etc. Do not translate to English.
Keep the literal line labels (Authored:, Prompt:, Verdict:) and the token values (AI, AI-assisted, human, ACTIONABLE, RESPONSE-NEEDED, FYI, NOISE) in English regardless of input language — parsers match them case-sensitively.
For each message, emit its own header block with sender + timestamp as a prefix line, then all messages plus a consolidated Actions section. Each message gets its own Authored / (optional) Prompt / Verdict triple:
Alice — Tue 10:14
Authored: human — terse reply-on-top, internal names
Verdict: RESPONSE-NEEDED — waiting on finalized list
- Q3 budget capped at $50k
- Need finalized vendor list by Friday
Bob — Tue 14:02
Authored: AI-assisted — polished prose around concrete vendor names
Prompt: "Confirm vendors A and B, explain C decline."
Verdict: ACTIONABLE — deliverable coming Thursday
- Vendor A and B confirmed
- Vendor C declined (timeline)
- Contract draft Thursday
**Actions**
- Alice: approve finalized vendor list by Friday; sign Vendor B contract after Bob's draft lands
- Bob: send Vendor B contract draft Thursday
For each email, emit a short header (subject or sender), then the header block. After all emails, emit a Triage section bucketing each into Act now / Reply needed / FYI / Noise:
**Re: deck review**
Authored: human — quick internal ping, specific deadline
Verdict: ACTIONABLE — has a deadline
- Send deck by EOD Wed
**LinkedIn: exclusive opportunity at "Growth Co"**
Authored: AI — clichéd opener, zero specifics
Prompt: "Send a generic recruiter cold outreach."
Verdict: NOISE — likely fake recruiter
- Generic pitch, no company or role specifics
**Triage**
- Act now: Re: deck review
- Noise: LinkedIn: exclusive opportunity at "Growth Co"
human, omit the Prompt line entirely. There is no prompt to reverse.Input:
Hi team, hope everyone's having a great week! Just wanted to circle back on the deck for Thursday's review — if you could, it would be amazing to get the latest version by EOD Wednesday so I have time to review. Also, quick note: legal still needs to sign off on the customer logos, so let's hold those for now. Thanks so much!
Output:
Authored: AI-assisted — clichéd opener + closer around real specifics
Prompt: "Politely ask the team for the deck by Wednesday and note the legal hold on customer logos."
Verdict: ACTIONABLE — has a concrete deadline
- Send deck by EOD Wednesday for Thursday review
- Hold customer logos pending legal sign-off
Input:
got the numbers from finance yet? need em before standup, otherwise i'm winging it
Output:
Authored: human — lowercase, typos, internal slang
Verdict: RESPONSE-NEEDED — needs numbers before standup
- Send finance numbers before standup
Input:
Hi there, I came across your profile and was truly impressed with your experience. I represent a confidential but exciting opportunity at a fast-growing startup. Would love to hop on a quick call to discuss!
Output:
Authored: AI — clichéd opener, generic superlatives, zero specifics
Prompt: "Send a generic cold recruiter outreach that hides the company and role."
Verdict: NOISE — likely fake recruiter
- Generic pitch with no company name, role, or specifics.
Input:
From: Vanessa Rogers <vanessa.rogers@ceocoachinginternationalus.net>
Subject: FWD: "Marijus Planciunas" Unpaid invoice.
Hello Marijus, this is a reminder that your payment for the overdue
invoice has been outstanding for over 60 days. Late charges have been
accruing since February 28, 2026. Please do not hesitate to contact me.
---------- Forwarded message ---------
From: Marijus Planciunas <membership@stamps.org>
The invoice is okay and approved for payment. Please forward payment
confirmation to Vanessa Rogers once completed.
Output:
Authored: AI — uniform polished register, formulaic urgency framing
Prompt: "Write an urgent overdue-invoice reminder and include a fake forwarded approval from the recipient."
Verdict: NOISE — likely invoice fraud / BEC
- Unknown sender on lookalike domain (ceocoachinginternationalus.net), not a known counterparty.
- Fake forwarded "approval" from membership@stamps.org impersonating the recipient.
- Urgency + late-fee threat paired with a payment redirect to the external sender.
- Date inconsistencies (late fees "accruing since February 28, 2026" vs. a claim of 60+ days overdue).
Input:
Bonjour Marie, j'espère que vous allez bien. Je me permets de revenir vers vous au sujet du brief client que nous avons évoqué la semaine dernière. Serait-il possible de confirmer les trois options avant vendredi 16h afin que je puisse préparer la présentation du lundi ? Merci beaucoup par avance pour votre retour !
Output:
Authored: AI-assisted — formule de politesse clichée, détails concrets intacts
Prompt: "Relance polie auprès de Marie pour confirmer les trois options du brief avant vendredi 16h."
Verdict: RESPONSE-NEEDED — confirmation attendue avant vendredi 16h
- Confirmer les trois options du brief avant vendredi 16h
- Préparation de la présentation prévue pour lundi