org.spongepowered.api.Server Maven / Gradle / Ivy
Show all versions of spongeapi Show documentation
/*
* 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;
import net.kyori.adventure.audience.Audience;
import net.kyori.adventure.audience.ForwardingAudience;
import net.kyori.adventure.resource.ResourcePackRequest;
import net.kyori.adventure.text.Component;
import org.spongepowered.api.block.entity.CommandBlock;
import org.spongepowered.api.command.manager.CommandManager;
import org.spongepowered.api.entity.living.Hostile;
import org.spongepowered.api.entity.living.animal.Animal;
import org.spongepowered.api.entity.living.player.gamemode.GameMode;
import org.spongepowered.api.entity.living.player.server.ServerPlayer;
import org.spongepowered.api.event.lifecycle.RegisterCommandEvent;
import org.spongepowered.api.item.recipe.RecipeManager;
import org.spongepowered.api.map.MapStorage;
import org.spongepowered.api.network.ServerSideConnection;
import org.spongepowered.api.profile.GameProfileManager;
import org.spongepowered.api.scoreboard.Scoreboard;
import org.spongepowered.api.service.ServiceProvider;
import org.spongepowered.api.user.UserManager;
import org.spongepowered.api.util.Ticks;
import org.spongepowered.api.util.locale.LocaleSource;
import org.spongepowered.api.world.difficulty.Difficulty;
import org.spongepowered.api.world.generation.config.WorldGenerationConfig;
import org.spongepowered.api.world.server.DataPackManager;
import org.spongepowered.api.world.server.ServerLocation;
import org.spongepowered.api.world.server.ServerWorld;
import org.spongepowered.api.world.server.WorldManager;
import org.spongepowered.api.world.storage.ChunkLayout;
import org.spongepowered.api.world.teleport.TeleportHelper;
import java.net.InetSocketAddress;
import java.util.Collection;
import java.util.Optional;
import java.util.UUID;
import java.util.stream.Stream;
/**
* Represents a typical Minecraft Server.
*/
public interface Server extends ForwardingAudience, Engine, LocaleSource {
/**
* Gets the {@link WorldManager}.
*
* @return The world manager
*/
WorldManager worldManager();
/**
* Returns the {@link DataPackManager}
*
* @return The datapack manager
*/
DataPackManager dataPackManager();
/**
* Retrieves the {@link RecipeManager}.
*
* @return The recipe manager
*/
RecipeManager recipeManager();
/**
* Gets if multiple {@link ServerWorld worlds} will be loaded by the server.
*
* @implNote If false, no calls to loading worlds via the {@link WorldManager world manager} or otherwise will
* load a world
* @return True if enabled, false if not
*/
boolean isMultiWorldEnabled();
/**
* Gets the {@link WorldGenerationConfig}.
*
* @return The world generator config
*/
WorldGenerationConfig worldGenerationConfig();
/**
* Gets the max {@link ServerPlayer players} allowed to join.
*
* @return The max players
*/
int maxPlayers();
/**
* Gets if the whitelist is currently enforced.
*
* @return True if enabled, false if not
*/
boolean isWhitelistEnabled();
/**
* Gets if incoming {@link ServerSideConnection connections} are authenticated against Mojang's servers.
*
* @return True if enabled, false if not
*/
boolean isOnlineModeEnabled();
/**
* Gets the "message of the day" presented to clients who have this server saved as a connection profile
* in the multiplayer menu
*
* @return The message of the day
*/
Component motd();
/**
* Gets the {@link ResourcePackRequest pack} sent to clients when they join.
*
* @return The resource pack
*/
Optional resourcePack();
/**
* Gets the player idle timeout, in minutes.
*
* @implNote A value of {@code 0} means the timeout is disabled
* @return The player idle timeout
*/
int playerIdleTimeout();
/**
* Gets if hardcode mode has been enabled.
*
* @return True if enabled, false if not
*/
boolean isHardcoreModeEnabled();
/**
* Gets the {@link Difficulty}.
*
* @return The difficulty
*/
Difficulty difficulty();
/**
* Gets the {@link GameMode}.
*
* @return The gamemode
*/
GameMode gameMode();
/**
* Gets if {@link ServerPlayer players} will have their {@link GameMode game mode} set to the default.
*
* {@link Server#gameMode()}
*
* @return True if enforced, false if not
*/
boolean isGameModeEnforced();
/**
* Gets if pvp is enabled.
*
* @return True if enabled, false if not
*/
boolean isPVPEnabled();
/**
* Gets if {@link CommandBlock command blocks} will run commands.
*
* @return True if enabled, false if not
*/
boolean areCommandBlocksEnabled();
/**
* Gets if {@link Hostile monsters} will naturally spawn.
*
* @return True if enabled, false if not
*/
boolean isMonsterSpawnsEnabled();
/**
* Gets if {@link Animal animals} will naturally spawn.
*
* @return True if enabled, false if not
*/
boolean isAnimalSpawnsEnabled();
/**
* Gets whether this server is dedicated to being a global server, or
* whether this server is local to a game client where a {@link Client}
* instance may be available.
*
* @return True if this is a dedicated server without a game client
*/
boolean isDedicatedServer();
/**
* Gets the {@link UserManager}.
*
* @return The user manager
*/
UserManager userManager();
/**
* Gets the {@link TeleportHelper}, used to find safe {@link ServerLocation}s.
*
* @return The teleport helper
*/
TeleportHelper teleportHelper();
/**
* Gets a {@link Stream} of all the {@link ServerPlayer}s currently online.
*
* @return The stream of online players
*/
Stream streamOnlinePlayers();
/**
* Gets the {@link ServerPlayer}s currently online.
*
* @return A {@link Collection} of online players
*/
Collection onlinePlayers();
/**
* Gets a {@link ServerPlayer} by their UUID.
*
* @param uniqueId The UUID to get the player from
* @return The {@link ServerPlayer} or empty if not found
*/
Optional player(UUID uniqueId);
/**
* Gets a {@link ServerPlayer} by their name.
*
* This only works for online players.
*
* @implNote Do not use names for persistent storage, the
* Notch of today may not be the Notch of yesterday.
* @param name The name to get the player from
* @return The {@link ServerPlayer} or empty if not found
*/
Optional player(String name);
/**
* Gets the 'server' scoreboard. In Vanilla, this is the scoreboard of
* dimension 0 (the overworld).
*
* The server scoreboard is used with the Vanilla /scoreboard command,
* automatic score updating through criteria, and other things.
*
* @implNote The server scoreboard may not be available if dimension 0
* is not yet loaded. In Vanilla, this will only occur when the
* server is first starting, as dimension 0 is normally always loaded.
* @return the server scoreboard, if available.
*/
Optional extends Scoreboard> serverScoreboard();
/**
* Returns information about the chunk layout used by this server
* implementation.
*
* @return The chunk layout used by the implementation
*/
ChunkLayout chunkLayout();
/**
* Gets the time, in ticks, since this server began running for the current
* session.
*
* @implNote This value is not persisted across server restarts, it is set to zero
* each time the server starts.
* @return The number of ticks since this server started running
*/
Ticks runningTimeTicks();
/**
* Gets the message channel that server-wide messages are sent through.
*
* @return The server-wide broadcast channel
*/
Audience broadcastAudience();
/**
* Sets the channel that server-wide messages should be sent through.
*
* @param channel The broadcast channel
*/
void setBroadcastAudience(Audience channel);
/**
* Gets the bound {@link InetSocketAddress} from where this server is
* accepting connections.
*
* @return The address or Optional.empty() if not found
*/
Optional boundAddress();
/**
* Sets whether the server is utilizing a whitelist.
*
* @param enabled True to enable the whitelist, false to disable
*/
void setHasWhitelist(boolean enabled);
/**
* Shuts down the server, and kicks all players with the default kick
* message.
*
* @implNote For the Sponge implementation on the client, this will trigger the
* Integrated Server to shutdown a tick later.
*/
void shutdown();
/**
* Shuts down the server, and kicks all players with the given message.
*
* @param kickMessage The message to kick players with
*/
void shutdown(Component kickMessage);
/**
* Gets the {@link GameProfileManager} for resolving game profiles.
*
* @return This server's game profile manager
*/
GameProfileManager gameProfileManager();
/**
* Gets the current ticks per second. A tick represents one cycle of the
* game loop.
*
* @return The current ticks per second
*/
double ticksPerSecond();
/**
* Gets the current average milliseconds per tick.
*
* @return The current average tick time.
*/
double averageTickTime();
/**
* Gets the target ticks per second for this server.
*
* This is dependent on the implementation.
*
* @return The target tick per second rate.
*/
int targetTicksPerSecond();
/**
* Sets the player idle timeout, in minutes.
*
* @implNote A value of {@code 0} disables the player idle timeout.
* @param timeout The player idle timeout
*/
void setPlayerIdleTimeout(int timeout);
/**
* Gets the {@link ServiceProvider.ServerScoped}, used to provide Sponge
* services that plugins may provide. Services provided here are
* scoped to the lifetime of this Server.
*
* @implNote The provider will not be available during plugin construction and will
* throw an {@link IllegalStateException} if there is an attempt to access
* this before the provider is ready.
* @return The service manager
*/
ServiceProvider.ServerScoped serviceProvider();
/**
* Gets the {@link CommandManager} for executing and inspecting commands.
*
* Commands must be registered by listening to the
* {@link RegisterCommandEvent} instead.
*
* @return The {@link CommandManager} instance.
*/
CommandManager commandManager();
/**
* Gets the map storage for this server
*
* This allows for control over the server's maps,
* including obtaining and creating them
*
* @return MapStorage
*/
MapStorage mapStorage();
}