mirror of
https://github.com/LuckPerms/LuckPerms.git
synced 2025-03-02 11:31:13 +01:00
Add cancellable UserUnloadEvent
This commit is contained in:
parent
843eaaed0c
commit
84c5b818b8
@ -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();
|
||||
|
||||
}
|
@ -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
|
||||
);
|
||||
|
@ -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);
|
||||
|
Loading…
Reference in New Issue
Block a user