Add cancellable UserUnloadEvent

This commit is contained in:
Luck 2021-02-27 18:24:39 +00:00
parent 843eaaed0c
commit 84c5b818b8
No known key found for this signature in database
GPG Key ID: EFA9B3EC5FD90F8B
3 changed files with 66 additions and 0 deletions

View File

@ -0,0 +1,50 @@
/*
* This file is part of LuckPerms, licensed under the MIT License.
*
* Copyright (c) lucko (Luck) <luck@lucko.me>
* Copyright (c) contributors
*
* Permission is hereby granted, free of charge, to any person obtaining a copy
* of this software and associated documentation files (the "Software"), to deal
* in the Software without restriction, including without limitation the rights
* to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
* copies of the Software, and to permit persons to whom the Software is
* furnished to do so, subject to the following conditions:
*
* The above copyright notice and this permission notice shall be included in all
* copies or substantial portions of the Software.
*
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
* SOFTWARE.
*/
package net.luckperms.api.event.user;
import net.luckperms.api.event.LuckPermsEvent;
import net.luckperms.api.event.type.Cancellable;
import net.luckperms.api.event.util.Param;
import net.luckperms.api.model.user.User;
import org.checkerframework.checker.nullness.qual.NonNull;
/**
* Called when a user is about to be unloaded from memory.
*
* @since 5.3
*/
public interface UserUnloadEvent extends LuckPermsEvent, Cancellable {
/**
* Gets the user that is being unloaded
*
* @return the user that is being unloaded
*/
@Param(0)
@NonNull User getUser();
}

View File

@ -88,6 +88,7 @@ import net.luckperms.api.event.user.UserCacheLoadEvent;
import net.luckperms.api.event.user.UserDataRecalculateEvent;
import net.luckperms.api.event.user.UserFirstLoginEvent;
import net.luckperms.api.event.user.UserLoadEvent;
import net.luckperms.api.event.user.UserUnloadEvent;
import net.luckperms.api.event.user.track.UserDemoteEvent;
import net.luckperms.api.event.user.track.UserPromoteEvent;
import net.luckperms.api.extension.Extension;
@ -365,6 +366,10 @@ public final class EventDispatcher {
postAsync(UserLoadEvent.class, user.getApiProxy());
}
public boolean dispatchUserUnload(User user) {
return postCancellable(UserUnloadEvent.class, false, user.getApiProxy());
}
public void dispatchUserDemote(User user, Track track, String from, String to, @Nullable Sender sender) {
Source source = sender == null ? UnknownSource.INSTANCE : new EntitySourceImpl(new SenderPlatformEntity(sender));
postAsync(UserDemoteEvent.class, source, track.getApiProxy(), user.getApiProxy(), Optional.ofNullable(from), Optional.ofNullable(to));
@ -424,6 +429,7 @@ public final class EventDispatcher {
UserDataRecalculateEvent.class,
UserFirstLoginEvent.class,
UserLoadEvent.class,
UserUnloadEvent.class,
UserDemoteEvent.class,
UserPromoteEvent.class
);

View File

@ -26,6 +26,7 @@
package me.lucko.luckperms.common.model.manager.user;
import me.lucko.luckperms.common.config.ConfigKeys;
import me.lucko.luckperms.common.model.User;
import me.lucko.luckperms.common.plugin.LuckPermsPlugin;
import me.lucko.luckperms.common.util.ExpiringSet;
@ -78,6 +79,15 @@ public class UserHousekeeper implements Runnable {
return;
}
User user = this.userManager.getIfLoaded(uuid);
if (user == null) {
return;
}
if (this.plugin.getEventDispatcher().dispatchUserUnload(user)) {
return;
}
// unload them
if (this.plugin.getConfiguration().get(ConfigKeys.DEBUG_LOGINS)) {
this.plugin.getLogger().info("User Housekeeper: unloading user data for " + uuid);