All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.spongepowered.api.user.UserManager Maven / Gradle / Ivy

/*
 * This file is part of SpongeAPI, licensed under the MIT License (MIT).
 *
 * Copyright (c) SpongePowered 
 * 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 org.spongepowered.api.user;

import org.spongepowered.api.entity.living.player.Player;
import org.spongepowered.api.entity.living.player.User;
import org.spongepowered.api.profile.GameProfile;
import org.spongepowered.api.profile.GameProfileManager;

import java.util.Optional;
import java.util.UUID;
import java.util.concurrent.CompletableFuture;
import java.util.stream.Stream;

/**
 * Stores the persistent {@link User} data of a {@link Player}.
 *
 * 

Any {@link User}s retrieved from this manager should not be stored, as * they may become invalid at any time.

*/ public interface UserManager { /** * Gets the data of a {@link User} by their unique id. * * @param uniqueId The UUID of the user * @return {@link User} or Optional.empty() if not found */ CompletableFuture> load(UUID uniqueId); /** * Gets the data of a {@link User} by their last known user name * (case-insensitive). * *

To get the current name of a player, use the * {@link GameProfileManager} service.

* * @param lastKnownName The user name * @return {@link User} or Optional.empty() if not found */ CompletableFuture> load(String lastKnownName); /** * Gets the data of a {@link User} by their {@link GameProfile}. * * @param profile The profile * @return {@link User} or Optional.empty() if not found */ CompletableFuture> load(GameProfile profile); /** * Gets or creates a persistent {@link User} with the given UUID. * * @param uuid The {@link UUID} of the player to load or create. * @return The user object */ CompletableFuture loadOrCreate(UUID uuid); /** * Deletes the data associated with a {@link User}, if the player is * offline. * * @param uuid The uuid of the user to delete * @return true if the deletion was successful */ CompletableFuture delete(UUID uuid); /** * If the implementation supports caching user objects, this will hint * to the implementation that the user with the given UUID should no * longer be cached. Any {@link User} objects held that this point * will become invalid (though developers should not be storing * users). * *

Be aware, any changes that have been made to the user may not * be saved.

* *

Users that are online will not be affected by this call.

* * @param uuid The UUID of the user to save. * @return {@code true} if the user was removed from a cache. */ boolean removeFromCache(UUID uuid); /** * If the implementation supports caching user objects, this will hint * to the implementation that the user with the given UUID should be saved * to the disk immediately. * *

If an exception is encountered during save, the completed future * will be exceptional and the boolean will be {@code null}. It is therefore * recommended that you check for any exceptions this future holds.

* * @param uuid The user to attempt to save. * @return A completed future that returns {@code true} if the implementation * saved the user. */ CompletableFuture forceSave(UUID uuid); /** * Returns whether data to create a {@link User} exists for a given * player with a specified {@link UUID}. * *

If this is {@code false}, then {@link #load(UUID)} will return * an {@linkplain Optional#empty() empty optional}.

* * @param playerUuid The {@link UUID} of the player to check. * @return If the player has existing user data that can be loaded. */ boolean exists(UUID playerUuid); /** * Gets a {@link Stream} that returns a {@link GameProfile} for each stored * {@link User}s. * *

This {@link Stream} may contain profiles that only hold a result for * {@link GameProfile#uniqueId()}, that is, do not return a user's name. * Such profiles should thus be treated as incomplete and are no more than * an indicator that a {@link User} associated with the given {@link UUID} * exists.

* *

Similarly, for {@link GameProfile}s that are filled and thus contain * name data, the profile information is based on the latest information * the server holds and no attempt is made to update this information.

* *

If you require up to date {@link GameProfile}s, use the appropriate * methods on the {@link GameProfileManager} and/or its associated * {@link GameProfileManager}.

* *

Use {@link #load(GameProfile)} to load the {@link User} data associated * with the associated {@link GameProfile}.

* * @return A {@link Stream} of {@link GameProfile}s */ Stream streamAll(); /** * Gets a {@link Stream} that returns a {@link GameProfile} for each stored * {@link User} whose last known user names start with the given string * (case-insensitive). * *

It is important to note that the names this method uses to perform the * matching is based on the latest information the server holds and no * attempt is made to update this information.

* *

If you require up to date {@link GameProfile}s, use the appropriate * methods on the {@link GameProfileManager} and/or its associated * {@link GameProfileManager}.

* *

Use {@link #load(GameProfile)} to load associated {@link User} data. *

* * @param lastKnownName The name to check for * @return A {@link Stream} of {@link GameProfile}s */ Stream streamOfMatches(String lastKnownName); }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy