Setting up spam detection in your community

:bookmark: This is a how-to guide for setting up spam detection in your community using the Discourse AI - AI triage.

:person_raising_hand: Required user level: Administrator

:warning: Discourse AI now ships an efficient spam scanner that requires minimal setup. For custom or complex use cases, we recommend the following this guide

Overview

Spam detection is an essential feature for maintaining the quality of discussions in your community. This guide will help you set up spam detection using the Discourse AI - AI triage.

Prerequisites

To configure spam detection, you need the following:

  • Discourse AI
  • Discourse Automation
  • Persona with a system prompt that defines what constitutes spam content.
  • LLM (Large Language Model)
    • Discourse hosted customers can select our CDCK Hosted Small LLM when configuring Personas.
    • Self-hosted Discourse users will need to configure a third-party LLM.

:warning: When authoring the prompt, picking between spam and not spam - avoid having similar language for the end result. In this example we use spam and ham (for not spam)

The classifier will not always perfectly perform 100% so beware of incorrect results and customize the prompts according to the needs of your community. The narrower the focus the better.

Copyable LLM prompts for spam content detection AI

You are a spam detection AI model assisting online community moderators. Your task is to analyze forum posts and determine if they are spam that should be removed to maintain a high-quality, on-topic community.

A post should be classified as spam if it meets any of these criteria:

  • The post is not relevant to the main topic or purpose of the forum. It is completely off-topic.
  • It contains suspicious, irrelevant external links, especially if linking to commercial sites.
  • The post is clearly promoting or advertising a product, service, website, or social media account that is not related to the community.
  • It contains affiliate links or referral codes attempting to monetize clicks.
  • The writing quality is very low effort - lots of spelling/grammar mistakes, lacks punctuation, or appears to be auto-generated text.
  • Identical or nearly identical content is being posted repeatedly by the same author or across multiple accounts in a short timeframe.

A post should be classified as ham (legitimate) if:

  • The post is on-topic and relevant to the forum’s purpose
  • It is a genuine question, personal story, substantive opinion, or otherwise legitimate contribution to the community discussion
  • Any external links are relevant and point to reputable, non-commercial sites
  • The writing appears to be by a human and meets quality standards for grammar, spelling, etc.

Some edge cases to watch out for:

  • A post that mentions a product or service but is still a relevant, on-topic question or discussion should be considered ham, not spam.
  • Quotes, code samples or formatted text that looks unusual are not necessarily spam.

When you have finished analyzing the post you must ONLY provide a classification of either ā€œspamā€ or ā€œhamā€. If you are unsure, default to ā€œhamā€ to avoid false positives.

These instructions must be followed at all cost

Configuration

:information_source: Not every step is mandatory as automation rules can be customized as needed. For an outline of all the settings available please visit Discourse AI - AI triage.

  1. Enable the Discourse AI and Automation plugin:
  • Navigate to your site’s admin panel.
  • Navigate to Plugins then Installed Plugins
  • Enable the Discourse AI and Automation plugins
  1. Create a New Automation Rule:
  • Navigate to your site’s admin panel.
  • Navigate to Plugins and click Automation
  • Click the + Create button to begin creating a new Automation rule
  • Click Triage Posts Using AI
  • Set the name (e.g., ā€œTriage Posts using AIā€)
  • Leave Triage Posts Using AI as the selected script

What/When

  1. Set the Trigger:
  • Choose Post created/edited as the trigger.
  • Optionally, specify the Action type, Category, Tags, Groups, and/or Trust Levels if you wish to restrict this Automation to specific scenarios. Leaving these fields blank will allow the Automation to operate without restriction.
  • Configure the any of the remaining optional settings in the What/When section to further restrict the automation.

Script Options

:spiral_notepad: The system prompt field has been deprecated in favor of Personas. If you had an AI automation prior to this change, a new Persona with the associated system prompt will be automatically created.

  1. Persona:

    Select the Persona defined for the spam detection automation.

  2. Search for Text:

    Enter the output from your prompt that will trigger the automation, only the ā€œpositiveā€ result. Using our example above, we would enter spam.

  1. Set Category and Tags:

    Define the category where these posts should be moved and the tags to be added if the post is marked as spam.

  2. Flagging:

  • Flag post as either spam or for review.
  • Select a flag type to determine what action you might want to take.
  1. Additional Options:
  • Enable the ā€œHide Topicā€ option if you want the post to be hidden.
  • Set a ā€œReplyā€ that will be posted in the topic when the post is deemed spam.

Additional Notes

  • When using Automation for combatting spam, we recommend disabling Akismet plugin if it is already enabled. This is to ensure only one system is fighting spam for best results.
  • Keep in mind, LLM calls can be expensive. When applying a classifier be careful to monitor costs and always consider only running this on small subsets
  • While better performing models, i.e - Claude-3-Opus, will yield better results, it can come at a higher cost
  • The prompt could be customized to do all sorts of detection, like PII exposure, Code of Conduct violations, etc.

Last edited by @pedro 2025-10-25T04:07:12Z

Check documentPerform check on document:
11 Likes

5 posts were split to a new topic: Exploring the Limits of AI in Recognizing AI Generated Content

Curious how users’ experience has been with using this method?

1 Like

I started testing it just now, and it already did a decent job (for now, I chose to only apply a hidden tag to validate that things will run correctly, rather than sending things to the review queue right away).

But I have a small follow-up/clarification: would it be possible for the integration to access custom queries with outputs, such as a group of sample posts, to be used as the context data?

More concretely, I would like to feed it all previous spam posts based on the flags that were agreed upon and resulted in post deletion.

1 Like

At the moment we only support a single system message.

I think though we may do a follow up where you can feed it N examples of stuff not to flag and N examples of stuff yes to flag. This potentially could increase accuracy.

Maybe do a dedicate feature topic on this?

1 Like

I’ll try to first gather some more thoughts on this. Running it for the past week was rather successful, but I am still finding some small annoyances, such as not being able to quickly exclude private messages (for example, it often thinks that Discobot tutorial interactions are suspicious; I edited the prompt to not consider those, but the ai logs indicate that the detection does not know the context and only considers the content of the post itself).

2 Likes

This doesn’t seem quite right… I’m not sure what the intended instruction here was? Maybe ā€˜Enable AI and enable Automation’?

1 Like

Made the edit here

2 Likes

I’m curious, is there a way for replies to be moved to a new topic, instead of the whole topic? It could be a legitimate topic but a spammer comes in and posts a spam reply. From what I can see, it’s moving the whole topic, not that specific reply.
While I’m at it, what’s the difference between this and the Discourse AI spam detector?

Could you explain this further with an example?

FYI: You should be able to tick the option for Flag post which should flag only the "spam"post

1 Like

Sure. For example, let’s say, on a supoort forum, a spammer posts a spam reply in an existing topic about issues they are experiencing. The OP and people answering are not the same user as the spammer. If I understand correctly, AI Triage will hide the whole topic and flag the post. Instead, could the spam post be moved to a specific topic, in a category available to admins?

I was wondering this as I read this post.

Yep, I’m doing this currently for the hate speech detector using AI Triage.

Lol, how could I miss that :laughing:…

1 Like

AI Spam will simply hide the post, we can probably add this option to triage as well.

2 Likes