-
-
Notifications
You must be signed in to change notification settings - Fork 343
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
[API-8] Standardize data directory #2325
Comments
How would that work where the game can boot multiple server engines - something like the client? Is there data for client side and server side? Should we make the distinction between game scoped and engine scoped - presumably the latter is more useful for plugin data? This is nowhere near as simple as config which is assumed to always be game scoped. It's not a simple as slapping an annotation on a |
It's probably worth having the same sort of discussion about scope on configurations as well, since plugins may want to have per-world or per-universe configurations (drawing from names used in the vanilla server CLI arguments here)
For universe and world, the injected type would have to be some sort of provider mapping engine/world -> a configuration location The part I've struggled to find a good answer for is how to handle invalidation of a certain scope -- when an integrated server shuts down, how do we indicate to plugins that their configuration has gone out of scope in a minimally error-prone way? |
Perhaps the desire to continue to do injected configuration loaders/paths are the issue here. You hit on this with your point on how to tell plugin devs that the config is now "stale". I don't really see a clean way to do this with injected loaders without introducing another concept for plugin devs to have to learn. With this is mind, maybe a better fix for this is (imo) granting configuration is own lifecycle event. This does more tightly couple Configurate to plugin development (well depends how the event looks) but given pseudocode below... interface LoadConfigurationEvent extends LifecycleEvent {
Path configDirectory();
// TODO Need a way for a dev to tell us "I want to be hocon!" and we give them back the appropriate configuration node?
interface GameScoped extends LoadConfigurationEvent {}
interface EngineScoped<E extends Engine> extends LoadConfigurationEvent {}
interface WorldScoped<W extends World> extends LoadConfigurationEvent {}
} Rough by far but perhaps a talking point. We would essentially mirror this for some "loading data" mechanism...just without configurate-specific bits there. |
The concept of the config directory has been standardized for a long time now. However, it is not very clear where plugins should store "user data" (assuming it's not stored on a remote database).
Currently, the main choices are:
SERVER_DIR/<pluginid>
SERVER_DIR/config/<pluginid>
Both have disadvantages; saving directly in the server directory can lead to an unorganized mess, whereas saving in the config directory seems weird considering "user data" is not "configuration data".
(As a side note, some users may delete the config directory to reset configuration data but this should not delete user data.)
Potential solution
There should be a standardized way of storing plugin data that is not configuration data. In my opinion, the most sensible convention would be
SERVER_DIR/data/<pluginid>
orSERVER_DIR/plugindata/<pluginid>
as this is similar to the structure of the current config directory.Deliverables
@ConfigDir
, maybe@DataDir
?)The text was updated successfully, but these errors were encountered: