Compatibility
Minecraft: Java Edition
Platforms
Supported environments
75% of ad revenue goes to creators
Support creators and Modrinth ad-free with Modrinth+Details
🚫SpicyAzisaBan
📖Description
SpicyAzisaBan is an all-in-one punishment system for Velocity. (Heavily inspired by AdvancedBan)
It supports various types of punishments, following are the types of punishments supported by SpicyAzisaBan:
- Ban
- Temp ban
- IP ban
- Temp IP ban
- Mute
- Temp mute
- IP mute
- Temp IP mute
- Warning
- Caution
- Kick
- Note
SpicyAzisaBan also supports multiple servers (such as multiple instances of Velocity), so you can use it in a network environment.
✨Features
- Ban, Mute, Warn, Caution, Kick, Note players
- Discord webhook support
- Support multiple instances of Velocity
- Pre-defined reasons for each server/type of punishment
- Customizable messages
- Ban all alt accounts at once
- Lockdown mode (prevent new players from joining the server)
- Punishment automation via external API (see below for more information)
❗️Requirements
- Java 17 or later
- Internet connection (for fetching dependencies)
- MySQL or MySQL-compatible (e.g. MariaDB) database
- We recommend using supported versions of MariaDB
💻Installation
- Download the plugin from Modrinth and place it in your server's
plugins
folder. - Start the server once to generate the configuration file. (Or you can just create the file manually)
- Configure the plugin in
plugins/SpicyAzisaBan/config.yml
. - Restart the server.
- Do
/sab info
to see if the plugin is working correctly.
📝Configuration
# SpicyAzisaBan config
#
# Important: If you are running from CLI, you only need to configure database settings, and you can just ignore
# anything else.
# Command prefix
# ----------
# You will be able to run command with: /${prefix}command
# So if you set this to "/", you can run command with //command
prefix: ""
# Database settings
# ----------
# MySQL or MySQL-compatible (e.g. MariaDB) database is required to run SpicyAzisaBan.
database:
host: localhost
name: spicyazisaban
user: spicyazisaban
password: p@55w0rd
verifyServerCertificate: false
useSSL: true
# If true, the plugin will prevent players from joining the server if database is inaccessible.
failsafe: true
warning:
# Don't set to 1s, it's too terrible because we fetch the punishments from database every time we check for warnings
sendTitleEvery: 10s
titleStayTime: 5s
# These settings below are reloadable by doing /sab reload
serverNames:
# "server" (key) must not contain UPPERCASE character.
server: FriendlyServerName
defaultReasons:
# valid types: ban, temp_ban, ip_ban, temp_ip_ban, mute, temp_mute, ip_mute, temp_ip_mute, warning, caution, kick, note
# invalid types are ignored
ban:
# <server/group/global>: reasons list
global:
- "ban reason (global) 1"
- "ban reason (global) 2"
lobby:
- "ban reason (lobby) 1"
- "ban reason (lobby) 2"
# a player wouldn't be able to bypass with eg /minecraft:tell
blockedCommandsWhenMuted:
# server: Array<String>
# "global" would affect all servers
global:
- tell
- r
- me
life:
- rpc
- me
banOnWarning:
# if warning count hits 3, 4, 5..., the player would be banned with specified reason
# this feature will be disabled if you set this value to <= 0
threshold: 3
time: "1mo"
# Available variables: %PREFIX%, %COUNT& (current warnings count), %TIME% (above), %ORIGINAL_REASON% (reason used for /warn)
reason: "You've got %COUNT% warnings and you've been banned for %TIME%. (Original reason: %ORIGINAL_REASON%)"
customBannedMessage:
# usually configured via messages.yml, but you can set the message per server here
# key = server
# value = message
rpg:
- "&cA player has been deleted from the server."
# Discord webhook URLs
# If you don't need this feature, simply uncomment the line below.
#webhookURLs: { __fallback__: {} }
# and comment out the lines below.
webhookURLs:
__fallback__:
default: "https://discord.com/api/webhooks/123456/secret"
server1:
default: "https://discord.com/api/webhooks/123456/secret"
global:
default: "https://discord.com/api/webhooks/123456/secret"
ban: "https://discord.com/api/webhooks/789012/secret"
Non-exhaustive list of permissions
We recommend using LuckPerms for permission management.
sab.command.spicyazisaban
sab.command.spicyazisaban.creategroup
sab.command.spicyazisaban.deletegroup
sab.command.spicyazisaban.group
sab.command.spicyazisaban.info
sab.command.spicyazisaban.debug
sab.command.spicyazisaban.reload
sab.command.spicyazisaban.deletepunishmenthistory
sab.command.spicyazisaban.deletepunishment
sab.command.spicyazisaban.link
sab.command.spicyazisaban.unlink
sab.check
sab.history
sab.seen
sab.banlist
sab.proofs
sab.delproof
sab.addproof
sab.changereason
sab.unban
sab.unmute
sab.unpunish
sab.punish.global
sab.punish.group.<groupName>
sab.punish.server.<serverName>
sab.ban.perm
sab.ban.temp
sab.ipban.perm
sab.ipban.temp
sab.mute.perm
sab.mute.temp
sab.ipmute.perm
sab.ipmute.temp
sab.warning
sab.caution
sab.kick
sab.note
sab.notify.ban
sab.notify.tempban
sab.notify.ipban
sab.notify.tempipban
sab.notify.mute
sab.notify.tempmute
sab.notify.ipmute
sab.notify.tempipmute
sab.notify.warn
sab.notify.caution
sab.notify.kick
sab.notify.note
sab.exempt.mute
sab.exempt.temp_mute
sab.exempt.ip_mute
sab.exempt.temp_ip_mute
🔧Developer API
Unfortunately, SpicyAzisaBan itself does not provide helpful APIs for developers to use. (There are a lot of internal APIs that are not intended to be used by other plugins.) If you do rely on internal API, you should be aware that it may change without notice.
If you need to automate the punishment system (but not unpunish) from backend Spigot/Paper server, you can use the API provided by AziPluginMessaging. This is one of our internal plugins, but we provide the API for developers who want to use it. You need to install the plugin on both the backend (Spigot/Paper) server and the proxy (Velocity) server.
You can see the example of using the API in PunishCommand.java.
🛟Support
Support is provided via our Discord server.
📜License
This project is licensed under the GNU General Public License v3.0.