Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

General minigame overhaul #134

Draft
wants to merge 112 commits into
base: development
Choose a base branch
from
Draft
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
112 commits
Select commit Hold shift + click to select a range
19b952c
feat: Wizard Kit updated
Plajer Sep 1, 2022
f06a59b
Bump pom.xml from 4.6.1-dev67 to 4.6.1-dev68
github-actions[bot] Sep 1, 2022
ab63efa
feat: Medic Kit update
Plajer Sep 1, 2022
6acf8fe
feat: Include power level in golem/wolf custom name
Plajer Sep 1, 2022
a92eb32
feat: Wizard kit cooldowns API change
Plajer Sep 5, 2022
f41c7a1
feat: Tornado kit (working on it)
Plajer Sep 5, 2022
a4daf99
feat: Kit actionbar abilities draft
Plajer Sep 5, 2022
81e99bd
Merge remote-tracking branch 'github/development' into development
Plajer Sep 5, 2022
243ed15
Merge remote-tracking branch 'github/development' into development
Plajer Sep 5, 2022
5c497cd
revert: Copyright modified
Plajer Sep 5, 2022
7f41d01
fix: 1.8 fixes and variables naming
Plajer Sep 5, 2022
439ed69
fix: 1.8 health attributes
Plajer Sep 5, 2022
26a4d10
fix: 1.8 material utils
Plajer Sep 5, 2022
8641ca3
sadsadasdas
Plajer Sep 5, 2022
6cea17a
feat: Improve Tornado kit
Plajer Sep 6, 2022
678b410
Merge remote-tracking branch 'origin/development' into development
Plajer Sep 26, 2022
0200c3d
feat: Final flight ability for Tornado kit
Plajer Sep 26, 2022
8eed808
Merge remote-tracking branch 'origin/development' into development
Plajer Nov 18, 2022
07b719f
fix: Adjust MessageInitializer
Plajer Nov 18, 2022
f54875c
Merge branch 'development' into development
Tigerpanzer02 Jul 31, 2023
fbb90d3
Bump version from 4.6.1-SNAPSHOT79 to 4.6.1-SNAPSHOT80
Jul 31, 2023
db0e29a
Updated MinigamesBox
Tigerpanzer02 Jul 31, 2023
327cf52
Merge remote-tracking branch 'Plajer/development' into development-pl…
Tigerpanzer02 Jul 31, 2023
d6efa58
Bump version from 4.6.1-SNAPSHOT80 to 4.6.1-SNAPSHOT81
Jul 31, 2023
34b9eb1
Merge remote-tracking branch 'github/development' into development
Plajer Aug 1, 2023
a2609b9
fix: Compilation fix for non UTF-8 setups
Plajer Aug 1, 2023
f175604
fix: Ensure compilation compatibility with Java 8
Plajer Aug 1, 2023
d06ef50
feat(QoL): wizard kit QoL updates
Plajer Aug 1, 2023
359933e
feat: Orbs recode proposal
Plajer Aug 1, 2023
853b51d
feat: Improve sounds and QoL for new kits
Plajer Aug 1, 2023
2af6507
feat: Update messages readability
Plajer Aug 1, 2023
eac7af4
feat: Dropped flesh should always be given to the killer
Plajer Aug 1, 2023
0e29908
feat: More aggressive glowing status
Plajer Aug 1, 2023
a755342
Bump version from 4.6.1-SNAPSHOT81 to 4.6.1-SNAPSHOT82
Aug 1, 2023
ea6e7f1
refactor: Use SoundHelper
Plajer Aug 1, 2023
99db1f6
refactor: Code complexity reduced
Plajer Aug 1, 2023
8c50927
refactor: Code complexity reduced
Plajer Aug 1, 2023
baf93d8
Merge remote-tracking branch 'github/development' into development
Plajer Aug 1, 2023
09c26f9
Bump version from 4.6.1-SNAPSHOT82 to 4.6.1-SNAPSHOT83
Aug 1, 2023
651b38c
feat: Implement new cleaner kit
Plajer Aug 2, 2023
e963ae9
feat: Ability unlocked message
Plajer Aug 2, 2023
23ccafc
feat: Ability/passive power increased message
Plajer Aug 2, 2023
f7579d7
feat: Improve hitbox for wizard kit
Plajer Aug 2, 2023
b479c65
fix: Cleaner kit threw stack overflow
Plajer Aug 2, 2023
e7223bc
Merge remote-tracking branch 'github/development' into development
Plajer Aug 2, 2023
bbec6f6
Bump version from 4.6.1-SNAPSHOT83 to 4.6.1-SNAPSHOT84
Aug 2, 2023
0193978
feat: Enemies killed by pets give kills to owner
Plajer Aug 4, 2023
dc41920
feat: Implement entities riding via ProtocolLib
Plajer Aug 4, 2023
c54c4c8
fix: Rideable entities steering logic
Plajer Aug 4, 2023
d00fb78
fix: Drops filter for enemies without drop item
Plajer Aug 4, 2023
ce2addf
Merge remote-tracking branch 'github/development' into development
Plajer Aug 4, 2023
56b45e9
Bump version from 4.6.1-SNAPSHOT84 to 4.6.1-SNAPSHOT85
Aug 4, 2023
7b3c520
fix: Poplust wrong cooldown given
Plajer Aug 4, 2023
b84225e
fix: Doors restoring logic
Plajer Aug 4, 2023
c6b6491
Merge remote-tracking branch 'github/development' into development
Plajer Aug 4, 2023
34a42fb
Bump version from 4.6.1-SNAPSHOT85 to 4.6.1-SNAPSHOT86
Aug 4, 2023
bd789eb
fix: Drops logic
Plajer Aug 4, 2023
4bd7765
feat: Wave locked shop items feature
Plajer Aug 4, 2023
78b1aa7
Merge remote-tracking branch 'github/development' into development
Plajer Aug 4, 2023
f1f5e69
Bump version from 4.6.1-SNAPSHOT86 to 4.6.1-SNAPSHOT87
Aug 4, 2023
e5376b9
feat: Orb statistics placeholder
Plajer Aug 4, 2023
c4d8ca0
feat: Redesign terminator kit
Plajer Aug 4, 2023
89dae76
Merge remote-tracking branch 'github/development' into development
Plajer Aug 4, 2023
dab8dfa
Bump version from 4.6.1-SNAPSHOT87 to 4.6.1-SNAPSHOT88
Aug 4, 2023
a9fbf41
feat: Implement builder kit
Plajer Aug 11, 2023
085a4af
Merge remote-tracking branch 'github/development' into development
Plajer Aug 11, 2023
125cf94
Bump version from 4.6.1-SNAPSHOT88 to 4.6.1-SNAPSHOT89
Aug 11, 2023
437d9e5
feat: Create Pets Friend kit, modify entity upgrades
Plajer Aug 28, 2023
23cd523
Merge remote-tracking branch 'github/development' into development
Plajer Aug 28, 2023
95b4b66
Bump version from 4.6.1-SNAPSHOT89 to 4.6.1-SNAPSHOT90
Aug 28, 2023
258d0d6
fix: Fix on game leave golems and wolves removal
Plajer Aug 28, 2023
13a4725
fix: Dangling javadoc element
Plajer Aug 28, 2023
93a6549
refactor: Minimum working version is now 1.12.2
Plajer Aug 28, 2023
f62c71f
refactor: Minimum working version is now 1.12.2
Plajer Aug 28, 2023
4920d9d
fix: Door destroy order matters
Plajer Aug 28, 2023
66dc6c6
feat(QoL): Builder fences break animation
Plajer Aug 28, 2023
1762d60
fix: Development fixes
Plajer Aug 28, 2023
d20d00d
fix: Logic fix
Plajer Aug 28, 2023
ae670fd
feat(QoL): Shop sounds
Plajer Aug 28, 2023
c070fbf
feat(QoL): Play global villager damage sound
Plajer Aug 28, 2023
59bbd6c
feat: Revamp door breaking logic
Plajer Aug 28, 2023
0f8be20
feat: Revamp door breaking logic
Plajer Aug 28, 2023
ea67415
feat: Door restore logic improved
Plajer Aug 29, 2023
443a920
feat: Entities health bars improved
Plajer Aug 29, 2023
fc6dac3
feat: Nerf baby zombie speed a bit
Plajer Aug 29, 2023
2710d91
feat: Assists system implemented
Plajer Aug 30, 2023
820a236
Merge remote-tracking branch 'github/development' into development
Plajer Aug 30, 2023
37030da
feat: Buff medic with villagers healing passive
Plajer Aug 30, 2023
34a8e27
fix: Door logc fix, remove debug
Plajer Aug 30, 2023
0ba5abc
feat: Change wave refresh logic
Plajer Aug 30, 2023
a1ae533
feat: Shot bow kit recreated
Plajer Aug 30, 2023
2c5a37c
fix: Apply normal speed for unprovoked golems
Plajer Aug 31, 2023
694b438
feat: Natural regeneration for pets
Plajer Aug 31, 2023
f54d74d
fix: Players can steal pets by upgrading them
Plajer Aug 31, 2023
1885731
fix: Pet spawn limits fixed
Plajer Aug 31, 2023
ce19560
fix: Small nerfs for kits
Plajer Aug 31, 2023
188023d
fix: Remove pets from arena properly
Plajer Aug 31, 2023
91b011c
feat: Disable AI after game end
Plajer Sep 1, 2023
44ad92c
fix: Nerf tnt explosion and friendly fire
Plajer Sep 1, 2023
c16b67e
fix: Shotbow fixes
Plajer Sep 1, 2023
8a4cc49
fix: No zombies to clean threw exception
Plajer Sep 1, 2023
92b4472
fix: Better villager hurt global sound
Plajer Sep 1, 2023
93d3ea7
fix: Vehicle steer fix
Plajer Sep 1, 2023
a60dfec
feat: Trying to smoothen orbs given in later wave
Plajer Sep 2, 2023
c8ad2d3
fix: Upgrade minigame core
Plajer Sep 2, 2023
2fc1611
fix: Do not give flesh to spectators
Plajer Sep 2, 2023
33744db
Bump version from 5.0.1-SNAPSHOT3 to 5.0.1-SNAPSHOT4
Mar 8, 2024
351ffc8
feat: Village Defense Gold
Plajer Apr 20, 2024
fcc9525
Merge remote-tracking branch 'origin/development' into development
Plajer Apr 20, 2024
1e86696
Bump version from 5.0.1-SNAPSHOT4 to 5.0.1-SNAPSHOT5
Apr 20, 2024
8964d93
feat: VDUserManager, README update
Plajer Apr 20, 2024
ae9aba5
Bump version from 5.0.1-SNAPSHOT5 to 5.0.1-SNAPSHOT6
Apr 20, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
80 changes: 30 additions & 50 deletions .github/README.md
Original file line number Diff line number Diff line change
@@ -1,50 +1,30 @@
![](https://images.plugily.xyz/banner/display.php?id=VillageDefense)

# Village Defense [![Maven Repository](https://maven.plugily.xyz/api/badge/latest/releases/plugily/projects/villagedefense?color=40c14a&name=Maven&prefix=v)](https://maven.plugily.xyz/#/releases/plugily/projects/villagedefense) [![JavaDoc Repository](https://maven.plugily.xyz/api/badge/latest/releases/plugily/projects/villagedefense?color=40c14a&name=JavaDoc&prefix=v)](https://maven.plugily.xyz/javadoc/releases/plugily/projects/villagedefense/latest) [![Maintainability Rating](https://sonarcloud.io/api/project_badges/measure?project=Plugily-Projects_Village_Defense&metric=sqale_rating)](https://sonarcloud.io/summary/overall?id=Plugily-Projects_Village_Defense) [![Discord](https://img.shields.io/discord/345628548716822530.svg?color=7289DA&style=for-the-badge&logo=discord)](https://discord.plugily.xyz) [![Patreon]( https://img.shields.io/badge/Patreon-F96854?style=for-the-badge&logo=patreon&logoColor=white)](https://patreon.com/plugily)

Village Defense is a Minecraft minigame designed for small and big servers. This minigame is unique and very
configurable, 100% free and open source!

The goal is to protect Villagers from hordes of undead Creatures. However, the game isn't that easy. There are more and
more zombies every wave and more types of them come in higher waves. There is no wave limit so try to survive as long as
you can!

Have fun using it! Leave a good rating if you really like it.

## Want to contribute in this project?

[**🉑 Code Contributions**](https://github.com/Plugily-Projects/Village_Defense/blob/master/.github/CONTRIBUTING.md)
[**💣 Issues Reporting (Discord)**](https://discordapp.com/invite/UXzUdTP)
[**❤ Make Donation**](https://www.paypal.me/plugilyprojects)

# Credits

## Open Source Libraries

| Library | Author | License |
|------------------------------------------------------------------|--------------------------------------------------------|------------------------------------------------------------------------------------|
| [MiniGamesBox](https://github.com/Plugily-Projects/MiniGamesBox) | [Plugily Projets](https://github.com/Plugily-Projects) | [GPLv3](https://github.com/Plugily-Projects/MiniGamesBox/blob/master/LICENSE.md) |
| [ScoreboardLib](https://github.com/TigerHix/ScoreboardLib/) | [TigerHix](https://github.com/TigerHix) | [LGPLv3](https://github.com/TigerHix/ScoreboardLib/blob/master/LICENSE) |
| [HikariCP](https://github.com/brettwooldridge/HikariCP) | [brettwooldridge](https://github.com/brettwooldridge) | [Apache License 2.0](https://github.com/brettwooldridge/HikariCP/blob/dev/LICENSE) |
| [bStats](https://github.com/Bastian/bStats-Metrics) | [Bastian](https://github.com/Bastian) | [LGPLv3](https://github.com/Bastian/bStats-Metrics/blob/master/LICENSE) |
| [Commons Box](https://github.com/Plajer/Commons-Box) | [Plajer](https://github.com/Plajer) | [GPLv3](https://github.com/Plajer/Commons-Box/blob/master/LICENSE.md) |

## Open Source Licenses

#### JetBrains

<img src="https://www.jetbrains.com/company/brand/img/jb-wrong-2.svg" alt="jetbrains logo" width="150"/>

Thanks to JetBrains for Open Source Program license for open source development.

#### Code Whale

<img src="https://poeditor.com/public/images/logo/logo_head_500_transparent.png" alt="jetbrains logo" width="150"/>

Thanks to Code Whale for Open Source license for POEditor project.

## Contributors

[List of all contributors here](https://plajer.xyz/contributors/villagedefense.html)

<img align="right" src="https://i.imgur.com/EmFfDXN.png">
# Village Defense Gold

A hard fork created to implement many new exciting features into Village Defense 4.0.0.

Formerly known as Village Defense 5.0.0 update this hard fork now focuses on personal upgrades to the codebase with new
gameplay stuff and other features.

**No support and maintenance obligations are provided for this hard fork as it's only intended for private/limited group
use only.**
**Feel free to compile sources yourself and edit the plugin accordingly to your needs**

Depends on [MinigamesBoxGold](https://github.com/Plajer/MinigamesBoxGold)

### List of features done and planned for this version:

* **Opinionated design choices and hardcoded values and options**
* Many QoL and gameplay loop and pacing improvements
* Drastically improved Look and Feel (sounds & effects)
* Many fixes including ally pets targeting villagers/other pets/players
* Kits balance changes
* Revamped powerups
* Revamped entity upgrades (including hidden & special upgrades)
* Mid-wave special events (shop offer, rotten flesh trader, pinata etc.)
* Arena personal records
* Enemies spawn system revamp
* New and more enjoyable enemies
* Shop auto armor equip
* Bosses between every game state (wave 15, wave 30, wave 50)
* Engineer kit - replacement for Builder kit but with Turrets
* Weekly random challenges
24 changes: 21 additions & 3 deletions build.gradle.kts
Original file line number Diff line number Diff line change
Expand Up @@ -33,19 +33,31 @@ repositories {
maven(uri("https://maven.plugily.xyz/snapshots"))
maven(uri("https://repo.citizensnpcs.co/"))
maven(uri("https://repo.maven.apache.org/maven2/"))
maven(uri("https://repo.dmulloy2.net/repository/public/"))
}



dependencies {
implementation("plugily.projects:MiniGamesBox-Classic:1.2.0-SNAPSHOT36") { isTransitive = false }
compileOnly("org.spigotmc:spigot-api:1.19.3-R0.1-SNAPSHOT")
implementation(files("lib/box-classic.jar"))
implementation(files("lib/box-db.jar"))
implementation(files("lib/box-inv.jar"))
implementation(files("lib/box-utils.jar"))
implementation("org.openjdk.nashorn:nashorn-core:15.1")
implementation("io.github.skytasul:glowingentities:1.3.2")
compileOnly("io.papermc.paper:paper-api:1.20.4-R0.1-SNAPSHOT")
compileOnly("org.jetbrains:annotations:24.0.1")

compileOnly("com.mojang:authlib:3.11.50")
compileOnly("com.comphenix.protocol:ProtocolLib:5.0.0")
compileOnly(files("lib/spigot/1.8.8-R0.1.jar"))

compileOnly("org.projectlombok:lombok:1.18.32")
annotationProcessor("org.projectlombok:lombok:1.18.32")
}

group = "plugily.projects"
version = "4.6.1-SNAPSHOT79"
version = "5.0.1-SNAPSHOT6"
description = "VillageDefense"
java {
withJavadocJar()
Expand Down Expand Up @@ -73,6 +85,12 @@ tasks {
options.encoding = "UTF-8"
}

compileJava {
options.encoding = "UTF-8"
targetCompatibility = JavaVersion.VERSION_17.toString()
sourceCompatibility = JavaVersion.VERSION_17.toString()
}

}

publishing {
Expand Down
147 changes: 76 additions & 71 deletions src/main/java/plugily/projects/villagedefense/Main.java
Original file line number Diff line number Diff line change
@@ -1,24 +1,25 @@
/*
* Village Defense - Protect villagers from hordes of zombies
* Copyright (c) 2023 Plugily Projects - maintained by Tigerpanzer_02 and contributors
* Village Defense - Protect villagers from hordes of zombies
* Copyright (c) 2024 Plugily Projects - maintained by Tigerpanzer_02 and contributors
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
* You should have received a copy of the GNU General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*/

package plugily.projects.villagedefense;

import org.bukkit.Bukkit;
import fr.skytasul.glowingentities.GlowingEntities;
import lombok.Getter;
import org.bukkit.configuration.file.FileConfiguration;
import org.bukkit.plugin.PluginDescriptionFile;
import org.bukkit.plugin.java.JavaPluginLoader;
Expand All @@ -27,6 +28,7 @@
import plugily.projects.minigamesbox.classic.handlers.setup.SetupInventory;
import plugily.projects.minigamesbox.classic.handlers.setup.categories.PluginSetupCategoryManager;
import plugily.projects.minigamesbox.classic.utils.configuration.ConfigUtils;
import plugily.projects.minigamesbox.classic.utils.misc.MiscUtils;
import plugily.projects.minigamesbox.classic.utils.services.metrics.Metrics;
import plugily.projects.minigamesbox.classic.utils.version.ServerVersion;
import plugily.projects.villagedefense.arena.Arena;
Expand All @@ -35,43 +37,32 @@
import plugily.projects.villagedefense.arena.ArenaRegistry;
import plugily.projects.villagedefense.arena.ArenaUtils;
import plugily.projects.villagedefense.arena.managers.enemy.spawner.EnemySpawnerRegistry;
import plugily.projects.villagedefense.arena.managers.enemy.spawner.EnemySpawnerRegistryLegacy;
import plugily.projects.villagedefense.arena.powerup.PowerupEvents;
import plugily.projects.villagedefense.boot.AdditionalValueInitializer;
import plugily.projects.villagedefense.boot.MessageInitializer;
import plugily.projects.villagedefense.boot.PlaceholderInitializer;
import plugily.projects.villagedefense.commands.arguments.ArgumentsRegistry;
import plugily.projects.villagedefense.creatures.CreatureUtils;
import plugily.projects.villagedefense.creatures.DoorBreakListener;
import plugily.projects.villagedefense.events.EntityUpgradeListener;
import plugily.projects.villagedefense.events.PluginEvents;
import plugily.projects.villagedefense.handlers.powerup.PowerupHandler;
import plugily.projects.villagedefense.handlers.hologram.NewHologramManager;
import plugily.projects.villagedefense.handlers.setup.SetupCategoryManager;
import plugily.projects.villagedefense.handlers.upgrade.EntityUpgradeMenu;
import plugily.projects.villagedefense.handlers.upgrade.upgrades.Upgrade;
import plugily.projects.villagedefense.handlers.upgrade.upgrades.UpgradeBuilder;
import plugily.projects.villagedefense.kits.free.KnightKit;
import plugily.projects.villagedefense.kits.free.LightTankKit;
import plugily.projects.villagedefense.kits.level.ArcherKit;
import plugily.projects.villagedefense.kits.level.GolemFriendKit;
import plugily.projects.villagedefense.kits.level.HardcoreKit;
import plugily.projects.villagedefense.kits.level.HealerKit;
import plugily.projects.villagedefense.kits.level.LooterKit;
import plugily.projects.villagedefense.kits.level.MediumTankKit;
import plugily.projects.villagedefense.kits.level.PuncherKit;
import plugily.projects.villagedefense.kits.level.RunnerKit;
import plugily.projects.villagedefense.kits.level.TerminatorKit;
import plugily.projects.villagedefense.kits.level.WorkerKit;
import plugily.projects.villagedefense.kits.level.ZombieFinderKit;
import plugily.projects.villagedefense.kits.premium.BlockerKit;
import plugily.projects.villagedefense.kits.premium.CleanerKit;
import plugily.projects.villagedefense.kits.premium.DogFriendKit;
import plugily.projects.villagedefense.kits.premium.HeavyTankKit;
import plugily.projects.villagedefense.kits.premium.MedicKit;
import plugily.projects.villagedefense.kits.premium.NakedKit;
import plugily.projects.villagedefense.kits.premium.PremiumHardcoreKit;
import plugily.projects.villagedefense.kits.premium.ShotBowKit;
import plugily.projects.villagedefense.kits.premium.TeleporterKit;
import plugily.projects.villagedefense.kits.premium.TornadoKit;
import plugily.projects.villagedefense.kits.premium.WizardKit;
import plugily.projects.villagedefense.handlers.upgrade.EntityUpgradeHandlerEvents;
import plugily.projects.villagedefense.handlers.upgrade.NewEntityUpgradeManager;
import plugily.projects.villagedefense.kits.BuilderKit;
import plugily.projects.villagedefense.kits.CleanerKit;
import plugily.projects.villagedefense.kits.CrusaderKit;
import plugily.projects.villagedefense.kits.KnightKit;
import plugily.projects.villagedefense.kits.MedicKit;
import plugily.projects.villagedefense.kits.PetsFriend;
import plugily.projects.villagedefense.kits.ShotBowKit;
import plugily.projects.villagedefense.kits.TerminatorKit;
import plugily.projects.villagedefense.kits.TornadoKit;
import plugily.projects.villagedefense.kits.WizardKit;
import plugily.projects.villagedefense.kits.utils.KitHelper;
import plugily.projects.villagedefense.user.VDUserManager;
import plugily.projects.villagedefense.utils.ProtocolUtils;

import java.io.File;
import java.util.logging.Level;
Expand All @@ -82,11 +73,16 @@
*/
public class Main extends PluginMain {

private FileConfiguration entityUpgradesConfig;
private EnemySpawnerRegistryLegacy enemySpawnerRegistry;
private @Getter FileConfiguration entityUpgradesConfig;
private @Getter EnemySpawnerRegistry enemySpawnerRegistry;
private @Getter NewEntityUpgradeManager entityUpgradeManager;
private @Getter NewHologramManager newHologramManager;
private @Getter VDUserManager vdUserManager;
private @Getter GlowingEntities glowingEntities;

private ArgumentsRegistry argumentsRegistry;
private ArenaRegistry arenaRegistry;
private ArenaManager arenaManager;
private ArgumentsRegistry argumentsRegistry;

@TestOnly
public Main() {
Expand All @@ -103,6 +99,9 @@ public void onEnable() {
long start = System.currentTimeMillis();
MessageInitializer messageInitializer = new MessageInitializer(this);
super.onEnable();
/*if(!validateStartup()) {
return;
}*/
getDebugger().debug("[System] [Plugin] Initialization start");
new PlaceholderInitializer(this);
messageInitializer.registerMessages();
Expand All @@ -113,47 +112,59 @@ public void onEnable() {
getDebugger().debug("[System] [Plugin] Initialization finished took {0}ms", System.currentTimeMillis() - start);
}

private boolean validateStartup() {
if (ServerVersion.Version.isCurrentLower(ServerVersion.Version.v1_12_R1)) {
MiscUtils.sendLineBreaker(this.getName());
getMessageUtils().thisVersionIsNotSupported();
MiscUtils.sendVersionInformation(this, this.getName(), this.getDescription());
getDebugger().sendConsoleMsg(getPluginMessagePrefix() + "&cYour server version is not supported by " + this.getDescription().getName() + "!");
getDebugger().sendConsoleMsg(getPluginMessagePrefix() + "&cSadly, we must shut off. Maybe you consider changing your server version?");
MiscUtils.sendLineBreaker(this.getName());
getServer().getPluginManager().disablePlugin(this);
return false;
}
return true;
}

public void initializePluginClasses() {
addFileName("powerups");
addFileName("creatures");
Arena.init(this);
ArenaUtils.init(this);
KitHelper.init(this);
ProtocolUtils.init(this);
new ArenaEvents(this);
new PowerupEvents(this);
vdUserManager = new VDUserManager(this);
arenaManager = new ArenaManager(this);
arenaRegistry = new ArenaRegistry(this);
arenaRegistry.registerArenas();
getSignManager().loadSigns();
getSignManager().updateSigns();
argumentsRegistry = new ArgumentsRegistry(this);
if(ServerVersion.Version.isCurrentEqualOrLower(ServerVersion.Version.v1_8_R3)) {
enemySpawnerRegistry = new EnemySpawnerRegistryLegacy(this);
} else {
enemySpawnerRegistry = new EnemySpawnerRegistry(this);
}
if(getConfigPreferences().getOption("UPGRADES")) {
entityUpgradesConfig = ConfigUtils.getConfig(this, "entity_upgrades");
Upgrade.init(this);
UpgradeBuilder.init(this);
new EntityUpgradeMenu(this);
}
enemySpawnerRegistry = new EnemySpawnerRegistry(this);
entityUpgradesConfig = ConfigUtils.getConfig(this, "entity_upgrades");
entityUpgradeManager = new NewEntityUpgradeManager(this);
newHologramManager = new NewHologramManager(this);
new DoorBreakListener(this);
CreatureUtils.init(this);
new PowerupHandler(this);
new PluginEvents(this);
new EntityUpgradeListener(this);
new EntityUpgradeHandlerEvents(this);
this.glowingEntities = new GlowingEntities(this);
addPluginMetrics();
}

public void addKits() {
long start = System.currentTimeMillis();
getDebugger().debug("Adding kits...");
addFileName("kits");
Class<?>[] classKitNames = new Class[]{KnightKit.class, LightTankKit.class, ZombieFinderKit.class, ArcherKit.class, PuncherKit.class, HealerKit.class, LooterKit.class, RunnerKit.class,
MediumTankKit.class, WorkerKit.class, GolemFriendKit.class, TerminatorKit.class, HardcoreKit.class, CleanerKit.class, TeleporterKit.class, HeavyTankKit.class, ShotBowKit.class,
DogFriendKit.class, PremiumHardcoreKit.class, TornadoKit.class, BlockerKit.class, MedicKit.class, NakedKit.class, WizardKit.class};
for(Class<?> kitClass : classKitNames) {
Class<?>[] classKitNames = new Class[]{KnightKit.class, BuilderKit.class, TornadoKit.class, ShotBowKit.class, MedicKit.class,
CleanerKit.class, PetsFriend.class, TerminatorKit.class, CrusaderKit.class, WizardKit.class};
for (Class<?> kitClass : classKitNames) {
try {
kitClass.getDeclaredConstructor().newInstance();
} catch(Exception e) {
} catch (Exception e) {
getLogger().log(Level.SEVERE, "Fatal error while registering existing game kit! Report this error to the developer!");
getLogger().log(Level.SEVERE, "Cause: " + e.getMessage() + " (kitClass " + kitClass.getName() + ")");
e.printStackTrace();
Expand All @@ -162,23 +173,16 @@ public void addKits() {
getDebugger().debug("Kit adding finished took {0}ms", System.currentTimeMillis() - start);
}


private void addPluginMetrics() {
getMetrics().addCustomChart(new Metrics.SimplePie("hooked_addons", () -> {
if(getServer().getPluginManager().getPlugin("VillageDefense-Enhancements") != null) {
if (getServer().getPluginManager().getPlugin("VillageDefense-Enhancements") != null) {
return "Enhancements";
}
return "None";
}));
}

public FileConfiguration getEntityUpgradesConfig() {
return entityUpgradesConfig;
}

public EnemySpawnerRegistryLegacy getEnemySpawnerRegistry() {
return enemySpawnerRegistry;
}

@Override
public ArenaRegistry getArenaRegistry() {
return arenaRegistry;
Expand All @@ -198,4 +202,5 @@ public ArenaManager getArenaManager() {
public PluginSetupCategoryManager getSetupCategoryManager(SetupInventory setupInventory) {
return new SetupCategoryManager(setupInventory);
}

}
Loading