Phoenix Profanity Filter

Add a moderation function to a Phoenix context and call it from your controller actions.

Quick start in Phoenix

defmodule MyApp.Moderation do
  def flagged?(text) do
    Req.post!("https://api.theprofanityapi.com/v1/check",
      headers: [{"authorization", "Bearer #{System.get_env("PROFANITY_API_KEY")}"}],
      json: %{text: text, context: "comment", mode: "balanced"}
    ).body["flagged"]
  end
end

Why context-aware matters

A plain word list flags "this game is sick" or medical text full of anatomical terms. The Profanity API runs a five-layer pipeline that scores intent, so "die" in a gaming taunt and "die" in a real threat are handled differently. Pick a context and the engine adjusts strictness automatically.


Other integrations

Ready to ship moderation?

Get an API key and 300 free requests a month. No credit card required.

Get started free →