Compatibility
Minecraft: Java Edition
Platforms
Tags
Creators
Details
TrialChamberPro
What's new in 1.4.4
- Vanilla loot is now one copy-paste away. Two ready-to-use loot tables โ
vanilla-normalandvanilla-ominousโ ship insideloot.ymlas a commented section. They're faithful three-pool recreations transcribed directly from Mojang's own datapack JSONs, so if you (or your players) just want unmodified Minecraft 1.21 Trial Chamber drops, you don't have to build them yourself. Uncomment the block, run/tcp reload, done.
Plus everything from the 1.4.x line: MiniMessage everywhere, smarter auto-discovery that merges chambers spanning multiple chunks, a flatter admin GUI, a startup schema check for messages.yml, trial spawner wave tracking fixes, and the chamber pause state added in 1.4.3. And from 1.3.x: custom mobs (MythicMobs, EliteMobs, EcoMobs, LevelledMobs, InfernalMobs, Citizens), fully translatable GUI (~330 gui.* keys), Bukkit events API, spawner presets, /tcp give, and Minecraft 26.x support via the -mc26 build.
๐ Full documentation: https://darkstarworks.gitbook.io/darkstarworks-plugins/tcp-documentation โ most questions are answered there, and every section below links to its own detailed page.
๐ Win a Premium Module Licence
Capture your best TrialChamberPro setup โ a screenshot or short clip โ and post it in #showcase on our Discord. The community votes via reactions, and the 3 most-loved entries each win a permanent premium licence (TCP-WildSpawners or TCP-VaultCrates, your pick). Surprise bonuses for runners-up.
๐ Join the Discord โ
Premium Add-on Modules
TrialChamberPro is, and always will be, completely free. But after a lot of requests from server owners wanting to push things further, we now offer optional premium modules for servers that need more.
๐ท TCP-WildSpawners
Place TCP preset spawners anywhere on your survival map โ no Trial Chamber required. Hand them out via shops, crates, or staff commands. Wherever a player puts one down, it summons your custom mobs. Includes an in-game GUI editor, per-preset griefing protection, holograms, mob tether, creative pick-block, and state-preserving mining so players can relocate a live spawner without losing cooldown progress.
Requires TrialChamberPro v1.4.0+ (free).
๐ esmp.fun/plugins โ purchase & download
๐ถ TCP-VaultCrates
The first crate plugin that doesn't use chests. Vanilla Trial Vaults are the only Minecraft block with built-in per-player loot state, two visual tiers (normal + ominous), a key mechanic, and a dramatic open animation that doesn't need a resource pack. TCP-VaultCrates lets you register vaults anywhere on your map as crates with configurable loot pools and per-tier keys. Hand keys out via shops, missions, or โ when paired with TCP-WildSpawners โ drop them from spawner mobs.
Requires TrialChamberPro v1.4.0+ (free).
๐ esmp.fun โ purchase & download
The definitive Trial Chamber management plugin for multiplayer servers.
Transform Minecraft's Trial Chambers from single-use dungeons into renewable, multiplayer-ready content. Automatic resets, per-player loot, custom rewards, griefing protection โ and it all works out of the box.
Why TrialChamberPro?
Vanilla Trial Chambers weren't designed for multiplayer. The first player takes everything, vaults stay locked forever, and griefers destroy spawners. TrialChamberPro fixes all of that.
| Problem | Solution |
|---|---|
| First player gets all loot | Per-player vault system with individual cooldowns |
| No way to reset chambers | Automatic scheduled resets with player warnings |
| Griefers break spawners | Full protection system with optional WorldGuard support |
| Paper trial key bugs | Built-in fixes for known Paper issues |
| No progression tracking | Statistics, leaderboards, and PlaceholderAPI support |
| Setup overhead per chamber | Auto-discovery โ chambers register themselves |
Two-Line Plug-and-Play Setup
For most servers, the only thing you need to configure is this:
# plugins/TrialChamberPro/config.yml
discovery:
enabled: true # find natural trial chambers automatically
auto-snapshot: true # capture blocks so resets can restore them
Restart once. Fly or walk through your world โ every natural trial chamber registers itself as its chunks load, with per-player loot, protection, and automatic resets already active. Done.
Why it's opt-in: on old worlds that pre-date 1.21, players sometimes build decorative structures out of tuff and copper blocks. The auto-detector could register those as chambers. On fresh worlds there's no risk. More detail in the docs โ
Prefer manual control? You can still register chambers with WorldEdit (/tcp generate wand MyChamber) or by coordinates โ see Your First Chamber.
Features
Core Systems
- Auto-Discovery โ natural chambers register themselves on chunk load + startup sweep. Docs โ
- Automatic Resets โ chambers restore on schedule with configurable warnings, or set interval to
0for manual-only. - Per-Player Vaults โ everyone gets their own loot with separate cooldowns.
- Full Protection โ block break/place, container access, mob griefing prevention. WorldGuard-aware.
- Statistics & Leaderboards โ vaults opened, mobs killed, time spent. Docs โ
- Admin GUI โ
/tcp menudoes everything. No YAML editing required.
Advanced Loot
- Multi-Pool Tables โ common / rare / unique pools like vanilla, fully configurable. Docs โ
- Per-Chamber Overrides โ assign a different loot table to any specific chamber.
- GUI Editing (new in 1.2.26) โ open
/tcp menuโ Loot Tables, click a table, and edit it. Changes save toloot.ymlinstantly. - Custom Plugin Items โ drop Nexo, ItemsAdder, or Oraxen items directly from vaults:
- type: CUSTOM_ITEM plugin: nexo # or itemsadder / oraxen / craftengine / mythiccrucible item-id: mythic_sword weight: 5 - Custom Model Data โ set
custom-model-dataon any vanilla item for resource-pack integration. - Command Rewards โ run any console command as loot (economy deposits, permission grants, XP).
- Potion & Tipped Arrows โ full attribute support including Bad Omen IIIโV ominous bottles.
- LUCK Integration โ optional bonus rolls for players with the LUCK effect.
Multiplayer Enhancements
- Spawner Wave Tracking โ boss bar shows wave progress as players fight. Hysteresis-based despawn means the bar disappears when you leave the area (improved in 1.2.26).
- Spectator Mode โ dead players can watch teammates complete the challenge, bounded to the chamber.
- PlaceholderAPI โ 20+ placeholders for scoreboards, holograms, tab lists.
Technical Excellence
- Folia Native โ full support for regionized multithreading.
- Paper / Purpur / Pufferfish โ works on all major Paper forks.
- Async Architecture โ Kotlin coroutines, zero main-thread blocking.
- Dual Database โ SQLite (default) or MySQL with connection pooling.
- WorldEdit / FAWE โ optional, used only if you want selection-based chamber creation.
Fully Translatable
Every user-facing string lives in plugins/TrialChamberPro/messages.yml. Want your server in French, Chinese, Spanish, or Klingon? Edit one file, /tcp reload, done.
Supports &-style color codes, {placeholder} substitution, and Adventure Components for boss bars.
๐ Full message reference โ
Quick Start (manual mode)
Prefer not to use auto-discovery? Classic workflow still works:
1. Drop the JAR in your plugins folder
2. Start your server
3. Select a Trial Chamber with WorldEdit (//wand)
4. Run: /tcp generate wand MyChamber
5. Run: /tcp snapshot create MyChamber (enables auto-reset)
6. Done!
Commands (at a glance)
| Command | Description |
|---|---|
/tcp menu |
Open the admin GUI (does everything) |
/tcp generate wand <name> |
Register chamber from WorldEdit selection |
/tcp reset <chamber> |
Force immediate reset |
/tcp snapshot create <chamber> |
Enable automatic resets |
/tcp loot set <chamber> <normal|ominous> <table> |
Override loot for a chamber |
/tcp stats [player] |
View statistics |
/tcp leaderboard <type> |
View top players |
/tcp reload |
Reload config & loot tables |
๐ Full command reference โ
Permissions (essentials)
| Permission | Description | Default |
|---|---|---|
tcp.admin |
Full admin access | OP |
tcp.stats ยท tcp.leaderboard |
View own stats / leaderboards | Everyone |
tcp.spectate |
Use spectator mode after death | Everyone |
tcp.bypass.cooldown |
Ignore vault cooldowns (careful: removes progression!) | OP |
tcp.bypass.protection |
Build in protected chambers | OP |
tcp.discovery.notify |
Get notified when auto-discovery registers a chamber | OP |
Heads up:
tcp.bypass.cooldownis granted to OPs by default. If you're testing cooldowns as an OP, they'll appear broken โ either test as a non-OP or explicitly negate the permission.
๐ Full permissions guide with rank examples โ
Requirements
| Requirement | Version |
|---|---|
| Minecraft | 1.21.1+ (use -mc26 JAR for 26.x) |
| Server | Paper, Folia, Purpur, or Pufferfish |
| Java | 21+ |
Optional Dependencies
- WorldEdit / FastAsyncWorldEdit โ selection-based chamber creation.
- WorldGuard โ additional region protection.
- PlaceholderAPI โ scoreboard / hologram placeholders.
- Vault โ economy command rewards.
- Nexo / ItemsAdder / Oraxen / CraftEngine / MythicCrucible โ custom items in loot tables.
- LuckPerms โ permission command rewards.
Essential Configuration
Sensible defaults work out of the box. The three settings most servers actually tweak:
global:
default-reset-interval: 172800 # 48 hours. Use 0 for manual-only resets.
vaults:
normal-cooldown-hours: -1 # -1 = vanilla (locked until chamber reset)
ominous-cooldown-hours: -1 # Set a positive number for per-player time cooldown.
discovery:
enabled: true # Auto-register natural chambers. Opt-in.
auto-snapshot: true # Allow auto-discovered chambers to restore on reset.
๐ Full config.yml reference โ ยท loot.yml reference โ
PlaceholderAPI (summary)
20+ placeholders for player stats (%tcp_vaults_opened%, %tcp_mobs_killed%, %tcp_time_spent%), current state (%tcp_current_chamber%), and leaderboards (%tcp_top_vaults_1_name% through _10_). Built-in 60-second cache.
๐ Full placeholder list โ
Support
- ๐ Documentation โ setup guides, configuration reference, troubleshooting. Please check here first! Most questions are already answered.
- ๐ฌ Discord โ community support, announcements, feature requests. Not everyone's a reader โ that's fine, come chat.
- ๐ GitHub Issues โ bug reports.
- โญ Source Code โ open source under CC-BY-NC-ND 4.0.
Target Audience
- Survival Servers โ renewable endgame content that keeps players engaged.
- SMP Networks โ fair loot distribution across your playerbase.
- Minigame Servers โ competitive Trial Chamber runs with leaderboards.
- Adventure / RP Servers โ protected dungeons with custom rewards.
Paper 1.21.1+ / 26.1.2+ ยท Folia Native ยท Java 21+
Made with Kotlin by darkstarworks
This plugin is free forever and actively maintained.
If you have questions or would like to just say Hi, come join the Discord.
Rather stay silent? (Anonymous) donations are also VERY welcome: https://ko-fi.com/darkstarworks


