Compatibility
Minecraft: Java Edition
1.21ā1.21.10
1.20.x
Platforms
Supported environments
Creators
Details
Licensed ARR
Published 3 months ago
Updated 3 months ago

Bring a fast, configurable ticket system to your Minecraft servers. Players file tickets in-game with a single command, you receive rich Discord notifications instantly.
Highlights
- Ināgame tickets with a simple command:
/ticket <category> <reason...> - Multiāword categories supported (e.g., "Staff Request", "Player Report")
- Smart tab completion that suggests only your configured categories
- Discord webhook integration using rich embeds
- Configurable embed color (hex)
- Player head/avatar shown in the embed
- Clean, readable layout using your message template
- Fully serverāside configuration (common config); no client required
- Customizable userāfacing messages (success/help/errors) with placeholders

-
Ticket command
/ticket <category> <reason...>- Works with multiāword categories
- Bare
/ticketshows a configurable help/usage message
-
Discord embeds
- Ticket is posted to a Discord channel via webhook
- Color is configurable (hex, e.g.,
#5865F2) - The player's Minecraft head is used as avatar and embed thumbnail
- All placeholders from your template are preserved
-
Serverāside config only
- Everything is configured from the server's common config (no client dependency)
- All players see the same messages no matter their client language
-
Clean admin UX
- Tab completion shows only categories from your config
- Invalid categories or missing reasons return clear, configurable errors

- Base command:
/ticket - Usage:
/ticket <category> <reason...> - Examples:
/ticket Bug Bees are escaping the hive enclosure/ticket Staff Request Please review my claim/ticket Player Report Steve griefed my base at spawn
Notes
- Multiāword categories are parsed correctly; the remainder becomes the reason
- Suggestions show only configured categories

All options live in config/sarosdiscordwebhook-common.toml. Key settings:
-
Core
tickets.enabledā enable/disable the systemtickets.categoriesā list of categories (strings). Supports multiāword entriestickets.discordWebhookUrlā your Discord webhook URLtickets.commandPermissionLevelā required vanilla permission (0ā4; 0 = everyone)tickets.messageTemplateā text used as the embed descriptiontickets.embedColorHexā embed color (e.g.,#5865F2)
-
Advanced
tickets.inputTimeoutSecondsā session timeout for future multiāstep flowstickets.hideReasonInChatā for future chatācapture flow (not used in default oneāline command)
-
Messages (all serverāside; placeholders are supported where shown)
tickets.messages.successSubmittedā shown on success- Placeholders:
{category},{reason}
- Placeholders:
tickets.messages.errorInvalidCategoryā invalid categorytickets.messages.errorMissingReasonā reason missingtickets.messages.errorWebhookNotConfiguredā webhook missingtickets.messages.errorOnlyPlayersā console/nonāplayer usagetickets.messages.usageHelpā displayed on bare/ticket- Placeholders:
{categories}(commaāseparated list)
- Placeholders:
tickets.messages.errorNoCategoriesā if category list is emptytickets.messages.errorSendFailedā Discord post failed
Placeholders available in tickets.messageTemplate (used inside the Discord embed):
{player},{uuid},{category},{reason},{dimension},{x},{y},{z}

FAQ & Tips
-
Nothing posts to Discord
- Ensure
tickets.discordWebhookUrlis set and valid - Check
tickets.enabled = true
- Ensure
-
Players can't use
/ticket- Lower
tickets.commandPermissionLevel(0 lets everyone use it)
- Lower
-
I want a different embed look
- Customize
tickets.messageTemplateandtickets.embedColorHex
- Customize
-
My categories have spaces
- Supported! The command matches the longest configured category at the start of the input




