-
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:
- If you used the LWC Trust add-on, this data will be automatically migrated when installing.
- If you had protectable blocks that aren't in the default config, these will automatically be copied over to Bolt's config when installing.
- If you had protected entities, converting these may take some time depending on the size of your world. You will be asked to convert these separately.
- Ensure both plugins are installed
- Use the command
/bolt admin convert lwc
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 bolt
to convert your Bolt data back to LWC - Uninstall Bolt and restart the server
- Do not delete your bolt.db file, as it will still be useful if you decide to switch back
Bolt includes conversions for Lockette, as well as other forks like Deadbolt, LockettePro, and BlockLocker. If you are using one of these plugins, it is incredibly easy to switch to Bolt, and your existing signs will be left in place in case you want to switch back at any point.
The conversion should be safe, but be responsible and make a backup of your world(s) before continuing in case anything happens.
Please note:
- Unlike the LWC migrations, converting data from Lockette can take a very long time. This is due to the fact that there is no database and Bolt will need to scan the entire world for signs and load those chunks to re-build protection data from scratch for those blocks. Simply leave it alone and it will eventually complete. It should be safe to continue using your server while the migration is taking place.
- Use one of the following commands to convert your Lockette data to Bolt, depending on which plugin you have:
/bolt admin convert lockette
/bolt admin convert deadbolt
/bolt admin convert lockettepro
/bolt admin convert blocklocker
- Uninstall Lockette if you have not already and restart the server
- Re-install Lockette
- Place back any signs (if applicable) that were removed after migrating to Bolt
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) <player>
Permission: bolt.command.edit
Description: Edit a protection to add or remove a player's access.
Usage: /bolt modify (add|remove) <access> <source-type> <sources...>
Permission: bolt.command.modify
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 (add|remove) <source-type> <source> [access]
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.cleanup
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.convert
Description: Convert an existing LWC database to Bolt. See the section above about migrating.
Usage: /bolt admin debug
Permission: bolt.command.admin.debug
Description: Displays technical protection information.
Usage: /bolt admin expire <time> (seconds|minutes|hours|days)
Permission: bolt.command.admin.expire
Description: Removes protections that have not been accessed in some time.
Usage: /bolt admin find <player>
Permission: bolt.command.admin.find
Description: Find protections for a given player.
Usage: /bolt admin flush
Permission: bolt.command.admin.flush
Description: Immediately save all protection changes to the database.
Usage: /bolt admin purge <player>
Permission: bolt.command.admin.purge
Description: Removes all protections for a given player.
Usage: /bolt admin reload
Permission: bolt.command.admin.reload
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.report
Description: Displays technical information regarding protection event triggers and cache hits/misses.
Usage: /bolt admin transfer <player> [to]
Permission: bolt.command.admin.transfer
Description: Force transfer a protection to a given player, or all protections from the player to another player.
bolt.mod
allows the player to access and view contents all protections without the ability to edit or destroy them.
bolt.admin
allows the player to bypass the ACL for all protections. Effective ownership over everything.
bolt.permission.<permission>
allows the player to bypass a permission on the ACL for all protections.
bolt.protection.notify
notifies the player when interacting with a protection.
bolt.protection.notify.self
notifies the player when interacting with their own protections.
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).
bolt.protection.autoprotect.<type>
grants permission to auto protect a protection (if autoProtectPermission: true
is set for that protection).
bolt.protection.lock.<type>
grants permission to lock a protection (if lockPermission: true
is set for that protection).
bolt.command.info.full
grants permission to view full info including access list with the info command.
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
: If enabled, action messages to go to your action bar instead of chat. -
per-player-locale
: If enabled, players will receive localized messages, rather than the language set via thelanguage
config option, if available. -
default-modes
: A list of player modes which are enabled by default.
settings:
use-action-bar: false
per-player-locale: true
default-modes: []
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
lockPermission: false
autoProtectPermission: false
'#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
...
Doors. This section is not standard and usually appears as a result of upgrading an existing server using LWC where the door features in doors.yml were enabled. It is offered primarily to make switching to Bolt easier for server owners and players expecting their old protections to work exactly as they did before.
Below are the settings as they correspond to their entries in the doors section of the config:
-
open-iron
is equivalent toenabled
; if players should be able to open locked iron doors bare handed. -
open-double
is equivalent todoubleDoors
; if locked double doors should open together. -
close-after
is equivalent tointerval
; how many seconds after opening door(s) before they automatically close. -
fix-plugins
is an experimental setting which attempts to fix plugin interactions with doors. For example, interacting with double doors or iron doors to open them in WorldGuard regions where the player does not have permission to the region. Keep in mind this may have unintended side effects so exercise caution while using this.
doors:
open-iron: false
open-double: false
close-after: 3
Special entries are also automatically added to the access
and sources
section of the configuration which are used by the migration tool to provide support for protections which previously had the autoclose
flag in LWC. The access type must be named exactly "autoclose" and allows the auto_close permission, and the source must be named exactly "door". Normally, it is recommended not to give players access to the special door source type and instead add the auto_close permission to protection types or access types for which auto closing is desired.
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.
If per-player-locale
is enabled in the config settings, players will receive a localized message, rather than the language set via the language
config option, unless one does not exist. In this case, you may wish to translate or stylize each language that you want to support.
Bolt has an API that can be used to interact with it from other plugins or to create add-ons for Bolt. The API is org.popcraft:bolt-bukkit
published on the CodeMC repository. For example, to add the dependency in Gradle Kotlin DSL, add the following to your build script:
repositories {
maven("https://repo.codemc.io/repository/maven-public/")
}
dependencies {
compileOnly("org.popcraft:bolt-bukkit:1.1.33")
}
API operations are performed using the BoltAPI
class, which can be obtained through the services manager.
BoltAPI bolt = Bukkit.getServer().getServicesManager().load(BoltAPI.class);
Bolt has a simple event system.
bolt.registerListener(LockBlockEvent.class, event -> {
// use event
});