KajetansMod.java 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299
  1. package me.km;
  2. import me.kcm.command.ModServerCommandManager;
  3. import me.km.api.Module;
  4. import me.km.api.SimpleConfig;
  5. import me.km.blockprotections.BlockProtectionBank;
  6. import me.km.chatmanager.ChatManager;
  7. import me.km.data.DataManager;
  8. import me.km.databank.DataBank;
  9. import me.km.dimensions.ModWorldGeneration;
  10. import me.km.dimensions.WorldData;
  11. import me.km.jobsystem.JobAPI;
  12. import me.km.networking.ModPacketHandler;
  13. import me.km.permissions.PermissionManager;
  14. import me.km.playerbank.PlayerManager;
  15. import me.km.plots.ProtectionBank;
  16. import me.km.scheduler.SnuviScheduler;
  17. import me.km.scoreboard.ScoreboardAPI;
  18. import me.km.skills.SkillManager;
  19. import me.km.snuviscript.ScriptModule;
  20. import me.km.snuviscript.ScriptBank;
  21. import net.minecraft.server.MinecraftServer;
  22. import net.minecraft.util.text.TextFormatting;
  23. import net.minecraftforge.fluids.FluidRegistry;
  24. import net.minecraftforge.fml.common.Mod;
  25. import net.minecraftforge.fml.common.SidedProxy;
  26. import net.minecraftforge.fml.common.event.FMLInitializationEvent;
  27. import net.minecraftforge.fml.common.event.FMLPreInitializationEvent;
  28. import net.minecraftforge.fml.common.event.FMLServerStartingEvent;
  29. import net.minecraftforge.fml.common.event.FMLServerAboutToStartEvent;
  30. import net.minecraftforge.fml.common.event.FMLServerStoppingEvent;
  31. import net.minecraftforge.fml.common.registry.GameRegistry;
  32. import net.minecraftforge.fml.relauncher.Side;
  33. import net.minecraftforge.fml.relauncher.SideOnly;
  34. @Mod(modid = KajetansMod.MODID, version = KajetansMod.VERSION, name = KajetansMod.NAME)
  35. public class KajetansMod
  36. {
  37. @SideOnly(Side.SERVER)
  38. public static SimpleConfig conf;
  39. public static Module error;
  40. public static DataBank databank;
  41. @SideOnly(Side.SERVER)
  42. public static SnuviScheduler scheduler;
  43. public static PlayerManager playerbank;
  44. public static Module generalCommands;
  45. public static ChatManager chatManager;
  46. public static Module afkManager;
  47. public static Module plots;
  48. public static Module blocks;
  49. public static Module datatools;
  50. public static WorldData worldManager;
  51. public static Module environment;
  52. public static ScriptModule scripts;
  53. public static JobAPI jobs;
  54. public static DataManager data;
  55. public static SkillManager skills;
  56. public static Module scrolls;
  57. public static ScoreboardAPI scoreboard;
  58. @SideOnly(Side.SERVER)
  59. public static PermissionManager perms;
  60. @SidedProxy(serverSide = "me.km.CommonProxy", clientSide = "me.km.ClientProxy")
  61. public static CommonProxy proxy;
  62. public static final String MODID = "km";
  63. public static final String NAME = "Kajetans Mod";
  64. public static final String VERSION = "0.0.31";
  65. @Mod.Instance(MODID)
  66. public static KajetansMod instance;
  67. public static MinecraftServer server;
  68. public static boolean debugMode;
  69. public static boolean singlePlayer;
  70. static
  71. {
  72. FluidRegistry.enableUniversalBucket();
  73. }
  74. public static int counter = 0;
  75. @Mod.EventHandler
  76. public void preInit(FMLPreInitializationEvent e)
  77. {
  78. System.out.println(NAME + " is loading!");
  79. ModPacketHandler.init();
  80. GameRegistry.registerWorldGenerator(new ModWorldGeneration(), 3);
  81. DamageUtils.init();
  82. /*net.minecraftforge.common.MinecraftForge.EVENT_BUS.register(new Object()
  83. {
  84. @net.minecraftforge.fml.common.eventhandler.SubscribeEvent
  85. public void wusi2(net.minecraftforge.event.ServerChatEvent e)
  86. {
  87. try
  88. {
  89. EntityPlayerMP p = e.getPlayer();
  90. EntityHuman human = new EntityHuman(p.world);
  91. human.setPosition(p.posX, p.posY, p.posZ);
  92. p.world.spawnEntity(human);
  93. human.setSkinName("e41b53353c7446e9a6c5dafc6334a477");
  94. }
  95. catch(Exception ex)
  96. {
  97. ex.printStackTrace();
  98. }
  99. }
  100. });*/
  101. }
  102. @Mod.EventHandler
  103. public void init(FMLInitializationEvent e)
  104. {
  105. proxy.init();
  106. }
  107. @Mod.EventHandler
  108. public void beforeStart(FMLServerAboutToStartEvent e)
  109. {
  110. // takes place after setting of playerlist but before world load
  111. server = e.getServer();
  112. }
  113. @Mod.EventHandler
  114. public void serverStarting(FMLServerStartingEvent e)
  115. {
  116. singlePlayer = e.getServer().isSinglePlayer();
  117. if(singlePlayer)
  118. {
  119. return;
  120. }
  121. // configuration and error-dummy
  122. error = new Module("ERROR", "ERROR", TextFormatting.RED);
  123. conf = new SimpleConfig(error, "", "config", true);
  124. debugMode = conf.getBoolean("debug", false);
  125. if(debugMode)
  126. {
  127. System.out.println("------------------------------------------------");
  128. System.out.println("Starting server in debug mode");
  129. System.out.println("------------------------------------------------");
  130. }
  131. else
  132. {
  133. System.out.println("------------------------------------------------");
  134. System.out.println("Starting server without debug mode");
  135. System.out.println("------------------------------------------------");
  136. }
  137. // Datenbankverbindung
  138. databank = new DataBank("DataBank", "DataBank", TextFormatting.RED, conf.getString("user", "root"), conf.getString("password", ""));
  139. if(!databank.openDataBankConnection())
  140. {
  141. System.out.println("------------------------------------------------");
  142. System.out.println("Starting server with dummy databank");
  143. System.out.println("------------------------------------------------");
  144. }
  145. // Scheduler
  146. scheduler = new SnuviScheduler("Scheduler", "Scheduler", TextFormatting.GREEN);
  147. scheduler.registerEvents("me.km.scheduler");
  148. databank.startReconnecting(scheduler);
  149. // Spielerdatenbank
  150. playerbank = new PlayerManager("PlayerBank", "PlayerBank", TextFormatting.RED, databank);
  151. // databank is initialized in JobAPI in order to have a reference
  152. playerbank.registerEvents("me.km.playerbank");
  153. // Grundlegende Commands
  154. generalCommands = new Module("GeneralCommands", "Commands", TextFormatting.GOLD);
  155. generalCommands.registerCommands(e, "me.km.commands");
  156. // Chatmanager
  157. chatManager = new ChatManager("ChatManager", "Chat", TextFormatting.BLUE);
  158. chatManager.registerCommands(e, "me.km.chatmanager");
  159. chatManager.registerEvents("me.km.chatmanager");
  160. // AFK-Manager
  161. afkManager = new Module("AfkManager", "AFK", TextFormatting.GRAY);
  162. afkManager.registerCommands(e, "me.km.afk");
  163. afkManager.registerEvents("me.km.afk");
  164. // Plot-System
  165. plots = new Module("Plots", "Plots", TextFormatting.GOLD);
  166. plots.setDataBank(new ProtectionBank(plots, databank));
  167. plots.registerCommands(e, "me.km.plots");
  168. plots.registerEvents("me.km.plots");
  169. // Chests- und Co-Protections
  170. blocks = new Module("BlockProtections", "Blocks", TextFormatting.BLUE);
  171. blocks.setDataBank(new BlockProtectionBank(blocks, databank));
  172. blocks.registerCommands(e, "me.km.blockprotections");
  173. blocks.registerEvents("me.km.blockprotections");
  174. // DataTools
  175. datatools = new Module("DataTools", "DataTools", TextFormatting.GRAY);
  176. datatools.registerCommands(e, "me.km.datatools");
  177. datatools.registerEvents("me.km.datatools");
  178. // Worldmanager
  179. worldManager = new WorldData("WorldManager", "Worlds", TextFormatting.RED);
  180. worldManager.registerCommands(e, "me.km.dimensions");
  181. worldManager.registerEvents("me.km.dimensions");
  182. // Scriptsystem
  183. scripts = new ScriptModule("Scripts", "Scripts", TextFormatting.LIGHT_PURPLE);
  184. scripts.setDataBank(new ScriptBank(scripts, databank));
  185. scripts.registerCommands(e, "me.km.snuviscript");
  186. scripts.registerEvents("me.km.snuviscript");
  187. // Jobsystem
  188. jobs = new JobAPI("JobSystem", "Jobs", TextFormatting.GREEN);
  189. // databank is initialized in JobAPI in order to have a reference
  190. jobs.registerCommands(e, "me.km.jobsystem");
  191. jobs.registerEvents("me.km.jobsystem");
  192. // DataManager
  193. data = new DataManager("DataManager", "Data", TextFormatting.GRAY);
  194. data.registerEvents("me.km.data");
  195. // Skills
  196. skills = new SkillManager("SkillSystem", "Skills", TextFormatting.BLUE);
  197. skills.registerCommands(e, "me.km.skills");
  198. skills.registerEvents("me.km.skills");
  199. skills.registerEvents("me.km.effects.passive");
  200. // Scrollsystem
  201. scrolls = new Module("Scrolls", "Scrolls", TextFormatting.BLUE);
  202. scrolls.registerCommands(e, "me.km.scrolls");
  203. // Environment
  204. environment = new Module("Environment", "Environment", TextFormatting.GREEN);
  205. environment.registerCommands(e, "me.km.environment");
  206. environment.registerEvents("me.km.environment");
  207. // Scoreboard
  208. scoreboard = new ScoreboardAPI("Scoreboard", "Scoreboard", TextFormatting.GREEN);
  209. // Permissions
  210. perms = new PermissionManager("Permissions", "Perms", TextFormatting.DARK_PURPLE);
  211. perms.registerEvents("me.km.permissions");
  212. setPermissionManager();
  213. scripts.startScript("startscript");
  214. }
  215. @SideOnly(Side.SERVER)
  216. private void setPermissionManager() // dependency workaround
  217. {
  218. if(server.commandManager instanceof ModServerCommandManager)
  219. {
  220. ((ModServerCommandManager) server.commandManager).setPermissionManager(perms);
  221. }
  222. }
  223. @Mod.EventHandler
  224. public void onServerStop(FMLServerStoppingEvent e)
  225. {
  226. if(singlePlayer)
  227. {
  228. return;
  229. }
  230. scripts.startScript("endscript");
  231. databank.closeDataBankConnection();
  232. }
  233. /*public static void main(String[] args)
  234. {
  235. // Erstellt alle Enums für die aktiven Effekte
  236. PackageHelper.getClassesInIde("me.km.effects.active").stream()
  237. .forEach(s ->
  238. {
  239. StringBuilder en = new StringBuilder(s.substring(0, s.length() - 6));
  240. int i = 1;
  241. while(i < en.length())
  242. {
  243. if(Character.isUpperCase(en.charAt(i)))
  244. {
  245. en.insert(i, "_");
  246. i++;
  247. }
  248. i++;
  249. }
  250. String wusi = " (true, " + s + "),";
  251. wusi = en.toString().toUpperCase() + wusi.substring(en.length());
  252. System.out.println(wusi);
  253. });
  254. }*/
  255. }