mirror of
https://github.com/Grasscutters/Grasscutter.git
synced 2025-01-08 08:42:53 +08:00
refactor: this can also be final
This commit is contained in:
parent
9fa0f2bcad
commit
7d3abb083b
@ -1,12 +1,12 @@
|
|||||||
package emu.grasscutter;
|
package emu.grasscutter;
|
||||||
|
|
||||||
public final class DebugConstants {
|
public final class DebugConstants {
|
||||||
public static boolean LOG_ABILITIES = false;
|
public static final boolean LOG_ABILITIES = false;
|
||||||
public static boolean LOG_LUA_SCRIPTS = false;
|
public static final boolean LOG_LUA_SCRIPTS = false;
|
||||||
public static boolean LOG_QUEST_START = false;
|
public static final boolean LOG_QUEST_START = false;
|
||||||
public static boolean LOG_MISSING_ABILITIES = false;
|
public static final boolean LOG_MISSING_ABILITIES = false;
|
||||||
public static boolean LOG_MISSING_LUA_SCRIPTS = false;
|
public static final boolean LOG_MISSING_LUA_SCRIPTS = false;
|
||||||
public static boolean LOG_MISSING_ABILITY_HANDLERS = false;
|
public static final boolean LOG_MISSING_ABILITY_HANDLERS = false;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* WARNING: THIS IS A DANGEROUS SETTING. DO NOT ENABLE UNLESS YOU KNOW WHAT YOU ARE DOING. This
|
* WARNING: THIS IS A DANGEROUS SETTING. DO NOT ENABLE UNLESS YOU KNOW WHAT YOU ARE DOING. This
|
||||||
|
@ -7,8 +7,8 @@ import emu.grasscutter.utils.objects.SparseSet;
|
|||||||
import java.util.Arrays;
|
import java.util.Arrays;
|
||||||
|
|
||||||
public final class GameConstants {
|
public final class GameConstants {
|
||||||
public static String VERSION = "4.0.0";
|
public static final String VERSION = "4.0.0";
|
||||||
public static int[] VERSION_PARTS = {4, 0, 0};
|
public static final int[] VERSION_PARTS = {4, 0, 0};
|
||||||
public static boolean DEBUG = false;
|
public static boolean DEBUG = false;
|
||||||
|
|
||||||
public static final int DEFAULT_TEAMS = 4;
|
public static final int DEFAULT_TEAMS = 4;
|
||||||
|
@ -291,9 +291,9 @@ public final class SetPropCommand implements CommandHandler {
|
|||||||
}
|
}
|
||||||
|
|
||||||
static class Prop {
|
static class Prop {
|
||||||
String name;
|
final String name;
|
||||||
PlayerProperty prop;
|
final PlayerProperty prop;
|
||||||
PseudoProp pseudoProp;
|
final PseudoProp pseudoProp;
|
||||||
|
|
||||||
public Prop(PlayerProperty prop) {
|
public Prop(PlayerProperty prop) {
|
||||||
this(prop.toString(), prop, PseudoProp.NONE);
|
this(prop.toString(), prop, PseudoProp.NONE);
|
||||||
|
@ -171,8 +171,8 @@ public final class SetStatsCommand implements CommandHandler {
|
|||||||
}
|
}
|
||||||
|
|
||||||
private static class Stat {
|
private static class Stat {
|
||||||
String name;
|
final String name;
|
||||||
FightProperty prop;
|
final FightProperty prop;
|
||||||
|
|
||||||
public Stat(FightProperty prop) {
|
public Stat(FightProperty prop) {
|
||||||
this.name = prop.toString();
|
this.name = prop.toString();
|
||||||
|
@ -78,11 +78,11 @@ public class ConfigContainer {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public Structure folderStructure = new Structure();
|
public final Structure folderStructure = new Structure();
|
||||||
public Database databaseInfo = new Database();
|
public final Database databaseInfo = new Database();
|
||||||
public Language language = new Language();
|
public final Language language = new Language();
|
||||||
public Account account = new Account();
|
public final Account account = new Account();
|
||||||
public Server server = new Server();
|
public final Server server = new Server();
|
||||||
|
|
||||||
// DO NOT. TOUCH. THE VERSION NUMBER.
|
// DO NOT. TOUCH. THE VERSION NUMBER.
|
||||||
public int version = version();
|
public int version = version();
|
||||||
@ -90,99 +90,99 @@ public class ConfigContainer {
|
|||||||
/* Option containers. */
|
/* Option containers. */
|
||||||
|
|
||||||
public static class Database {
|
public static class Database {
|
||||||
public DataStore server = new DataStore();
|
public final DataStore server = new DataStore();
|
||||||
public DataStore game = new DataStore();
|
public final DataStore game = new DataStore();
|
||||||
|
|
||||||
public static class DataStore {
|
public static class DataStore {
|
||||||
public String connectionUri = "mongodb://localhost:27017";
|
public final String connectionUri = "mongodb://localhost:27017";
|
||||||
public String collection = "grasscutter";
|
public final String collection = "grasscutter";
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public static class Structure {
|
public static class Structure {
|
||||||
public String resources = "./resources/";
|
public final String resources = "./resources/";
|
||||||
public String data = "./data/";
|
public final String data = "./data/";
|
||||||
public String packets = "./packets/";
|
public final String packets = "./packets/";
|
||||||
public String scripts = "resources:Scripts/";
|
public final String scripts = "resources:Scripts/";
|
||||||
public String plugins = "./plugins/";
|
public final String plugins = "./plugins/";
|
||||||
public String cache = "./cache/";
|
public final String cache = "./cache/";
|
||||||
|
|
||||||
// UNUSED (potentially added later?)
|
// UNUSED (potentially added later?)
|
||||||
// public String dumps = "./dumps/";
|
// public String dumps = "./dumps/";
|
||||||
}
|
}
|
||||||
|
|
||||||
public static class Server {
|
public static class Server {
|
||||||
public Set<Integer> debugWhitelist = Set.of();
|
public final Set<Integer> debugWhitelist = Set.of();
|
||||||
public Set<Integer> debugBlacklist = Set.of();
|
public final Set<Integer> debugBlacklist = Set.of();
|
||||||
public ServerRunMode runMode = ServerRunMode.HYBRID;
|
public final ServerRunMode runMode = ServerRunMode.HYBRID;
|
||||||
public boolean logCommands = false;
|
public final boolean logCommands = false;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* If enabled, the 'require' Lua function will load the script's compiled varient into the context. (faster; doesn't work as well)
|
* If enabled, the 'require' Lua function will load the script's compiled varient into the context. (faster; doesn't work as well)
|
||||||
* If disabled, all 'require' calls will be replaced with the referenced script's source. (slower; works better)
|
* If disabled, all 'require' calls will be replaced with the referenced script's source. (slower; works better)
|
||||||
*/
|
*/
|
||||||
public boolean fastRequire = true;
|
public final boolean fastRequire = true;
|
||||||
|
|
||||||
public HTTP http = new HTTP();
|
public final HTTP http = new HTTP();
|
||||||
public Game game = new Game();
|
public final Game game = new Game();
|
||||||
|
|
||||||
public Dispatch dispatch = new Dispatch();
|
public final Dispatch dispatch = new Dispatch();
|
||||||
public DebugMode debugMode = new DebugMode();
|
public final DebugMode debugMode = new DebugMode();
|
||||||
}
|
}
|
||||||
|
|
||||||
public static class Language {
|
public static class Language {
|
||||||
public Locale language = Locale.getDefault();
|
public Locale language = Locale.getDefault();
|
||||||
public Locale fallback = Locale.US;
|
public final Locale fallback = Locale.US;
|
||||||
public String document = "EN";
|
public final String document = "EN";
|
||||||
}
|
}
|
||||||
|
|
||||||
public static class Account {
|
public static class Account {
|
||||||
public boolean autoCreate = false;
|
public final boolean autoCreate = false;
|
||||||
public boolean EXPERIMENTAL_RealPassword = false;
|
public final boolean EXPERIMENTAL_RealPassword = false;
|
||||||
public String[] defaultPermissions = {};
|
public final String[] defaultPermissions = {};
|
||||||
public String playerEmail = "grasscutter.io";
|
public final String playerEmail = "grasscutter.io";
|
||||||
public int maxPlayer = -1;
|
public final int maxPlayer = -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Server options. */
|
/* Server options. */
|
||||||
|
|
||||||
public static class HTTP {
|
public static class HTTP {
|
||||||
/* This starts the HTTP server before the game server. */
|
/* This starts the HTTP server before the game server. */
|
||||||
public boolean startImmediately = false;
|
public final boolean startImmediately = false;
|
||||||
|
|
||||||
public String bindAddress = "0.0.0.0";
|
public final String bindAddress = "0.0.0.0";
|
||||||
public int bindPort = 443;
|
public final int bindPort = 443;
|
||||||
|
|
||||||
/* This is the address used in URLs. */
|
/* This is the address used in URLs. */
|
||||||
public String accessAddress = "127.0.0.1";
|
public final String accessAddress = "127.0.0.1";
|
||||||
/* This is the port used in URLs. */
|
/* This is the port used in URLs. */
|
||||||
public int accessPort = 0;
|
public final int accessPort = 0;
|
||||||
|
|
||||||
public Encryption encryption = new Encryption();
|
public final Encryption encryption = new Encryption();
|
||||||
public Policies policies = new Policies();
|
public final Policies policies = new Policies();
|
||||||
public Files files = new Files();
|
public final Files files = new Files();
|
||||||
}
|
}
|
||||||
|
|
||||||
public static class Game {
|
public static class Game {
|
||||||
public String bindAddress = "0.0.0.0";
|
public final String bindAddress = "0.0.0.0";
|
||||||
public int bindPort = 22102;
|
public final int bindPort = 22102;
|
||||||
|
|
||||||
/* This is the address used in the default region. */
|
/* This is the address used in the default region. */
|
||||||
public String accessAddress = "127.0.0.1";
|
public final String accessAddress = "127.0.0.1";
|
||||||
/* This is the port used in the default region. */
|
/* This is the port used in the default region. */
|
||||||
public int accessPort = 0;
|
public final int accessPort = 0;
|
||||||
|
|
||||||
/* Enabling this will generate a unique packet encryption key for each player. */
|
/* Enabling this will generate a unique packet encryption key for each player. */
|
||||||
public boolean useUniquePacketKey = true;
|
public final boolean useUniquePacketKey = true;
|
||||||
|
|
||||||
/* Entities within a certain range will be loaded for the player */
|
/* Entities within a certain range will be loaded for the player */
|
||||||
public int loadEntitiesForPlayerRange = 300;
|
public final int loadEntitiesForPlayerRange = 300;
|
||||||
/* Start in 'unstable-quests', Lua scripts will be enabled by default. */
|
/* Start in 'unstable-quests', Lua scripts will be enabled by default. */
|
||||||
public boolean enableScriptInBigWorld = true;
|
public final boolean enableScriptInBigWorld = true;
|
||||||
public boolean enableConsole = true;
|
public boolean enableConsole = true;
|
||||||
|
|
||||||
/* Kcp internal work interval (milliseconds) */
|
/* Kcp internal work interval (milliseconds) */
|
||||||
public int kcpInterval = 20;
|
public final int kcpInterval = 20;
|
||||||
/* Controls whether packets should be logged in console or not */
|
/* Controls whether packets should be logged in console or not */
|
||||||
public ServerDebugMode logPackets = ServerDebugMode.NONE;
|
public ServerDebugMode logPackets = ServerDebugMode.NONE;
|
||||||
/* Show packet payload in console or no (in any case the payload is shown in encrypted view) */
|
/* Show packet payload in console or no (in any case the payload is shown in encrypted view) */
|
||||||
@ -190,13 +190,13 @@ public class ConfigContainer {
|
|||||||
/* Show annoying loop packets or no */
|
/* Show annoying loop packets or no */
|
||||||
public boolean isShowLoopPackets = false;
|
public boolean isShowLoopPackets = false;
|
||||||
|
|
||||||
public boolean cacheSceneEntitiesEveryRun = false;
|
public final boolean cacheSceneEntitiesEveryRun = false;
|
||||||
|
|
||||||
public GameOptions gameOptions = new GameOptions();
|
public final GameOptions gameOptions = new GameOptions();
|
||||||
public JoinOptions joinOptions = new JoinOptions();
|
public final JoinOptions joinOptions = new JoinOptions();
|
||||||
public ConsoleAccount serverAccount = new ConsoleAccount();
|
public final ConsoleAccount serverAccount = new ConsoleAccount();
|
||||||
|
|
||||||
public VisionOptions[] visionOptions = new VisionOptions[] {
|
public final VisionOptions[] visionOptions = new VisionOptions[] {
|
||||||
new VisionOptions("VISION_LEVEL_NORMAL" , 80 , 20),
|
new VisionOptions("VISION_LEVEL_NORMAL" , 80 , 20),
|
||||||
new VisionOptions("VISION_LEVEL_LITTLE_REMOTE" , 16 , 40),
|
new VisionOptions("VISION_LEVEL_LITTLE_REMOTE" , 16 , 40),
|
||||||
new VisionOptions("VISION_LEVEL_REMOTE" , 1000 , 250),
|
new VisionOptions("VISION_LEVEL_REMOTE" , 1000 , 250),
|
||||||
@ -210,17 +210,17 @@ public class ConfigContainer {
|
|||||||
|
|
||||||
public static class Dispatch {
|
public static class Dispatch {
|
||||||
/* An array of servers. */
|
/* An array of servers. */
|
||||||
public List<Region> regions = List.of();
|
public final List<Region> regions = List.of();
|
||||||
|
|
||||||
/* The URL used to make HTTP requests to the dispatch server. */
|
/* The URL used to make HTTP requests to the dispatch server. */
|
||||||
public String dispatchUrl = "ws://127.0.0.1:1111";
|
public final String dispatchUrl = "ws://127.0.0.1:1111";
|
||||||
/* A unique key used for encryption. */
|
/* A unique key used for encryption. */
|
||||||
public byte[] encryptionKey = Crypto.createSessionKey(32);
|
public final byte[] encryptionKey = Crypto.createSessionKey(32);
|
||||||
/* A unique key used for authentication. */
|
/* A unique key used for authentication. */
|
||||||
public String dispatchKey = Utils.base64Encode(
|
public final String dispatchKey = Utils.base64Encode(
|
||||||
Crypto.createSessionKey(32));
|
Crypto.createSessionKey(32));
|
||||||
|
|
||||||
public String defaultName = "Grasscutter";
|
public final String defaultName = "Grasscutter";
|
||||||
|
|
||||||
/* Controls whether http requests should be logged in console or not */
|
/* Controls whether http requests should be logged in console or not */
|
||||||
public ServerDebugMode logRequests = ServerDebugMode.NONE;
|
public ServerDebugMode logRequests = ServerDebugMode.NONE;
|
||||||
@ -230,127 +230,127 @@ public class ConfigContainer {
|
|||||||
* (see StartupArguments.enableDebug) */
|
* (see StartupArguments.enableDebug) */
|
||||||
public static class DebugMode {
|
public static class DebugMode {
|
||||||
/* Log level of the main server code (works only with -debug arg) */
|
/* Log level of the main server code (works only with -debug arg) */
|
||||||
public Level serverLoggerLevel = Level.DEBUG;
|
public final Level serverLoggerLevel = Level.DEBUG;
|
||||||
|
|
||||||
/* Log level of the third-party services (works only with -debug arg):
|
/* Log level of the third-party services (works only with -debug arg):
|
||||||
javalin, quartz, reflections, jetty, mongodb.driver */
|
javalin, quartz, reflections, jetty, mongodb.driver */
|
||||||
public Level servicesLoggersLevel = Level.INFO;
|
public final Level servicesLoggersLevel = Level.INFO;
|
||||||
|
|
||||||
/* Controls whether packets should be logged in console or not */
|
/* Controls whether packets should be logged in console or not */
|
||||||
public ServerDebugMode logPackets = ServerDebugMode.ALL;
|
public final ServerDebugMode logPackets = ServerDebugMode.ALL;
|
||||||
|
|
||||||
/* Show packet payload in console or no (in any case the payload is shown in encrypted view) */
|
/* Show packet payload in console or no (in any case the payload is shown in encrypted view) */
|
||||||
public boolean isShowPacketPayload = false;
|
public final boolean isShowPacketPayload = false;
|
||||||
|
|
||||||
/* Show annoying loop packets or no */
|
/* Show annoying loop packets or no */
|
||||||
public boolean isShowLoopPackets = false;
|
public final boolean isShowLoopPackets = false;
|
||||||
|
|
||||||
/* Controls whether http requests should be logged in console or not */
|
/* Controls whether http requests should be logged in console or not */
|
||||||
public ServerDebugMode logRequests = ServerDebugMode.ALL;
|
public final ServerDebugMode logRequests = ServerDebugMode.ALL;
|
||||||
}
|
}
|
||||||
|
|
||||||
public static class Encryption {
|
public static class Encryption {
|
||||||
public boolean useEncryption = true;
|
public boolean useEncryption = true;
|
||||||
/* Should 'https' be appended to URLs? */
|
/* Should 'https' be appended to URLs? */
|
||||||
public boolean useInRouting = true;
|
public boolean useInRouting = true;
|
||||||
public String keystore = "./keystore.p12";
|
public final String keystore = "./keystore.p12";
|
||||||
public String keystorePassword = "123456";
|
public final String keystorePassword = "123456";
|
||||||
}
|
}
|
||||||
|
|
||||||
public static class Policies {
|
public static class Policies {
|
||||||
public Policies.CORS cors = new Policies.CORS();
|
public final Policies.CORS cors = new Policies.CORS();
|
||||||
|
|
||||||
public static class CORS {
|
public static class CORS {
|
||||||
public boolean enabled = true;
|
public final boolean enabled = true;
|
||||||
public String[] allowedOrigins = new String[]{"*"};
|
public final String[] allowedOrigins = new String[]{"*"};
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public static class GameOptions {
|
public static class GameOptions {
|
||||||
public InventoryLimits inventoryLimits = new InventoryLimits();
|
public final InventoryLimits inventoryLimits = new InventoryLimits();
|
||||||
public AvatarLimits avatarLimits = new AvatarLimits();
|
public final AvatarLimits avatarLimits = new AvatarLimits();
|
||||||
public int sceneEntityLimit = 1000; // Unenforced. TODO: Implement.
|
public final int sceneEntityLimit = 1000; // Unenforced. TODO: Implement.
|
||||||
|
|
||||||
public boolean watchGachaConfig = false;
|
public final boolean watchGachaConfig = false;
|
||||||
public boolean enableShopItems = true;
|
public final boolean enableShopItems = true;
|
||||||
public boolean staminaUsage = true;
|
public final boolean staminaUsage = true;
|
||||||
public boolean energyUsage = true;
|
public final boolean energyUsage = true;
|
||||||
public boolean fishhookTeleport = true;
|
public final boolean fishhookTeleport = true;
|
||||||
public boolean trialCostumes = false;
|
public final boolean trialCostumes = false;
|
||||||
|
|
||||||
@SerializedName(value = "questing", alternate = "questOptions")
|
@SerializedName(value = "questing", alternate = "questOptions")
|
||||||
public Questing questing = new Questing();
|
public final Questing questing = new Questing();
|
||||||
public ResinOptions resinOptions = new ResinOptions();
|
public final ResinOptions resinOptions = new ResinOptions();
|
||||||
public Rates rates = new Rates();
|
public final Rates rates = new Rates();
|
||||||
|
|
||||||
public HandbookOptions handbook = new HandbookOptions();
|
public final HandbookOptions handbook = new HandbookOptions();
|
||||||
|
|
||||||
public static class InventoryLimits {
|
public static class InventoryLimits {
|
||||||
public int weapons = 2000;
|
public final int weapons = 2000;
|
||||||
public int relics = 2000;
|
public final int relics = 2000;
|
||||||
public int materials = 2000;
|
public final int materials = 2000;
|
||||||
public int furniture = 2000;
|
public final int furniture = 2000;
|
||||||
public int all = 30000;
|
public final int all = 30000;
|
||||||
}
|
}
|
||||||
|
|
||||||
public static class AvatarLimits {
|
public static class AvatarLimits {
|
||||||
public int singlePlayerTeam = 4;
|
public final int singlePlayerTeam = 4;
|
||||||
public int multiplayerTeam = 4;
|
public final int multiplayerTeam = 4;
|
||||||
}
|
}
|
||||||
|
|
||||||
public static class Rates {
|
public static class Rates {
|
||||||
public float adventureExp = 1.0f;
|
public final float adventureExp = 1.0f;
|
||||||
public float mora = 1.0f;
|
public float mora = 1.0f;
|
||||||
public float leyLines = 1.0f;
|
public float leyLines = 1.0f;
|
||||||
}
|
}
|
||||||
|
|
||||||
public static class ResinOptions {
|
public static class ResinOptions {
|
||||||
public boolean resinUsage = false;
|
public final boolean resinUsage = false;
|
||||||
public int cap = 160;
|
public final int cap = 160;
|
||||||
public int rechargeTime = 480;
|
public final int rechargeTime = 480;
|
||||||
}
|
}
|
||||||
|
|
||||||
public static class Questing {
|
public static class Questing {
|
||||||
/* Should questing behavior be used? */
|
/* Should questing behavior be used? */
|
||||||
public boolean enabled = true;
|
public final boolean enabled = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
public static class HandbookOptions {
|
public static class HandbookOptions {
|
||||||
public boolean enable = false;
|
public final boolean enable = false;
|
||||||
public boolean allowCommands = true;
|
public final boolean allowCommands = true;
|
||||||
|
|
||||||
public Limits limits = new Limits();
|
public final Limits limits = new Limits();
|
||||||
public Server server = new Server();
|
public final Server server = new Server();
|
||||||
|
|
||||||
public static class Limits {
|
public static class Limits {
|
||||||
/* Are rate limits checked? */
|
/* Are rate limits checked? */
|
||||||
public boolean enabled = false;
|
public final boolean enabled = false;
|
||||||
/* The time for limits to expire. */
|
/* The time for limits to expire. */
|
||||||
public int interval = 3;
|
public final int interval = 3;
|
||||||
|
|
||||||
/* The maximum amount of normal requests. */
|
/* The maximum amount of normal requests. */
|
||||||
public int maxRequests = 10;
|
public final int maxRequests = 10;
|
||||||
/* The maximum amount of entities to be spawned in one request. */
|
/* The maximum amount of entities to be spawned in one request. */
|
||||||
public int maxEntities = 25;
|
public final int maxEntities = 25;
|
||||||
}
|
}
|
||||||
|
|
||||||
public static class Server {
|
public static class Server {
|
||||||
/* Are the server settings sent to the handbook? */
|
/* Are the server settings sent to the handbook? */
|
||||||
public boolean enforced = false;
|
public final boolean enforced = false;
|
||||||
/* The default server address for the handbook's authentication. */
|
/* The default server address for the handbook's authentication. */
|
||||||
public String address = "127.0.0.1";
|
public final String address = "127.0.0.1";
|
||||||
/* The default server port for the handbook's authentication. */
|
/* The default server port for the handbook's authentication. */
|
||||||
public int port = 443;
|
public final int port = 443;
|
||||||
/* Should the defaults be enforced? */
|
/* Should the defaults be enforced? */
|
||||||
public boolean canChange = true;
|
public final boolean canChange = true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public static class VisionOptions {
|
public static class VisionOptions {
|
||||||
public String name;
|
public final String name;
|
||||||
public int visionRange;
|
public final int visionRange;
|
||||||
public int gridWidth;
|
public final int gridWidth;
|
||||||
|
|
||||||
public VisionOptions(String name, int visionRange, int gridWidth) {
|
public VisionOptions(String name, int visionRange, int gridWidth) {
|
||||||
this.name = name;
|
this.name = name;
|
||||||
@ -360,21 +360,21 @@ public class ConfigContainer {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public static class JoinOptions {
|
public static class JoinOptions {
|
||||||
public int[] welcomeEmotes = {2007, 1002, 4010};
|
public final int[] welcomeEmotes = {2007, 1002, 4010};
|
||||||
public String welcomeMessage = "Welcome to a Grasscutter server.";
|
public final String welcomeMessage = "Welcome to a Grasscutter server.";
|
||||||
public JoinOptions.Mail welcomeMail = new JoinOptions.Mail();
|
public final JoinOptions.Mail welcomeMail = new JoinOptions.Mail();
|
||||||
|
|
||||||
public static class Mail {
|
public static class Mail {
|
||||||
public String title = "Welcome to Grasscutter!";
|
public final String title = "Welcome to Grasscutter!";
|
||||||
public String content = """
|
public final String content = """
|
||||||
Hi there!\r
|
Hi there!\r
|
||||||
First of all, welcome to Grasscutter. If you have any issues, please let us know so that Lawnmower can help you! \r
|
First of all, welcome to Grasscutter. If you have any issues, please let us know so that Lawnmower can help you! \r
|
||||||
\r
|
\r
|
||||||
Check out our:\r
|
Check out our:\r
|
||||||
<type="browser" text="Discord" href="https://discord.gg/T5vZU6UyeG"/>
|
<type="browser" text="Discord" href="https://discord.gg/T5vZU6UyeG"/>
|
||||||
""";
|
""";
|
||||||
public String sender = "Lawnmower";
|
public final String sender = "Lawnmower";
|
||||||
public emu.grasscutter.game.mail.Mail.MailItem[] items = {
|
public final emu.grasscutter.game.mail.Mail.MailItem[] items = {
|
||||||
new emu.grasscutter.game.mail.Mail.MailItem(13509, 1, 1),
|
new emu.grasscutter.game.mail.Mail.MailItem(13509, 1, 1),
|
||||||
new emu.grasscutter.game.mail.Mail.MailItem(201, 99999, 1)
|
new emu.grasscutter.game.mail.Mail.MailItem(201, 99999, 1)
|
||||||
};
|
};
|
||||||
@ -382,18 +382,18 @@ public class ConfigContainer {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public static class ConsoleAccount {
|
public static class ConsoleAccount {
|
||||||
public int avatarId = 10000007;
|
public final int avatarId = 10000007;
|
||||||
public int nameCardId = 210001;
|
public final int nameCardId = 210001;
|
||||||
public int adventureRank = 1;
|
public final int adventureRank = 1;
|
||||||
public int worldLevel = 0;
|
public final int worldLevel = 0;
|
||||||
|
|
||||||
public String nickName = "Server";
|
public final String nickName = "Server";
|
||||||
public String signature = "Welcome to Grasscutter!";
|
public final String signature = "Welcome to Grasscutter!";
|
||||||
}
|
}
|
||||||
|
|
||||||
public static class Files {
|
public static class Files {
|
||||||
public String indexFile = "./index.html";
|
public final String indexFile = "./index.html";
|
||||||
public String errorFile = "./404.html";
|
public final String errorFile = "./404.html";
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Objects. */
|
/* Objects. */
|
||||||
|
@ -4,9 +4,9 @@ import emu.grasscutter.data.binout.AbilityModifier.AbilityModifierAction;
|
|||||||
import java.util.*;
|
import java.util.*;
|
||||||
|
|
||||||
public class AbilityModifierEntry {
|
public class AbilityModifierEntry {
|
||||||
public List<AbilityModifierAction> onModifierAdded;
|
public final List<AbilityModifierAction> onModifierAdded;
|
||||||
public List<AbilityModifierAction> onThinkInterval;
|
public final List<AbilityModifierAction> onThinkInterval;
|
||||||
public List<AbilityModifierAction> onRemoved;
|
public final List<AbilityModifierAction> onRemoved;
|
||||||
private final String name; // Custom value
|
private final String name; // Custom value
|
||||||
|
|
||||||
public AbilityModifierEntry(String name) {
|
public AbilityModifierEntry(String name) {
|
||||||
|
@ -92,7 +92,7 @@ public class DynamicFloat {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public static class StackOp {
|
public static class StackOp {
|
||||||
public Op op;
|
public final Op op;
|
||||||
|
|
||||||
public float fValue;
|
public float fValue;
|
||||||
public String sValue;
|
public String sValue;
|
||||||
|
@ -9,11 +9,11 @@ import emu.grasscutter.net.proto.TowerLevelEndNotifyOuterClass.TowerLevelEndNoti
|
|||||||
import emu.grasscutter.net.proto.TowerLevelEndNotifyOuterClass.TowerLevelEndNotify.ContinueStateType;
|
import emu.grasscutter.net.proto.TowerLevelEndNotifyOuterClass.TowerLevelEndNotify.ContinueStateType;
|
||||||
|
|
||||||
public class TowerResult extends BaseDungeonResult {
|
public class TowerResult extends BaseDungeonResult {
|
||||||
WorldChallenge challenge;
|
final WorldChallenge challenge;
|
||||||
boolean canJump;
|
final boolean canJump;
|
||||||
boolean hasNextLevel;
|
final boolean hasNextLevel;
|
||||||
int nextFloorId;
|
final int nextFloorId;
|
||||||
int currentStars;
|
final int currentStars;
|
||||||
|
|
||||||
public TowerResult(
|
public TowerResult(
|
||||||
DungeonData dungeonData,
|
DungeonData dungeonData,
|
||||||
|
@ -6,7 +6,7 @@ import emu.grasscutter.net.proto.DungeonSettleNotifyOuterClass;
|
|||||||
import emu.grasscutter.net.proto.TrialAvatarFirstPassDungeonNotifyOuterClass.TrialAvatarFirstPassDungeonNotify;
|
import emu.grasscutter.net.proto.TrialAvatarFirstPassDungeonNotifyOuterClass.TrialAvatarFirstPassDungeonNotify;
|
||||||
|
|
||||||
public class TrialAvatarDungeonResult extends BaseDungeonResult {
|
public class TrialAvatarDungeonResult extends BaseDungeonResult {
|
||||||
int trialCharacterIndexId;
|
final int trialCharacterIndexId;
|
||||||
|
|
||||||
public TrialAvatarDungeonResult(
|
public TrialAvatarDungeonResult(
|
||||||
DungeonData dungeonData, DungeonEndStats dungeonStats, int trialCharacterIndexId) {
|
DungeonData dungeonData, DungeonEndStats dungeonStats, int trialCharacterIndexId) {
|
||||||
|
@ -17,14 +17,14 @@ import org.bson.types.ObjectId;
|
|||||||
public final class Mail {
|
public final class Mail {
|
||||||
@Id private ObjectId id;
|
@Id private ObjectId id;
|
||||||
@Indexed private int ownerUid;
|
@Indexed private int ownerUid;
|
||||||
public MailContent mailContent;
|
public final MailContent mailContent;
|
||||||
public List<MailItem> itemList;
|
public final List<MailItem> itemList;
|
||||||
public long sendTime;
|
public final long sendTime;
|
||||||
public long expireTime;
|
public long expireTime;
|
||||||
public int importance;
|
public int importance;
|
||||||
public boolean isRead;
|
public boolean isRead;
|
||||||
public boolean isAttachmentGot;
|
public boolean isAttachmentGot;
|
||||||
public int stateValue;
|
public final int stateValue;
|
||||||
@Transient private boolean shouldDelete;
|
@Transient private boolean shouldDelete;
|
||||||
|
|
||||||
public Mail() {
|
public Mail() {
|
||||||
@ -122,9 +122,9 @@ public final class Mail {
|
|||||||
|
|
||||||
@Entity
|
@Entity
|
||||||
public static class MailItem {
|
public static class MailItem {
|
||||||
public int itemId;
|
public final int itemId;
|
||||||
public int itemCount;
|
public final int itemCount;
|
||||||
public int itemLevel;
|
public final int itemLevel;
|
||||||
|
|
||||||
public MailItem() {
|
public MailItem() {
|
||||||
this.itemId = 11101;
|
this.itemId = 11101;
|
||||||
|
@ -6,8 +6,8 @@ import emu.grasscutter.game.props.ItemUseTarget;
|
|||||||
|
|
||||||
public class UseItemParams {
|
public class UseItemParams {
|
||||||
// Don't want to change 40 method signatures when this gets extended!
|
// Don't want to change 40 method signatures when this gets extended!
|
||||||
public Player player;
|
public final Player player;
|
||||||
public ItemUseTarget itemUseTarget;
|
public final ItemUseTarget itemUseTarget;
|
||||||
public Avatar targetAvatar = null;
|
public Avatar targetAvatar = null;
|
||||||
public int count = 1;
|
public int count = 1;
|
||||||
public int optionId = 0;
|
public int optionId = 0;
|
||||||
|
@ -7,7 +7,7 @@ import java.io.*;
|
|||||||
public class BasePacket {
|
public class BasePacket {
|
||||||
private static final int const1 = 17767; // 0x4567
|
private static final int const1 = 17767; // 0x4567
|
||||||
private static final int const2 = -30293; // 0x89ab
|
private static final int const2 = -30293; // 0x89ab
|
||||||
public boolean shouldEncrypt = true;
|
public final boolean shouldEncrypt = true;
|
||||||
private int opcode;
|
private int opcode;
|
||||||
private boolean shouldBuildHeader = false;
|
private boolean shouldBuildHeader = false;
|
||||||
private byte[] header;
|
private byte[] header;
|
||||||
|
@ -20,7 +20,7 @@ public final class PluginManager {
|
|||||||
* A 'breaking change' is something which changes the existing logic of the API.
|
* A 'breaking change' is something which changes the existing logic of the API.
|
||||||
*/
|
*/
|
||||||
@SuppressWarnings("FieldCanBeLocal")
|
@SuppressWarnings("FieldCanBeLocal")
|
||||||
public static int API_VERSION = 2;
|
public static final int API_VERSION = 2;
|
||||||
|
|
||||||
/* All loaded plugins. */
|
/* All loaded plugins. */
|
||||||
private final Map<String, Plugin> plugins = new LinkedHashMap<>();
|
private final Map<String, Plugin> plugins = new LinkedHashMap<>();
|
||||||
|
@ -3,7 +3,7 @@ package emu.grasscutter.server.http.objects;
|
|||||||
public class ComboTokenResJson {
|
public class ComboTokenResJson {
|
||||||
public String message;
|
public String message;
|
||||||
public int retcode;
|
public int retcode;
|
||||||
public LoginData data = new LoginData();
|
public final LoginData data = new LoginData();
|
||||||
|
|
||||||
public static class LoginData {
|
public static class LoginData {
|
||||||
public int account_type = 1;
|
public int account_type = 1;
|
||||||
|
@ -3,10 +3,10 @@ package emu.grasscutter.server.http.objects;
|
|||||||
public class LoginResultJson {
|
public class LoginResultJson {
|
||||||
public String message;
|
public String message;
|
||||||
public int retcode;
|
public int retcode;
|
||||||
public VerifyData data = new VerifyData();
|
public final VerifyData data = new VerifyData();
|
||||||
|
|
||||||
public static class VerifyData {
|
public static class VerifyData {
|
||||||
public VerifyAccountData account = new VerifyAccountData();
|
public final VerifyAccountData account = new VerifyAccountData();
|
||||||
public boolean device_grant_required = false;
|
public boolean device_grant_required = false;
|
||||||
public String realname_operation = "NONE";
|
public String realname_operation = "NONE";
|
||||||
public boolean realperson_required = false;
|
public boolean realperson_required = false;
|
||||||
|
@ -14,7 +14,7 @@ import org.quartz.*;
|
|||||||
triggerName = "AnnouncementTrigger")
|
triggerName = "AnnouncementTrigger")
|
||||||
public final class AnnouncementTask extends TaskHandler {
|
public final class AnnouncementTask extends TaskHandler {
|
||||||
|
|
||||||
static Map<Integer, Integer> intervalMap = new ConcurrentHashMap<>();
|
static final Map<Integer, Integer> intervalMap = new ConcurrentHashMap<>();
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void onEnable() {
|
public void onEnable() {
|
||||||
|
@ -19,12 +19,12 @@ public final class Crypto {
|
|||||||
public static byte[] DISPATCH_SEED;
|
public static byte[] DISPATCH_SEED;
|
||||||
|
|
||||||
public static byte[] ENCRYPT_KEY;
|
public static byte[] ENCRYPT_KEY;
|
||||||
public static long ENCRYPT_SEED = Long.parseUnsignedLong("11468049314633205968");
|
public static final long ENCRYPT_SEED = Long.parseUnsignedLong("11468049314633205968");
|
||||||
public static byte[] ENCRYPT_SEED_BUFFER = new byte[0];
|
public static byte[] ENCRYPT_SEED_BUFFER = new byte[0];
|
||||||
|
|
||||||
public static PrivateKey CUR_SIGNING_KEY;
|
public static PrivateKey CUR_SIGNING_KEY;
|
||||||
|
|
||||||
public static Map<Integer, PublicKey> EncryptionKeys = new HashMap<>();
|
public static final Map<Integer, PublicKey> EncryptionKeys = new HashMap<>();
|
||||||
|
|
||||||
public static void loadKeys() {
|
public static void loadKeys() {
|
||||||
DISPATCH_KEY = FileUtils.readResource("/keys/dispatchKey.bin");
|
DISPATCH_KEY = FileUtils.readResource("/keys/dispatchKey.bin");
|
||||||
|
@ -4,7 +4,8 @@ import java.util.*;
|
|||||||
|
|
||||||
public class KahnsSort {
|
public class KahnsSort {
|
||||||
public static class Node {
|
public static class Node {
|
||||||
int source, dest; // Dest is a value, and source too
|
final int source;
|
||||||
|
final int dest; // Dest is a value, and source too
|
||||||
|
|
||||||
public Node(int source, int dest) {
|
public Node(int source, int dest) {
|
||||||
this.source = source;
|
this.source = source;
|
||||||
@ -13,10 +14,10 @@ public class KahnsSort {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public static class Graph {
|
public static class Graph {
|
||||||
Map<Integer, List<Integer>> mainList;
|
final Map<Integer, List<Integer>> mainList;
|
||||||
Map<Integer, Integer> degreeList;
|
final Map<Integer, Integer> degreeList;
|
||||||
|
|
||||||
List<Integer> nodeList;
|
final List<Integer> nodeList;
|
||||||
|
|
||||||
public Graph(List<Node> nodes, List<Integer> nodeList) {
|
public Graph(List<Node> nodes, List<Integer> nodeList) {
|
||||||
mainList = new HashMap<>();
|
mainList = new HashMap<>();
|
||||||
|
Loading…
Reference in New Issue
Block a user