Skip to content

Cancels messages containing blocked words, enforces mutes, prevents chat spam, prompts captcha verification, logs offender actions, implements escalating penalties.

License

Notifications You must be signed in to change notification settings

AleksandarHaralanov/ChatGuard

Repository files navigation

ChatGuard

ChatGuard-Banner.png

ChatGuard is a Minecraft plugin designed for servers running version b1.7.3.

It cancels player messages containing blocked terms or matching RegEx patterns, logs actions (via Discord webhooks, console, or local files), prevents chat spam, prompts captcha verification on suspected bot-like behavior, issues temporary mutes (as of v3.0.0, it requires Essentials v2.5.8), enforces escalating penalties via a six strike tier system, and plays sound cues local to the offending player upon a detection.

The plugin is entirely configurable.


Contributing Code & Reporting Issues

Consider helping ChatGuard become even more versatile and robust.

Visit the CONTRIBUTING guide for details on how to get started and where to focus your efforts.

For any issues with the plugin, or suggestions, please report them here.


Download

Latest releases of ChatGuard can be found here on GitHub.
Alternatively, you can also download through Modrinth.

The plugin is fully open-source and transparent.
If you'd like additional peace of mind, you're welcome to scan the .jar file using VirusTotal.


Requirements

Your b1.7.3 server must be running one of the following APIs: CB1060-CB1092, Project Poseidon or UberBukkit.

You also need to be running Essentials v2.5.8 or newer for the current newest version of ChatGuard to work.
You can download it from here.


Usage

By default, only OPs have permission.

Use PermissionsEx or similar plugins to grant groups the permission, enabling the commands.

Commands:

  • /cg - View ChatGuard commands.
  • /cg about - About ChatGuard.
  • /cg captcha <code> - Captcha verification.
  • /cg reload - chatguard.config - Reload ChatGuard configuration.
  • /cg strike <username> - chatguard.config - View strike of player.
  • /cg strike <username> [0-5] - chatguard.config - Set strike of player.

Permissions:

Single permissions:

  • chatguard.bypass - Allows player to bypass the ChatGuard protection.
  • chatguard.config - Allows player to reload and modify the ChatGuard configuration.
  • chatguard.captcha - Allows player to be notified when someone is prompted a captcha verification.

Wildcard permissions:

  • chatguard.* - Wildcard permission that grants all permissions.

Configurations

Generates config.yml and strikes.yml located at plugins/ChatGuard.

Caution

🔖v3.0.0: If your server is not running Essentials v2.5.8 or newer, make sure to download and install it. Without it, the entire plugin will break, and in-game messages will fail to send properly.

You can find the download here in the requirements heading.

Config

This is the default config.yml configuration file:

miscellaneous:        # Configurations that are QoL.
  sound-cues: true    # Plays a sound cue local to the offending player when ChatGuard detects something.

spam-prevention:      # Configuration for chat spam prevention.
  enabled: true       # Toggles chat spam prevention feature.
  warn-player: true   # Sends a warning to the player when they trigger spam prevention.
  cooldown-ms:        # Specifies cooldown durations in milliseconds for different strike tiers (s0-s5).
    s0: 1000
    s1: 2000
    s2: 3000
    s3: 4000
    s4: 5000
    s5: 6000

captcha:              # Configuration for captcha verification.
  enabled: true       # Toggles the captcha verification feature.
  threshold: 4        # Triggers captcha verification when the same message is sent X times, canceling it on the final attempt.
  code:               # Characters to be used in the generated captcha and the length of the captcha.
    characters: "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789"
    length: 5
  log:
    console: true     # Logs captcha verification to the server console.
    local-file: true  # Logs captcha verification to a local file.
    discord-webhook:  # Logs captcha verification through a Discord webhook by an embed.
      enabled: false  # Toggles Discord webhook logging.
      url: ""         # The URL of the Discord webhook.
  whitelist: []       # List of terms explicitly allowed to bypass captcha.

filter:
  enabled: true       # Toggles the chat filtering feature.
  warn-player: true   # Sends a warning to the player when their message is blocked.
  log:                
    console: true     # Logs blocked messages to the server console.
    local-file: true  # Logs blocked messages to a local file.
    discord-webhook:  # Logs blocked messages through a Discord webhook by an embed.
      enabled: false  # Toggles Discord webhook logging.
      url: ""         # The URL of the Discord webhook.
  mute:               # Configuration for muting players who violate filter rules.
    enabled: true     # Toggles the muting feature.
    duration:         # Specifies mute durations for different strike tiers (s0-s5).
      s0: "30m"
      s1: "1h"
      s2: "2h"
      s3: "4h"
      s4: "8h"
      s5: "24h"
  rules:              # Configuration for blocking rules.
    regex: []         # List of regular expressions used for blocking messages.
    terms:            # Configuration for blocking specific terms.
      whitelist: []   # List of terms explicitly allowed in messages.
      blacklist: []   # List of terms that are not allowed in messages.

Strikes

The default strikes.yml configuration file is initially empty. When a player joins for the first time after ChatGuard is installed on the server, they are added to the configuration with 0 strikes. From there, the plugin manages their strikes, incrementing them up to a maximum of 5 as necessary. Read note below on how that works.

Note

🔖v3.0.0: Strike tiers will increment only when the filter is enabled, and a disallowed term or matching regex pattern is detected in a message. Otherwise, all strike tiers will default to 0 unless manually modified in the configuration file or through the included command.

About

Cancels messages containing blocked words, enforces mutes, prevents chat spam, prompts captcha verification, logs offender actions, implements escalating penalties.

Topics

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages