0.4.2: rewrite of the Skill system of player, refactored to be Attributes
started some work on Entity => need some time on it. that's all :)
This commit is contained in:
parent
d943dfadaa
commit
22000e12ca
28 changed files with 780 additions and 264 deletions
5
pom.xml
5
pom.xml
|
@ -6,7 +6,7 @@
|
||||||
|
|
||||||
<groupId>gq.unurled</groupId>
|
<groupId>gq.unurled</groupId>
|
||||||
<artifactId>raxen</artifactId>
|
<artifactId>raxen</artifactId>
|
||||||
<version>0.0.4</version>
|
<version>0.4.2</version>
|
||||||
<packaging>jar</packaging>
|
<packaging>jar</packaging>
|
||||||
|
|
||||||
<name>Raxen</name>
|
<name>Raxen</name>
|
||||||
|
@ -32,6 +32,7 @@
|
||||||
<configuration>
|
<configuration>
|
||||||
<source>17</source>
|
<source>17</source>
|
||||||
<target>17</target>
|
<target>17</target>
|
||||||
|
<compilerArgs>--enable-preview</compilerArgs>
|
||||||
</configuration>
|
</configuration>
|
||||||
</plugin>
|
</plugin>
|
||||||
<plugin>
|
<plugin>
|
||||||
|
@ -126,13 +127,13 @@
|
||||||
<version>2.9.0-SNAPSHOT</version>
|
<version>2.9.0-SNAPSHOT</version>
|
||||||
<scope>compile</scope>
|
<scope>compile</scope>
|
||||||
</dependency>
|
</dependency>
|
||||||
|
<!--
|
||||||
<dependency>
|
<dependency>
|
||||||
<groupId>de.tr7zw</groupId>
|
<groupId>de.tr7zw</groupId>
|
||||||
<artifactId>nbt-injector</artifactId>
|
<artifactId>nbt-injector</artifactId>
|
||||||
<version>2.9.0-SNAPSHOT</version>
|
<version>2.9.0-SNAPSHOT</version>
|
||||||
<scope>compile</scope>
|
<scope>compile</scope>
|
||||||
</dependency>
|
</dependency>
|
||||||
<!--
|
|
||||||
<dependency>
|
<dependency>
|
||||||
<groupId>com.github.simplix-softworks</groupId>
|
<groupId>com.github.simplix-softworks</groupId>
|
||||||
<artifactId>SimplixStorage</artifactId>
|
<artifactId>SimplixStorage</artifactId>
|
||||||
|
|
|
@ -20,7 +20,7 @@ public final class Raxen extends JavaPlugin {
|
||||||
|
|
||||||
private static final String prefix = ChatColor.AQUA + "Rx" + ChatColor.LIGHT_PURPLE + "> ";
|
private static final String prefix = ChatColor.AQUA + "Rx" + ChatColor.LIGHT_PURPLE + "> ";
|
||||||
@Getter
|
@Getter
|
||||||
private static final String version = "0.0.4";
|
private static final String version = "0.4.2";
|
||||||
private final PluginManager pm = getServer().getPluginManager();
|
private final PluginManager pm = getServer().getPluginManager();
|
||||||
|
|
||||||
@Getter
|
@Getter
|
||||||
|
@ -99,6 +99,8 @@ public final class Raxen extends JavaPlugin {
|
||||||
public void onDisable() {
|
public void onDisable() {
|
||||||
Reload.kickAll();
|
Reload.kickAll();
|
||||||
|
|
||||||
|
playerConfig.close();
|
||||||
|
|
||||||
getServer().getConsoleSender().sendMessage(Component.text(prefix +"§cServer Stopped Successfully!"));
|
getServer().getConsoleSender().sendMessage(Component.text(prefix +"§cServer Stopped Successfully!"));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -2,6 +2,7 @@ package gq.unurled.raxen.commands;
|
||||||
|
|
||||||
import gq.unurled.raxen.Raxen;
|
import gq.unurled.raxen.Raxen;
|
||||||
import gq.unurled.raxen.manager.StorageManager;
|
import gq.unurled.raxen.manager.StorageManager;
|
||||||
|
import gq.unurled.raxen.utils.Utils;
|
||||||
import net.kyori.adventure.text.Component;
|
import net.kyori.adventure.text.Component;
|
||||||
import net.kyori.adventure.text.TextComponent;
|
import net.kyori.adventure.text.TextComponent;
|
||||||
import net.kyori.adventure.text.event.ClickEvent;
|
import net.kyori.adventure.text.event.ClickEvent;
|
||||||
|
@ -14,8 +15,7 @@ import org.jetbrains.annotations.Nullable;
|
||||||
|
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
|
||||||
import static gq.unurled.raxen.utils.Utils.color;
|
import static gq.unurled.raxen.utils.Utils.*;
|
||||||
import static gq.unurled.raxen.utils.Utils.msgPlayer;
|
|
||||||
|
|
||||||
public class RaxenCommand implements TabExecutor {
|
public class RaxenCommand implements TabExecutor {
|
||||||
|
|
||||||
|
@ -33,33 +33,33 @@ public class RaxenCommand implements TabExecutor {
|
||||||
msgPlayer(player, Raxen.getPrefix() + color("&cYou can't execute this command. Insufficient permission."));
|
msgPlayer(player, Raxen.getPrefix() + color("&cYou can't execute this command. Insufficient permission."));
|
||||||
}
|
}
|
||||||
switch (args.length) {
|
switch (args.length) {
|
||||||
case 0:
|
case 0 -> msgPl(player, 0);
|
||||||
msgPl(player, 0);
|
case 1 -> {
|
||||||
case 1:
|
|
||||||
switch (args[0]) {
|
switch (args[0]) {
|
||||||
case "mongodb":
|
case "mongodb", "mongo", "MONGODB", "MONGO" -> {
|
||||||
case "mongo":
|
|
||||||
case "MONGODB":
|
|
||||||
case "MONGO":
|
|
||||||
//print info about connection
|
//print info about connection
|
||||||
msgPlayer(player, Raxen.getPrefix() + color("&6--------------------------------"),color("&cMONGO DB"));
|
sender.sendMessage(Raxen.getPrefix() + color("&6Printing About Raxen's MongoDB connection..."));
|
||||||
|
msgPlayer(player, Raxen.getPrefix() + color("&6---------------------------------------------"),
|
||||||
|
color("&cMONGO DB"));
|
||||||
msgPlayer(player, StorageManager.getMongo().getMongoClient().getClusterDescription().toString());
|
msgPlayer(player, StorageManager.getMongo().getMongoClient().getClusterDescription().toString());
|
||||||
msgPlayer(player, StorageManager.getMongo().getMongoDatabase().getName());
|
msgPlayer(player, StorageManager.getMongo().getMongoDatabase().getName());
|
||||||
msgPlayer(player, StorageManager.getMongo().getMongoCollection().getNamespace().toString());
|
msgPlayer(player, StorageManager.getMongo().getMongoCollection().getNamespace().toString());
|
||||||
case "v":
|
msgPlayer(player, color("&6---------------------------------------------"));
|
||||||
case "version":
|
}
|
||||||
case "ver":
|
case "v", "version", "ver" -> {
|
||||||
msgPl(player, 0);
|
msgPl(player, 0);
|
||||||
case "hemlp":
|
}
|
||||||
case "?":
|
case "hemlp", "?", "h" -> {
|
||||||
case "h":
|
|
||||||
//print help
|
//print help
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
|
log(String.valueOf(args.length));
|
||||||
switch (args.length) {
|
switch (args.length) {
|
||||||
case 0:
|
case 0 -> {
|
||||||
sender.sendMessage(Raxen.getPrefix() + color("&6Printing About Raxen..."),
|
sender.sendMessage(Raxen.getPrefix() + color("&6Printing About Raxen..."),
|
||||||
color("&6---------------------------------------------"),
|
color("&6---------------------------------------------"),
|
||||||
color("&3 Raxen "),
|
color("&3 Raxen "),
|
||||||
|
@ -67,33 +67,38 @@ public class RaxenCommand implements TabExecutor {
|
||||||
color("&3 - Author: &l&cU&6n&eu&2r&al&be&3d&r"));
|
color("&3 - Author: &l&cU&6n&eu&2r&al&be&3d&r"));
|
||||||
TextComponent txt = Component.text(color("&3 - Website: https://unurled.gq"));
|
TextComponent txt = Component.text(color("&3 - Website: https://unurled.gq"));
|
||||||
sender.sendMessage(txt);
|
sender.sendMessage(txt);
|
||||||
case 1:
|
sender.sendMessage(color("&6---------------------------------------------"));
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
case 1 -> {
|
||||||
|
log("hello");
|
||||||
switch (args[0]) {
|
switch (args[0]) {
|
||||||
case "mongodb":
|
case "mongodb", "mongo", "MONGODB", "MONGO" -> {
|
||||||
case "mongo":
|
|
||||||
case "MONGODB":
|
|
||||||
case "MONGO":
|
|
||||||
//print info about connection
|
//print info about connection
|
||||||
sender.sendMessage( Raxen.getPrefix() + color("&6--------------------------------"),color("&cMONGO DB"));
|
sender.sendMessage(Raxen.getPrefix() + color("&6Printing About Raxen's MongoDB connection..."));
|
||||||
sender.sendMessage( StorageManager.getMongo().getMongoClient().getClusterDescription().toString());
|
sender.sendMessage(color("&6---------------------------------------------"), color("&cMONGO DB"));
|
||||||
sender.sendMessage( StorageManager.getMongo().getMongoDatabase().getName());
|
sender.sendMessage(StorageManager.getMongo().getMongoClient().getClusterDescription().toString());
|
||||||
sender.sendMessage( StorageManager.getMongo().getMongoCollection().getNamespace().toString());
|
sender.sendMessage(StorageManager.getMongo().getMongoDatabase().getName());
|
||||||
case "v":
|
sender.sendMessage(StorageManager.getMongo().getMongoCollection().getNamespace().toString());
|
||||||
case "version":
|
sender.sendMessage(color("&6---------------------------------------------"));
|
||||||
case "ver":
|
return true;
|
||||||
|
}
|
||||||
|
case "v", "version", "ver" -> {
|
||||||
sender.sendMessage(Raxen.getPrefix() + color("&6Printing About Raxen..."),
|
sender.sendMessage(Raxen.getPrefix() + color("&6Printing About Raxen..."),
|
||||||
color("&6---------------------------------------------"),
|
color("&6---------------------------------------------"),
|
||||||
color("&3 Raxen "),
|
color("&3 Raxen "),
|
||||||
color("&3 - Version: " + Raxen.getVersion()),
|
color("&3 - Version: " + Raxen.getVersion()),
|
||||||
color("&3 - Author: &l&cU&6n&eu&2r&al&be&3d&r"));
|
color("&3 - Author: &l&cU&6n&eu&2r&al&be&3d&r"));
|
||||||
txt = Component.text(color("&3 - Website: https://unurled.gq"));
|
TextComponent txt= Component.text(color("&3 - Website: https://unurled.gq"));
|
||||||
sender.sendMessage(txt);
|
sender.sendMessage(txt);
|
||||||
sender.sendMessage(color("&6---------------------------------------------"));
|
sender.sendMessage(color("&6---------------------------------------------"));
|
||||||
case "hemlp":
|
return true;
|
||||||
case "?":
|
}
|
||||||
case "h":
|
case "hemlp", "?", "h" ->
|
||||||
//print help
|
//print help
|
||||||
|
log("why tf?");
|
||||||
}
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return false;
|
return false;
|
||||||
|
@ -106,8 +111,7 @@ public class RaxenCommand implements TabExecutor {
|
||||||
color("&6---------------------------------------------"),
|
color("&6---------------------------------------------"),
|
||||||
color("&3 Raxen "),
|
color("&3 Raxen "),
|
||||||
color("&3 - Version: " + Raxen.getVersion()),
|
color("&3 - Version: " + Raxen.getVersion()),
|
||||||
color("&3 - Author: &l&cU&6n&eu&2r&al&be&3d&r"),
|
color("&3 - Author: &l&cU&6n&eu&2r&al&be&3d&r"));
|
||||||
color("&3 - Website: https://unurled.gq"));
|
|
||||||
TextComponent txt = Component.text(color("&3 - Website: https://unurled.gq"))
|
TextComponent txt = Component.text(color("&3 - Website: https://unurled.gq"))
|
||||||
.clickEvent(ClickEvent.openUrl("https://unurled.gq"));
|
.clickEvent(ClickEvent.openUrl("https://unurled.gq"));
|
||||||
player.sendMessage(txt);
|
player.sendMessage(txt);
|
||||||
|
|
|
@ -2,7 +2,7 @@ package gq.unurled.raxen.commands.admin;
|
||||||
|
|
||||||
import de.tr7zw.changeme.nbtapi.NBTItem;
|
import de.tr7zw.changeme.nbtapi.NBTItem;
|
||||||
import gq.unurled.raxen.Raxen;
|
import gq.unurled.raxen.Raxen;
|
||||||
import gq.unurled.raxen.components.player.Skills;
|
import gq.unurled.raxen.components.player.Attributes.Attributes;
|
||||||
import gq.unurled.raxen.manager.ProfileManager;
|
import gq.unurled.raxen.manager.ProfileManager;
|
||||||
import net.kyori.adventure.text.Component;
|
import net.kyori.adventure.text.Component;
|
||||||
import org.bukkit.Material;
|
import org.bukkit.Material;
|
||||||
|
@ -12,6 +12,7 @@ import org.bukkit.command.TabExecutor;
|
||||||
import org.bukkit.entity.Player;
|
import org.bukkit.entity.Player;
|
||||||
import org.bukkit.inventory.ItemStack;
|
import org.bukkit.inventory.ItemStack;
|
||||||
import org.bukkit.inventory.meta.ItemMeta;
|
import org.bukkit.inventory.meta.ItemMeta;
|
||||||
|
import org.checkerframework.checker.units.qual.A;
|
||||||
import org.jetbrains.annotations.NotNull;
|
import org.jetbrains.annotations.NotNull;
|
||||||
import org.jetbrains.annotations.Nullable;
|
import org.jetbrains.annotations.Nullable;
|
||||||
|
|
||||||
|
@ -24,9 +25,11 @@ import static gq.unurled.raxen.utils.Utils.*;
|
||||||
|
|
||||||
public class NbtCommand implements TabExecutor {
|
public class NbtCommand implements TabExecutor {
|
||||||
|
|
||||||
|
private Raxen main;
|
||||||
private ProfileManager profileManager;
|
private ProfileManager profileManager;
|
||||||
|
|
||||||
public NbtCommand(Raxen main) {
|
public NbtCommand(Raxen main) {
|
||||||
|
this.main = main;
|
||||||
this.profileManager = main.getProfileManager();
|
this.profileManager = main.getProfileManager();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -78,23 +81,23 @@ public class NbtCommand implements TabExecutor {
|
||||||
}
|
}
|
||||||
itm.lore(lore);
|
itm.lore(lore);
|
||||||
it.setItemMeta(itm);
|
it.setItemMeta(itm);
|
||||||
Skills skills = profileManager.getPlayerProfile(player.getUniqueId()).getSkils();
|
Attributes attributes = new Attributes(main);
|
||||||
nbti.setInteger(args[0], Integer.parseInt(args[1]) + a);
|
nbti.setInteger(args[0], Integer.parseInt(args[1]) + a);
|
||||||
if(nbti.hasKey("SPEED")) {
|
if(nbti.hasKey("SPEED")) {
|
||||||
skills.addSpeed(nbti.getInteger("SPEED"));
|
attributes.addSpeed(player, nbti.getInteger("SPEED"));
|
||||||
}
|
}
|
||||||
if(nbti.hasKey("HEALTH")) {
|
if(nbti.hasKey("HEALTH")) {
|
||||||
skills.addHealth(nbti.getInteger("HEALTH"));
|
attributes.addHealth(player, nbti.getInteger("HEALTH"));
|
||||||
}
|
}
|
||||||
if(nbti.hasKey("DEFENSE")) {
|
if(nbti.hasKey("DEFENSE")) {
|
||||||
skills.addDefense(nbti.getInteger("DEFENSE"));
|
attributes.addDefense(player, nbti.getInteger("DEFENSE"));
|
||||||
}
|
}
|
||||||
if(nbti.hasKey("STRENGTH")) {
|
if(nbti.hasKey("STRENGTH")) {
|
||||||
skills.addStrength(nbti.getInteger("STRENGTH"));
|
attributes.addStrength(player, nbti.getInteger("STRENGTH"));
|
||||||
}
|
}
|
||||||
it = nbti.getItem();
|
it = nbti.getItem();
|
||||||
msgPlayer(player, Raxen.getPrefix() + color("&fYou successfully added the nbt " +attributes(args[0]) + "&fwith " + args[1] + "&f."));
|
msgPlayer(player, Raxen.getPrefix() + color("&fYou successfully added the nbt " +attributes(args[0]) + "&fwith " + args[1] + "&f."));
|
||||||
updateSkills(player);
|
updateSkills(main, player);
|
||||||
player.getInventory().setItem(player.getInventory().getHeldItemSlot(), it);
|
player.getInventory().setItem(player.getInventory().getHeldItemSlot(), it);
|
||||||
}
|
}
|
||||||
return true;
|
return true;
|
||||||
|
|
|
@ -0,0 +1,54 @@
|
||||||
|
package gq.unurled.raxen.commands.admin;
|
||||||
|
|
||||||
|
import gq.unurled.raxen.Raxen;
|
||||||
|
import gq.unurled.raxen.components.entity.EntityNamespacedKey;
|
||||||
|
import org.bukkit.command.Command;
|
||||||
|
import org.bukkit.command.CommandSender;
|
||||||
|
import org.bukkit.command.TabExecutor;
|
||||||
|
import org.bukkit.entity.Entity;
|
||||||
|
import org.bukkit.entity.EntityType;
|
||||||
|
import org.bukkit.entity.Player;
|
||||||
|
import org.bukkit.persistence.PersistentDataContainer;
|
||||||
|
import org.bukkit.persistence.PersistentDataType;
|
||||||
|
import org.jetbrains.annotations.NotNull;
|
||||||
|
import org.jetbrains.annotations.Nullable;
|
||||||
|
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.UUID;
|
||||||
|
|
||||||
|
import static gq.unurled.raxen.components.entity.Entity.setNameSpacedKeys;
|
||||||
|
import static gq.unurled.raxen.utils.Utils.*;
|
||||||
|
|
||||||
|
public class SpawnEntity implements TabExecutor {
|
||||||
|
|
||||||
|
private Raxen main;
|
||||||
|
private EntityNamespacedKey namespacedKey;
|
||||||
|
|
||||||
|
public SpawnEntity(Raxen main) {
|
||||||
|
this.main = main;
|
||||||
|
this.namespacedKey = new EntityNamespacedKey(main);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean onCommand(@NotNull CommandSender sender, @NotNull Command command, @NotNull String label, @NotNull String[] args) {
|
||||||
|
if (!(sender instanceof Player)) {
|
||||||
|
log("&cConsole can't execute this command!");
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
Player player = (Player) sender;
|
||||||
|
if (player.hasPermission("raxen.entityspawn.cmd")) {
|
||||||
|
player.sendMessage(noPerms());
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
//example command : /entityspawn ZOMBIE "&cHello folks" 50 200
|
||||||
|
EntityType type = EntityType.valueOf(args[0]);
|
||||||
|
Entity e = player.getWorld().spawnEntity(player.getLocation(), type, false);
|
||||||
|
setNameSpacedKeys(e, "&cName", 100, 100,0,50,0,100,0,100,0);
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public @Nullable List<String> onTabComplete(@NotNull CommandSender sender, @NotNull Command command, @NotNull String alias, @NotNull String[] args) {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
}
|
|
@ -1,7 +1,7 @@
|
||||||
package gq.unurled.raxen.commands.player;
|
package gq.unurled.raxen.commands.player;
|
||||||
|
|
||||||
import gq.unurled.raxen.Raxen;
|
import gq.unurled.raxen.Raxen;
|
||||||
import gq.unurled.raxen.components.player.Skills;
|
import gq.unurled.raxen.components.player.Attributes.Attributes;
|
||||||
import gq.unurled.raxen.manager.ProfileManager;
|
import gq.unurled.raxen.manager.ProfileManager;
|
||||||
import net.kyori.adventure.text.Component;
|
import net.kyori.adventure.text.Component;
|
||||||
import org.bukkit.command.Command;
|
import org.bukkit.command.Command;
|
||||||
|
@ -18,8 +18,10 @@ import static gq.unurled.raxen.utils.Utils.*;
|
||||||
public class SkillsCommand implements TabExecutor {
|
public class SkillsCommand implements TabExecutor {
|
||||||
|
|
||||||
private ProfileManager profileManager;
|
private ProfileManager profileManager;
|
||||||
|
private Raxen main;
|
||||||
|
|
||||||
public SkillsCommand(Raxen main) {
|
public SkillsCommand(Raxen main) {
|
||||||
|
this.main = main;
|
||||||
this.profileManager = main.getProfileManager();
|
this.profileManager = main.getProfileManager();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -30,7 +32,7 @@ public class SkillsCommand implements TabExecutor {
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
Player player = (Player) sender;
|
Player player = (Player) sender;
|
||||||
Skills skills = profileManager.getPlayerProfile(player.getUniqueId()).getSkils();
|
Attributes attributes = new Attributes(main);
|
||||||
switch (args.length) {
|
switch (args.length) {
|
||||||
case 0:
|
case 0:
|
||||||
//open gui
|
//open gui
|
||||||
|
@ -45,64 +47,64 @@ public class SkillsCommand implements TabExecutor {
|
||||||
switch (args[0]) {
|
switch (args[0]) {
|
||||||
case "health":
|
case "health":
|
||||||
if(args[1].equalsIgnoreCase("add")) {
|
if(args[1].equalsIgnoreCase("add")) {
|
||||||
skills.setHealth(skills.getHealth() + Integer.parseInt(args[2]));
|
attributes.setHealth(player, attributes.getHealth(player) + Integer.parseInt(args[2]));
|
||||||
msgPlayer(player,"You were added " + args[2] + " health more!");
|
msgPlayer(player,"You were added " + args[2] + " health more!");
|
||||||
}
|
}
|
||||||
if(args[1].equalsIgnoreCase("set")) {
|
if(args[1].equalsIgnoreCase("set")) {
|
||||||
skills.setHealth(Integer.parseInt(args[2]));
|
attributes.setHealth(player, Integer.parseInt(args[2]));
|
||||||
msgPlayer(player,"You are set " + args[2] + " health!");
|
msgPlayer(player,"You are set " + args[2] + " health!");
|
||||||
}
|
}
|
||||||
if(args[1].equalsIgnoreCase("remove")) {
|
if(args[1].equalsIgnoreCase("remove")) {
|
||||||
skills.setHealth(skills.getHealth() - Integer.parseInt(args[2]));
|
attributes.setHealth(player ,attributes.getHealth(player) - Integer.parseInt(args[2]));
|
||||||
msgPlayer(player,"You were removeded " + args[2] + " health less!");
|
msgPlayer(player,"You were removeded " + args[2] + " health less!");
|
||||||
|
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case "defense":
|
case "defense":
|
||||||
if(args[1].equalsIgnoreCase("add")) {
|
if(args[1].equalsIgnoreCase("add")) {
|
||||||
skills.setDefense(skills.getDefense() + Integer.parseInt(args[2]));
|
attributes.setDefense(player, attributes.getDefense(player) + Integer.parseInt(args[2]));
|
||||||
msgPlayer(player,"You were added " + args[2] + " defense more!");
|
msgPlayer(player,"You were added " + args[2] + " defense more!");
|
||||||
|
|
||||||
}
|
}
|
||||||
if(args[1].equalsIgnoreCase("set")) {
|
if(args[1].equalsIgnoreCase("set")) {
|
||||||
skills.setDefense(Integer.parseInt(args[2]));
|
attributes.setDefense(player, Integer.parseInt(args[2]));
|
||||||
msgPlayer(player,"You are set " + args[2] + " defense!");
|
msgPlayer(player,"You are set " + args[2] + " defense!");
|
||||||
}
|
}
|
||||||
if(args[1].equalsIgnoreCase("remove")) {
|
if(args[1].equalsIgnoreCase("remove")) {
|
||||||
skills.setDefense(skills.getDefense() - Integer.parseInt(args[2]));
|
attributes.setDefense(player, attributes.getDefense(player) - Integer.parseInt(args[2]));
|
||||||
msgPlayer(player,"You were removed " + args[2] + " defense less!");
|
msgPlayer(player,"You were removed " + args[2] + " defense less!");
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case "speed":
|
case "speed":
|
||||||
if(args[1].equalsIgnoreCase("add")) {
|
if(args[1].equalsIgnoreCase("add")) {
|
||||||
skills.setSpeed(skills.getSpeed() + Integer.parseInt(args[2]));
|
attributes.setSpeed(player, attributes.getSpeed(player) + Integer.parseInt(args[2]));
|
||||||
msgPlayer(player,"You were added " + args[2] + " speed more!");
|
msgPlayer(player,"You were added " + args[2] + " speed more!");
|
||||||
}
|
}
|
||||||
if(args[1].equalsIgnoreCase("set")) {
|
if(args[1].equalsIgnoreCase("set")) {
|
||||||
skills.setSpeed(Integer.parseInt(args[2]));
|
attributes.setSpeed(player, Integer.parseInt(args[2]));
|
||||||
msgPlayer(player,"You are set " + args[2] + " speed!");
|
msgPlayer(player,"You are set " + args[2] + " speed!");
|
||||||
}
|
}
|
||||||
if(args[1].equalsIgnoreCase("remove")) {
|
if(args[1].equalsIgnoreCase("remove")) {
|
||||||
skills.setSpeed(skills.getSpeed() - Integer.parseInt(args[2]));
|
attributes.setSpeed(player, attributes.getSpeed(player) - Integer.parseInt(args[2]));
|
||||||
msgPlayer(player,"You were removed " + args[2] + " speed less!");
|
msgPlayer(player,"You were removed " + args[2] + " speed less!");
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case "stregnth":
|
case "stregnth":
|
||||||
if(args[1].equalsIgnoreCase("add")) {
|
if(args[1].equalsIgnoreCase("add")) {
|
||||||
skills.setStrength(skills.getStrength() + Integer.parseInt(args[2]));
|
attributes.setStrength(player, attributes.getStrength(player) + Integer.parseInt(args[2]));
|
||||||
msgPlayer(player,"You were added " + args[2] + " strength more!");
|
msgPlayer(player,"You were added " + args[2] + " strength more!");
|
||||||
}
|
}
|
||||||
if(args[1].equalsIgnoreCase("set")) {
|
if(args[1].equalsIgnoreCase("set")) {
|
||||||
skills.setStrength(Integer.parseInt(args[2]));
|
attributes.setStrength(player, Integer.parseInt(args[2]));
|
||||||
msgPlayer(player,"You are set " + args[2] + " strength!");
|
msgPlayer(player,"You are set " + args[2] + " strength!");
|
||||||
}
|
}
|
||||||
if(args[1].equalsIgnoreCase("remove")) {
|
if(args[1].equalsIgnoreCase("remove")) {
|
||||||
skills.setStrength(skills.getStrength() - Integer.parseInt(args[2]));
|
attributes.setStrength(player, attributes.getStrength(player) - Integer.parseInt(args[2]));
|
||||||
msgPlayer(player,"You were removed " + args[2] + " strength less!");
|
msgPlayer(player,"You were removed " + args[2] + " strength less!");
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
gq.unurled.raxen.utils.Skills.updateSkills(player);
|
gq.unurled.raxen.utils.Skills.updateSkills(main, player);
|
||||||
}
|
}
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
178
src/main/java/gq/unurled/raxen/components/entity/Attributes.java
Normal file
178
src/main/java/gq/unurled/raxen/components/entity/Attributes.java
Normal file
|
@ -0,0 +1,178 @@
|
||||||
|
package gq.unurled.raxen.components.entity;
|
||||||
|
|
||||||
|
import gq.unurled.raxen.Raxen;
|
||||||
|
import gq.unurled.raxen.components.player.Attributes.Attribute;
|
||||||
|
import org.bukkit.persistence.PersistentDataContainer;
|
||||||
|
import org.bukkit.persistence.PersistentDataType;
|
||||||
|
import org.bukkit.entity.Entity;
|
||||||
|
|
||||||
|
public class Attributes {
|
||||||
|
|
||||||
|
private static EntityNamespacedKey namespacedKey;
|
||||||
|
|
||||||
|
public Attributes(Raxen main) {
|
||||||
|
namespacedKey = new EntityNamespacedKey(main);
|
||||||
|
}
|
||||||
|
|
||||||
|
public static Attribute getAttribute(Entity e) {
|
||||||
|
PersistentDataContainer data = e.getPersistentDataContainer();
|
||||||
|
int health, itemHealth, defense, itemDefense, speed, itemSpeed, strength, itemDmg;
|
||||||
|
health = data.get(namespacedKey.healthKey, PersistentDataType.INTEGER);
|
||||||
|
itemHealth = data.get(namespacedKey.itemHealthKey, PersistentDataType.INTEGER);
|
||||||
|
defense = data.get(namespacedKey.defenseKey, PersistentDataType.INTEGER);
|
||||||
|
itemDefense = data.get(namespacedKey.itemDefenseKey, PersistentDataType.INTEGER);
|
||||||
|
speed = data.get(namespacedKey.speedKey, PersistentDataType.INTEGER);
|
||||||
|
itemSpeed = data.get(namespacedKey.itemSpeedKey, PersistentDataType.INTEGER);
|
||||||
|
strength = data.get(namespacedKey.strengthKey , PersistentDataType.INTEGER);
|
||||||
|
itemDmg = data.get(namespacedKey.itemStrengthKey, PersistentDataType.INTEGER);
|
||||||
|
return new Attribute(health, itemHealth, defense, itemDefense, speed, itemSpeed, strength, itemDmg);
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void setAttributes(Entity e, int health, int itemHealth, int defense, int itemDefense, int speed, int itemSpeed, int strength, int itemDmg) {
|
||||||
|
PersistentDataContainer data = e.getPersistentDataContainer();
|
||||||
|
data.set(namespacedKey.healthKey, PersistentDataType.INTEGER, health);
|
||||||
|
data.set(namespacedKey.itemHealthKey, PersistentDataType.INTEGER, itemHealth);
|
||||||
|
data.set(namespacedKey.defenseKey, PersistentDataType.INTEGER, defense);
|
||||||
|
data.set(namespacedKey.itemDefenseKey, PersistentDataType.INTEGER, itemDefense);
|
||||||
|
data.set(namespacedKey.speedKey, PersistentDataType.INTEGER, speed);
|
||||||
|
data.set(namespacedKey.itemSpeedKey, PersistentDataType.INTEGER, itemSpeed);
|
||||||
|
data.set(namespacedKey.strengthKey , PersistentDataType.INTEGER, strength);
|
||||||
|
data.set(namespacedKey.itemStrengthKey, PersistentDataType.INTEGER, itemDmg);
|
||||||
|
}
|
||||||
|
|
||||||
|
public void removeSpeed(Entity e, int i) {
|
||||||
|
PersistentDataContainer data = e.getPersistentDataContainer();
|
||||||
|
data.set(namespacedKey.speedKey, PersistentDataType.INTEGER, data.get(namespacedKey.speedKey, PersistentDataType.INTEGER) -i);
|
||||||
|
}
|
||||||
|
public void removeHealth(Entity e, int i) {
|
||||||
|
PersistentDataContainer data = e.getPersistentDataContainer();
|
||||||
|
data.set(namespacedKey.healthKey, PersistentDataType.INTEGER, data.get(namespacedKey.healthKey, PersistentDataType.INTEGER) -i);
|
||||||
|
}
|
||||||
|
public void removeDefense(Entity e, int i) {
|
||||||
|
PersistentDataContainer data = e.getPersistentDataContainer();
|
||||||
|
data.set(namespacedKey.defenseKey, PersistentDataType.INTEGER, data.get(namespacedKey.defenseKey, PersistentDataType.INTEGER) -i);
|
||||||
|
}
|
||||||
|
public void removeStrength(Entity e, int i) {
|
||||||
|
PersistentDataContainer data = e.getPersistentDataContainer();
|
||||||
|
data.set(namespacedKey.strengthKey, PersistentDataType.INTEGER, data.get(namespacedKey.strengthKey, PersistentDataType.INTEGER) -i);
|
||||||
|
}
|
||||||
|
|
||||||
|
public void removeItemSpeed(Entity e, int i) {
|
||||||
|
PersistentDataContainer data = e.getPersistentDataContainer();
|
||||||
|
data.set(namespacedKey.itemSpeedKey, PersistentDataType.INTEGER, data.get(namespacedKey.itemSpeedKey, PersistentDataType.INTEGER) -i);
|
||||||
|
}
|
||||||
|
public void removeItemHealth(Entity e, int i) {
|
||||||
|
PersistentDataContainer data = e.getPersistentDataContainer();
|
||||||
|
data.set(namespacedKey.itemHealthKey, PersistentDataType.INTEGER, data.get(namespacedKey.itemHealthKey, PersistentDataType.INTEGER) -i);
|
||||||
|
}
|
||||||
|
public void removeItemDefense(Entity e, int i) {
|
||||||
|
PersistentDataContainer data = e.getPersistentDataContainer();
|
||||||
|
data.set(namespacedKey.itemDefenseKey, PersistentDataType.INTEGER, data.get(namespacedKey.itemDefenseKey, PersistentDataType.INTEGER) -i);
|
||||||
|
}
|
||||||
|
public void removeItemStrength(Entity e, int i) {
|
||||||
|
PersistentDataContainer data = e.getPersistentDataContainer();
|
||||||
|
data.set(namespacedKey.itemStrengthKey, PersistentDataType.INTEGER, data.get(namespacedKey.itemStrengthKey, PersistentDataType.INTEGER) -i);
|
||||||
|
}
|
||||||
|
|
||||||
|
public void addSpeed(Entity e, int i) {
|
||||||
|
PersistentDataContainer data = e.getPersistentDataContainer();
|
||||||
|
data.set(namespacedKey.speedKey, PersistentDataType.INTEGER, data.get(namespacedKey.speedKey, PersistentDataType.INTEGER) +i);
|
||||||
|
}
|
||||||
|
public void addHealth(Entity e, int i) {
|
||||||
|
PersistentDataContainer data = e.getPersistentDataContainer();
|
||||||
|
data.set(namespacedKey.healthKey, PersistentDataType.INTEGER, data.get(namespacedKey.healthKey, PersistentDataType.INTEGER) +i);
|
||||||
|
}
|
||||||
|
public void addDefense(Entity e, int i) {
|
||||||
|
PersistentDataContainer data = e.getPersistentDataContainer();
|
||||||
|
data.set(namespacedKey.defenseKey, PersistentDataType.INTEGER, data.get(namespacedKey.defenseKey, PersistentDataType.INTEGER) +i);
|
||||||
|
}
|
||||||
|
public void addStrength(Entity e, int i) {
|
||||||
|
PersistentDataContainer data = e.getPersistentDataContainer();
|
||||||
|
data.set(namespacedKey.strengthKey, PersistentDataType.INTEGER, data.get(namespacedKey.strengthKey, PersistentDataType.INTEGER) +i);
|
||||||
|
}
|
||||||
|
|
||||||
|
public void addItemSpeed(Entity e, int i) {
|
||||||
|
PersistentDataContainer data = e.getPersistentDataContainer();
|
||||||
|
data.set(namespacedKey.itemSpeedKey, PersistentDataType.INTEGER, data.get(namespacedKey.itemSpeedKey, PersistentDataType.INTEGER) +i);
|
||||||
|
}
|
||||||
|
public void addItemHealth(Entity e, int i) {
|
||||||
|
PersistentDataContainer data = e.getPersistentDataContainer();
|
||||||
|
data.set(namespacedKey.itemHealthKey, PersistentDataType.INTEGER, data.get(namespacedKey.itemHealthKey, PersistentDataType.INTEGER) +i);
|
||||||
|
}
|
||||||
|
public void addItemDefense(Entity e, int i) {
|
||||||
|
PersistentDataContainer data = e.getPersistentDataContainer();
|
||||||
|
data.set(namespacedKey.itemDefenseKey, PersistentDataType.INTEGER, data.get(namespacedKey.defenseKey, PersistentDataType.INTEGER) +i);
|
||||||
|
}
|
||||||
|
public void addItemStrength(Entity e, int i) {
|
||||||
|
PersistentDataContainer data = e.getPersistentDataContainer();
|
||||||
|
data.set(namespacedKey.itemStrengthKey, PersistentDataType.INTEGER, data.get(namespacedKey.itemStrengthKey, PersistentDataType.INTEGER) +i);
|
||||||
|
}
|
||||||
|
|
||||||
|
public Integer getSpeed(Entity e) {
|
||||||
|
PersistentDataContainer data = e.getPersistentDataContainer();
|
||||||
|
return data.get(namespacedKey.speedKey, PersistentDataType.INTEGER);
|
||||||
|
}
|
||||||
|
public Integer getStrength(Entity e) {
|
||||||
|
PersistentDataContainer data = e.getPersistentDataContainer();
|
||||||
|
return data.get(namespacedKey.strengthKey, PersistentDataType.INTEGER);
|
||||||
|
}
|
||||||
|
public Integer getHealth(Entity e) {
|
||||||
|
PersistentDataContainer data = e.getPersistentDataContainer();
|
||||||
|
return data.get(namespacedKey.healthKey, PersistentDataType.INTEGER);
|
||||||
|
}
|
||||||
|
public Integer getDefense(Entity e) {
|
||||||
|
PersistentDataContainer data = e.getPersistentDataContainer();
|
||||||
|
return data.get(namespacedKey.defenseKey, PersistentDataType.INTEGER);
|
||||||
|
}
|
||||||
|
|
||||||
|
public Integer getItemSpeed(Entity e) {
|
||||||
|
PersistentDataContainer data = e.getPersistentDataContainer();
|
||||||
|
return data.get(namespacedKey.itemSpeedKey, PersistentDataType.INTEGER);
|
||||||
|
}
|
||||||
|
public Integer getItemStrength(Entity e) {
|
||||||
|
PersistentDataContainer data = e.getPersistentDataContainer();
|
||||||
|
return data.get(namespacedKey.itemStrengthKey, PersistentDataType.INTEGER);
|
||||||
|
}
|
||||||
|
public Integer getItemHealth(Entity e) {
|
||||||
|
PersistentDataContainer data = e.getPersistentDataContainer();
|
||||||
|
return data.get(namespacedKey.itemHealthKey, PersistentDataType.INTEGER);
|
||||||
|
}
|
||||||
|
public Integer getItemDefense(Entity e) {
|
||||||
|
PersistentDataContainer data = e.getPersistentDataContainer();
|
||||||
|
return data.get(namespacedKey.itemDefenseKey, PersistentDataType.INTEGER);
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setHealth(Entity e, int i) {
|
||||||
|
PersistentDataContainer data = e.getPersistentDataContainer();
|
||||||
|
data.set(namespacedKey.healthKey, PersistentDataType.INTEGER, i);
|
||||||
|
}
|
||||||
|
public void setDefense(Entity e, int i) {
|
||||||
|
PersistentDataContainer data = e.getPersistentDataContainer();
|
||||||
|
data.set(namespacedKey.defenseKey, PersistentDataType.INTEGER, i);
|
||||||
|
}
|
||||||
|
public void setSpeed(Entity e, int i) {
|
||||||
|
PersistentDataContainer data = e.getPersistentDataContainer();
|
||||||
|
data.set(namespacedKey.speedKey, PersistentDataType.INTEGER, i);
|
||||||
|
}
|
||||||
|
public void setStrength(Entity e, int i) {
|
||||||
|
PersistentDataContainer data = e.getPersistentDataContainer();
|
||||||
|
data.set(namespacedKey.strengthKey, PersistentDataType.INTEGER, i);
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setItemHealth(Entity e, int i) {
|
||||||
|
PersistentDataContainer data = e.getPersistentDataContainer();
|
||||||
|
data.set(namespacedKey.itemHealthKey, PersistentDataType.INTEGER, i);
|
||||||
|
}
|
||||||
|
public void setItemDefense(Entity e, int i) {
|
||||||
|
PersistentDataContainer data = e.getPersistentDataContainer();
|
||||||
|
data.set(namespacedKey.itemDefenseKey, PersistentDataType.INTEGER, i);
|
||||||
|
}
|
||||||
|
public void setItemSpeed(Entity e, int i) {
|
||||||
|
PersistentDataContainer data = e.getPersistentDataContainer();
|
||||||
|
data.set(namespacedKey.itemSpeedKey, PersistentDataType.INTEGER, i);
|
||||||
|
}
|
||||||
|
public void setItemStrength(Entity e, int i) {
|
||||||
|
PersistentDataContainer data = e.getPersistentDataContainer();
|
||||||
|
data.set(namespacedKey.itemStrengthKey, PersistentDataType.INTEGER, i);
|
||||||
|
}
|
||||||
|
}
|
68
src/main/java/gq/unurled/raxen/components/entity/Entity.java
Normal file
68
src/main/java/gq/unurled/raxen/components/entity/Entity.java
Normal file
|
@ -0,0 +1,68 @@
|
||||||
|
package gq.unurled.raxen.components.entity;
|
||||||
|
|
||||||
|
import gq.unurled.raxen.Raxen;
|
||||||
|
import gq.unurled.raxen.components.player.Attributes.Attribute;
|
||||||
|
import org.bukkit.entity.LivingEntity;
|
||||||
|
import org.bukkit.persistence.PersistentDataContainer;
|
||||||
|
import org.bukkit.persistence.PersistentDataType;
|
||||||
|
|
||||||
|
import static gq.unurled.raxen.utils.Utils.log;
|
||||||
|
import static gq.unurled.raxen.utils.Utils.msgPlayer;
|
||||||
|
|
||||||
|
public class Entity {
|
||||||
|
|
||||||
|
private static Raxen main;
|
||||||
|
private static EntityNamespacedKey namespacedKey;
|
||||||
|
|
||||||
|
public Entity(Raxen main) {
|
||||||
|
main = main;
|
||||||
|
namespacedKey = new EntityNamespacedKey(main);
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void setNameSpacedKeys(org.bukkit.entity.Entity e, String name, Integer level, int health, int itemHealth, int defense, int itemDefense, int speed, int itemSpeed, int strength, int itemDmg) {
|
||||||
|
PersistentDataContainer data = e.getPersistentDataContainer();
|
||||||
|
data.set(namespacedKey.healthKey, PersistentDataType.INTEGER, health);
|
||||||
|
data.set(namespacedKey.itemHealthKey, PersistentDataType.INTEGER, itemHealth);
|
||||||
|
data.set(namespacedKey.speedKey, PersistentDataType.INTEGER, speed);
|
||||||
|
data.set(namespacedKey.itemSpeedKey, PersistentDataType.INTEGER, itemSpeed);
|
||||||
|
data.set(namespacedKey.defenseKey, PersistentDataType.INTEGER, defense);
|
||||||
|
data.set(namespacedKey.itemDefenseKey, PersistentDataType.INTEGER, defense);
|
||||||
|
data.set(namespacedKey.strengthKey, PersistentDataType.INTEGER, strength);
|
||||||
|
data.set(namespacedKey.itemStrengthKey, PersistentDataType.INTEGER, itemDmg);
|
||||||
|
data.set(namespacedKey.nameKey, PersistentDataType.STRING, name);
|
||||||
|
data.set(namespacedKey.levelKey, PersistentDataType.INTEGER, level);
|
||||||
|
}
|
||||||
|
|
||||||
|
public static Attribute getattributesEntity(org.bukkit.entity.Entity e) {
|
||||||
|
PersistentDataContainer data = e.getPersistentDataContainer();
|
||||||
|
int health, itemHealth, defense, itemDefense, speed, itemSpeed, strength, itemDmg;
|
||||||
|
health = data.get(namespacedKey.healthKey, PersistentDataType.INTEGER);
|
||||||
|
itemHealth = data.get(namespacedKey.itemHealthKey, PersistentDataType.INTEGER);
|
||||||
|
defense = data.get(namespacedKey.defenseKey, PersistentDataType.INTEGER);
|
||||||
|
itemDefense = data.get(namespacedKey.itemDefenseKey, PersistentDataType.INTEGER);
|
||||||
|
speed = data.get(namespacedKey.speedKey, PersistentDataType.INTEGER);
|
||||||
|
itemSpeed = data.get(namespacedKey.itemSpeedKey, PersistentDataType.INTEGER);
|
||||||
|
strength = data.get(namespacedKey.strengthKey , PersistentDataType.INTEGER);
|
||||||
|
itemDmg = data.get(namespacedKey.itemStrengthKey, PersistentDataType.INTEGER);
|
||||||
|
return new Attribute(health, itemHealth, defense, itemDefense, speed, itemSpeed, strength, itemDmg);
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void updateSkills(LivingEntity livingEntity) {
|
||||||
|
Attributes attributes = new Attributes(main);
|
||||||
|
int health, itemHealth, defense, itemDefense, speed, itemSpeed, strength, itemDmg;
|
||||||
|
org.bukkit.entity.Entity e = livingEntity;
|
||||||
|
health = attributes.getHealth(e);
|
||||||
|
itemHealth = attributes.getItemHealth(e);
|
||||||
|
defense = attributes.getDefense(e);
|
||||||
|
itemDefense = attributes.getItemDefense(e);
|
||||||
|
speed = attributes.getSpeed(e);
|
||||||
|
itemSpeed = attributes.getItemSpeed(e);
|
||||||
|
strength = attributes.getStrength(e);
|
||||||
|
itemDmg = attributes.getItemStrength(e);
|
||||||
|
livingEntity.getAttribute(org.bukkit.attribute.Attribute.GENERIC_MAX_HEALTH).setBaseValue(20D + (health + itemHealth) / 100);
|
||||||
|
livingEntity.getAttribute(org.bukkit.attribute.Attribute.GENERIC_FLYING_SPEED).setBaseValue((float) (0.0 + ((speed + itemSpeed) / 100) * 0.2));
|
||||||
|
livingEntity.getAttribute(org.bukkit.attribute.Attribute.GENERIC_MOVEMENT_SPEED).setBaseValue((float) (0.0 + ((speed + itemSpeed) / 100) * 0.2));
|
||||||
|
log("Speed " + (speed + itemSpeed), "Health " + (health + itemHealth), "Defense " + (defense+itemDefense), "Strength " + (strength+itemDmg));
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
|
@ -5,16 +5,27 @@ import org.bukkit.NamespacedKey;
|
||||||
|
|
||||||
public class EntityNamespacedKey {
|
public class EntityNamespacedKey {
|
||||||
public EntityNamespacedKey(Raxen main) {
|
public EntityNamespacedKey(Raxen main) {
|
||||||
|
nameKey = new NamespacedKey(main, "name");
|
||||||
levelKey = new NamespacedKey(main, "level");
|
levelKey = new NamespacedKey(main, "level");
|
||||||
strengthKey = new NamespacedKey(main, "strength");
|
|
||||||
healthKey = new NamespacedKey(main, "health");
|
healthKey = new NamespacedKey(main, "health");
|
||||||
|
itemHealthKey = new NamespacedKey(main, "itemHealth");
|
||||||
speedKey = new NamespacedKey(main, "speed");
|
speedKey = new NamespacedKey(main, "speed");
|
||||||
|
itemSpeedKey = new NamespacedKey(main, "itemSpeedKey");
|
||||||
defenseKey = new NamespacedKey(main, "defense");
|
defenseKey = new NamespacedKey(main, "defense");
|
||||||
|
itemDefenseKey = new NamespacedKey(main, "itemDefense");
|
||||||
|
strengthKey = new NamespacedKey(main, "strength");
|
||||||
|
itemStrengthKey = new NamespacedKey(main, "itemDmg");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public final NamespacedKey nameKey;
|
||||||
public final NamespacedKey levelKey;
|
public final NamespacedKey levelKey;
|
||||||
public final NamespacedKey healthKey;
|
public final NamespacedKey healthKey;
|
||||||
|
public final NamespacedKey itemHealthKey;
|
||||||
public final NamespacedKey speedKey;
|
public final NamespacedKey speedKey;
|
||||||
|
public final NamespacedKey itemSpeedKey;
|
||||||
public final NamespacedKey defenseKey;
|
public final NamespacedKey defenseKey;
|
||||||
|
public final NamespacedKey itemDefenseKey;
|
||||||
public final NamespacedKey strengthKey;
|
public final NamespacedKey strengthKey;
|
||||||
|
public final NamespacedKey itemStrengthKey;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -0,0 +1,9 @@
|
||||||
|
package gq.unurled.raxen.components.entity.spawn;
|
||||||
|
|
||||||
|
import org.bukkit.Material;
|
||||||
|
import org.bukkit.attribute.Attribute;
|
||||||
|
import org.bukkit.inventory.ItemStack;
|
||||||
|
import org.bukkit.inventory.meta.ItemMeta;
|
||||||
|
|
||||||
|
public class Eggs {
|
||||||
|
}
|
|
@ -0,0 +1,22 @@
|
||||||
|
package gq.unurled.raxen.components.player.Attributes;
|
||||||
|
|
||||||
|
import lombok.Getter;
|
||||||
|
import lombok.Setter;
|
||||||
|
|
||||||
|
public class Attribute {
|
||||||
|
|
||||||
|
@Getter
|
||||||
|
@Setter
|
||||||
|
private int health, itemHealth, defense, itemDefense, speed, itemSpeed, strength, itemDmg;
|
||||||
|
|
||||||
|
public Attribute(int health, int itemHealth, int defense, int itemDefense, int speed, int itemSpeed, int strength, int itemDmg) {
|
||||||
|
this.health = health;
|
||||||
|
this.itemHealth = itemHealth;
|
||||||
|
this.defense = defense;
|
||||||
|
this.itemDefense = itemDefense;
|
||||||
|
this.speed = speed;
|
||||||
|
this.itemSpeed = itemSpeed;
|
||||||
|
this.strength = strength;
|
||||||
|
this.itemDmg = itemDmg;
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,180 @@
|
||||||
|
package gq.unurled.raxen.components.player.Attributes;
|
||||||
|
|
||||||
|
import gq.unurled.raxen.Raxen;
|
||||||
|
import gq.unurled.raxen.components.entity.EntityNamespacedKey;
|
||||||
|
import lombok.Getter;
|
||||||
|
import lombok.Setter;
|
||||||
|
import org.bukkit.entity.Player;
|
||||||
|
import org.bukkit.persistence.PersistentDataContainer;
|
||||||
|
import org.bukkit.persistence.PersistentDataType;
|
||||||
|
|
||||||
|
public class Attributes {
|
||||||
|
|
||||||
|
private static EntityNamespacedKey namespacedKey;
|
||||||
|
|
||||||
|
public Attributes(Raxen main) {
|
||||||
|
namespacedKey = new EntityNamespacedKey(main);
|
||||||
|
}
|
||||||
|
|
||||||
|
public static Attribute getAttribute(Player player) {
|
||||||
|
PersistentDataContainer data = player.getPersistentDataContainer();
|
||||||
|
int health, itemHealth, defense, itemDefense, speed, itemSpeed, strength, itemDmg;
|
||||||
|
health = data.get(namespacedKey.healthKey, PersistentDataType.INTEGER);
|
||||||
|
itemHealth = data.get(namespacedKey.itemHealthKey, PersistentDataType.INTEGER);
|
||||||
|
defense = data.get(namespacedKey.defenseKey, PersistentDataType.INTEGER);
|
||||||
|
itemDefense = data.get(namespacedKey.itemDefenseKey, PersistentDataType.INTEGER);
|
||||||
|
speed = data.get(namespacedKey.speedKey, PersistentDataType.INTEGER);
|
||||||
|
itemSpeed = data.get(namespacedKey.itemSpeedKey, PersistentDataType.INTEGER);
|
||||||
|
strength = data.get(namespacedKey.strengthKey , PersistentDataType.INTEGER);
|
||||||
|
itemDmg = data.get(namespacedKey.itemStrengthKey, PersistentDataType.INTEGER);
|
||||||
|
return new Attribute(health, itemHealth, defense, itemDefense, speed, itemSpeed, strength, itemDmg);
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void setAttributes(Player player, int health, int itemHealth, int defense, int itemDefense, int speed, int itemSpeed, int strength, int itemDmg) {
|
||||||
|
PersistentDataContainer data = player.getPersistentDataContainer();
|
||||||
|
data.set(namespacedKey.healthKey, PersistentDataType.INTEGER, health);
|
||||||
|
data.set(namespacedKey.itemHealthKey, PersistentDataType.INTEGER, itemHealth);
|
||||||
|
data.set(namespacedKey.defenseKey, PersistentDataType.INTEGER, defense);
|
||||||
|
data.set(namespacedKey.itemDefenseKey, PersistentDataType.INTEGER, itemDefense);
|
||||||
|
data.set(namespacedKey.speedKey, PersistentDataType.INTEGER, speed);
|
||||||
|
data.set(namespacedKey.itemSpeedKey, PersistentDataType.INTEGER, itemSpeed);
|
||||||
|
data.set(namespacedKey.strengthKey , PersistentDataType.INTEGER, strength);
|
||||||
|
data.set(namespacedKey.itemStrengthKey, PersistentDataType.INTEGER, itemDmg);
|
||||||
|
}
|
||||||
|
|
||||||
|
public void removeSpeed(Player player, int i) {
|
||||||
|
PersistentDataContainer data = player.getPersistentDataContainer();
|
||||||
|
data.set(namespacedKey.speedKey, PersistentDataType.INTEGER, data.get(namespacedKey.speedKey, PersistentDataType.INTEGER) -i);
|
||||||
|
}
|
||||||
|
public void removeHealth(Player player, int i) {
|
||||||
|
PersistentDataContainer data = player.getPersistentDataContainer();
|
||||||
|
data.set(namespacedKey.healthKey, PersistentDataType.INTEGER, data.get(namespacedKey.healthKey, PersistentDataType.INTEGER) -i);
|
||||||
|
}
|
||||||
|
public void removeDefense(Player player, int i) {
|
||||||
|
PersistentDataContainer data = player.getPersistentDataContainer();
|
||||||
|
data.set(namespacedKey.defenseKey, PersistentDataType.INTEGER, data.get(namespacedKey.defenseKey, PersistentDataType.INTEGER) -i);
|
||||||
|
}
|
||||||
|
public void removeStrength(Player player, int i) {
|
||||||
|
PersistentDataContainer data = player.getPersistentDataContainer();
|
||||||
|
data.set(namespacedKey.strengthKey, PersistentDataType.INTEGER, data.get(namespacedKey.strengthKey, PersistentDataType.INTEGER) -i);
|
||||||
|
}
|
||||||
|
|
||||||
|
public void removeItemSpeed(Player player, int i) {
|
||||||
|
PersistentDataContainer data = player.getPersistentDataContainer();
|
||||||
|
data.set(namespacedKey.itemSpeedKey, PersistentDataType.INTEGER, data.get(namespacedKey.itemSpeedKey, PersistentDataType.INTEGER) -i);
|
||||||
|
}
|
||||||
|
public void removeItemHealth(Player player, int i) {
|
||||||
|
PersistentDataContainer data = player.getPersistentDataContainer();
|
||||||
|
data.set(namespacedKey.itemHealthKey, PersistentDataType.INTEGER, data.get(namespacedKey.itemHealthKey, PersistentDataType.INTEGER) -i);
|
||||||
|
}
|
||||||
|
public void removeItemDefense(Player player, int i) {
|
||||||
|
PersistentDataContainer data = player.getPersistentDataContainer();
|
||||||
|
data.set(namespacedKey.itemDefenseKey, PersistentDataType.INTEGER, data.get(namespacedKey.itemDefenseKey, PersistentDataType.INTEGER) -i);
|
||||||
|
}
|
||||||
|
public void removeItemStrength(Player player, int i) {
|
||||||
|
PersistentDataContainer data = player.getPersistentDataContainer();
|
||||||
|
data.set(namespacedKey.itemStrengthKey, PersistentDataType.INTEGER, data.get(namespacedKey.itemStrengthKey, PersistentDataType.INTEGER) -i);
|
||||||
|
}
|
||||||
|
|
||||||
|
public void addSpeed(Player player, int i) {
|
||||||
|
PersistentDataContainer data = player.getPersistentDataContainer();
|
||||||
|
data.set(namespacedKey.speedKey, PersistentDataType.INTEGER, data.get(namespacedKey.speedKey, PersistentDataType.INTEGER) +i);
|
||||||
|
}
|
||||||
|
public void addHealth(Player player, int i) {
|
||||||
|
PersistentDataContainer data = player.getPersistentDataContainer();
|
||||||
|
data.set(namespacedKey.healthKey, PersistentDataType.INTEGER, data.get(namespacedKey.healthKey, PersistentDataType.INTEGER) +i);
|
||||||
|
}
|
||||||
|
public void addDefense(Player player, int i) {
|
||||||
|
PersistentDataContainer data = player.getPersistentDataContainer();
|
||||||
|
data.set(namespacedKey.defenseKey, PersistentDataType.INTEGER, data.get(namespacedKey.defenseKey, PersistentDataType.INTEGER) +i);
|
||||||
|
}
|
||||||
|
public void addStrength(Player player, int i) {
|
||||||
|
PersistentDataContainer data = player.getPersistentDataContainer();
|
||||||
|
data.set(namespacedKey.strengthKey, PersistentDataType.INTEGER, data.get(namespacedKey.strengthKey, PersistentDataType.INTEGER) +i);
|
||||||
|
}
|
||||||
|
|
||||||
|
public void addItemSpeed(Player player, int i) {
|
||||||
|
PersistentDataContainer data = player.getPersistentDataContainer();
|
||||||
|
data.set(namespacedKey.itemSpeedKey, PersistentDataType.INTEGER, data.get(namespacedKey.itemSpeedKey, PersistentDataType.INTEGER) +i);
|
||||||
|
}
|
||||||
|
public void addItemHealth(Player player, int i) {
|
||||||
|
PersistentDataContainer data = player.getPersistentDataContainer();
|
||||||
|
data.set(namespacedKey.itemHealthKey, PersistentDataType.INTEGER, data.get(namespacedKey.itemHealthKey, PersistentDataType.INTEGER) +i);
|
||||||
|
}
|
||||||
|
public void addItemDefense(Player player, int i) {
|
||||||
|
PersistentDataContainer data = player.getPersistentDataContainer();
|
||||||
|
data.set(namespacedKey.itemDefenseKey, PersistentDataType.INTEGER, data.get(namespacedKey.defenseKey, PersistentDataType.INTEGER) +i);
|
||||||
|
}
|
||||||
|
public void addItemStrength(Player player, int i) {
|
||||||
|
PersistentDataContainer data = player.getPersistentDataContainer();
|
||||||
|
data.set(namespacedKey.itemStrengthKey, PersistentDataType.INTEGER, data.get(namespacedKey.itemStrengthKey, PersistentDataType.INTEGER) +i);
|
||||||
|
}
|
||||||
|
|
||||||
|
public Integer getSpeed(Player player) {
|
||||||
|
PersistentDataContainer data = player.getPersistentDataContainer();
|
||||||
|
return data.get(namespacedKey.speedKey, PersistentDataType.INTEGER);
|
||||||
|
}
|
||||||
|
public Integer getStrength(Player player) {
|
||||||
|
PersistentDataContainer data = player.getPersistentDataContainer();
|
||||||
|
return data.get(namespacedKey.strengthKey, PersistentDataType.INTEGER);
|
||||||
|
}
|
||||||
|
public Integer getHealth(Player player) {
|
||||||
|
PersistentDataContainer data = player.getPersistentDataContainer();
|
||||||
|
return data.get(namespacedKey.healthKey, PersistentDataType.INTEGER);
|
||||||
|
}
|
||||||
|
public Integer getDefense(Player player) {
|
||||||
|
PersistentDataContainer data = player.getPersistentDataContainer();
|
||||||
|
return data.get(namespacedKey.defenseKey, PersistentDataType.INTEGER);
|
||||||
|
}
|
||||||
|
|
||||||
|
public Integer getItemSpeed(Player player) {
|
||||||
|
PersistentDataContainer data = player.getPersistentDataContainer();
|
||||||
|
return data.get(namespacedKey.itemSpeedKey, PersistentDataType.INTEGER);
|
||||||
|
}
|
||||||
|
public Integer getItemStrength(Player player) {
|
||||||
|
PersistentDataContainer data = player.getPersistentDataContainer();
|
||||||
|
return data.get(namespacedKey.itemStrengthKey, PersistentDataType.INTEGER);
|
||||||
|
}
|
||||||
|
public Integer getItemHealth(Player player) {
|
||||||
|
PersistentDataContainer data = player.getPersistentDataContainer();
|
||||||
|
return data.get(namespacedKey.itemHealthKey, PersistentDataType.INTEGER);
|
||||||
|
}
|
||||||
|
public Integer getItemDefense(Player player) {
|
||||||
|
PersistentDataContainer data = player.getPersistentDataContainer();
|
||||||
|
return data.get(namespacedKey.itemDefenseKey, PersistentDataType.INTEGER);
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setHealth(Player player, int i) {
|
||||||
|
PersistentDataContainer data = player.getPersistentDataContainer();
|
||||||
|
data.set(namespacedKey.healthKey, PersistentDataType.INTEGER, i);
|
||||||
|
}
|
||||||
|
public void setDefense(Player player, int i) {
|
||||||
|
PersistentDataContainer data = player.getPersistentDataContainer();
|
||||||
|
data.set(namespacedKey.defenseKey, PersistentDataType.INTEGER, i);
|
||||||
|
}
|
||||||
|
public void setSpeed(Player player, int i) {
|
||||||
|
PersistentDataContainer data = player.getPersistentDataContainer();
|
||||||
|
data.set(namespacedKey.speedKey, PersistentDataType.INTEGER, i);
|
||||||
|
}
|
||||||
|
public void setStrength(Player player, int i) {
|
||||||
|
PersistentDataContainer data = player.getPersistentDataContainer();
|
||||||
|
data.set(namespacedKey.strengthKey, PersistentDataType.INTEGER, i);
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setItemHealth(Player player, int i) {
|
||||||
|
PersistentDataContainer data = player.getPersistentDataContainer();
|
||||||
|
data.set(namespacedKey.itemHealthKey, PersistentDataType.INTEGER, i);
|
||||||
|
}
|
||||||
|
public void setItemDefense(Player player, int i) {
|
||||||
|
PersistentDataContainer data = player.getPersistentDataContainer();
|
||||||
|
data.set(namespacedKey.itemDefenseKey, PersistentDataType.INTEGER, i);
|
||||||
|
}
|
||||||
|
public void setItemSpeed(Player player, int i) {
|
||||||
|
PersistentDataContainer data = player.getPersistentDataContainer();
|
||||||
|
data.set(namespacedKey.itemSpeedKey, PersistentDataType.INTEGER, i);
|
||||||
|
}
|
||||||
|
public void setItemStrength(Player player, int i) {
|
||||||
|
PersistentDataContainer data = player.getPersistentDataContainer();
|
||||||
|
data.set(namespacedKey.itemStrengthKey, PersistentDataType.INTEGER, i);
|
||||||
|
}
|
||||||
|
}
|
|
@ -1,18 +1,20 @@
|
||||||
package gq.unurled.raxen.components.player;
|
package gq.unurled.raxen.components.player;
|
||||||
|
|
||||||
|
import gq.unurled.raxen.components.player.Attributes.Attributes;
|
||||||
|
|
||||||
public class Profile {
|
public class Profile {
|
||||||
|
|
||||||
private Skills skils;
|
private Attributes skils;
|
||||||
|
|
||||||
public Profile(Skills skils) {
|
public Profile(Attributes skils) {
|
||||||
this.skils = skils;
|
this.skils = skils;
|
||||||
}
|
}
|
||||||
|
|
||||||
public Skills getSkils() {
|
public Attributes getSkils() {
|
||||||
return skils;
|
return skils;
|
||||||
}
|
}
|
||||||
|
|
||||||
public void setSkils(Skills skils) {
|
public void setSkils(Attributes skils) {
|
||||||
this.skils = skils;
|
this.skils = skils;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,74 +0,0 @@
|
||||||
package gq.unurled.raxen.components.player;
|
|
||||||
|
|
||||||
import lombok.Getter;
|
|
||||||
import lombok.Setter;
|
|
||||||
|
|
||||||
public class Skills {
|
|
||||||
|
|
||||||
@Getter
|
|
||||||
@Setter
|
|
||||||
private int health, itemHealth, defense, itemDefense, speed, itemSpeed, strength, itemDmg;
|
|
||||||
|
|
||||||
public Skills(int health, int itemHealth, int defense, int itemDefense, int speed, int itemSpeed, int strength, int itemDmg) {
|
|
||||||
this.health = health;
|
|
||||||
this.itemHealth = health;
|
|
||||||
this.defense = defense;
|
|
||||||
this.itemDefense = itemDefense;
|
|
||||||
this.speed = speed;
|
|
||||||
this.itemSpeed = speed;
|
|
||||||
this.strength = strength;
|
|
||||||
this.itemDmg = itemDmg;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void removeSpeed(int i) {
|
|
||||||
this.speed =this.getSpeed() - i;
|
|
||||||
}
|
|
||||||
public void removeHealth(int i) {
|
|
||||||
this.health =this.getHealth() - i;
|
|
||||||
}
|
|
||||||
public void removeDefense(int i) {
|
|
||||||
this.defense =this.getDefense() - i;
|
|
||||||
}
|
|
||||||
public void removeStrength(int i) {
|
|
||||||
this.strength =this.getStrength() - i;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void removeItemSpeed(int i) {
|
|
||||||
this.itemSpeed =this.getItemSpeed() - i;
|
|
||||||
}
|
|
||||||
public void removeItemHealth(int i) {
|
|
||||||
this.itemHealth =this.getItemHealth() - i;
|
|
||||||
}
|
|
||||||
public void removeItemDefense(int i) {
|
|
||||||
this.itemDefense =this.getItemDefense() - i;
|
|
||||||
}
|
|
||||||
public void removeItemStrength(int i) {
|
|
||||||
this.itemDmg =this.getItemDmg() - i;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void addSpeed(int i) {
|
|
||||||
this.speed = this.getSpeed() + i;
|
|
||||||
}
|
|
||||||
public void addHealth(int i) {
|
|
||||||
this.health = this.getHealth() + i;
|
|
||||||
}
|
|
||||||
public void addDefense(int i) {
|
|
||||||
this.defense = this.getDefense() + i;
|
|
||||||
}
|
|
||||||
public void addStrength(int i) {
|
|
||||||
this.strength = this.getStrength() + i;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void addItemSpeed(int i) {
|
|
||||||
this.itemSpeed = this.getItemSpeed() + i;
|
|
||||||
}
|
|
||||||
public void addItemHealth(int i) {
|
|
||||||
this.itemHealth = this.getItemHealth() + i;
|
|
||||||
}
|
|
||||||
public void addItemDefense(int i) {
|
|
||||||
this.itemDefense = this.getItemDefense() + i;
|
|
||||||
}
|
|
||||||
public void addItemStrength(int i) {
|
|
||||||
this.itemDmg = this.getItemDmg() + i;
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -12,10 +12,10 @@ public class ResourcePack {
|
||||||
private FileConfiguration config;
|
private FileConfiguration config;
|
||||||
private ResourcePackManager resourcePackManager;
|
private ResourcePackManager resourcePackManager;
|
||||||
|
|
||||||
public ResourcePack(Raxen main) {
|
public ResourcePack(Raxen main, ResourcePackManager manager) {
|
||||||
this.main = main;
|
this.main = main;
|
||||||
this.config = main.getConfig();
|
this.config = main.getConfig();
|
||||||
this.resourcePackManager = main.getResourcePackManager();
|
this.resourcePackManager = manager;
|
||||||
}
|
}
|
||||||
|
|
||||||
public void join(Player player) {
|
public void join(Player player) {
|
||||||
|
|
|
@ -2,9 +2,15 @@ package gq.unurled.raxen.config;
|
||||||
|
|
||||||
import gq.unurled.raxen.Raxen;
|
import gq.unurled.raxen.Raxen;
|
||||||
import lombok.Getter;
|
import lombok.Getter;
|
||||||
|
import org.bukkit.configuration.InvalidConfigurationException;
|
||||||
import org.bukkit.configuration.file.FileConfiguration;
|
import org.bukkit.configuration.file.FileConfiguration;
|
||||||
|
import org.bukkit.configuration.file.YamlConfiguration;
|
||||||
|
|
||||||
import java.io.File;
|
import java.io.File;
|
||||||
|
import java.io.FileNotFoundException;
|
||||||
|
import java.io.IOException;
|
||||||
|
|
||||||
|
import static gq.unurled.raxen.utils.Utils.log;
|
||||||
|
|
||||||
public class Config {
|
public class Config {
|
||||||
private Raxen main;
|
private Raxen main;
|
||||||
|
@ -27,8 +33,16 @@ public class Config {
|
||||||
if (!(configFile.exists())) {
|
if (!(configFile.exists())) {
|
||||||
main.saveDefaultConfig();
|
main.saveDefaultConfig();
|
||||||
}
|
}
|
||||||
if(!main.getVersion().equalsIgnoreCase((String) config.get("version"))){
|
FileConfiguration conf = new YamlConfiguration();
|
||||||
main.saveDefaultConfig();
|
log(config.getString("version"));
|
||||||
|
try {
|
||||||
|
conf.load(configFile);
|
||||||
|
} catch (IOException | InvalidConfigurationException e) {
|
||||||
|
e.printStackTrace();
|
||||||
|
}
|
||||||
|
log(conf.getString("version"));
|
||||||
|
if(!Raxen.getVersion().equals(config.getString("version"))){
|
||||||
|
main.saveResource("config.yml", true);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -3,9 +3,9 @@ package gq.unurled.raxen.config;
|
||||||
import com.mongodb.client.MongoCollection;
|
import com.mongodb.client.MongoCollection;
|
||||||
import com.mongodb.client.model.Filters;
|
import com.mongodb.client.model.Filters;
|
||||||
import gq.unurled.raxen.Raxen;
|
import gq.unurled.raxen.Raxen;
|
||||||
|
import gq.unurled.raxen.components.player.Attributes.Attribute;
|
||||||
|
import gq.unurled.raxen.components.player.Attributes.Attributes;
|
||||||
import gq.unurled.raxen.components.player.Inventories;
|
import gq.unurled.raxen.components.player.Inventories;
|
||||||
import gq.unurled.raxen.components.player.Profile;
|
|
||||||
import gq.unurled.raxen.components.player.Skills;
|
|
||||||
import gq.unurled.raxen.components.player.Storage;
|
import gq.unurled.raxen.components.player.Storage;
|
||||||
import gq.unurled.raxen.components.player.Storages.EnderChest;
|
import gq.unurled.raxen.components.player.Storages.EnderChest;
|
||||||
import gq.unurled.raxen.manager.ProfileManager;
|
import gq.unurled.raxen.manager.ProfileManager;
|
||||||
|
@ -38,25 +38,28 @@ public class PlayerConfig {
|
||||||
private static StorageManager sto;
|
private static StorageManager sto;
|
||||||
|
|
||||||
public PlayerConfig(Raxen main) {
|
public PlayerConfig(Raxen main) {
|
||||||
this.main = main;
|
PlayerConfig.main = main;
|
||||||
this.sto = main.getStorageManager();
|
sto = Raxen.getStorageManager();
|
||||||
this.mongoDB = sto.getMongo();
|
this.mongoDB = StorageManager.getMongo();
|
||||||
this.mongoDB.connect();
|
|
||||||
this.mongoCollection = mongoDB.getMongoCollection();
|
this.mongoCollection = mongoDB.getMongoCollection();
|
||||||
this.profileManager = main.getProfileManager();
|
profileManager = Raxen.getProfileManager();
|
||||||
}
|
}
|
||||||
|
|
||||||
public void saveUsingMongoDB(Player player, Skills skills, String invstr, Integer reverse) {
|
public void close() {
|
||||||
|
mongoDB.close();
|
||||||
|
}
|
||||||
|
|
||||||
|
public void saveUsingMongoDB(Player player, Attributes attributes, String invstr, Integer reverse) {
|
||||||
Document doc = new Document("uuid", player.getUniqueId().toString())
|
Document doc = new Document("uuid", player.getUniqueId().toString())
|
||||||
.append("name", player.getName())
|
.append("name", player.getName())
|
||||||
.append("health", skills.getHealth())
|
.append("health", attributes.getHealth(player))
|
||||||
.append("itemHealth", skills.getItemHealth())
|
.append("itemHealth", attributes.getItemHealth(player))
|
||||||
.append("defense", skills.getDefense())
|
.append("defense", attributes.getDefense(player))
|
||||||
.append("itemDefense", skills.getItemDefense())
|
.append("itemDefense", attributes.getItemDefense(player))
|
||||||
.append("speed", skills.getSpeed())
|
.append("speed", attributes.getSpeed(player))
|
||||||
.append("itemSpeed", skills.getItemSpeed())
|
.append("itemSpeed", attributes.getItemSpeed(player))
|
||||||
.append("strength", skills.getStrength())
|
.append("strength", attributes.getStrength(player))
|
||||||
.append("itemDmg", skills.getItemDmg())
|
.append("itemDmg", attributes.getItemStrength(player))
|
||||||
.append("inv", invstr);
|
.append("inv", invstr);
|
||||||
if (profileManager.getPlayerStorage(player.getUniqueId()) != null) {
|
if (profileManager.getPlayerStorage(player.getUniqueId()) != null) {
|
||||||
if(profileManager.getPlayerStorage(player.getUniqueId()).getEc() != null) {
|
if(profileManager.getPlayerStorage(player.getUniqueId()).getEc() != null) {
|
||||||
|
@ -77,23 +80,25 @@ public class PlayerConfig {
|
||||||
Document playerDoc = mongoCollection.find(Filters.eq("uuid", player.getUniqueId().toString())).first();
|
Document playerDoc = mongoCollection.find(Filters.eq("uuid", player.getUniqueId().toString())).first();
|
||||||
if(playerDoc == null) {
|
if(playerDoc == null) {
|
||||||
mongoCollection.insertOne(doc);
|
mongoCollection.insertOne(doc);
|
||||||
|
log("insert one");
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
mongoCollection.replaceOne(Filters.eq("uuid", player.getUniqueId().toString()), doc);
|
mongoCollection.replaceOne(Filters.eq("uuid", player.getUniqueId().toString()), doc);
|
||||||
|
log("replace one");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public void saveUsingYml(Player player, Skills skills, String invstr, Integer reverse) {
|
public void saveUsingYml(Player player, Attributes attributes, String invstr, Integer reverse) {
|
||||||
FileConfiguration config = sto.createYml(player);
|
FileConfiguration config = sto.createYml(player);
|
||||||
config.set("name", player.getName());
|
config.set("name", player.getName());
|
||||||
config.set("health", skills.getHealth());
|
config.set("health", attributes.getHealth(player));
|
||||||
config.set("itemHealth", skills.getItemHealth());
|
config.set("itemHealth", attributes.getItemHealth(player));
|
||||||
config.set("strength", skills.getStrength());
|
config.set("strength", attributes.getStrength(player));
|
||||||
config.set("itemDmg", skills.getItemDmg());
|
config.set("itemDmg", attributes.getItemStrength(player));
|
||||||
config.set("speed", skills.getSpeed());
|
config.set("speed", attributes.getSpeed(player));
|
||||||
config.set("itemSpeed", skills.getItemSpeed());
|
config.set("itemSpeed", attributes.getItemSpeed(player));
|
||||||
config.set("defense", skills.getDefense());
|
config.set("defense", attributes.getDefense(player));
|
||||||
config.set("itemDefense", skills.getItemDefense());
|
config.set("itemDefense", attributes.getItemDefense(player));
|
||||||
config.set("inv", invstr);
|
config.set("inv", invstr);
|
||||||
if (profileManager.getPlayerStorage(player.getUniqueId()) != null) {
|
if (profileManager.getPlayerStorage(player.getUniqueId()) != null) {
|
||||||
if(profileManager.getPlayerStorage(player.getUniqueId()).getEc() != null) {
|
if(profileManager.getPlayerStorage(player.getUniqueId()).getEc() != null) {
|
||||||
|
@ -121,15 +126,16 @@ public class PlayerConfig {
|
||||||
public void loadUsingMongoDB(Player player) {
|
public void loadUsingMongoDB(Player player) {
|
||||||
Document playerDoc = mongoCollection.find(Filters.eq("uuid", player.getUniqueId().toString())).first();
|
Document playerDoc = mongoCollection.find(Filters.eq("uuid", player.getUniqueId().toString())).first();
|
||||||
if(playerDoc == null) {
|
if(playerDoc == null) {
|
||||||
|
log("something went wrong");
|
||||||
profileManager.createNewProfile(player);
|
profileManager.createNewProfile(player);
|
||||||
profileManager.createNewStorage(player);
|
profileManager.createNewStorage(player);
|
||||||
profileManager.createNewInventory(player);
|
profileManager.createNewInventory(player);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
Skills skills = new Skills(playerDoc.getInteger("health"), playerDoc.getInteger("itemHealth"), playerDoc.getInteger("defense"), playerDoc.getInteger("itemDefense"), playerDoc.getInteger("speed"), playerDoc.getInteger("itemSpeed"), playerDoc.getInteger("strength"), playerDoc.getInteger("itemDmg"));
|
Attributes.setAttributes(player, playerDoc.getInteger("health"), playerDoc.getInteger("itemHealth"), playerDoc.getInteger("defense"),
|
||||||
Profile profile = new Profile(skills);
|
playerDoc.getInteger("itemDefense"), playerDoc.getInteger("speed"), playerDoc.getInteger("itemSpeed"),
|
||||||
|
playerDoc.getInteger("strength"), playerDoc.getInteger("itemDmg"));
|
||||||
|
|
||||||
profileManager.setPlayerProfile(player.getUniqueId(), profile);
|
|
||||||
Inventory ec = Bukkit.createInventory(null, 54, Component.text("Ender Chest"));
|
Inventory ec = Bukkit.createInventory(null, 54, Component.text("Ender Chest"));
|
||||||
if(playerDoc.getString("ec") != null) {
|
if(playerDoc.getString("ec") != null) {
|
||||||
ItemStack[] itList = Items.listItemStackDeserilize(playerDoc.getString("ec"));
|
ItemStack[] itList = Items.listItemStackDeserilize(playerDoc.getString("ec"));
|
||||||
|
@ -148,13 +154,11 @@ public class PlayerConfig {
|
||||||
}
|
}
|
||||||
|
|
||||||
public void loadUsingYml(Player player) throws IOException {
|
public void loadUsingYml(Player player) throws IOException {
|
||||||
FileConfiguration config = sto.createYml(player);
|
FileConfiguration config = sto.createYml(player);
|
||||||
Skills skills = new Skills(config.getInt("health"), config.getInt("itemHealth"),
|
Attributes.setAttributes(player, config.getInt("health"), config.getInt("itemHealth"),
|
||||||
config.getInt("defense"), config.getInt("itemDefense"),
|
config.getInt("defense"), config.getInt("itemDefense"),
|
||||||
config.getInt("speed"), config.getInt("itemSpeed"),
|
config.getInt("speed"), config.getInt("itemSpeed"),
|
||||||
config.getInt("strength"), config.getInt("itemDmg"));
|
config.getInt("strength"), config.getInt("itemDmg"));
|
||||||
Profile profile = new Profile(skills);
|
|
||||||
profileManager.setPlayerProfile(player.getUniqueId(), profile);
|
|
||||||
|
|
||||||
Inventory ec = Bukkit.createInventory(null, 54, Component.text("Ender Chest"));
|
Inventory ec = Bukkit.createInventory(null, 54, Component.text("Ender Chest"));
|
||||||
if((String) config.get("ec") != null) {
|
if((String) config.get("ec") != null) {
|
||||||
|
@ -174,7 +178,7 @@ public class PlayerConfig {
|
||||||
}
|
}
|
||||||
|
|
||||||
public void savePlayerConfig(Player player) {
|
public void savePlayerConfig(Player player) {
|
||||||
Skills skills = profileManager.getPlayerProfile(player.getUniqueId()).getSkils();
|
Attributes attributes = new Attributes(main);
|
||||||
Inventory inv = player.getInventory();
|
Inventory inv = player.getInventory();
|
||||||
List<String> listInv = new ArrayList<String>();
|
List<String> listInv = new ArrayList<String>();
|
||||||
Integer reverse = 0;
|
Integer reverse = 0;
|
||||||
|
@ -186,34 +190,36 @@ public class PlayerConfig {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
String invstr = Items.listItemStackSerelize(listInv);
|
String invstr = Items.listItemStackSerelize(listInv);
|
||||||
|
log("saving...");
|
||||||
|
String storage = sto.getConfig().getString("storage");
|
||||||
Object storage = sto.getConfig().get("storage");
|
saveUsingMongoDB(player, attributes, invstr, reverse);
|
||||||
if (storage == "MONGODB") {
|
log("using mongo");
|
||||||
saveUsingMongoDB(player, skills, invstr, reverse);
|
if (storage == "MYSQL" || storage == "YML") {
|
||||||
saveUsingMongoDB(player, skills, invstr, reverse);
|
saveUsingYml(player, attributes, invstr, reverse);
|
||||||
} else if (storage == "MYSQL" || storage == "YML") {
|
log("using yml");
|
||||||
saveUsingYml(player, skills, invstr, reverse);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
log("Player: " + player.getName() + " data successfully saved!");
|
log("Player: " + player.getName() + " data successfully saved!");
|
||||||
}
|
}
|
||||||
|
|
||||||
public void loadPlayerConfig(Player player) {
|
public void loadPlayerConfig(Player player) {
|
||||||
String st = (String) StorageManager.getConfig().get("storage");
|
String st = StorageManager.getConfig().getString("storage");
|
||||||
|
String value = "";
|
||||||
if (st.equals("MONGODB")) {
|
if (st.equals("MONGODB")) {
|
||||||
loadUsingMongoDB(player);
|
loadUsingMongoDB(player);
|
||||||
|
value = "mongodb";
|
||||||
warn("'" + st + "'");
|
warn("'" + st + "'");
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
warn("'" + st + "'");
|
warn("'" + st + "'");
|
||||||
|
value = "yml";
|
||||||
try {
|
try {
|
||||||
loadUsingYml(player);
|
loadUsingYml(player);
|
||||||
} catch (IOException e) {
|
} catch (IOException e) {
|
||||||
e.printStackTrace();
|
e.printStackTrace();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
log("Player: " + player.getName() + " data successfully loaded!");
|
log("Player: " + player.getName() + " data successfully loaded using " + value);
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -3,7 +3,6 @@ package gq.unurled.raxen.listener.entity;
|
||||||
import gq.unurled.raxen.Raxen;
|
import gq.unurled.raxen.Raxen;
|
||||||
import gq.unurled.raxen.components.entity.EntityNamespacedKey;
|
import gq.unurled.raxen.components.entity.EntityNamespacedKey;
|
||||||
import gq.unurled.raxen.components.items.Attributes;
|
import gq.unurled.raxen.components.items.Attributes;
|
||||||
import gq.unurled.raxen.components.player.Skills;
|
|
||||||
import gq.unurled.raxen.manager.ProfileManager;
|
import gq.unurled.raxen.manager.ProfileManager;
|
||||||
import gq.unurled.raxen.utils.Items;
|
import gq.unurled.raxen.utils.Items;
|
||||||
import org.bukkit.attribute.Attribute;
|
import org.bukkit.attribute.Attribute;
|
||||||
|
@ -16,6 +15,8 @@ import org.bukkit.event.entity.EntityDamageByEntityEvent;
|
||||||
import org.bukkit.persistence.PersistentDataContainer;
|
import org.bukkit.persistence.PersistentDataContainer;
|
||||||
import org.bukkit.persistence.PersistentDataType;
|
import org.bukkit.persistence.PersistentDataType;
|
||||||
|
|
||||||
|
import static gq.unurled.raxen.utils.Utils.log;
|
||||||
|
|
||||||
public class DamageEntity implements Listener {
|
public class DamageEntity implements Listener {
|
||||||
private Raxen main;
|
private Raxen main;
|
||||||
private ProfileManager profileManager;
|
private ProfileManager profileManager;
|
||||||
|
@ -38,11 +39,12 @@ public class DamageEntity implements Listener {
|
||||||
Integer health = 0;
|
Integer health = 0;
|
||||||
Integer itemHealth = 0;
|
Integer itemHealth = 0;
|
||||||
Integer initDamage = 0;
|
Integer initDamage = 0;
|
||||||
|
log(e.getEntity().getName(), e.getEntity().getType().toString(), e.getDamager().getType().toString(), e.getDamager().getName());
|
||||||
if (e.getDamager() instanceof Player) {
|
if (e.getDamager() instanceof Player) {
|
||||||
Player playerDamager = (Player) e.getDamager();
|
Player playerDamager = (Player) e.getDamager();
|
||||||
Skills skills = profileManager.getPlayerProfile(playerDamager.getUniqueId()).getSkils();
|
gq.unurled.raxen.components.player.Attributes.Attributes attributes = new gq.unurled.raxen.components.player.Attributes.Attributes(main);
|
||||||
strength = skills.getStrength();
|
strength = attributes.getStrength(playerDamager);
|
||||||
itemDmg = skills.getItemDmg();
|
itemDmg = attributes.getItemStrength(playerDamager);
|
||||||
} else {
|
} else {
|
||||||
Entity entityDamager = e.getDamager();
|
Entity entityDamager = e.getDamager();
|
||||||
PersistentDataContainer data = entityDamager.getPersistentDataContainer();
|
PersistentDataContainer data = entityDamager.getPersistentDataContainer();
|
||||||
|
@ -54,11 +56,11 @@ public class DamageEntity implements Listener {
|
||||||
}
|
}
|
||||||
if (e.getEntity() instanceof Player) {
|
if (e.getEntity() instanceof Player) {
|
||||||
Player playerVictim = (Player) e.getEntity();
|
Player playerVictim = (Player) e.getEntity();
|
||||||
Skills skills = profileManager.getPlayerProfile(playerVictim.getUniqueId()).getSkils();
|
gq.unurled.raxen.components.player.Attributes.Attributes attributes = new gq.unurled.raxen.components.player.Attributes.Attributes(main);
|
||||||
defense = skills.getDefense();
|
defense = attributes.getDefense(playerVictim);
|
||||||
health = skills.getHealth();
|
health = attributes.getHealth(playerVictim);
|
||||||
itemDefense = skills.getItemDefense();
|
itemDefense = attributes.getItemDefense(playerVictim);
|
||||||
itemHealth = skills.getItemHealth();
|
itemHealth = attributes.getItemHealth(playerVictim);
|
||||||
} else {
|
} else {
|
||||||
Entity entityVictim = e.getEntity();
|
Entity entityVictim = e.getEntity();
|
||||||
PersistentDataContainer data = entityVictim.getPersistentDataContainer();
|
PersistentDataContainer data = entityVictim.getPersistentDataContainer();
|
||||||
|
@ -75,16 +77,22 @@ public class DamageEntity implements Listener {
|
||||||
initDamage = (5+ itemDmg) * (1+ (strength/100));
|
initDamage = (5+ itemDmg) * (1+ (strength/100));
|
||||||
damage = initDamage;
|
damage = initDamage;
|
||||||
defense = defense + itemDefense;
|
defense = defense + itemDefense;
|
||||||
|
log(String.valueOf(damage));
|
||||||
defense = defense/(defense+100);
|
defense = defense/(defense+100);
|
||||||
damage = damage*defense;
|
log(String.valueOf(damage));
|
||||||
if (damage >= health) {
|
log(String.valueOf(defense));
|
||||||
|
Integer health_with_defense = health * (1+ (defense/100));
|
||||||
|
log(String.valueOf(damage));
|
||||||
|
log(String.valueOf(health));
|
||||||
|
log(String.valueOf(health_with_defense));
|
||||||
|
if (damage >= health_with_defense) {
|
||||||
e.setDamage(e.getEntity().getType().getDefaultAttributes().getAttribute(Attribute.GENERIC_MAX_HEALTH).getDefaultValue());
|
e.setDamage(e.getEntity().getType().getDefaultAttributes().getAttribute(Attribute.GENERIC_MAX_HEALTH).getDefaultValue());
|
||||||
} else {
|
} else {
|
||||||
health = health - damage;
|
health = health_with_defense - health - damage;
|
||||||
if (e.getEntity() instanceof Player) {
|
if (e.getEntity() instanceof Player) {
|
||||||
Player playerVictim = (Player) e.getEntity();
|
Player playerVictim = (Player) e.getEntity();
|
||||||
Skills skills = profileManager.getPlayerProfile(playerVictim.getUniqueId()).getSkils();
|
gq.unurled.raxen.components.player.Attributes.Attributes attributes = new gq.unurled.raxen.components.player.Attributes.Attributes(main);
|
||||||
skills.setHealth(health);
|
attributes.setHealth(playerVictim, health);
|
||||||
} else {
|
} else {
|
||||||
Entity entityVictim = e.getEntity();
|
Entity entityVictim = e.getEntity();
|
||||||
PersistentDataContainer data = entityVictim.getPersistentDataContainer();
|
PersistentDataContainer data = entityVictim.getPersistentDataContainer();
|
||||||
|
|
|
@ -0,0 +1,24 @@
|
||||||
|
package gq.unurled.raxen.listener.entity;
|
||||||
|
|
||||||
|
import org.bukkit.entity.Entity;
|
||||||
|
import org.bukkit.entity.LivingEntity;
|
||||||
|
import org.bukkit.entity.Player;
|
||||||
|
import org.bukkit.event.EventHandler;
|
||||||
|
import org.bukkit.event.Listener;
|
||||||
|
import org.bukkit.event.entity.EntitySpawnEvent;
|
||||||
|
|
||||||
|
import static gq.unurled.raxen.components.entity.Entity.updateSkills;
|
||||||
|
import static gq.unurled.raxen.utils.Utils.log;
|
||||||
|
|
||||||
|
public class SpawnEvent implements Listener {
|
||||||
|
@EventHandler
|
||||||
|
public void Spawn(EntitySpawnEvent e) {
|
||||||
|
if (e.getEntity() instanceof Player) {
|
||||||
|
//player stuff dont want to talk about it;
|
||||||
|
log("Player: " + ((Player) e.getEntity()).getName());
|
||||||
|
} else {
|
||||||
|
log(e.getEntity().getName());
|
||||||
|
updateSkills((LivingEntity) e.getEntity());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
|
@ -3,7 +3,7 @@ package gq.unurled.raxen.listener.player;
|
||||||
import com.destroystokyo.paper.event.player.PlayerArmorChangeEvent;
|
import com.destroystokyo.paper.event.player.PlayerArmorChangeEvent;
|
||||||
import de.tr7zw.changeme.nbtapi.NBTItem;
|
import de.tr7zw.changeme.nbtapi.NBTItem;
|
||||||
import gq.unurled.raxen.Raxen;
|
import gq.unurled.raxen.Raxen;
|
||||||
import gq.unurled.raxen.components.player.Skills;
|
import gq.unurled.raxen.components.player.Attributes.Attributes;
|
||||||
import gq.unurled.raxen.manager.ProfileManager;
|
import gq.unurled.raxen.manager.ProfileManager;
|
||||||
import org.bukkit.Material;
|
import org.bukkit.Material;
|
||||||
import org.bukkit.entity.Player;
|
import org.bukkit.entity.Player;
|
||||||
|
@ -14,47 +14,49 @@ import org.bukkit.inventory.ItemStack;
|
||||||
public class ArmorEvent implements Listener {
|
public class ArmorEvent implements Listener {
|
||||||
|
|
||||||
private ProfileManager profileManager;
|
private ProfileManager profileManager;
|
||||||
|
private Raxen main;
|
||||||
|
|
||||||
public ArmorEvent(Raxen main) {
|
public ArmorEvent(Raxen main) {
|
||||||
|
this.main = main;
|
||||||
this.profileManager = main.getProfileManager();
|
this.profileManager = main.getProfileManager();
|
||||||
}
|
}
|
||||||
|
|
||||||
@EventHandler
|
@EventHandler
|
||||||
public void ArmorChangeEvent(PlayerArmorChangeEvent e) {
|
public void ArmorChangeEvent(PlayerArmorChangeEvent e) {
|
||||||
Player player = e.getPlayer();
|
Player player = e.getPlayer();
|
||||||
Skills skills = profileManager.getPlayerProfile(player.getUniqueId()).getSkils();
|
Attributes attributes = new Attributes(main);
|
||||||
if(e.getOldItem() != null && e.getOldItem().getType() != Material.AIR) {
|
if(e.getOldItem() != null && e.getOldItem().getType() != Material.AIR) {
|
||||||
ItemStack oldItem = e.getOldItem();
|
ItemStack oldItem = e.getOldItem();
|
||||||
NBTItem nbti = new NBTItem(oldItem);
|
NBTItem nbti = new NBTItem(oldItem);
|
||||||
if(nbti.hasKey("SPEED")) {
|
if(nbti.hasKey("SPEED")) {
|
||||||
skills.removeSpeed(nbti.getInteger("SPEED"));
|
attributes.removeSpeed(player, nbti.getInteger("SPEED"));
|
||||||
}
|
}
|
||||||
if(nbti.hasKey("HEALTH")) {
|
if(nbti.hasKey("HEALTH")) {
|
||||||
skills.removeHealth(nbti.getInteger("HEALTH"));
|
attributes.removeHealth(player, nbti.getInteger("HEALTH"));
|
||||||
}
|
}
|
||||||
if(nbti.hasKey("DEFENSE")) {
|
if(nbti.hasKey("DEFENSE")) {
|
||||||
skills.removeDefense(nbti.getInteger("DEFENSE"));
|
attributes.removeDefense(player, nbti.getInteger("DEFENSE"));
|
||||||
}
|
}
|
||||||
if(nbti.hasKey("STRENGTH")) {
|
if(nbti.hasKey("STRENGTH")) {
|
||||||
skills.removeStrength(nbti.getInteger("STRENGTH"));
|
attributes.removeStrength(player, nbti.getInteger("STRENGTH"));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if(e.getNewItem() != null && e.getNewItem().getType() != Material.AIR) {
|
if(e.getNewItem() != null && e.getNewItem().getType() != Material.AIR) {
|
||||||
ItemStack newItem = e.getNewItem();
|
ItemStack newItem = e.getNewItem();
|
||||||
NBTItem nbti = new NBTItem(newItem);
|
NBTItem nbti = new NBTItem(newItem);
|
||||||
if(nbti.hasKey("SPEED")) {
|
if(nbti.hasKey("SPEED")) {
|
||||||
skills.addSpeed(nbti.getInteger("SPEED"));
|
attributes.addSpeed(player, nbti.getInteger("SPEED"));
|
||||||
}
|
}
|
||||||
if(nbti.hasKey("HEALTH")) {
|
if(nbti.hasKey("HEALTH")) {
|
||||||
skills.addHealth(nbti.getInteger("HEALTH"));
|
attributes.addHealth(player, nbti.getInteger("HEALTH"));
|
||||||
}
|
}
|
||||||
if(nbti.hasKey("DEFENSE")) {
|
if(nbti.hasKey("DEFENSE")) {
|
||||||
skills.addDefense(nbti.getInteger("DEFENSE"));
|
attributes.addDefense(player, nbti.getInteger("DEFENSE"));
|
||||||
}
|
}
|
||||||
if(nbti.hasKey("STRENGTH")) {
|
if(nbti.hasKey("STRENGTH")) {
|
||||||
skills.addStrength(nbti.getInteger("STRENGTH"));
|
attributes.addStrength(player, nbti.getInteger("STRENGTH"));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
gq.unurled.raxen.utils.Skills.updateSkills(player);
|
gq.unurled.raxen.utils.Skills.updateSkills(main, player);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -2,7 +2,7 @@ package gq.unurled.raxen.listener.player;
|
||||||
|
|
||||||
import de.tr7zw.changeme.nbtapi.NBTItem;
|
import de.tr7zw.changeme.nbtapi.NBTItem;
|
||||||
import gq.unurled.raxen.Raxen;
|
import gq.unurled.raxen.Raxen;
|
||||||
import gq.unurled.raxen.components.player.Skills;
|
import gq.unurled.raxen.components.player.Attributes.Attributes;
|
||||||
import gq.unurled.raxen.manager.ProfileManager;
|
import gq.unurled.raxen.manager.ProfileManager;
|
||||||
import org.bukkit.Material;
|
import org.bukkit.Material;
|
||||||
import org.bukkit.entity.Player;
|
import org.bukkit.entity.Player;
|
||||||
|
@ -14,47 +14,49 @@ import org.bukkit.inventory.ItemStack;
|
||||||
public class ItemHandEvent implements Listener {
|
public class ItemHandEvent implements Listener {
|
||||||
|
|
||||||
private ProfileManager profileManager;
|
private ProfileManager profileManager;
|
||||||
|
private Raxen main;
|
||||||
|
|
||||||
public ItemHandEvent(Raxen main) {
|
public ItemHandEvent(Raxen main) {
|
||||||
|
this.main = main;
|
||||||
this.profileManager = main.getProfileManager();
|
this.profileManager = main.getProfileManager();
|
||||||
}
|
}
|
||||||
|
|
||||||
@EventHandler
|
@EventHandler
|
||||||
public void ItemHeldEvent(PlayerItemHeldEvent e) {
|
public void ItemHeldEvent(PlayerItemHeldEvent e) {
|
||||||
Player player = e.getPlayer();
|
Player player = e.getPlayer();
|
||||||
Skills skills = profileManager.getPlayerProfile(player.getUniqueId()).getSkils();
|
Attributes attributes = new Attributes(main);
|
||||||
ItemStack oldItem = player.getInventory().getItem(e.getPreviousSlot());
|
ItemStack oldItem = player.getInventory().getItem(e.getPreviousSlot());
|
||||||
ItemStack newItem = player.getInventory().getItem(e.getNewSlot());
|
ItemStack newItem = player.getInventory().getItem(e.getNewSlot());
|
||||||
if(oldItem != null && oldItem.getType() != Material.AIR) {
|
if(oldItem != null && oldItem.getType() != Material.AIR) {
|
||||||
NBTItem nbti = new NBTItem(oldItem);
|
NBTItem nbti = new NBTItem(oldItem);
|
||||||
if(nbti.hasKey("SPEED")) {
|
if(nbti.hasKey("SPEED")) {
|
||||||
skills.removeItemSpeed(nbti.getInteger("SPEED"));
|
attributes.removeItemSpeed(player, nbti.getInteger("SPEED"));
|
||||||
}
|
}
|
||||||
if(nbti.hasKey("HEALTH")) {
|
if(nbti.hasKey("HEALTH")) {
|
||||||
skills.removeItemHealth(nbti.getInteger("HEALTH"));
|
attributes.removeItemHealth(player, nbti.getInteger("HEALTH"));
|
||||||
}
|
}
|
||||||
if(nbti.hasKey("DEFENSE")) {
|
if(nbti.hasKey("DEFENSE")) {
|
||||||
skills.removeItemDefense(nbti.getInteger("DEFENSE"));
|
attributes.removeItemDefense(player, nbti.getInteger("DEFENSE"));
|
||||||
}
|
}
|
||||||
if(nbti.hasKey("STRENGTH")) {
|
if(nbti.hasKey("STRENGTH")) {
|
||||||
skills.removeItemStrength(nbti.getInteger("STRENGTH"));
|
attributes.removeItemStrength(player, nbti.getInteger("STRENGTH"));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if(newItem != null && newItem.getType() != Material.AIR) {
|
if(newItem != null && newItem.getType() != Material.AIR) {
|
||||||
NBTItem nbti = new NBTItem(newItem);
|
NBTItem nbti = new NBTItem(newItem);
|
||||||
if(nbti.hasKey("SPEED")) {
|
if(nbti.hasKey("SPEED")) {
|
||||||
skills.addItemSpeed(nbti.getInteger("SPEED"));
|
attributes.addItemSpeed(player, nbti.getInteger("SPEED"));
|
||||||
}
|
}
|
||||||
if(nbti.hasKey("HEALTH")) {
|
if(nbti.hasKey("HEALTH")) {
|
||||||
skills.addItemHealth(nbti.getInteger("HEALTH"));
|
attributes.addItemHealth(player, nbti.getInteger("HEALTH"));
|
||||||
}
|
}
|
||||||
if(nbti.hasKey("DEFENSE")) {
|
if(nbti.hasKey("DEFENSE")) {
|
||||||
skills.addItemDefense(nbti.getInteger("DEFENSE"));
|
attributes.addItemDefense(player, nbti.getInteger("DEFENSE"));
|
||||||
}
|
}
|
||||||
if(nbti.hasKey("STRENGTH")) {
|
if(nbti.hasKey("STRENGTH")) {
|
||||||
skills.addItemStrength(nbti.getInteger("STRENGTH"));
|
attributes.addItemStrength(player, nbti.getInteger("STRENGTH"));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
gq.unurled.raxen.utils.Skills.updateSkills(player);
|
gq.unurled.raxen.utils.Skills.updateSkills(main, player);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,9 +1,9 @@
|
||||||
package gq.unurled.raxen.manager;
|
package gq.unurled.raxen.manager;
|
||||||
|
|
||||||
import gq.unurled.raxen.Raxen;
|
import gq.unurled.raxen.Raxen;
|
||||||
|
import gq.unurled.raxen.components.entity.EntityNamespacedKey;
|
||||||
|
import gq.unurled.raxen.components.player.Attributes.Attributes;
|
||||||
import gq.unurled.raxen.components.player.Inventories;
|
import gq.unurled.raxen.components.player.Inventories;
|
||||||
import gq.unurled.raxen.components.player.Profile;
|
|
||||||
import gq.unurled.raxen.components.player.Skills;
|
|
||||||
import gq.unurled.raxen.components.player.Storage;
|
import gq.unurled.raxen.components.player.Storage;
|
||||||
import gq.unurled.raxen.components.player.Storages.EnderChest;
|
import gq.unurled.raxen.components.player.Storages.EnderChest;
|
||||||
import gq.unurled.raxen.components.player.Storages.Inventory;
|
import gq.unurled.raxen.components.player.Storages.Inventory;
|
||||||
|
@ -21,33 +21,17 @@ import static gq.unurled.raxen.utils.Utils.log;
|
||||||
public class ProfileManager {
|
public class ProfileManager {
|
||||||
|
|
||||||
private Raxen main;
|
private Raxen main;
|
||||||
private Map<UUID, Profile> profiles = new HashMap<>();
|
private EntityNamespacedKey namespacedKey;
|
||||||
private Map<UUID, Storage> storages = new HashMap<>();
|
private Map<UUID, Storage> storages = new HashMap<>();
|
||||||
private Map<UUID, Inventories> inventory = new HashMap<>();
|
private Map<UUID, Inventories> inventory = new HashMap<>();
|
||||||
|
|
||||||
public ProfileManager(Raxen main) {
|
public ProfileManager(Raxen main) {
|
||||||
this.main = main;
|
this.main = main;
|
||||||
|
this.namespacedKey = new EntityNamespacedKey(main);
|
||||||
}
|
}
|
||||||
|
|
||||||
public Profile createNewProfile(Player player) {
|
public void createNewProfile(Player player) {
|
||||||
Skills skills = new Skills( 100, 0, 50, 0, 100, 0, 100, 0);
|
Attributes.setAttributes(player, 100,0,50,0,100,0,100,0);
|
||||||
Profile profile = new Profile(skills);
|
|
||||||
profiles.put(player.getUniqueId(), profile);
|
|
||||||
return profile;
|
|
||||||
}
|
|
||||||
|
|
||||||
public Profile getPlayerProfile(UUID uuid) {
|
|
||||||
return profiles.get(uuid);
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setPlayerProfile(UUID uuid, Profile profile) {
|
|
||||||
if(profiles.get(uuid) == null) {
|
|
||||||
profiles.put(uuid, profile);
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
profiles.replace(uuid, profile);
|
|
||||||
}
|
|
||||||
log("Profile Updated!");
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public Storage createNewStorage(Player player) {
|
public Storage createNewStorage(Player player) {
|
||||||
|
|
|
@ -21,7 +21,7 @@ public class ResourcePackManager {
|
||||||
|
|
||||||
public ResourcePackManager(Raxen main) {
|
public ResourcePackManager(Raxen main) {
|
||||||
this.main = main;
|
this.main = main;
|
||||||
this.resourcePack = new ResourcePack(main);
|
this.resourcePack = new ResourcePack(main, this);
|
||||||
this.config = main.getConfig();
|
this.config = main.getConfig();
|
||||||
this.useRP = this.config.getBoolean("useResourcePack");
|
this.useRP = this.config.getBoolean("useResourcePack");
|
||||||
enable();
|
enable();
|
||||||
|
|
|
@ -79,9 +79,13 @@ public class StorageManager {
|
||||||
customConfig.set("uuid", player.getUniqueId().toString());
|
customConfig.set("uuid", player.getUniqueId().toString());
|
||||||
customConfig.set("name", player.getName());
|
customConfig.set("name", player.getName());
|
||||||
customConfig.set("health", 100);
|
customConfig.set("health", 100);
|
||||||
|
customConfig.set("itemHealth", 0);
|
||||||
customConfig.set("defense", 50);
|
customConfig.set("defense", 50);
|
||||||
|
customConfig.set("itemDefense", 0);
|
||||||
customConfig.set("speed", 100);
|
customConfig.set("speed", 100);
|
||||||
|
customConfig.set("itemSpeed", 0);
|
||||||
customConfig.set("strength", 100);
|
customConfig.set("strength", 100);
|
||||||
|
customConfig.set("itemDmg", 0);
|
||||||
customConfig.set("inv","");
|
customConfig.set("inv","");
|
||||||
customConfig.set("ec","");
|
customConfig.set("ec","");
|
||||||
try {
|
try {
|
||||||
|
|
|
@ -274,42 +274,42 @@ public class Items {
|
||||||
Integer speed = 0;
|
Integer speed = 0;
|
||||||
Integer strength = 0;
|
Integer strength = 0;
|
||||||
if (equi != null) {
|
if (equi != null) {
|
||||||
if (equi.getItemInMainHand().getType() != Material.AIR || equi.getItemInMainHand() != null) {
|
if (equi.getItemInMainHand().getType() != Material.AIR && equi.getHelmet() != null) {
|
||||||
ItemStack item = equi.getItemInMainHand();
|
ItemStack item = equi.getItemInMainHand();
|
||||||
health = health + getHealth(item);
|
health = health + getHealth(item);
|
||||||
defense = defense + getDefense(item);
|
defense = defense + getDefense(item);
|
||||||
speed = speed + getSpeed(item);
|
speed = speed + getSpeed(item);
|
||||||
strength = strength + getStrength(item);
|
strength = strength + getStrength(item);
|
||||||
}
|
}
|
||||||
if (equi.getHelmet().getType() != Material.AIR || equi.getHelmet() != null) {
|
if (equi.getHelmet().getType() != Material.AIR && equi.getHelmet() != null) {
|
||||||
ItemStack item = equi.getHelmet();
|
ItemStack item = equi.getHelmet();
|
||||||
health = health + getHealth(item);
|
health = health + getHealth(item);
|
||||||
defense = defense + getDefense(item);
|
defense = defense + getDefense(item);
|
||||||
speed = speed + getSpeed(item);
|
speed = speed + getSpeed(item);
|
||||||
strength = strength + getStrength(item);
|
strength = strength + getStrength(item);
|
||||||
}
|
}
|
||||||
if (equi.getChestplate().getType() != Material.AIR || equi.getChestplate() != null) {
|
if (equi.getChestplate().getType() != Material.AIR && equi.getChestplate() != null) {
|
||||||
ItemStack item = equi.getChestplate();
|
ItemStack item = equi.getChestplate();
|
||||||
health = health + getHealth(item);
|
health = health + getHealth(item);
|
||||||
defense = defense + getDefense(item);
|
defense = defense + getDefense(item);
|
||||||
speed = speed + getSpeed(item);
|
speed = speed + getSpeed(item);
|
||||||
strength = strength + getStrength(item);
|
strength = strength + getStrength(item);
|
||||||
}
|
}
|
||||||
if (equi.getChestplate().getType() != Material.AIR || equi.getChestplate() != null) {
|
if (equi.getChestplate().getType() != Material.AIR && equi.getChestplate() != null) {
|
||||||
ItemStack item = equi.getChestplate();
|
ItemStack item = equi.getChestplate();
|
||||||
health = health + getHealth(item);
|
health = health + getHealth(item);
|
||||||
defense = defense + getDefense(item);
|
defense = defense + getDefense(item);
|
||||||
speed = speed + getSpeed(item);
|
speed = speed + getSpeed(item);
|
||||||
strength = strength + getStrength(item);
|
strength = strength + getStrength(item);
|
||||||
}
|
}
|
||||||
if (equi.getLeggings().getType() != Material.AIR || equi.getLeggings() != null) {
|
if (equi.getLeggings().getType() != Material.AIR && equi.getLeggings() != null) {
|
||||||
ItemStack item = equi.getLeggings();
|
ItemStack item = equi.getLeggings();
|
||||||
health = health + getHealth(item);
|
health = health + getHealth(item);
|
||||||
defense = defense + getDefense(item);
|
defense = defense + getDefense(item);
|
||||||
speed = speed + getSpeed(item);
|
speed = speed + getSpeed(item);
|
||||||
strength = strength + getStrength(item);
|
strength = strength + getStrength(item);
|
||||||
}
|
}
|
||||||
if (equi.getBoots().getType() != Material.AIR || equi.getBoots() != null) {
|
if (equi.getBoots().getType() != Material.AIR && equi.getBoots() != null) {
|
||||||
ItemStack item = equi.getBoots();
|
ItemStack item = equi.getBoots();
|
||||||
health = health + getHealth(item);
|
health = health + getHealth(item);
|
||||||
defense = defense + getDefense(item);
|
defense = defense + getDefense(item);
|
||||||
|
|
|
@ -26,4 +26,10 @@ public class MongoDB {
|
||||||
|
|
||||||
Bukkit.getConsoleSender().sendMessage(ChatColor.GREEN + "MongoDB connected!");
|
Bukkit.getConsoleSender().sendMessage(ChatColor.GREEN + "MongoDB connected!");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public void close() {
|
||||||
|
mongoClient.close();
|
||||||
|
|
||||||
|
Bukkit.getConsoleSender().sendMessage(ChatColor.RED + "MongoDB disconnected!");
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,6 +1,7 @@
|
||||||
package gq.unurled.raxen.utils;
|
package gq.unurled.raxen.utils;
|
||||||
|
|
||||||
import gq.unurled.raxen.Raxen;
|
import gq.unurled.raxen.Raxen;
|
||||||
|
import gq.unurled.raxen.components.player.Attributes.Attributes;
|
||||||
import org.bukkit.attribute.Attribute;
|
import org.bukkit.attribute.Attribute;
|
||||||
import org.bukkit.entity.Player;
|
import org.bukkit.entity.Player;
|
||||||
|
|
||||||
|
@ -8,17 +9,17 @@ import static gq.unurled.raxen.utils.Utils.msgPlayer;
|
||||||
|
|
||||||
public class Skills {
|
public class Skills {
|
||||||
|
|
||||||
public static void updateSkills(Player player) {
|
public static void updateSkills(Raxen main, Player player) {
|
||||||
gq.unurled.raxen.components.player.Skills skills = Raxen.getProfileManager().getPlayerProfile(player.getUniqueId()).getSkils();
|
Attributes attributes = new Attributes(main);
|
||||||
int health, itemHealth, defense, itemDefense, speed, itemSpeed, strength, itemDmg;
|
int health, itemHealth, defense, itemDefense, speed, itemSpeed, strength, itemDmg;
|
||||||
health = skills.getHealth();
|
health = attributes.getHealth(player);
|
||||||
itemHealth = skills.getItemHealth();
|
itemHealth = attributes.getItemHealth(player);
|
||||||
defense = skills.getDefense();
|
defense = attributes.getDefense(player);
|
||||||
itemDefense = skills.getItemDefense();
|
itemDefense = attributes.getItemDefense(player);
|
||||||
speed = skills.getSpeed();
|
speed = attributes.getSpeed(player);
|
||||||
itemSpeed = skills.getItemSpeed();
|
itemSpeed = attributes.getItemSpeed(player);
|
||||||
strength = skills.getStrength();
|
strength = attributes.getStrength(player);
|
||||||
itemDmg = skills.getItemDmg();
|
itemDmg = attributes.getItemStrength(player);
|
||||||
player.getAttribute(Attribute.GENERIC_MAX_HEALTH).setBaseValue(20D + (health + itemHealth) / 100);
|
player.getAttribute(Attribute.GENERIC_MAX_HEALTH).setBaseValue(20D + (health + itemHealth) / 100);
|
||||||
player.setWalkSpeed((float) (0.0 + ((speed + itemSpeed) / 100) * 0.2));
|
player.setWalkSpeed((float) (0.0 + ((speed + itemSpeed) / 100) * 0.2));
|
||||||
player.setFlySpeed((float) (0.0 + ((speed + itemSpeed) / 100) * 0.2));
|
player.setFlySpeed((float) (0.0 + ((speed + itemSpeed) / 100) * 0.2));
|
||||||
|
|
|
@ -26,7 +26,8 @@ commands:
|
||||||
itemlist:
|
itemlist:
|
||||||
aliases: itl
|
aliases: itl
|
||||||
description: Open ItemList menu
|
description: Open ItemList menu
|
||||||
usage: /itemlist
|
entityspawn:
|
||||||
|
description: Spawn an custom entity
|
||||||
|
|
||||||
permissions:
|
permissions:
|
||||||
raxen.reload.cmd:
|
raxen.reload.cmd:
|
||||||
|
@ -39,3 +40,5 @@ permissions:
|
||||||
description: raxen command permssion
|
description: raxen command permssion
|
||||||
raxen.itemlist.cmd:
|
raxen.itemlist.cmd:
|
||||||
description: itemlist command permission
|
description: itemlist command permission
|
||||||
|
raxen.entityspawn.cmd:
|
||||||
|
description: entityspawn command permission
|
Loading…
Reference in a new issue