2012-01-09 20:00:13 +01:00
|
|
|
package com.gmail.nossr50;
|
|
|
|
|
|
|
|
import java.io.BufferedReader;
|
|
|
|
import java.io.FileReader;
|
|
|
|
import java.util.logging.Level;
|
|
|
|
import java.util.logging.Logger;
|
|
|
|
|
|
|
|
import org.bukkit.Bukkit;
|
|
|
|
import org.bukkit.Location;
|
|
|
|
import org.bukkit.block.Block;
|
|
|
|
import org.bukkit.entity.*;
|
2012-03-02 19:18:23 +01:00
|
|
|
import org.bukkit.event.entity.EntityDamageEvent;
|
2012-02-25 13:27:09 +01:00
|
|
|
import org.bukkit.event.player.PlayerAnimationEvent;
|
2012-01-09 20:00:13 +01:00
|
|
|
import org.bukkit.inventory.ItemStack;
|
|
|
|
import com.gmail.nossr50.config.*;
|
|
|
|
import com.gmail.nossr50.datatypes.PlayerProfile;
|
|
|
|
import com.gmail.nossr50.datatypes.SkillType;
|
2012-02-15 22:57:48 +01:00
|
|
|
import com.gmail.nossr50.events.FakeBlockBreakEvent;
|
2012-01-29 08:51:59 +01:00
|
|
|
import com.gmail.nossr50.events.McMMOItemSpawnEvent;
|
2012-02-25 08:49:53 +01:00
|
|
|
import com.gmail.nossr50.skills.Repair;
|
2012-01-09 20:00:13 +01:00
|
|
|
|
2012-03-07 22:38:48 +01:00
|
|
|
public class m {
|
|
|
|
public static final Logger log = Logger.getLogger("Minecraft");
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Gets a capitalized version of the target string.
|
|
|
|
*
|
|
|
|
* @param target String to capitalize
|
|
|
|
* @return the capitalized string
|
|
|
|
*/
|
|
|
|
public static String getCapitalized(String target) {
|
|
|
|
String firstLetter = target.substring(0,1);
|
|
|
|
String remainder = target.substring(1);
|
|
|
|
String capitalized = firstLetter.toUpperCase() + remainder.toLowerCase();
|
|
|
|
|
|
|
|
return capitalized;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Gets the int represented by this string.
|
|
|
|
*
|
|
|
|
* @param string The string to parse
|
|
|
|
* @return the int represented by this string
|
|
|
|
*/
|
|
|
|
public static int getInt(String string) {
|
|
|
|
if (isInt(string)) {
|
|
|
|
return Integer.parseInt(string);
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Checks to see if an entity is currently invincible.
|
|
|
|
*
|
|
|
|
* @param le The LivingEntity to check
|
|
|
|
* @param event The event the entity is involved in
|
|
|
|
* @return true if the entity is invincible, false otherwise
|
|
|
|
*/
|
|
|
|
public static boolean isInvincible(LivingEntity le, EntityDamageEvent event) {
|
|
|
|
|
|
|
|
/*
|
|
|
|
* So apparently if you do more damage to a LivingEntity than its last damage int you bypass the invincibility.
|
|
|
|
* So yeah, this is for that.
|
|
|
|
*/
|
|
|
|
if (le.getNoDamageTicks() > le.getMaximumNoDamageTicks() / 2.0F && event.getDamage() <= le.getLastDamage()) {
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
}
|
2012-01-09 20:00:13 +01:00
|
|
|
|
2012-03-07 22:38:48 +01:00
|
|
|
/**
|
|
|
|
* Gets the power level of a player.
|
|
|
|
*
|
|
|
|
* @param player The player to get the power level of
|
|
|
|
* @param PP The profile of the player
|
|
|
|
* @return the power level of the player
|
|
|
|
*/
|
|
|
|
public static int getPowerLevel(Player player, PlayerProfile PP) {
|
|
|
|
int powerLevel = 0;
|
|
|
|
|
|
|
|
for (SkillType type : SkillType.values()) {
|
|
|
|
if (type.getPermissions(player)) {
|
|
|
|
powerLevel += PP.getSkillLevel(type);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return powerLevel;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Simulate a block break event.
|
|
|
|
*
|
|
|
|
* @param block The block to break
|
|
|
|
* @param player The player breaking the block
|
|
|
|
* @param shouldArmSwing true if an armswing event should be fired, false otherwise
|
|
|
|
* @return true if the event wasn't cancelled, false otherwise
|
|
|
|
*/
|
|
|
|
public static boolean blockBreakSimulate(Block block, Player player, Boolean shouldArmSwing) {
|
|
|
|
|
|
|
|
//Support for NoCheat
|
|
|
|
if (shouldArmSwing) {
|
|
|
|
PlayerAnimationEvent armswing = new PlayerAnimationEvent(player);
|
2012-02-25 13:27:09 +01:00
|
|
|
Bukkit.getPluginManager().callEvent(armswing);
|
2012-03-07 22:38:48 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
FakeBlockBreakEvent event = new FakeBlockBreakEvent(block, player);
|
|
|
|
Bukkit.getPluginManager().callEvent(event);
|
|
|
|
|
|
|
|
if (!event.isCancelled()) {
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get the upgrade tier of the item in hand.
|
|
|
|
*
|
|
|
|
* @param inHand The item to check the tier of
|
|
|
|
* @return the tier of the item
|
|
|
|
*/
|
2012-03-08 22:17:57 +01:00
|
|
|
public static Integer getTier(ItemStack inHand) {
|
|
|
|
int tier = 0;
|
|
|
|
|
|
|
|
if (Repair.isWoodTools(inHand)) {
|
|
|
|
tier = 1;
|
|
|
|
}
|
|
|
|
else if (Repair.isStoneTools(inHand)) {
|
|
|
|
tier = 2;
|
|
|
|
}
|
|
|
|
else if (Repair.isIronTools(inHand)) {
|
|
|
|
tier = 3;
|
|
|
|
}
|
|
|
|
else if(Repair.isGoldTools(inHand)) {
|
|
|
|
tier = 1;
|
|
|
|
}
|
|
|
|
else if(Repair.isDiamondTools(inHand))
|
|
|
|
tier = 4;
|
|
|
|
|
|
|
|
return tier;
|
2012-03-07 22:38:48 +01:00
|
|
|
}
|
2012-03-08 22:17:57 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Determine if two locations are near each other.
|
|
|
|
*
|
|
|
|
* @param first The first location
|
|
|
|
* @param second The second location
|
|
|
|
* @param maxDistance The max distance apart
|
|
|
|
* @return true if the distance between <code>first</code> and <code>second</code> is less than <code>maxDistance</code>, false otherwise
|
|
|
|
*/
|
2012-03-07 22:38:48 +01:00
|
|
|
public static boolean isNear(Location first, Location second, int maxDistance) {
|
|
|
|
double relX = first.getX() - second.getX();
|
|
|
|
double relY = first.getY() - second.getY();
|
|
|
|
double relZ = first.getZ() - second.getZ();
|
2012-03-08 22:17:57 +01:00
|
|
|
double dist = (relX * relX) + (relY * relY) + (relZ * relZ);
|
|
|
|
|
|
|
|
if (dist < maxDistance * maxDistance) {
|
2012-03-07 22:38:48 +01:00
|
|
|
return true;
|
|
|
|
}
|
2012-03-08 22:17:57 +01:00
|
|
|
else {
|
2012-03-07 22:38:48 +01:00
|
|
|
return false;
|
2012-03-08 22:17:57 +01:00
|
|
|
}
|
2012-03-07 22:38:48 +01:00
|
|
|
}
|
2012-03-08 22:17:57 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Determine if a string represents an Integer
|
|
|
|
*
|
|
|
|
* @param string String to check
|
|
|
|
* @return true if the string is an Integer, false otherwise
|
|
|
|
*/
|
|
|
|
public static boolean isInt(String string) {
|
|
|
|
try {
|
2012-03-07 22:38:48 +01:00
|
|
|
Integer.parseInt(string);
|
2012-03-08 22:17:57 +01:00
|
|
|
return true;
|
2012-03-07 22:38:48 +01:00
|
|
|
}
|
2012-03-08 22:17:57 +01:00
|
|
|
catch (NumberFormatException nFE) {
|
2012-03-07 22:38:48 +01:00
|
|
|
return false;
|
|
|
|
}
|
|
|
|
}
|
2012-03-08 22:17:57 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Drop items at a given location.
|
|
|
|
*
|
|
|
|
* @param location The location to drop the items at
|
|
|
|
* @param is The items to drop
|
|
|
|
* @param quantity The amount of items to drop
|
|
|
|
*/
|
|
|
|
public static void mcDropItems(Location location, ItemStack is, int quantity) {
|
|
|
|
for (int i = 0; i < quantity; i++) {
|
2012-03-07 22:38:48 +01:00
|
|
|
mcDropItem(location, is);
|
2012-03-08 22:17:57 +01:00
|
|
|
}
|
2012-03-07 22:38:48 +01:00
|
|
|
}
|
2012-03-08 22:17:57 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Randomly drop an item at a given location.
|
|
|
|
*
|
|
|
|
* @param location The location to drop the items at
|
|
|
|
* @param is The item to drop
|
|
|
|
* @param chance The percentage chance for the item to drop
|
|
|
|
*/
|
|
|
|
public static void mcRandomDropItem(Location location, ItemStack is, double chance) {
|
|
|
|
if (Math.random() * 100 < chance) {
|
2012-03-07 22:38:48 +01:00
|
|
|
mcDropItem(location, is);
|
2012-03-08 22:17:57 +01:00
|
|
|
}
|
2012-03-07 22:38:48 +01:00
|
|
|
}
|
2012-03-08 22:17:57 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Randomly drop items at a given location.
|
|
|
|
*
|
|
|
|
* @param location The location to drop the items at
|
|
|
|
* @param is The item to drop
|
|
|
|
* @param chance The percentage chance for the item to drop
|
|
|
|
* @param quantity The amount of items to drop
|
|
|
|
*/
|
|
|
|
public static void mcRandomDropItems(Location location, ItemStack is, int chance, int quantity) {
|
|
|
|
for(int i = 0; i < quantity; i++) {
|
2012-03-07 22:38:48 +01:00
|
|
|
mcRandomDropItem(location, is, chance);
|
2012-03-08 22:17:57 +01:00
|
|
|
}
|
2012-03-07 22:38:48 +01:00
|
|
|
}
|
2012-03-08 22:17:57 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Drop an item at a given location.
|
|
|
|
*
|
|
|
|
* @param location The location to drop the item at
|
|
|
|
* @param itemStack The item to drop
|
|
|
|
*/
|
2012-03-07 22:38:48 +01:00
|
|
|
public static void mcDropItem(Location location, ItemStack itemStack) {
|
2012-03-08 22:17:57 +01:00
|
|
|
|
2012-03-07 22:38:48 +01:00
|
|
|
// We can't get the item until we spawn it and we want to make it cancellable, so we have a custom event.
|
|
|
|
McMMOItemSpawnEvent event = new McMMOItemSpawnEvent(location, itemStack);
|
|
|
|
Bukkit.getPluginManager().callEvent(event);
|
2012-01-09 20:00:13 +01:00
|
|
|
|
2012-03-08 22:17:57 +01:00
|
|
|
if (event.isCancelled()) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
location.getWorld().dropItemNaturally(location, itemStack);
|
2012-03-07 22:38:48 +01:00
|
|
|
}
|
|
|
|
}
|
2012-03-08 22:17:57 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Convert FlatFile data to MySQL data.
|
|
|
|
*/
|
|
|
|
public static void convertToMySQL() {
|
|
|
|
if (!LoadProperties.useMySQL) {
|
2012-03-07 22:38:48 +01:00
|
|
|
return;
|
2012-03-08 22:17:57 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
Bukkit.getScheduler().scheduleAsyncDelayedTask(Bukkit.getPluginManager().getPlugin("mcMMO"), new Runnable() {
|
2012-03-07 22:38:48 +01:00
|
|
|
public void run() {
|
|
|
|
String location = "plugins/mcMMO/FlatFileStuff/mcmmo.users";
|
2012-03-08 22:17:57 +01:00
|
|
|
|
2012-03-07 22:38:48 +01:00
|
|
|
try {
|
2012-03-08 22:17:57 +01:00
|
|
|
|
2012-03-07 22:38:48 +01:00
|
|
|
//Open the user file
|
|
|
|
FileReader file = new FileReader(location);
|
|
|
|
BufferedReader in = new BufferedReader(file);
|
|
|
|
String line = "";
|
2012-03-08 22:17:57 +01:00
|
|
|
String playerName = null;
|
|
|
|
String party = null;
|
|
|
|
String mining = null;
|
|
|
|
String woodcutting = null;
|
|
|
|
String repair = null;
|
|
|
|
String unarmed = null;
|
|
|
|
String herbalism = null;
|
|
|
|
String excavation = null;
|
|
|
|
String archery = null;
|
|
|
|
String swords = null;
|
|
|
|
String axes = null;
|
|
|
|
String acrobatics = null;
|
|
|
|
String taming = null;
|
|
|
|
String fishing = null;
|
|
|
|
String miningXP = null;
|
|
|
|
String woodCuttingXP = null;
|
|
|
|
String repairXP = null;
|
|
|
|
String unarmedXP = null;
|
|
|
|
String herbalismXP = null;
|
|
|
|
String excavationXP = null;
|
|
|
|
String archeryXP = null;
|
|
|
|
String swordsXP = null;
|
|
|
|
String axesXP = null;
|
|
|
|
String acrobaticsXP = null;
|
|
|
|
String tamingXP = null;
|
|
|
|
String fishingXP = null;
|
|
|
|
int id = 0;
|
|
|
|
int theCount = 0;
|
|
|
|
|
2012-03-07 22:38:48 +01:00
|
|
|
while ((line = in.readLine()) != null) {
|
2012-03-08 22:17:57 +01:00
|
|
|
|
2012-03-07 22:38:48 +01:00
|
|
|
//Find if the line contains the player we want.
|
|
|
|
String[] character = line.split(":");
|
|
|
|
playerName = character[0];
|
2012-03-08 22:17:57 +01:00
|
|
|
|
2012-03-07 22:38:48 +01:00
|
|
|
//Check for things we don't want put in the DB
|
2012-03-08 22:17:57 +01:00
|
|
|
if (playerName == null || playerName.equals("null") || playerName.equals("#Storage place for user information")) {
|
2012-03-07 22:38:48 +01:00
|
|
|
continue;
|
2012-03-08 22:17:57 +01:00
|
|
|
}
|
2012-01-09 20:00:13 +01:00
|
|
|
|
2012-03-08 22:17:57 +01:00
|
|
|
if (character.length > 1) {
|
2012-03-07 22:38:48 +01:00
|
|
|
mining = character[1];
|
2012-03-08 22:17:57 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
if (character.length > 3) {
|
2012-03-07 22:38:48 +01:00
|
|
|
party = character[3];
|
2012-03-08 22:17:57 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
if (character.length > 4) {
|
2012-03-07 22:38:48 +01:00
|
|
|
miningXP = character[4];
|
2012-03-08 22:17:57 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
if (character.length > 5) {
|
2012-03-07 22:38:48 +01:00
|
|
|
woodcutting = character[5];
|
2012-03-08 22:17:57 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
if (character.length > 6) {
|
2012-03-07 22:38:48 +01:00
|
|
|
woodCuttingXP = character[6];
|
2012-03-08 22:17:57 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
if (character.length > 7) {
|
2012-03-07 22:38:48 +01:00
|
|
|
repair = character[7];
|
2012-03-08 22:17:57 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
if (character.length > 8) {
|
2012-03-07 22:38:48 +01:00
|
|
|
unarmed = character[8];
|
2012-03-08 22:17:57 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
if (character.length > 9) {
|
2012-03-07 22:38:48 +01:00
|
|
|
herbalism = character[9];
|
2012-03-08 22:17:57 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
if (character.length > 10) {
|
2012-03-07 22:38:48 +01:00
|
|
|
excavation = character[10];
|
2012-03-08 22:17:57 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
if (character.length > 11) {
|
2012-03-07 22:38:48 +01:00
|
|
|
archery = character[11];
|
2012-03-08 22:17:57 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
if (character.length > 12) {
|
2012-03-07 22:38:48 +01:00
|
|
|
swords = character[12];
|
2012-03-08 22:17:57 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
if (character.length > 13) {
|
2012-03-07 22:38:48 +01:00
|
|
|
axes = character[13];
|
2012-03-08 22:17:57 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
if (character.length > 14) {
|
2012-03-07 22:38:48 +01:00
|
|
|
acrobatics = character[14];
|
2012-03-08 22:17:57 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
if (character.length > 15) {
|
2012-03-07 22:38:48 +01:00
|
|
|
repairXP = character[15];
|
2012-03-08 22:17:57 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
if (character.length > 16) {
|
2012-03-07 22:38:48 +01:00
|
|
|
unarmedXP = character[16];
|
2012-03-08 22:17:57 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
if (character.length > 17) {
|
2012-03-07 22:38:48 +01:00
|
|
|
herbalismXP = character[17];
|
2012-03-08 22:17:57 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
if (character.length > 18) {
|
2012-03-07 22:38:48 +01:00
|
|
|
excavationXP = character[18];
|
2012-03-08 22:17:57 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
if (character.length > 19) {
|
2012-03-07 22:38:48 +01:00
|
|
|
archeryXP = character[19];
|
2012-03-08 22:17:57 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
if (character.length > 20) {
|
2012-03-07 22:38:48 +01:00
|
|
|
swordsXP = character[20];
|
2012-03-08 22:17:57 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
if (character.length > 21) {
|
2012-03-07 22:38:48 +01:00
|
|
|
axesXP = character[21];
|
2012-03-08 22:17:57 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
if (character.length > 22) {
|
2012-03-07 22:38:48 +01:00
|
|
|
acrobaticsXP = character[22];
|
2012-03-08 22:17:57 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
if (character.length > 24) {
|
2012-03-07 22:38:48 +01:00
|
|
|
taming = character[24];
|
2012-03-08 22:17:57 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
if (character.length > 25) {
|
2012-03-07 22:38:48 +01:00
|
|
|
tamingXP = character[25];
|
2012-03-08 22:17:57 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
if (character.length > 34) {
|
2012-03-07 22:38:48 +01:00
|
|
|
fishing = character[34];
|
2012-03-08 22:17:57 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
if (character.length > 35) {
|
2012-03-07 22:38:48 +01:00
|
|
|
fishingXP = character[35];
|
2012-03-08 22:17:57 +01:00
|
|
|
}
|
2012-01-09 20:00:13 +01:00
|
|
|
|
2012-03-07 22:38:48 +01:00
|
|
|
//Check to see if the user is in the DB
|
|
|
|
id = mcMMO.database.getInt("SELECT id FROM "
|
|
|
|
+ LoadProperties.MySQLtablePrefix
|
|
|
|
+ "users WHERE user = '" + playerName + "'");
|
2012-01-09 20:00:13 +01:00
|
|
|
|
2012-03-07 22:38:48 +01:00
|
|
|
if (id > 0) {
|
|
|
|
theCount++;
|
2012-03-08 22:17:57 +01:00
|
|
|
|
2012-03-07 22:38:48 +01:00
|
|
|
//Update the skill values
|
|
|
|
mcMMO.database.write("UPDATE "
|
|
|
|
+ LoadProperties.MySQLtablePrefix
|
|
|
|
+ "users SET lastlogin = " + 0
|
|
|
|
+ " WHERE id = " + id);
|
|
|
|
mcMMO.database.write("UPDATE "
|
|
|
|
+ LoadProperties.MySQLtablePrefix
|
|
|
|
+ "skills SET " + " taming = taming+"
|
|
|
|
+ getInt(taming) + ", mining = mining+"
|
|
|
|
+ getInt(mining) + ", repair = repair+"
|
|
|
|
+ getInt(repair)
|
|
|
|
+ ", woodcutting = woodcutting+"
|
|
|
|
+ getInt(woodcutting)
|
|
|
|
+ ", unarmed = unarmed+" + getInt(unarmed)
|
|
|
|
+ ", herbalism = herbalism+"
|
|
|
|
+ getInt(herbalism)
|
|
|
|
+ ", excavation = excavation+"
|
|
|
|
+ getInt(excavation)
|
|
|
|
+ ", archery = archery+" + getInt(archery)
|
|
|
|
+ ", swords = swords+" + getInt(swords)
|
|
|
|
+ ", axes = axes+" + getInt(axes)
|
|
|
|
+ ", acrobatics = acrobatics+"
|
|
|
|
+ getInt(acrobatics)
|
|
|
|
+ ", fishing = fishing+" + getInt(fishing)
|
|
|
|
+ " WHERE user_id = " + id);
|
|
|
|
mcMMO.database.write("UPDATE "
|
|
|
|
+ LoadProperties.MySQLtablePrefix
|
|
|
|
+ "experience SET " + " taming = "
|
|
|
|
+ getInt(tamingXP) + ", mining = "
|
|
|
|
+ getInt(miningXP) + ", repair = "
|
|
|
|
+ getInt(repairXP) + ", woodcutting = "
|
|
|
|
+ getInt(woodCuttingXP) + ", unarmed = "
|
|
|
|
+ getInt(unarmedXP) + ", herbalism = "
|
|
|
|
+ getInt(herbalismXP) + ", excavation = "
|
|
|
|
+ getInt(excavationXP) + ", archery = "
|
|
|
|
+ getInt(archeryXP) + ", swords = "
|
|
|
|
+ getInt(swordsXP) + ", axes = "
|
|
|
|
+ getInt(axesXP) + ", acrobatics = "
|
|
|
|
+ getInt(acrobaticsXP) + ", fishing = "
|
|
|
|
+ getInt(fishingXP) + " WHERE user_id = "
|
|
|
|
+ id);
|
2012-03-08 22:17:57 +01:00
|
|
|
}
|
|
|
|
else {
|
2012-03-07 22:38:48 +01:00
|
|
|
theCount++;
|
2012-03-08 22:17:57 +01:00
|
|
|
|
2012-03-07 22:38:48 +01:00
|
|
|
//Create the user in the DB
|
|
|
|
mcMMO.database.write("INSERT INTO "
|
|
|
|
+ LoadProperties.MySQLtablePrefix
|
|
|
|
+ "users (user, lastlogin) VALUES ('"
|
|
|
|
+ playerName + "',"
|
|
|
|
+ System.currentTimeMillis() / 1000 + ")");
|
|
|
|
id = mcMMO.database
|
|
|
|
.getInt("SELECT id FROM "
|
|
|
|
+ LoadProperties.MySQLtablePrefix
|
|
|
|
+ "users WHERE user = '"
|
|
|
|
+ playerName + "'");
|
|
|
|
mcMMO.database.write("INSERT INTO "
|
|
|
|
+ LoadProperties.MySQLtablePrefix
|
|
|
|
+ "skills (user_id) VALUES (" + id + ")");
|
|
|
|
mcMMO.database.write("INSERT INTO "
|
|
|
|
+ LoadProperties.MySQLtablePrefix
|
|
|
|
+ "experience (user_id) VALUES (" + id
|
|
|
|
+ ")");
|
|
|
|
//Update the skill values
|
|
|
|
mcMMO.database.write("UPDATE "
|
|
|
|
+ LoadProperties.MySQLtablePrefix
|
|
|
|
+ "users SET lastlogin = " + 0
|
|
|
|
+ " WHERE id = " + id);
|
|
|
|
mcMMO.database.write("UPDATE "
|
|
|
|
+ LoadProperties.MySQLtablePrefix
|
|
|
|
+ "users SET party = '" + party
|
|
|
|
+ "' WHERE id = " + id);
|
|
|
|
mcMMO.database.write("UPDATE "
|
|
|
|
+ LoadProperties.MySQLtablePrefix
|
|
|
|
+ "skills SET " + " taming = "
|
|
|
|
+ getInt(taming) + ", mining = "
|
|
|
|
+ getInt(mining) + ", repair = "
|
|
|
|
+ getInt(repair) + ", woodcutting = "
|
|
|
|
+ getInt(woodcutting) + ", unarmed = "
|
|
|
|
+ getInt(unarmed) + ", herbalism = "
|
|
|
|
+ getInt(herbalism) + ", excavation = "
|
|
|
|
+ getInt(excavation) + ", archery = "
|
|
|
|
+ getInt(archery) + ", swords = "
|
|
|
|
+ getInt(swords) + ", axes = "
|
|
|
|
+ getInt(axes) + ", acrobatics = "
|
|
|
|
+ getInt(acrobatics) + ", fishing = "
|
|
|
|
+ getInt(fishing) + " WHERE user_id = "
|
|
|
|
+ id);
|
|
|
|
mcMMO.database.write("UPDATE "
|
|
|
|
+ LoadProperties.MySQLtablePrefix
|
|
|
|
+ "experience SET " + " taming = "
|
|
|
|
+ getInt(tamingXP) + ", mining = "
|
|
|
|
+ getInt(miningXP) + ", repair = "
|
|
|
|
+ getInt(repairXP) + ", woodcutting = "
|
|
|
|
+ getInt(woodCuttingXP) + ", unarmed = "
|
|
|
|
+ getInt(unarmedXP) + ", herbalism = "
|
|
|
|
+ getInt(herbalismXP) + ", excavation = "
|
|
|
|
+ getInt(excavationXP) + ", archery = "
|
|
|
|
+ getInt(archeryXP) + ", swords = "
|
|
|
|
+ getInt(swordsXP) + ", axes = "
|
|
|
|
+ getInt(axesXP) + ", acrobatics = "
|
|
|
|
+ getInt(acrobaticsXP) + ", fishing = "
|
|
|
|
+ getInt(fishingXP) + " WHERE user_id = "
|
|
|
|
+ id);
|
|
|
|
}
|
|
|
|
}
|
2012-03-08 22:17:57 +01:00
|
|
|
|
|
|
|
System.out.println("[mcMMO] MySQL Updated from users file, " + theCount + " items added/updated to MySQL DB");
|
2012-03-07 22:38:48 +01:00
|
|
|
in.close();
|
2012-03-08 22:17:57 +01:00
|
|
|
}
|
|
|
|
catch (Exception e) {
|
|
|
|
log.log(Level.SEVERE, "Exception while reading " + location + " (Are you sure you formatted it correctly?)", e);
|
2012-03-07 22:38:48 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}, 1);
|
|
|
|
}
|
2012-03-08 22:17:57 +01:00
|
|
|
}
|