-
Notifications
You must be signed in to change notification settings - Fork 8
Home
Development Builds: CodeMC or Github Actions
LWC has been the go-to protection plugin for a long time. It's a classic. Unfortunately though, due to its age and the complexity of the code, as well as some of the design decisions made early on in its development, it's difficult to update and support new modern features.
Because of this, I decided to start working on Bolt, which is intended to be a complete replacement for LWC.
Bolt currently has these advantages over LWC:
- Completely rewritten database handling: No blocking reads on the server thread. Faster and hopefully safer too.
- Improved protection matchers: Every block can be protected, not only containers. Scaffolds, nether portals, vines, you name it.
- A permission system that is much more flexible: Default protection types and permissions as well as access types and permissions can be fully customized.
- First class entity locking support: Finally you can protect item frames, armor stands, and more. Entities can even be matched with blocks (for example, a locked lead attached to a fence will also cause the fence to be protected to prevent breaking the lead through the fence).
- Improved handling of many game features: For example, use a redstone protection type wherever you need to protect redstone components. Also, hoppers automatically resolve their permission to take/put items from containers (so if you have a chain of protected hoppers, since you own them all items will transfer through seamlessly - no unnecessary hopper flag).
- Custom translations with MiniMessage formatting are supported: Yes, finally easy-to-read color codes and named placeholders.
- And much more: TBH the stuff above is just what I can come up with off the top of my head. Read on to see more in-depth explanations of Bolt's features.
If that hasn't convinced you, don't worry. LWC will still be updated, however most new and interesting development will be focused on Bolt.
Bolt includes conversions between the database formats of Bolt and LWC. If you are currently using LWC, it is incredibly easy to switch to Bolt, and likewise, switch back to LWC if things aren't working the way you expect.
The conversion should be safe, but be responsible and make a backup of your database(s) before continuing in case anything happens.
Please note:
- Conversion of LWC entity protections to Bolt is supported when a recent dev build of Chunky is installed
- If you used the LWC Trust add-on, this data will be automatically migrated when installing Bolt for the first time
- If you had protectable blocks that aren't default in LWC, these will automatically be copied over to Bolt's config when installing Bolt
- Ensure both plugins are installed
- Use the command
/bolt admin convert
to convert your LWC data to Bolt - Uninstall LWC and restart the server
- Do not delete your lwc.db file, as it will still be useful if you decide to switch back
Important: Please let us know by making an issue or posting on the Bolt Discord if you are temporarily uninstalling due to a problem or missing feature. It is a goal to fix any issues preventing you from fully switching to Bolt.
- Ensure both plugins are installed
- Use the command
/bolt admin convert back
to convert your Bolt data back to LWC - Uninstall Bolt and restart the server
Usage: /bolt lock [type]
(alias: /lock [type]
)
Permission: bolt.command.lock
Description: Lock something. Optionally provide a protection type to lock with (defaults to private).
Usage: /bolt unlock
(alias: /unlock
)
Permission: bolt.command.unlock
Description: Unlock something.
Usage: /bolt edit (add|remove) <access> <source-type> <sources...>
Permission: bolt.command.edit
Description: Add or remove sources with given access to a protection's access list (ACL).
There are a few notable built-in access source types:
-
player
for players -
password
for passwords entered with/bolt password
-
permission
for permission nodes -
group
for groups managed by/bolt group
Usage: /bolt group (create|delete|add|remove|list) <group> [players...]
Permission: bolt.command.group
Description: Manage custom player groups, which can be used in access lists (ACLs).
Usage: /bolt trust [list|confirm]
Permission: bolt.command.trust
Description: Prompt, list, or confirm changes to your trust access list.
Usage: /bolt transfer <player>
Permission: bolt.command.transfer
Description: Transfer a protection that you own to another player.
Usage: /bolt password <password>
Permission: bolt.command.password
Description: Enter a password for a protection that has a password source added.
Usage: /bolt mode <mode>
Permission: bolt.command.mode
Description: Toggle a player mode. For example: persist, no lock, no spam.
Usage: /bolt help [command]
Permission: bolt.command.help
Description: Displays help.
Usage: /bolt info
Permission: bolt.command.info
Description: Display protection information.
Usage: /bolt admin cleanup
Permission: bolt.command.admin
Description: Clean up protections from the database that no longer physically exist in the world. This can happen, for example, when removing blocks without breaking them using other plugins such as WorldEdit.
Usage: /bolt admin convert
or /bolt admin convert back
Permission: bolt.command.admin
Description: Convert an existing LWC database to Bolt. See the section above about migrating.
Usage: /bolt admin debug
Permission: bolt.command.admin
Description: Displays technical protection information.
Usage: /bolt admin find <player>
Permission: bolt.command.admin
Description: Find protections for a given player.
Usage: /bolt admin purge <player>
Permission: bolt.command.admin
Description: Removes all protections for a given player.
Usage: /bolt admin reload
Permission: bolt.command.admin
Description: Forces a complete reload of Bolt's configuration, re-loads translations, and updates protection types, access types, and protection matchers.
Usage: /bolt admin report [disable]
Permission: bolt.command.admin
Description: Displays technical information regarding protection event triggers and cache hits/misses.
Usage: /bolt admin transfer <player> [to]
Permission: bolt.command.admin
Description: Force transfer a protection to a given player, or all protections from the player to another player.
bolt.admin
allows the player to bypass the ACL for all protections. Effective ownership over everything.
bolt.protection.notify
notifies the player when interacting with a protection.
bolt.type.protection.<type>
grants permission to use a protection type (if require-permission: true
is set for that type).
bolt.type.source.<type>
grants permission to use a source type (if require-permission: true
is set for that type).
bolt.type.access.<type>
grants permission to use an access type (if require-permission: true
is set for that type).
Default translation language.
Built-in support currently only for English, however you can create your own custom translation and use that value here.
language: en
Settings
- Use Action Bar will cause all action messages to go to your action bar instead of chat.
settings:
use-action-bar: false
Database configuration
- Type is the database type; either
sqlite
(recommended) ormysql
. - Path is the path of the database file (SQLite only).
- Hostname is the host name, and optionally port, to connect to (MySQL only).
- Database is the database name (MySQL only).
- Username is the database login username (MySQL only).
- Password is the database login password (MySQL only).
- Prefix is the database table prefix.
- Properties are a list of optional connection properties to set for the connection (MySQL only).
database:
type: sqlite
path: plugins/Bolt/bolt.db
hostname: ""
database: ""
username: ""
password: ""
prefix: ""
properties: [ ]
Protection types. You can define your own here or change the permissions that they come with.
There are a few built-in permissions currently:
-
interact
allows interaction with a protection -
open
allows opening a container or menu -
deposit
allows putting items into containers -
withdraw
allows taking items from containers -
mount
allows mounting protected entities -
redstone
allows using redstone on a protection -
edit
allows editing a protection's ACL -
destroy
allows destroying (literally, by destroying / killing, or via unlocking) the protection -
entity_interact
allows entities to interact with the protection -
entity_break_door
allows entities to break the door of a protection
protections:
private:
require-permission: false
allows: [ "redstone" ]
display:
require-permission: false
allows: [ "redstone", "interact", "open" ]
deposit:
require-permission: false
allows: [ "redstone", "interact", "open", "deposit" ]
withdrawal:
require-permission: false
allows: [ "redstone", "interact", "open", "withdraw" ]
public:
require-permission: false
allows: [ "redstone", "interact", "open", "deposit", "withdraw", "mount" ]
Access types. Uses the same permissions mentioned above for permission types. The only difference is these are used in a protections ACL. A user's effective permission to the protection are the combination of the protection type's and any additional access they have. For example, no protection type allows users to edit the protection by default, however this can be granted using the admin
access type.
access:
normal:
require-permission: false
allows: [ "redstone", "interact", "open", "deposit", "withdraw", "mount" ]
admin:
require-permission: true
allows: [ "redstone", "interact", "open", "deposit", "withdraw", "mount", "edit" ]
Source types. These are targets for access when editing protections.
sources:
player:
require-permission: false
group:
require-permission: false
password:
require-permission: false
permission:
require-permission: true
Blocks. This is a list of blocks that are protectable, and if they will be automatically protected to a certain type upon placement.
Refer to Material for valid values here. You can also use block tags, which can be useful for grouping many similar blocks together under one configuration. Tags start with #
and must be quoted.
blocks:
chest:
autoProtect: private
'#shulker_boxes':
autoProtect: private
...
Entities. Similar to blocks, this lists any entities that are protectable and their default protection type when spawned.
Refer to EntityType for valid values here. You can also use entity type tags, which can be useful for grouping many similar entities together under one configuration. Tags start with #
and must be quoted.
entities:
armor_stand:
autoProtect: private
...
Bolt comes with many translations already included! These are contributed by community members via Crowdin.
Simply edit the language option in the configuration to select any of these pre-included translations.
You can find a list here. Keep in mind not all may be complete! Please contribute if you notice any missing translations.
Making your own translation is super simple in Bolt. Simply drop a <lang>.properties
file into the Bolt plugin folder. Replace <lang>
with the name of the language that you want, and make sure that in the configuration you set this to the same value.
Copy the contents of en.properties
and customize to your liking!
Messages use MiniMessage formatting. You can test here first to make sure it works (although it won't resolve custom placeholder tags which are added by Bolt).
Keep in mind that custom translations are likely to break between versions. It is your responsibility to keep them updated.
This section will be updated with questions that people have about LWC and Bolt.