2014-11-08 20:27:09 +01:00
////////////////////////////////////////////////////////////////////////////////////////////////////
// PlotSquared - A plot manager and world generator for the Bukkit API /
// Copyright (c) 2014 IntellectualSites/IntellectualCrafters /
// /
// This program is free software; you can redistribute it and/or modify /
// it under the terms of the GNU General Public License as published by /
// the Free Software Foundation; either version 3 of the License, or /
// (at your option) any later version. /
// /
// This program is distributed in the hope that it will be useful, /
// but WITHOUT ANY WARRANTY; without even the implied warranty of /
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the /
// GNU General Public License for more details. /
// /
// You should have received a copy of the GNU General Public License /
// along with this program; if not, write to the Free Software Foundation, /
// Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA /
// /
// You can contact us via: support@intellectualsites.com /
////////////////////////////////////////////////////////////////////////////////////////////////////
2014-10-22 08:08:55 +02:00
package com.intellectualcrafters.plot.database ;
2015-07-05 17:44:10 +02:00
import java.sql.Connection ;
import java.sql.DatabaseMetaData ;
import java.sql.PreparedStatement ;
import java.sql.ResultSet ;
import java.sql.SQLException ;
import java.sql.Statement ;
import java.sql.Timestamp ;
import java.util.ArrayList ;
import java.util.Collection ;
import java.util.HashMap ;
import java.util.HashSet ;
import java.util.Iterator ;
import java.util.LinkedHashMap ;
import java.util.List ;
import java.util.Set ;
import java.util.UUID ;
import org.apache.commons.lang.StringUtils ;
import org.bukkit.block.Biome ;
2015-07-03 14:15:20 +02:00
import com.intellectualcrafters.plot.PS ;
2015-04-29 15:07:12 +02:00
import com.intellectualcrafters.plot.config.Settings ;
2014-11-16 10:48:18 +01:00
import com.intellectualcrafters.plot.flag.Flag ;
import com.intellectualcrafters.plot.flag.FlagManager ;
2015-07-05 17:44:10 +02:00
import com.intellectualcrafters.plot.object.BlockLoc ;
import com.intellectualcrafters.plot.object.Plot ;
import com.intellectualcrafters.plot.object.PlotCluster ;
import com.intellectualcrafters.plot.object.PlotClusterId ;
import com.intellectualcrafters.plot.object.PlotId ;
import com.intellectualcrafters.plot.object.PlotSettings ;
import com.intellectualcrafters.plot.object.RunnableVal ;
2015-04-05 16:59:56 +02:00
import com.intellectualcrafters.plot.object.comment.PlotComment ;
2015-01-26 05:16:10 +01:00
import com.intellectualcrafters.plot.util.ClusterManager ;
2015-02-20 05:32:40 +01:00
import com.intellectualcrafters.plot.util.TaskManager ;
2015-01-07 07:44:03 +01:00
2014-10-22 08:08:55 +02:00
/ * *
* @author Citymonstret
* /
2014-11-19 18:18:18 +01:00
public class SQLManager implements AbstractDB {
2014-11-16 09:43:30 +01:00
// Public final
2014-12-18 03:15:11 +01:00
public final String SET_OWNER ;
public final String GET_ALL_PLOTS ;
public final String CREATE_PLOTS ;
public final String CREATE_SETTINGS ;
2015-04-29 14:04:25 +02:00
public final String CREATE_TIERS ;
2014-12-18 03:15:11 +01:00
public final String CREATE_PLOT ;
2015-01-26 05:16:10 +01:00
public final String CREATE_CLUSTER ;
2015-02-10 21:17:30 +01:00
private final String prefix ;
2014-11-16 09:43:30 +01:00
// Private Final
2014-12-18 03:15:11 +01:00
private Connection connection ;
2015-02-23 02:32:27 +01:00
2014-11-16 09:43:30 +01:00
/ * *
* Constructor
*
2014-12-18 03:15:11 +01:00
* @param c connection
* @param p prefix
2014-11-16 09:43:30 +01:00
* /
2014-12-16 06:03:20 +01:00
public SQLManager ( final Connection c , final String p ) {
2014-11-16 09:43:30 +01:00
// Private final
2014-12-16 06:03:20 +01:00
this . connection = c ;
this . prefix = p ;
2014-12-14 02:12:21 +01:00
// Set timout
2014-12-16 06:03:20 +01:00
// setTimout();
2014-11-16 09:43:30 +01:00
// Public final
2015-04-02 13:18:08 +02:00
this . SET_OWNER = " UPDATE ` " + this . prefix + " plot` SET `owner` = ? WHERE `plot_id_x` = ? AND `plot_id_z` = ? AND `world` = ? " ;
2014-12-16 06:03:20 +01:00
this . GET_ALL_PLOTS = " SELECT `id`, `plot_id_x`, `plot_id_z`, `world` FROM ` " + this . prefix + " plot` " ;
this . CREATE_PLOTS = " INSERT INTO ` " + this . prefix + " plot`(`plot_id_x`, `plot_id_z`, `owner`, `world`) values " ;
this . CREATE_SETTINGS = " INSERT INTO ` " + this . prefix + " plot_settings` (`plot_plot_id`) values " ;
2015-04-29 14:04:25 +02:00
this . CREATE_TIERS = " INSERT INTO ` " + this . prefix + " plot_%tier%` (`plot_plot_id`, `user_uuid`) values " ;
2014-12-16 06:03:20 +01:00
this . CREATE_PLOT = " INSERT INTO ` " + this . prefix + " plot`(`plot_id_x`, `plot_id_z`, `owner`, `world`) VALUES(?, ?, ?, ?) " ;
2015-01-26 05:16:10 +01:00
this . CREATE_CLUSTER = " INSERT INTO ` " + this . prefix + " cluster`(`pos1_x`, `pos1_z`, `pos2_x`, `pos2_z`, `owner`, `world`) VALUES(?, ?, ?, ?, ?, ?) " ;
2014-12-16 06:03:20 +01:00
// schedule reconnect
2015-04-29 15:07:12 +02:00
if ( Settings . DB . USE_MYSQL ) {
2015-02-20 05:32:40 +01:00
TaskManager . runTaskRepeat ( new Runnable ( ) {
2014-12-16 06:03:20 +01:00
@Override
public void run ( ) {
2015-04-26 09:47:45 +02:00
try {
2015-07-03 14:15:20 +02:00
SQLManager . this . connection = PS . get ( ) . getDatabase ( ) . forceConnection ( ) ;
2015-07-03 11:30:26 +02:00
} catch ( Exception e ) {
2015-04-26 09:47:45 +02:00
e . printStackTrace ( ) ;
}
2014-12-14 02:12:21 +01:00
}
2015-04-26 09:47:45 +02:00
} , 11000 ) ;
2014-12-15 02:04:13 +01:00
}
2015-04-06 14:16:24 +02:00
updateTables ( ) ;
2014-12-14 02:12:21 +01:00
}
2015-02-23 02:32:27 +01:00
2015-07-03 11:30:26 +02:00
public Connection getConnection ( ) {
return this . connection ;
}
2014-11-05 04:42:08 +01:00
/ * *
* Set Plot owner
*
2014-12-18 03:15:11 +01:00
* @param plot Plot Object
* @param uuid Owner UUID
2014-11-05 04:42:08 +01:00
* /
@Override
public void setOwner ( final Plot plot , final UUID uuid ) {
2015-02-20 07:34:19 +01:00
TaskManager . runTaskAsync ( new Runnable ( ) {
2014-11-05 04:42:08 +01:00
@Override
public void run ( ) {
try {
2014-12-16 06:03:20 +01:00
final PreparedStatement statement = SQLManager . this . connection . prepareStatement ( SQLManager . this . SET_OWNER ) ;
2014-11-05 04:42:08 +01:00
statement . setString ( 1 , uuid . toString ( ) ) ;
statement . setInt ( 2 , plot . id . x ) ;
statement . setInt ( 3 , plot . id . y ) ;
2015-04-02 13:18:08 +02:00
statement . setString ( 4 , plot . world ) ;
2014-11-05 04:42:08 +01:00
statement . executeUpdate ( ) ;
statement . close ( ) ;
2014-12-18 03:15:11 +01:00
} catch ( final SQLException e ) {
2014-11-05 04:42:08 +01:00
e . printStackTrace ( ) ;
2015-07-03 14:15:20 +02:00
PS . log ( " &c[ERROR] " + " Could not set owner for plot " + plot . id ) ;
2014-11-05 04:42:08 +01:00
}
}
} ) ;
}
2015-02-23 02:32:27 +01:00
2015-04-29 14:04:25 +02:00
@Override
public void createPlotsAndData ( final ArrayList < Plot > myList , final Runnable whenDone ) {
TaskManager . runTaskAsync ( new Runnable ( ) {
@Override
public void run ( ) {
try {
2015-07-15 18:54:06 +02:00
try {
connection . setAutoCommit ( false ) ;
}
catch ( SQLException e ) { }
2015-04-29 14:04:25 +02:00
// Create the plots
2015-07-12 21:08:41 +02:00
createPlots ( myList , new Runnable ( ) {
@Override
public void run ( ) {
try {
// Creating datastructures
HashMap < PlotId , Plot > plotMap = new HashMap < > ( ) ;
for ( Plot plot : myList ) {
plotMap . put ( plot . id , plot ) ;
}
final ArrayList < SettingsPair > settings = new ArrayList < > ( ) ;
final ArrayList < UUIDPair > helpers = new ArrayList < > ( ) ;
final ArrayList < UUIDPair > trusted = new ArrayList < > ( ) ;
final ArrayList < UUIDPair > denied = new ArrayList < > ( ) ;
2015-04-29 14:04:25 +02:00
2015-07-12 21:08:41 +02:00
// Populating structures
final PreparedStatement stmt = connection . prepareStatement ( GET_ALL_PLOTS ) ;
final ResultSet result = stmt . executeQuery ( ) ;
while ( result . next ( ) ) {
final int id = result . getInt ( " id " ) ;
int x = result . getInt ( " plot_id_x " ) ;
int y = result . getInt ( " plot_id_z " ) ;
PlotId plotId = new PlotId ( x , y ) ;
Plot plot = plotMap . get ( plotId ) ;
if ( plot ! = null ) {
settings . add ( new SettingsPair ( id , plot . settings ) ) ;
if ( plot . denied ! = null ) {
for ( UUID uuid : plot . denied ) {
denied . add ( new UUIDPair ( id , uuid ) ) ;
}
}
if ( plot . members ! = null ) {
for ( UUID uuid : plot . members ) {
trusted . add ( new UUIDPair ( id , uuid ) ) ;
}
}
if ( plot . trusted ! = null ) {
for ( UUID uuid : plot . trusted ) {
helpers . add ( new UUIDPair ( id , uuid ) ) ;
}
}
2015-04-29 14:04:25 +02:00
}
}
2015-07-12 21:08:41 +02:00
createSettings ( settings , new Runnable ( ) {
@Override
public void run ( ) {
createTiers ( helpers , " helpers " , new Runnable ( ) {
@Override
public void run ( ) {
createTiers ( trusted , " trusted " , new Runnable ( ) {
@Override
public void run ( ) {
createTiers ( denied , " denied " , new Runnable ( ) {
@Override
public void run ( ) {
try {
connection . commit ( ) ;
connection . setAutoCommit ( true ) ;
} catch ( SQLException e ) {
e . printStackTrace ( ) ;
}
if ( whenDone ! = null ) whenDone . run ( ) ;
}
} ) ;
}
} ) ;
}
} ) ;
2015-04-29 14:04:25 +02:00
}
2015-07-12 21:08:41 +02:00
} ) ;
2015-04-29 14:04:25 +02:00
}
2015-07-12 21:08:41 +02:00
catch ( SQLException e ) {
e . printStackTrace ( ) ;
PS . log ( " &7[WARN] " + " Failed to set all helpers for plots " ) ;
try {
connection . commit ( ) ;
connection . setAutoCommit ( true ) ;
} catch ( SQLException e1 ) {
e1 . printStackTrace ( ) ;
2015-04-29 14:04:25 +02:00
}
}
}
2015-07-12 21:08:41 +02:00
} ) ;
2015-07-15 18:54:06 +02:00
} catch ( Exception e ) {
2015-04-29 14:04:25 +02:00
e . printStackTrace ( ) ;
2015-07-03 14:15:20 +02:00
PS . log ( " &7[WARN] " + " Failed to set all helpers for plots " ) ;
2015-07-12 21:08:41 +02:00
try {
connection . commit ( ) ;
connection . setAutoCommit ( true ) ;
} catch ( SQLException e1 ) {
e1 . printStackTrace ( ) ;
}
2014-11-05 04:42:08 +01:00
}
}
2015-04-29 14:04:25 +02:00
} ) ;
}
2015-07-03 11:30:26 +02:00
2015-04-29 14:04:25 +02:00
/ * *
* Create a plot
*
* @param myList list of plots to be created
* /
2015-07-12 21:08:41 +02:00
public void createTiers ( final ArrayList < UUIDPair > myList , final String tier , final Runnable whenDone ) {
2015-04-29 14:04:25 +02:00
final StmtMod < UUIDPair > mod = new StmtMod < UUIDPair > ( ) {
@Override
public String getCreateMySQL ( int size ) {
return getCreateMySQL ( size , CREATE_TIERS . replaceAll ( " %tier% " , tier ) , 2 ) ;
2014-11-05 04:42:08 +01:00
}
2015-04-29 14:04:25 +02:00
@Override
public String getCreateSQLite ( int size ) {
2015-07-03 11:30:26 +02:00
return getCreateSQLite ( size ,
" INSERT INTO ` " + prefix + " plot_ " + tier + " ` SELECT ? AS `plot_plot_id`, ? AS `user_uuid` " , 2 ) ;
2014-12-21 05:03:59 +01:00
}
2015-04-29 14:04:25 +02:00
@Override
public String getCreateSQL ( ) {
return " INSERT INTO ` " + SQLManager . this . prefix + " plot_ " + tier + " ` (`plot_plot_id`, `user_uuid`) VALUES(?,?) " ;
2014-11-05 04:42:08 +01:00
}
2015-04-29 14:04:25 +02:00
@Override
public void setMySQL ( PreparedStatement stmt , int i , UUIDPair pair ) throws SQLException {
stmt . setInt ( ( i * 2 ) + 1 , pair . id ) ;
stmt . setString ( ( i * 2 ) + 2 , pair . uuid . toString ( ) ) ;
2014-11-05 04:42:08 +01:00
}
2015-04-29 14:04:25 +02:00
@Override
public void setSQLite ( PreparedStatement stmt , int i , UUIDPair pair ) throws SQLException {
stmt . setInt ( ( i * 2 ) + 1 , pair . id ) ;
stmt . setString ( ( i * 2 ) + 2 , pair . uuid . toString ( ) ) ;
2015-01-29 23:16:31 +01:00
}
2015-04-29 14:04:25 +02:00
@Override
public void setSQL ( PreparedStatement stmt , UUIDPair pair ) throws SQLException {
stmt . setInt ( 1 , pair . id ) ;
stmt . setString ( 2 , pair . uuid . toString ( ) ) ;
}
} ;
2015-07-12 21:08:41 +02:00
setBulk ( myList , mod , whenDone ) ;
2015-04-29 14:04:25 +02:00
}
/ * *
* Create a plot
*
* @param myList list of plots to be created
* /
2015-07-12 21:08:41 +02:00
public void createPlots ( final ArrayList < Plot > myList , final Runnable whenDone ) {
2015-04-29 14:04:25 +02:00
final StmtMod < Plot > mod = new StmtMod < Plot > ( ) {
@Override
public String getCreateMySQL ( int size ) {
return getCreateMySQL ( size , CREATE_PLOTS , 4 ) ;
}
@Override
public String getCreateSQLite ( int size ) {
return getCreateSQLite ( size , " INSERT INTO ` " + prefix + " plot` SELECT ? AS `id`, ? AS `plot_id_x`, ? AS `plot_id_z`, ? AS `owner`, ? AS `world`, ? AS `timestamp` " , 6 ) ;
}
@Override
public String getCreateSQL ( ) {
return CREATE_PLOT ;
}
2015-07-03 11:30:26 +02:00
2015-04-29 14:04:25 +02:00
@Override
public void setMySQL ( PreparedStatement stmt , int i , Plot plot ) throws SQLException {
stmt . setInt ( ( i * 4 ) + 1 , plot . id . x ) ;
stmt . setInt ( ( i * 4 ) + 2 , plot . id . y ) ;
try {
stmt . setString ( ( i * 4 ) + 3 , plot . owner . toString ( ) ) ;
} catch ( final Exception e ) {
stmt . setString ( ( i * 4 ) + 3 , DBFunc . everyone . toString ( ) ) ;
2015-01-29 23:16:31 +01:00
}
2015-04-29 14:04:25 +02:00
stmt . setString ( ( i * 4 ) + 4 , plot . world ) ;
}
@Override
public void setSQLite ( PreparedStatement stmt , int i , Plot plot ) throws SQLException {
stmt . setNull ( ( i * 6 ) + 1 , 4 ) ;
stmt . setInt ( ( i * 6 ) + 2 , plot . id . x ) ;
stmt . setInt ( ( i * 6 ) + 3 , plot . id . y ) ;
2015-01-29 23:16:31 +01:00
try {
2015-04-29 14:04:25 +02:00
stmt . setString ( ( i * 6 ) + 4 , plot . owner . toString ( ) ) ;
} catch ( final Exception e1 ) {
stmt . setString ( ( i * 6 ) + 4 , DBFunc . everyone . toString ( ) ) ;
2014-12-21 05:03:59 +01:00
}
2015-04-29 14:04:25 +02:00
stmt . setString ( ( i * 6 ) + 5 , plot . world ) ;
stmt . setTimestamp ( ( i * 6 ) + 6 , new Timestamp ( System . currentTimeMillis ( ) ) ) ;
2014-12-21 05:03:59 +01:00
}
2015-04-29 14:04:25 +02:00
@Override
public void setSQL ( PreparedStatement stmt , Plot plot ) throws SQLException {
stmt . setInt ( 1 , plot . id . x ) ;
stmt . setInt ( 2 , plot . id . y ) ;
stmt . setString ( 3 , plot . owner . toString ( ) ) ;
stmt . setString ( 4 , plot . world ) ;
}
} ;
2015-07-12 21:08:41 +02:00
setBulk ( myList , mod , whenDone ) ;
2014-11-05 04:42:08 +01:00
}
2015-07-03 11:30:26 +02:00
2015-07-12 21:08:41 +02:00
public < T > void setBulk ( ArrayList < T > objList , StmtMod < T > mod , Runnable whenDone ) {
2015-07-03 11:30:26 +02:00
final int size = objList . size ( ) ;
if ( size = = 0 ) {
2015-07-12 21:08:41 +02:00
if ( whenDone ! = null ) whenDone . run ( ) ;
2015-07-03 11:30:26 +02:00
return ;
}
2015-04-29 10:09:29 +02:00
int packet ;
2015-04-29 15:07:12 +02:00
if ( Settings . DB . USE_MYSQL ) {
2015-05-30 21:47:31 +02:00
packet = Math . min ( size , 5000 ) ;
2015-04-29 10:09:29 +02:00
} else {
packet = Math . min ( size , 50 ) ;
}
final int amount = size / packet ;
2015-05-30 21:47:31 +02:00
try {
int count = 0 ;
PreparedStatement preparedStmt = null ;
String statement = null ;
int last = - 1 ;
for ( int j = 0 ; j < = amount ; j + + ) {
final List < T > subList = objList . subList ( j * packet , Math . min ( size , ( j + 1 ) * packet ) ) ;
if ( subList . size ( ) = = 0 ) {
2015-06-13 09:55:40 +02:00
break ;
2015-05-30 21:47:31 +02:00
}
if ( last = = - 1 ) {
last = subList . size ( ) ;
statement = mod . getCreateMySQL ( subList . size ( ) ) ;
preparedStmt = this . connection . prepareStatement ( statement . toString ( ) ) ;
}
if ( subList . size ( ) ! = last | | ( count % 5000 = = 0 & & count > 0 ) ) {
preparedStmt . executeBatch ( ) ;
preparedStmt . close ( ) ;
statement = mod . getCreateMySQL ( subList . size ( ) ) ;
preparedStmt = this . connection . prepareStatement ( statement . toString ( ) ) ;
}
for ( int i = 0 ; i < subList . size ( ) ; i + + ) {
count + + ;
final T obj = subList . get ( i ) ;
2015-07-03 11:30:26 +02:00
mod . setMySQL ( preparedStmt , i , obj ) ;
2015-05-30 21:47:31 +02:00
}
last = subList . size ( ) ;
preparedStmt . addBatch ( ) ;
}
2015-07-03 14:15:20 +02:00
PS . log ( " &aBatch 1: " + count + " | " + objList . get ( 0 ) . getClass ( ) . getCanonicalName ( ) ) ;
2015-05-30 21:47:31 +02:00
preparedStmt . executeBatch ( ) ;
preparedStmt . clearParameters ( ) ;
preparedStmt . close ( ) ;
2015-07-12 21:08:41 +02:00
if ( whenDone ! = null ) whenDone . run ( ) ;
2015-05-30 21:47:31 +02:00
return ;
2015-07-03 11:30:26 +02:00
} catch ( Exception e ) {
2015-05-30 21:47:31 +02:00
if ( Settings . DB . USE_MYSQL ) {
e . printStackTrace ( ) ;
2015-07-03 14:15:20 +02:00
PS . log ( " &cERROR 1: " + " | " + objList . get ( 0 ) . getClass ( ) . getCanonicalName ( ) ) ;
2015-04-29 10:09:29 +02:00
}
2015-05-30 21:47:31 +02:00
}
try {
int count = 0 ;
PreparedStatement preparedStmt = null ;
String statement = null ;
int last = - 1 ;
for ( int j = 0 ; j < = amount ; j + + ) {
final List < T > subList = objList . subList ( j * packet , Math . min ( size , ( j + 1 ) * packet ) ) ;
if ( subList . size ( ) = = 0 ) {
2015-07-10 16:08:07 +02:00
break ;
2015-05-30 21:47:31 +02:00
}
if ( last = = - 1 ) {
last = subList . size ( ) ;
statement = mod . getCreateSQLite ( subList . size ( ) ) ;
preparedStmt = this . connection . prepareStatement ( statement . toString ( ) ) ;
}
if ( subList . size ( ) ! = last | | ( count % 5000 = = 0 & & count > 0 ) ) {
preparedStmt . executeBatch ( ) ;
2015-07-12 21:08:41 +02:00
preparedStmt . clearParameters ( ) ;
2015-05-30 21:47:31 +02:00
statement = mod . getCreateSQLite ( subList . size ( ) ) ;
preparedStmt = this . connection . prepareStatement ( statement . toString ( ) ) ;
}
2015-04-29 10:09:29 +02:00
for ( int i = 0 ; i < subList . size ( ) ; i + + ) {
2015-05-30 21:47:31 +02:00
count + + ;
2015-04-29 10:09:29 +02:00
final T obj = subList . get ( i ) ;
2015-07-03 11:30:26 +02:00
mod . setSQLite ( preparedStmt , i , obj ) ;
2015-04-29 10:09:29 +02:00
}
2015-05-30 21:47:31 +02:00
last = subList . size ( ) ;
preparedStmt . addBatch ( ) ;
}
2015-07-03 14:15:20 +02:00
PS . log ( " &aBatch 2: " + count + " | " + objList . get ( 0 ) . getClass ( ) . getCanonicalName ( ) ) ;
2015-05-30 21:47:31 +02:00
preparedStmt . executeBatch ( ) ;
preparedStmt . clearParameters ( ) ;
preparedStmt . close ( ) ;
2015-07-03 11:30:26 +02:00
} catch ( Exception e ) {
2015-05-30 21:47:31 +02:00
e . printStackTrace ( ) ;
2015-07-03 14:15:20 +02:00
PS . log ( " &cERROR 2: " + " | " + objList . get ( 0 ) . getClass ( ) . getCanonicalName ( ) ) ;
2015-07-12 21:08:41 +02:00
PS . log ( " &6[WARN] " + " Could not bulk save! " ) ;
try {
PreparedStatement preparedStmt = null ;
String nonBulk = mod . getCreateSQL ( ) ;
preparedStmt = this . connection . prepareStatement ( nonBulk . toString ( ) ) ;
for ( final T obj : objList ) {
try {
mod . setSQL ( preparedStmt , obj ) ;
preparedStmt . addBatch ( ) ;
} catch ( final Exception e3 ) {
PS . log ( " &c[ERROR] " + " Failed to save " + obj + " ! " ) ;
}
2015-04-29 10:09:29 +02:00
}
2015-07-12 21:08:41 +02:00
PS . log ( " &aBatch 3 " ) ;
preparedStmt . executeBatch ( ) ;
preparedStmt . close ( ) ;
} catch ( Exception e3 ) {
e3 . printStackTrace ( ) ;
PS . log ( " &c[ERROR] " + " Failed to save all! " ) ;
2015-04-29 10:09:29 +02:00
}
}
2015-07-12 21:08:41 +02:00
if ( whenDone ! = null ) whenDone . run ( ) ;
2015-04-29 10:09:29 +02:00
}
2015-07-03 11:30:26 +02:00
2015-07-12 21:08:41 +02:00
public void createSettings ( final ArrayList < SettingsPair > myList , final Runnable whenDone ) {
2015-04-29 14:04:25 +02:00
final StmtMod < SettingsPair > mod = new StmtMod < SettingsPair > ( ) {
@Override
public String getCreateMySQL ( int size ) {
2015-05-30 21:47:31 +02:00
return getCreateMySQL ( size , " INSERT INTO ` " + prefix + " plot_settings`(`plot_plot_id`,`biome`,`rain`,`custom_time`,`time`,`deny_entry`,`alias`,`flags`,`merged`,`position`) VALUES " , 10 ) ;
2015-04-29 14:04:25 +02:00
}
@Override
public String getCreateSQLite ( int size ) {
2015-05-14 11:45:14 +02:00
return getCreateSQLite ( size , " INSERT INTO ` " + prefix + " plot_settings` SELECT ? AS `plot_plot_id`, ? AS `biome`, ? AS `rain`, ? AS `custom_time`, ? AS `time`, ? AS `deny_entry`, ? AS `alias`, ? AS `flags`, ? AS `merged`, ? AS `position` " , 10 ) ;
2015-04-29 14:04:25 +02:00
}
@Override
public String getCreateSQL ( ) {
return " INSERT INTO ` " + SQLManager . this . prefix + " plot_settings`(`plot_plot_id`) VALUES(?) " ;
}
@Override
2015-04-29 16:22:06 +02:00
public void setMySQL ( PreparedStatement stmt , int i , SettingsPair pair ) throws SQLException {
2015-07-03 11:30:26 +02:00
stmt . setInt ( ( i * 10 ) + 1 , pair . id ) ; // id
2015-04-29 16:22:06 +02:00
stmt . setNull ( ( i * 10 ) + 2 , 4 ) ; // biome
stmt . setNull ( ( i * 10 ) + 3 , 4 ) ; // rain
stmt . setNull ( ( i * 10 ) + 4 , 4 ) ; // custom_time
stmt . setNull ( ( i * 10 ) + 5 , 4 ) ; // time
stmt . setNull ( ( i * 10 ) + 6 , 4 ) ; // deny_entry
if ( pair . settings . getAlias ( ) . equals ( " " ) ) {
stmt . setNull ( ( i * 10 ) + 7 , 4 ) ;
2015-07-03 11:30:26 +02:00
} else {
2015-04-29 16:22:06 +02:00
stmt . setString ( ( i * 10 ) + 7 , pair . settings . getAlias ( ) ) ;
}
if ( pair . settings . flags = = null ) {
stmt . setNull ( ( i * 10 ) + 8 , 4 ) ;
2015-07-03 11:30:26 +02:00
} else {
2015-04-29 16:22:06 +02:00
final StringBuilder flag_string = new StringBuilder ( ) ;
int k = 0 ;
2015-06-23 23:44:44 +02:00
for ( final Flag flag : pair . settings . flags . values ( ) ) {
2015-04-29 16:22:06 +02:00
if ( k ! = 0 ) {
flag_string . append ( " , " ) ;
}
flag_string . append ( flag . getKey ( ) + " : " + flag . getValueString ( ) . replaceAll ( " : " , " \ u00AF " ) . replaceAll ( " , " , " \ u00B4 " ) ) ;
k + + ;
}
stmt . setString ( ( i * 10 ) + 8 , flag_string . toString ( ) ) ;
}
boolean [ ] merged = pair . settings . getMerged ( ) ;
int n = 0 ;
for ( int j = 0 ; j < 4 ; + + j ) {
n = ( n < < 1 ) + ( merged [ j ] ? 1 : 0 ) ;
}
stmt . setInt ( ( i * 10 ) + 9 , n ) ;
BlockLoc loc = pair . settings . getPosition ( ) ;
String position ;
if ( loc . y = = 0 ) {
position = " DEFAULT " ;
2015-07-03 11:30:26 +02:00
} else {
2015-04-29 16:22:06 +02:00
position = loc . x + " , " + loc . y + " , " + loc . z ;
}
stmt . setString ( ( i * 10 ) + 10 , position ) ;
2015-04-29 14:04:25 +02:00
}
2015-04-29 10:09:29 +02:00
2015-04-29 14:04:25 +02:00
@Override
2015-04-29 16:22:06 +02:00
public void setSQLite ( PreparedStatement stmt , int i , SettingsPair pair ) throws SQLException {
2015-07-03 11:30:26 +02:00
stmt . setInt ( ( i * 10 ) + 1 , pair . id ) ; // id
2015-05-14 11:45:14 +02:00
stmt . setNull ( ( i * 10 ) + 2 , 4 ) ; // biome
stmt . setNull ( ( i * 10 ) + 3 , 4 ) ; // rain
stmt . setNull ( ( i * 10 ) + 4 , 4 ) ; // custom_time
stmt . setNull ( ( i * 10 ) + 5 , 4 ) ; // time
stmt . setNull ( ( i * 10 ) + 6 , 4 ) ; // deny_entry
if ( pair . settings . getAlias ( ) . equals ( " " ) ) {
stmt . setNull ( ( i * 10 ) + 7 , 4 ) ;
2015-07-03 11:30:26 +02:00
} else {
2015-05-14 11:45:14 +02:00
stmt . setString ( ( i * 10 ) + 7 , pair . settings . getAlias ( ) ) ;
}
if ( pair . settings . flags = = null ) {
stmt . setNull ( ( i * 10 ) + 8 , 4 ) ;
2015-07-03 11:30:26 +02:00
} else {
2015-05-14 11:45:14 +02:00
final StringBuilder flag_string = new StringBuilder ( ) ;
int k = 0 ;
2015-06-23 23:44:44 +02:00
for ( final Flag flag : pair . settings . flags . values ( ) ) {
2015-05-14 11:45:14 +02:00
if ( k ! = 0 ) {
flag_string . append ( " , " ) ;
}
flag_string . append ( flag . getKey ( ) + " : " + flag . getValueString ( ) . replaceAll ( " : " , " \ u00AF " ) . replaceAll ( " , " , " \ u00B4 " ) ) ;
k + + ;
}
stmt . setString ( ( i * 10 ) + 8 , flag_string . toString ( ) ) ;
}
boolean [ ] merged = pair . settings . getMerged ( ) ;
int n = 0 ;
for ( int j = 0 ; j < 4 ; + + j ) {
n = ( n < < 1 ) + ( merged [ j ] ? 1 : 0 ) ;
}
stmt . setInt ( ( i * 10 ) + 9 , n ) ;
BlockLoc loc = pair . settings . getPosition ( ) ;
String position ;
if ( loc . y = = 0 ) {
position = " DEFAULT " ;
2015-07-03 11:30:26 +02:00
} else {
2015-05-14 11:45:14 +02:00
position = loc . x + " , " + loc . y + " , " + loc . z ;
}
stmt . setString ( ( i * 10 ) + 10 , position ) ;
2015-04-29 14:04:25 +02:00
}
2015-04-29 10:09:29 +02:00
2015-04-29 14:04:25 +02:00
@Override
2015-04-29 16:22:06 +02:00
public void setSQL ( PreparedStatement stmt , SettingsPair pair ) throws SQLException {
stmt . setInt ( 1 , pair . id ) ;
2015-04-29 14:04:25 +02:00
}
} ;
TaskManager . runTaskAsync ( new Runnable ( ) {
2015-04-29 10:42:40 +02:00
@Override
public void run ( ) {
2015-07-12 21:08:41 +02:00
setBulk ( myList , mod , whenDone ) ;
2015-04-02 10:56:20 +02:00
}
2015-04-29 10:42:40 +02:00
} ) ;
2015-04-02 10:56:20 +02:00
}
2015-07-03 11:30:26 +02:00
2015-07-12 21:08:41 +02:00
public void createEmptySettings ( final ArrayList < Integer > myList , final Runnable whenDone ) {
2015-04-29 14:04:25 +02:00
final StmtMod < Integer > mod = new StmtMod < Integer > ( ) {
2015-04-29 10:42:40 +02:00
@Override
public String getCreateMySQL ( int size ) {
2015-04-29 14:04:25 +02:00
return getCreateMySQL ( size , CREATE_SETTINGS , 1 ) ;
2014-11-05 04:42:08 +01:00
}
2015-04-29 10:42:40 +02:00
@Override
public String getCreateSQLite ( int size ) {
2015-04-29 14:04:25 +02:00
return getCreateSQLite ( size , " INSERT INTO ` " + prefix + " plot_settings` SELECT ? AS `plot_plot_id`, ? AS `biome`, ? AS `rain`, ? AS `custom_time`, ? AS `time`, ? AS `deny_entry`, ? AS `alias`, ? AS `flags`, ? AS `merged`, ? AS `position` " , 10 ) ;
2015-01-29 23:16:31 +01:00
}
2015-04-29 10:42:40 +02:00
@Override
public String getCreateSQL ( ) {
2015-04-29 14:04:25 +02:00
return " INSERT INTO ` " + SQLManager . this . prefix + " plot_settings`(`plot_plot_id`) VALUES(?) " ;
2015-04-29 10:42:40 +02:00
}
@Override
2015-04-29 14:04:25 +02:00
public void setMySQL ( PreparedStatement stmt , int i , Integer id ) throws SQLException {
stmt . setInt ( ( i * 1 ) + 1 , id ) ;
2015-04-29 10:42:40 +02:00
}
@Override
2015-04-29 14:04:25 +02:00
public void setSQLite ( PreparedStatement stmt , int i , Integer id ) throws SQLException {
2015-07-03 11:30:26 +02:00
stmt . setInt ( ( i * 10 ) + 1 , id ) ;
2015-04-29 14:04:25 +02:00
stmt . setNull ( ( i * 10 ) + 2 , 4 ) ;
stmt . setNull ( ( i * 10 ) + 3 , 4 ) ;
stmt . setNull ( ( i * 10 ) + 4 , 4 ) ;
stmt . setNull ( ( i * 10 ) + 5 , 4 ) ;
stmt . setNull ( ( i * 10 ) + 6 , 4 ) ;
stmt . setNull ( ( i * 10 ) + 7 , 4 ) ;
stmt . setNull ( ( i * 10 ) + 8 , 4 ) ;
stmt . setNull ( ( i * 10 ) + 9 , 4 ) ;
stmt . setString ( ( i * 10 ) + 10 , " DEFAULT " ) ;
2014-12-21 05:03:59 +01:00
}
2015-04-29 10:42:40 +02:00
@Override
2015-04-29 14:04:25 +02:00
public void setSQL ( PreparedStatement stmt , Integer id ) throws SQLException {
stmt . setInt ( 1 , id ) ;
2015-04-29 10:42:40 +02:00
}
} ;
TaskManager . runTaskAsync ( new Runnable ( ) {
@Override
public void run ( ) {
2015-07-12 21:08:41 +02:00
setBulk ( myList , mod , whenDone ) ;
2015-04-29 10:42:40 +02:00
}
} ) ;
2014-11-05 04:42:08 +01:00
}
2015-02-23 02:32:27 +01:00
2014-11-05 04:42:08 +01:00
/ * *
* Create a plot
*
* @param plot
* /
@Override
public void createPlot ( final Plot plot ) {
2015-02-20 07:34:19 +01:00
TaskManager . runTaskAsync ( new Runnable ( ) {
2014-12-21 10:25:57 +01:00
@Override
public void run ( ) {
PreparedStatement stmt = null ;
try {
stmt = SQLManager . this . connection . prepareStatement ( SQLManager . this . CREATE_PLOT ) ;
stmt . setInt ( 1 , plot . id . x ) ;
stmt . setInt ( 2 , plot . id . y ) ;
2015-03-20 05:11:02 +01:00
stmt . setString ( 3 , plot . owner . toString ( ) ) ;
2014-12-21 10:25:57 +01:00
stmt . setString ( 4 , plot . world ) ;
stmt . executeUpdate ( ) ;
stmt . close ( ) ;
} catch ( final Exception e ) {
e . printStackTrace ( ) ;
2015-07-03 14:15:20 +02:00
PS . log ( " &c[ERROR] " + " Failed to save plot " + plot . id ) ;
2014-12-21 10:25:57 +01:00
}
}
} ) ;
2014-11-05 04:42:08 +01:00
}
2015-02-23 02:32:27 +01:00
2014-12-22 17:04:56 +01:00
@Override
public void createPlotAndSettings ( final Plot plot ) {
2015-02-20 07:34:19 +01:00
TaskManager . runTaskAsync ( new Runnable ( ) {
2014-12-22 17:04:56 +01:00
@Override
public void run ( ) {
PreparedStatement stmt = null ;
try {
stmt = SQLManager . this . connection . prepareStatement ( SQLManager . this . CREATE_PLOT ) ;
stmt . setInt ( 1 , plot . id . x ) ;
stmt . setInt ( 2 , plot . id . y ) ;
2015-03-20 05:11:02 +01:00
stmt . setString ( 3 , plot . owner . toString ( ) ) ;
2014-12-22 17:04:56 +01:00
stmt . setString ( 4 , plot . world ) ;
stmt . executeUpdate ( ) ;
stmt . close ( ) ;
2015-02-20 07:34:19 +01:00
final int id = getId ( plot . world , plot . id ) ;
2014-12-22 17:04:56 +01:00
stmt = SQLManager . this . connection . prepareStatement ( " INSERT INTO ` " + SQLManager . this . prefix + " plot_settings`(`plot_plot_id`) VALUES( " + " ?) " ) ;
stmt . setInt ( 1 , id ) ;
stmt . executeUpdate ( ) ;
stmt . close ( ) ;
} catch ( final Exception e ) {
e . printStackTrace ( ) ;
2015-07-03 14:15:20 +02:00
PS . log ( " &c[ERROR] " + " Failed to save plot " + plot . id ) ;
2014-12-22 17:04:56 +01:00
}
}
} ) ;
}
2015-02-23 02:32:27 +01:00
2014-11-05 04:42:08 +01:00
/ * *
* Create tables
*
* @throws SQLException
* /
@Override
2015-06-05 12:45:13 +02:00
public void createTables ( final String database ) throws SQLException {
final String [ ] tables ;
if ( Settings . ENABLE_CLUSTERS ) {
2015-07-03 11:30:26 +02:00
tables = new String [ ] { " plot " , " plot_denied " , " plot_helpers " , " plot_comments " , " plot_trusted " , " plot_rating " , " plot_settings " , " cluster " } ;
} else {
tables = new String [ ] { " plot " , " plot_denied " , " plot_helpers " , " plot_comments " , " plot_trusted " , " plot_rating " , " plot_settings " } ;
2015-06-05 12:45:13 +02:00
}
2015-07-12 21:08:41 +02:00
final boolean mysql = database . equals ( " mysql " ) ;
2015-06-05 12:45:13 +02:00
final DatabaseMetaData meta = connection . getMetaData ( ) ;
int create = 0 ;
for ( final String s : tables ) {
ResultSet set = meta . getTables ( null , null , prefix + s , null ) ;
if ( ! set . next ( ) ) {
create + + ;
}
set . close ( ) ;
}
if ( create = = 0 ) {
return ;
}
boolean add_constraint ;
2015-07-03 11:30:26 +02:00
add_constraint = create = = tables . length ;
2015-07-03 14:15:20 +02:00
PS . log ( " Creating tables " ) ;
2014-12-16 06:03:20 +01:00
final Statement stmt = this . connection . createStatement ( ) ;
2014-11-05 04:42:08 +01:00
if ( mysql ) {
2015-01-29 08:45:14 +01:00
stmt . addBatch ( " CREATE TABLE IF NOT EXISTS ` " + this . prefix + " plot` ( " + " `id` INT(11) NOT NULL AUTO_INCREMENT, " + " `plot_id_x` INT(11) NOT NULL, " + " `plot_id_z` INT(11) NOT NULL, " + " `owner` VARCHAR(40) NOT NULL, " + " `world` VARCHAR(45) NOT NULL, " + " `timestamp` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP, " + " PRIMARY KEY (`id`) " + " ) ENGINE=InnoDB DEFAULT CHARSET=utf8 AUTO_INCREMENT=0 " ) ;
2014-12-16 06:03:20 +01:00
stmt . addBatch ( " CREATE TABLE IF NOT EXISTS ` " + this . prefix + " plot_denied` ( " + " `plot_plot_id` INT(11) NOT NULL, " + " `user_uuid` VARCHAR(40) NOT NULL " + " ) ENGINE=InnoDB DEFAULT CHARSET=utf8 " ) ;
stmt . addBatch ( " CREATE TABLE IF NOT EXISTS ` " + this . prefix + " plot_helpers` ( " + " `plot_plot_id` INT(11) NOT NULL, " + " `user_uuid` VARCHAR(40) NOT NULL " + " ) ENGINE=InnoDB DEFAULT CHARSET=utf8 " ) ;
2015-07-03 11:30:26 +02:00
stmt . addBatch ( " CREATE TABLE IF NOT EXISTS ` " + this . prefix + " plot_comments` ( " + " `world` VARCHAR(40) NOT NULL, `hashcode` INT(11) NOT NULL, " + " `comment` VARCHAR(40) NOT NULL, " + " `inbox` VARCHAR(40) NOT NULL, " + " `timestamp` INT(11) NOT NULL, " + " `sender` VARCHAR(40) NOT NULL " + " ) ENGINE=InnoDB DEFAULT CHARSET=utf8 " ) ;
2014-12-16 06:03:20 +01:00
stmt . addBatch ( " CREATE TABLE IF NOT EXISTS ` " + this . prefix + " plot_trusted` ( " + " `plot_plot_id` INT(11) NOT NULL, " + " `user_uuid` VARCHAR(40) NOT NULL " + " ) ENGINE=InnoDB DEFAULT CHARSET=utf8 " ) ;
stmt . addBatch ( " CREATE TABLE IF NOT EXISTS ` " + this . prefix + " plot_settings` ( " + " `plot_plot_id` INT(11) NOT NULL, " + " `biome` VARCHAR(45) DEFAULT 'FOREST', " + " `rain` INT(1) DEFAULT 0, " + " `custom_time` TINYINT(1) DEFAULT '0', " + " `time` INT(11) DEFAULT '8000', " + " `deny_entry` TINYINT(1) DEFAULT '0', " + " `alias` VARCHAR(50) DEFAULT NULL, " + " `flags` VARCHAR(512) DEFAULT NULL, " + " `merged` INT(11) DEFAULT NULL, " + " `position` VARCHAR(50) NOT NULL DEFAULT 'DEFAULT', " + " PRIMARY KEY (`plot_plot_id`), " + " UNIQUE KEY `unique_alias` (`alias`) " + " ) ENGINE=InnoDB DEFAULT CHARSET=utf8 " ) ;
2015-06-05 12:45:13 +02:00
stmt . addBatch ( " CREATE TABLE IF NOT EXISTS ` " + this . prefix + " plot_rating` ( `plot_plot_id` INT(11) NOT NULL, `rating` INT(2) NOT NULL, `player` VARCHAR(40) NOT NULL) ENGINE=InnoDB DEFAULT CHARSET=utf8 " ) ;
2014-11-05 04:42:08 +01:00
if ( add_constraint ) {
2014-12-16 06:03:20 +01:00
stmt . addBatch ( " ALTER TABLE ` " + this . prefix + " plot_settings` ADD CONSTRAINT ` " + this . prefix + " plot_settings_ibfk_1` FOREIGN KEY (`plot_plot_id`) REFERENCES ` " + this . prefix + " plot` (`id`) ON DELETE CASCADE " ) ;
2014-11-05 04:42:08 +01:00
}
2015-01-29 08:45:14 +01:00
stmt . addBatch ( " CREATE TABLE IF NOT EXISTS ` " + this . prefix + " cluster` ( " + " `id` INT(11) NOT NULL AUTO_INCREMENT, " + " `pos1_x` INT(11) NOT NULL, " + " `pos1_z` INT(11) NOT NULL, " + " `pos2_x` INT(11) NOT NULL, " + " `pos2_z` INT(11) NOT NULL, " + " `owner` VARCHAR(40) NOT NULL, " + " `world` VARCHAR(45) NOT NULL, " + " `timestamp` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP, " + " PRIMARY KEY (`id`) " + " ) ENGINE=InnoDB DEFAULT CHARSET=utf8 AUTO_INCREMENT=0 " ) ;
stmt . addBatch ( " CREATE TABLE IF NOT EXISTS ` " + this . prefix + " cluster_helpers` ( " + " `cluster_id` INT(11) NOT NULL, " + " `user_uuid` VARCHAR(40) NOT NULL " + " ) ENGINE=InnoDB DEFAULT CHARSET=utf8 " ) ;
2015-02-20 07:34:19 +01:00
stmt . addBatch ( " CREATE TABLE IF NOT EXISTS ` " + this . prefix + " cluster_invited` ( " + " `cluster_id` INT(11) NOT NULL, " + " `user_uuid` VARCHAR(40) NOT NULL " + " ) ENGINE=InnoDB DEFAULT CHARSET=utf8 " ) ;
2015-01-26 05:16:10 +01:00
stmt . addBatch ( " CREATE TABLE IF NOT EXISTS ` " + this . prefix + " cluster_settings` ( " + " `cluster_id` INT(11) NOT NULL, " + " `biome` VARCHAR(45) DEFAULT 'FOREST', " + " `rain` INT(1) DEFAULT 0, " + " `custom_time` TINYINT(1) DEFAULT '0', " + " `time` INT(11) DEFAULT '8000', " + " `deny_entry` TINYINT(1) DEFAULT '0', " + " `alias` VARCHAR(50) DEFAULT NULL, " + " `flags` VARCHAR(512) DEFAULT NULL, " + " `merged` INT(11) DEFAULT NULL, " + " `position` VARCHAR(50) NOT NULL DEFAULT 'DEFAULT', " + " PRIMARY KEY (`cluster_id`) " + " ) ENGINE=InnoDB DEFAULT CHARSET=utf8 " ) ;
2014-12-18 03:15:11 +01:00
} else {
2015-02-20 07:34:19 +01:00
stmt . addBatch ( " CREATE TABLE IF NOT EXISTS ` " + this . prefix + " plot` ( " + " `id` INTEGER PRIMARY KEY AUTOINCREMENT, " + " `plot_id_x` INT(11) NOT NULL, " + " `plot_id_z` INT(11) NOT NULL, " + " `owner` VARCHAR(45) NOT NULL, " + " `world` VARCHAR(45) NOT NULL, " + " `timestamp` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP) " ) ;
2014-12-16 06:03:20 +01:00
stmt . addBatch ( " CREATE TABLE IF NOT EXISTS ` " + this . prefix + " plot_denied` ( " + " `plot_plot_id` INT(11) NOT NULL, " + " `user_uuid` VARCHAR(40) NOT NULL " + " ) " ) ;
stmt . addBatch ( " CREATE TABLE IF NOT EXISTS ` " + this . prefix + " plot_helpers` ( " + " `plot_plot_id` INT(11) NOT NULL, " + " `user_uuid` VARCHAR(40) NOT NULL " + " ) " ) ;
stmt . addBatch ( " CREATE TABLE IF NOT EXISTS ` " + this . prefix + " plot_trusted` ( " + " `plot_plot_id` INT(11) NOT NULL, " + " `user_uuid` VARCHAR(40) NOT NULL " + " ) " ) ;
2015-04-06 14:16:24 +02:00
stmt . addBatch ( " CREATE TABLE IF NOT EXISTS ` " + this . prefix + " plot_comments` ( " + " `world` VARCHAR(40) NOT NULL, `hashcode` INT(11) NOT NULL, " + " `comment` VARCHAR(40) NOT NULL, " + " `inbox` VARCHAR(40) NOT NULL, `timestamp` INT(11) NOT NULL, " + " `sender` VARCHAR(40) NOT NULL " + " ) " ) ;
2014-12-16 06:03:20 +01:00
stmt . addBatch ( " CREATE TABLE IF NOT EXISTS ` " + this . prefix + " plot_settings` ( " + " `plot_plot_id` INT(11) NOT NULL, " + " `biome` VARCHAR(45) DEFAULT 'FOREST', " + " `rain` INT(1) DEFAULT 0, " + " `custom_time` TINYINT(1) DEFAULT '0', " + " `time` INT(11) DEFAULT '8000', " + " `deny_entry` TINYINT(1) DEFAULT '0', " + " `alias` VARCHAR(50) DEFAULT NULL, " + " `flags` VARCHAR(512) DEFAULT NULL, " + " `merged` INT(11) DEFAULT NULL, " + " `position` VARCHAR(50) NOT NULL DEFAULT 'DEFAULT', " + " PRIMARY KEY (`plot_plot_id`) " + " ) " ) ;
2015-06-05 12:45:13 +02:00
stmt . addBatch ( " CREATE TABLE IF NOT EXISTS ` " + this . prefix + " plot_rating` (`plot_plot_id` INT(11) NOT NULL, `rating` INT(2) NOT NULL, `player` VARCHAR(40) NOT NULL) " ) ;
2015-01-29 08:45:14 +01:00
stmt . addBatch ( " CREATE TABLE IF NOT EXISTS ` " + this . prefix + " cluster` ( " + " `id` INTEGER PRIMARY KEY AUTOINCREMENT, " + " `pos1_x` INT(11) NOT NULL, " + " `pos1_z` INT(11) NOT NULL, " + " `pos2_x` INT(11) NOT NULL, " + " `pos2_z` INT(11) NOT NULL, " + " `owner` VARCHAR(40) NOT NULL, " + " `world` VARCHAR(45) NOT NULL, " + " `timestamp` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP " + " ) " ) ;
2015-01-29 04:20:29 +01:00
stmt . addBatch ( " CREATE TABLE IF NOT EXISTS ` " + this . prefix + " cluster_helpers` ( " + " `cluster_id` INT(11) NOT NULL, " + " `user_uuid` VARCHAR(40) NOT NULL " + " ) " ) ;
stmt . addBatch ( " CREATE TABLE IF NOT EXISTS ` " + this . prefix + " cluster_invited` ( " + " `cluster_id` INT(11) NOT NULL, " + " `user_uuid` VARCHAR(40) NOT NULL " + " ) " ) ;
2015-01-26 05:16:10 +01:00
stmt . addBatch ( " CREATE TABLE IF NOT EXISTS ` " + this . prefix + " cluster_settings` ( " + " `cluster_id` INT(11) NOT NULL, " + " `biome` VARCHAR(45) DEFAULT 'FOREST', " + " `rain` INT(1) DEFAULT 0, " + " `custom_time` TINYINT(1) DEFAULT '0', " + " `time` INT(11) DEFAULT '8000', " + " `deny_entry` TINYINT(1) DEFAULT '0', " + " `alias` VARCHAR(50) DEFAULT NULL, " + " `flags` VARCHAR(512) DEFAULT NULL, " + " `merged` INT(11) DEFAULT NULL, " + " `position` VARCHAR(50) NOT NULL DEFAULT 'DEFAULT', " + " PRIMARY KEY (`cluster_id`) " + " ) " ) ;
2014-11-05 04:42:08 +01:00
}
stmt . executeBatch ( ) ;
stmt . clearBatch ( ) ;
stmt . close ( ) ;
}
2015-02-23 02:32:27 +01:00
2014-11-05 04:42:08 +01:00
/ * *
* Delete a plot
*
* @param plot
* /
@Override
2015-07-04 08:37:33 +02:00
public void delete ( final Plot plot ) {
PS . get ( ) . removePlot ( plot . world , plot . id , false ) ;
2015-02-20 07:34:19 +01:00
TaskManager . runTaskAsync ( new Runnable ( ) {
2014-11-05 04:42:08 +01:00
@Override
public void run ( ) {
PreparedStatement stmt = null ;
2015-07-04 08:37:33 +02:00
final int id = getId ( plot . world , plot . id ) ;
2014-11-05 04:42:08 +01:00
try {
2014-12-16 06:03:20 +01:00
stmt = SQLManager . this . connection . prepareStatement ( " DELETE FROM ` " + SQLManager . this . prefix + " plot_settings` WHERE `plot_plot_id` = ? " ) ;
2014-11-05 04:42:08 +01:00
stmt . setInt ( 1 , id ) ;
stmt . executeUpdate ( ) ;
stmt . close ( ) ;
2014-12-16 06:03:20 +01:00
stmt = SQLManager . this . connection . prepareStatement ( " DELETE FROM ` " + SQLManager . this . prefix + " plot_helpers` WHERE `plot_plot_id` = ? " ) ;
2014-11-05 04:42:08 +01:00
stmt . setInt ( 1 , id ) ;
stmt . executeUpdate ( ) ;
stmt . close ( ) ;
2014-12-16 06:03:20 +01:00
stmt = SQLManager . this . connection . prepareStatement ( " DELETE FROM ` " + SQLManager . this . prefix + " plot_trusted` WHERE `plot_plot_id` = ? " ) ;
2015-05-15 05:29:23 +02:00
stmt . setInt ( 1 , id ) ;
stmt . executeUpdate ( ) ;
stmt . close ( ) ;
stmt = SQLManager . this . connection . prepareStatement ( " DELETE FROM ` " + SQLManager . this . prefix + " plot_denied` WHERE `plot_plot_id` = ? " ) ;
2014-11-05 04:42:08 +01:00
stmt . setInt ( 1 , id ) ;
stmt . executeUpdate ( ) ;
stmt . close ( ) ;
2015-04-09 07:41:14 +02:00
stmt = SQLManager . this . connection . prepareStatement ( " DELETE FROM ` " + SQLManager . this . prefix + " plot_comments` WHERE `world` = ? AND `hashcode` = ? " ) ;
2015-07-04 08:37:33 +02:00
stmt . setString ( 1 , plot . world ) ;
2015-04-09 07:41:14 +02:00
stmt . setInt ( 2 , plot . hashCode ( ) ) ;
2014-11-06 08:23:21 +01:00
stmt . executeUpdate ( ) ;
2014-12-16 06:03:20 +01:00
stmt = SQLManager . this . connection . prepareStatement ( " DELETE FROM ` " + SQLManager . this . prefix + " plot` WHERE `id` = ? " ) ;
2014-11-05 04:42:08 +01:00
stmt . setInt ( 1 , id ) ;
stmt . executeUpdate ( ) ;
stmt . close ( ) ;
2014-12-18 03:15:11 +01:00
} catch ( final SQLException e ) {
2014-11-05 04:42:08 +01:00
e . printStackTrace ( ) ;
2015-07-03 14:15:20 +02:00
PS . log ( " &c[ERROR] " + " Failed to delete plot " + plot . id ) ;
2014-11-05 04:42:08 +01:00
}
}
} ) ;
}
2015-02-23 02:32:27 +01:00
2014-11-05 04:42:08 +01:00
/ * *
* Create plot settings
*
* @param id
* @param plot
* /
@Override
public void createPlotSettings ( final int id , final Plot plot ) {
2015-02-20 07:34:19 +01:00
TaskManager . runTaskAsync ( new Runnable ( ) {
2014-11-05 04:42:08 +01:00
@Override
public void run ( ) {
PreparedStatement stmt = null ;
try {
2014-12-16 06:03:20 +01:00
stmt = SQLManager . this . connection . prepareStatement ( " INSERT INTO ` " + SQLManager . this . prefix + " plot_settings`(`plot_plot_id`) VALUES( " + " ?) " ) ;
2014-11-05 04:42:08 +01:00
stmt . setInt ( 1 , id ) ;
stmt . executeUpdate ( ) ;
stmt . close ( ) ;
2014-12-18 03:15:11 +01:00
} catch ( final SQLException e ) {
2014-11-05 04:42:08 +01:00
e . printStackTrace ( ) ;
}
}
} ) ;
}
2015-02-23 02:32:27 +01:00
2014-11-05 04:42:08 +01:00
@Override
public int getId ( final String world , final PlotId id2 ) {
PreparedStatement stmt = null ;
try {
2014-12-16 06:03:20 +01:00
stmt = this . connection . prepareStatement ( " SELECT `id` FROM ` " + this . prefix + " plot` WHERE `plot_id_x` = ? AND `plot_id_z` = ? AND world = ? ORDER BY `timestamp` ASC " ) ;
2014-11-05 04:42:08 +01:00
stmt . setInt ( 1 , id2 . x ) ;
stmt . setInt ( 2 , id2 . y ) ;
stmt . setString ( 3 , world ) ;
final ResultSet r = stmt . executeQuery ( ) ;
int id = Integer . MAX_VALUE ;
while ( r . next ( ) ) {
id = r . getInt ( " id " ) ;
}
2015-02-19 04:24:05 +01:00
r . close ( ) ;
2014-11-05 04:42:08 +01:00
stmt . close ( ) ;
return id ;
2014-12-18 03:15:11 +01:00
} catch ( final SQLException e ) {
2014-11-05 04:42:08 +01:00
e . printStackTrace ( ) ;
}
return Integer . MAX_VALUE ;
}
2015-07-03 11:30:26 +02:00
2015-04-06 11:59:22 +02:00
public void updateTables ( ) {
2015-07-12 21:08:41 +02:00
if ( PS . get ( ) . getVersion ( ) . equals ( PS . get ( ) . getLastVersion ( ) ) | | PS . get ( ) . getLastVersion ( ) = = null ) {
return ;
}
2015-04-06 11:59:22 +02:00
try {
final DatabaseMetaData data = this . connection . getMetaData ( ) ;
2015-04-11 06:07:19 +02:00
ResultSet rs = data . getColumns ( null , null , this . prefix + " plot_comments " , " plot_plot_id " ) ;
2015-04-07 08:19:16 +02:00
if ( rs . next ( ) ) {
2015-04-17 08:39:45 +02:00
rs . close ( ) ;
2015-04-11 06:07:19 +02:00
rs = data . getColumns ( null , null , this . prefix + " plot_comments " , " hashcode " ) ;
2015-04-07 08:19:16 +02:00
if ( ! rs . next ( ) ) {
rs . close ( ) ;
2015-04-16 15:37:50 +02:00
try {
final Statement statement = this . connection . createStatement ( ) ;
statement . addBatch ( " DROP TABLE ` " + this . prefix + " plot_comments` " ) ;
2015-04-29 15:07:12 +02:00
if ( Settings . DB . USE_MYSQL ) {
2015-07-03 11:30:26 +02:00
statement . addBatch ( " CREATE TABLE IF NOT EXISTS ` " + this . prefix + " plot_comments` ( " + " `world` VARCHAR(40) NOT NULL, `hashcode` INT(11) NOT NULL, " + " `comment` VARCHAR(40) NOT NULL, " + " `inbox` VARCHAR(40) NOT NULL, " + " `timestamp` INT(11) NOT NULL, " + " `sender` VARCHAR(40) NOT NULL " + " ) ENGINE=InnoDB DEFAULT CHARSET=utf8 " ) ;
} else {
2015-04-16 15:37:50 +02:00
statement . addBatch ( " CREATE TABLE IF NOT EXISTS ` " + this . prefix + " plot_comments` ( " + " `world` VARCHAR(40) NOT NULL, `hashcode` INT(11) NOT NULL, " + " `comment` VARCHAR(40) NOT NULL, " + " `inbox` VARCHAR(40) NOT NULL, `timestamp` INT(11) NOT NULL, " + " `sender` VARCHAR(40) NOT NULL " + " ) " ) ;
}
statement . executeBatch ( ) ;
statement . close ( ) ;
2015-07-03 11:30:26 +02:00
} catch ( SQLException e ) {
2015-04-17 08:39:45 +02:00
final Statement statement = this . connection . createStatement ( ) ;
statement . addBatch ( " ALTER IGNORE TABLE ` " + this . prefix + " plot_comments` ADD `inbox` VARCHAR(11) DEFAULT `public` " ) ;
statement . addBatch ( " ALTER IGNORE TABLE ` " + this . prefix + " plot_comments` ADD `timestamp` INT(11) DEFAULT 0 " ) ;
statement . addBatch ( " ALTER TABLE ` " + this . prefix + " plot` DROP `tier` " ) ;
statement . executeBatch ( ) ;
statement . close ( ) ;
}
2015-04-06 14:16:24 +02:00
}
2015-04-06 11:59:22 +02:00
}
2015-04-07 08:19:16 +02:00
rs . close ( ) ;
2015-07-12 21:08:41 +02:00
try ( Statement statement = connection . createStatement ( ) ; ) {
for ( String table : new String [ ] { " plot_denied " , " plot_helpers " , " plot_trusted " } ) {
ResultSet result = statement . executeQuery ( " SELECT plot_plot_id, user_uuid, COUNT(*) FROM " + this . prefix + table + " GROUP BY plot_plot_id, user_uuid HAVING COUNT(*) > 1 " ) ;
if ( result . next ( ) ) {
PS . log ( " BACKING UP: " + table ) ;
result . close ( ) ;
statement . executeUpdate ( " CREATE TABLE " + table + " _tmp AS SELECT * FROM " + this . prefix + table + " GROUP BY plot_plot_id, user_uuid " ) ;
statement . executeUpdate ( " DROP TABLE " + this . prefix + table ) ;
statement . executeUpdate ( " CREATE TABLE " + this . prefix + table + " AS SELECT * FROM " + table + " _tmp " ) ;
statement . executeUpdate ( " DROP TABLE " + this . prefix + table + " _tmp " ) ;
PS . log ( " RESTORING: " + table ) ;
}
}
}
catch ( Exception e2 ) {
e2 . printStackTrace ( ) ;
}
}
catch ( Exception e ) {
2015-04-06 14:16:24 +02:00
e . printStackTrace ( ) ;
}
2015-07-12 21:08:41 +02:00
2015-04-06 11:59:22 +02:00
}
2015-02-23 02:32:27 +01:00
2014-11-05 04:42:08 +01:00
/ * *
2015-02-10 10:24:19 +01:00
* Load all plots , helpers , denied , trusted , and every setting from DB into a hashmap
2014-11-05 04:42:08 +01:00
* /
@Override
public LinkedHashMap < String , HashMap < PlotId , Plot > > getPlots ( ) {
2014-11-21 23:45:46 +01:00
final LinkedHashMap < String , HashMap < PlotId , Plot > > newplots = new LinkedHashMap < > ( ) ;
final HashMap < Integer , Plot > plots = new HashMap < > ( ) ;
2014-11-05 04:42:08 +01:00
Statement stmt = null ;
try {
2014-11-21 23:45:46 +01:00
Set < String > worlds = new HashSet < > ( ) ;
2015-07-03 14:15:20 +02:00
if ( PS . get ( ) . config . contains ( " worlds " ) ) {
worlds = PS . get ( ) . config . getConfigurationSection ( " worlds " ) . getKeys ( false ) ;
2014-11-05 04:42:08 +01:00
}
final HashMap < String , UUID > uuids = new HashMap < String , UUID > ( ) ;
final HashMap < String , Integer > noExist = new HashMap < String , Integer > ( ) ;
/ *
2014-10-28 08:54:41 +01:00
* Getting plots
* /
2014-12-16 06:03:20 +01:00
stmt = this . connection . createStatement ( ) ;
ResultSet r = stmt . executeQuery ( " SELECT `id`, `plot_id_x`, `plot_id_z`, `owner`, `world` FROM ` " + this . prefix + " plot` " ) ;
2014-11-05 04:42:08 +01:00
PlotId plot_id ;
int id ;
Plot p ;
String o ;
UUID user ;
while ( r . next ( ) ) {
plot_id = new PlotId ( r . getInt ( " plot_id_x " ) , r . getInt ( " plot_id_z " ) ) ;
id = r . getInt ( " id " ) ;
final String worldname = r . getString ( " world " ) ;
if ( ! worlds . contains ( worldname ) ) {
if ( noExist . containsKey ( worldname ) ) {
noExist . put ( worldname , noExist . get ( worldname ) + 1 ) ;
2014-12-18 03:15:11 +01:00
} else {
2014-11-05 04:42:08 +01:00
noExist . put ( worldname , 1 ) ;
}
}
o = r . getString ( " owner " ) ;
user = uuids . get ( o ) ;
if ( user = = null ) {
user = UUID . fromString ( o ) ;
uuids . put ( o , user ) ;
}
2015-07-03 11:30:26 +02:00
p = new Plot ( plot_id , user , new ArrayList < UUID > ( ) , new ArrayList < UUID > ( ) , new ArrayList < UUID > ( ) , " " , null , null , worldname , new boolean [ ] { false , false , false , false } ) ;
2014-11-05 04:42:08 +01:00
plots . put ( id , p ) ;
}
2015-06-28 02:54:57 +02:00
if ( Settings . CACHE_RATINGS ) {
r = stmt . executeQuery ( " SELECT `plot_plot_id`, `player`, `rating` FROM ` " + this . prefix + " plot_rating` " ) ;
while ( r . next ( ) ) {
id = r . getInt ( " plot_plot_id " ) ;
o = r . getString ( " player " ) ;
user = uuids . get ( o ) ;
if ( user = = null ) {
user = UUID . fromString ( o ) ;
uuids . put ( o , user ) ;
}
final Plot plot = plots . get ( id ) ;
if ( plot ! = null ) {
2015-07-03 11:30:26 +02:00
if ( plot . settings . ratings = = null ) {
2015-06-28 02:54:57 +02:00
plot . settings . ratings = new HashMap < UUID , Integer > ( ) ;
}
plot . settings . ratings . put ( user , r . getInt ( " rating " ) ) ;
} else {
2015-07-03 14:15:20 +02:00
PS . log ( " &cPLOT " + id + " in plot_helpers does not exist. Please create the plot or remove this entry. " ) ;
2015-06-28 02:54:57 +02:00
}
}
}
2015-07-04 15:38:47 +02:00
2014-11-05 04:42:08 +01:00
/ *
* Getting helpers
* /
2014-12-16 06:03:20 +01:00
r = stmt . executeQuery ( " SELECT `user_uuid`, `plot_plot_id` FROM ` " + this . prefix + " plot_helpers` " ) ;
2014-10-28 08:54:41 +01:00
while ( r . next ( ) ) {
id = r . getInt ( " plot_plot_id " ) ;
o = r . getString ( " user_uuid " ) ;
user = uuids . get ( o ) ;
2014-11-05 04:42:08 +01:00
if ( user = = null ) {
2014-10-28 08:54:41 +01:00
user = UUID . fromString ( o ) ;
uuids . put ( o , user ) ;
}
2014-11-05 04:42:08 +01:00
final Plot plot = plots . get ( id ) ;
if ( plot ! = null ) {
2015-07-12 21:08:41 +02:00
plot . trusted . add ( user ) ;
2014-12-18 03:15:11 +01:00
} else {
2015-07-03 14:15:20 +02:00
PS . log ( " &cPLOT " + id + " in plot_helpers does not exist. Please create the plot or remove this entry. " ) ;
2014-10-28 08:54:41 +01:00
}
}
2015-07-04 15:38:47 +02:00
2014-10-28 08:54:41 +01:00
/ *
* Getting trusted
* /
2014-12-16 06:03:20 +01:00
r = stmt . executeQuery ( " SELECT `user_uuid`, `plot_plot_id` FROM ` " + this . prefix + " plot_trusted` " ) ;
2014-10-28 08:54:41 +01:00
while ( r . next ( ) ) {
id = r . getInt ( " plot_plot_id " ) ;
o = r . getString ( " user_uuid " ) ;
user = uuids . get ( o ) ;
2014-11-05 04:42:08 +01:00
if ( user = = null ) {
2014-10-28 08:54:41 +01:00
user = UUID . fromString ( o ) ;
uuids . put ( o , user ) ;
}
2014-11-05 04:42:08 +01:00
final Plot plot = plots . get ( id ) ;
if ( plot ! = null ) {
2015-07-12 21:08:41 +02:00
plot . members . add ( user ) ;
2014-12-18 03:15:11 +01:00
} else {
2015-07-03 14:15:20 +02:00
PS . log ( " &cPLOT " + id + " in plot_trusted does not exist. Please create the plot or remove this entry. " ) ;
2014-10-28 08:54:41 +01:00
}
}
2015-07-04 15:38:47 +02:00
2014-10-28 08:54:41 +01:00
/ *
* Getting denied
* /
2014-12-16 06:03:20 +01:00
r = stmt . executeQuery ( " SELECT `user_uuid`, `plot_plot_id` FROM ` " + this . prefix + " plot_denied` " ) ;
2014-10-28 08:54:41 +01:00
while ( r . next ( ) ) {
id = r . getInt ( " plot_plot_id " ) ;
o = r . getString ( " user_uuid " ) ;
user = uuids . get ( o ) ;
2014-11-05 04:42:08 +01:00
if ( user = = null ) {
2014-10-28 08:54:41 +01:00
user = UUID . fromString ( o ) ;
uuids . put ( o , user ) ;
}
2014-11-05 04:42:08 +01:00
final Plot plot = plots . get ( id ) ;
if ( plot ! = null ) {
2015-07-12 21:08:41 +02:00
plot . denied . add ( user ) ;
2014-12-18 03:15:11 +01:00
} else {
2015-07-03 14:15:20 +02:00
PS . log ( " &cPLOT " + id + " in plot_denied does not exist. Please create the plot or remove this entry. " ) ;
2014-10-28 08:54:41 +01:00
}
}
2015-07-04 15:38:47 +02:00
2014-12-16 06:03:20 +01:00
r = stmt . executeQuery ( " SELECT * FROM ` " + this . prefix + " plot_settings` " ) ;
2014-10-28 08:54:41 +01:00
while ( r . next ( ) ) {
id = r . getInt ( " plot_plot_id " ) ;
2014-11-05 04:42:08 +01:00
final Plot plot = plots . get ( id ) ;
if ( plot ! = null ) {
2015-04-02 10:56:20 +02:00
plots . remove ( id ) ;
if ( ! newplots . containsKey ( plot . world ) ) {
newplots . put ( plot . world , new HashMap < PlotId , Plot > ( ) ) ;
}
newplots . get ( plot . world ) . put ( plot . id , plot ) ;
2014-11-05 04:42:08 +01:00
final String b = r . getString ( " biome " ) ;
if ( b ! = null ) {
for ( final Biome mybiome : Biome . values ( ) ) {
2014-10-28 08:54:41 +01:00
if ( mybiome . toString ( ) . equalsIgnoreCase ( b ) ) {
break ;
}
}
}
2014-11-05 04:42:08 +01:00
final String alias = r . getString ( " alias " ) ;
if ( alias ! = null ) {
2014-10-28 08:54:41 +01:00
plot . settings . setAlias ( alias ) ;
}
2014-11-05 04:42:08 +01:00
final String pos = r . getString ( " position " ) ;
2015-01-12 16:52:33 +01:00
switch ( pos . toLowerCase ( ) ) {
case " " :
case " default " :
case " 0,0,0 " :
case " center " :
break ;
default :
try {
2015-05-24 03:15:30 +02:00
plot . settings . setPosition ( BlockLoc . fromString ( pos ) ) ;
2015-02-20 07:34:19 +01:00
} catch ( final Exception e ) {
2014-10-28 08:54:41 +01:00
}
}
2014-11-05 04:42:08 +01:00
final Integer m = r . getInt ( " merged " ) ;
if ( m ! = null ) {
final boolean [ ] merged = new boolean [ 4 ] ;
2014-10-28 08:54:41 +01:00
for ( int i = 0 ; i < 4 ; i + + ) {
2014-11-05 04:42:08 +01:00
merged [ 3 - i ] = ( ( m ) & ( 1 < < i ) ) ! = 0 ;
2014-10-28 08:54:41 +01:00
}
plot . settings . setMerged ( merged ) ;
2014-12-18 03:15:11 +01:00
} else {
2015-07-03 11:30:26 +02:00
plot . settings . setMerged ( new boolean [ ] { false , false , false , false } ) ;
2014-10-28 08:54:41 +01:00
}
String [ ] flags_string ;
2014-11-05 04:42:08 +01:00
final String myflags = r . getString ( " flags " ) ;
2014-10-28 08:54:41 +01:00
if ( myflags = = null ) {
2015-07-03 11:30:26 +02:00
flags_string = new String [ ] { } ;
2014-12-18 03:15:11 +01:00
} else {
2015-01-09 15:05:10 +01:00
if ( myflags . length ( ) > 0 ) {
flags_string = myflags . split ( " , " ) ;
2015-02-20 07:34:19 +01:00
} else {
2015-07-03 11:30:26 +02:00
flags_string = new String [ ] { } ;
2015-01-09 15:05:10 +01:00
}
2014-10-28 08:54:41 +01:00
}
2015-06-23 23:44:44 +02:00
final HashMap < String , Flag > flags = new HashMap < > ( ) ;
2014-10-28 08:54:41 +01:00
boolean exception = false ;
2015-05-04 11:52:37 +02:00
for ( String element : flags_string ) {
2014-11-05 04:42:08 +01:00
if ( element . contains ( " : " ) ) {
final String [ ] split = element . split ( " : " ) ;
2014-10-28 08:54:41 +01:00
try {
2015-02-20 07:34:19 +01:00
final String flag_str = split [ 1 ] . replaceAll ( " \ u00AF " , " : " ) . replaceAll ( " \ u00B4 " , " , " ) ;
final Flag flag = new Flag ( FlagManager . getFlag ( split [ 0 ] , true ) , flag_str ) ;
2015-06-23 23:44:44 +02:00
flags . put ( flag . getKey ( ) , flag ) ;
2014-12-18 03:15:11 +01:00
} catch ( final Exception e ) {
2015-01-09 15:05:10 +01:00
e . printStackTrace ( ) ;
2014-10-28 08:54:41 +01:00
exception = true ;
}
2014-12-18 03:15:11 +01:00
} else {
2015-05-04 11:52:37 +02:00
element = element . replaceAll ( " \ u00AF " , " : " ) . replaceAll ( " \ u00B4 " , " , " ) ;
if ( StringUtils . isAlpha ( element . replaceAll ( " _ " , " " ) . replaceAll ( " - " , " " ) ) ) {
2015-06-23 23:44:44 +02:00
Flag flag = new Flag ( FlagManager . getFlag ( element , true ) , " " ) ;
flags . put ( flag . getKey ( ) , flag ) ;
2015-07-03 11:30:26 +02:00
} else {
2015-07-03 14:15:20 +02:00
PS . log ( " INVALID FLAG: " + element ) ;
2015-05-04 11:52:37 +02:00
}
2014-10-28 08:54:41 +01:00
}
}
if ( exception ) {
2015-07-03 14:15:20 +02:00
PS . log ( " &cPlot " + id + " had an invalid flag. A fix has been attempted. " ) ;
PS . log ( " &c " + myflags ) ;
2015-06-23 23:44:44 +02:00
setFlags ( id , flags . values ( ) ) ;
2014-10-28 08:54:41 +01:00
}
2015-01-09 15:05:10 +01:00
plot . settings . flags = flags ;
2014-12-18 03:15:11 +01:00
} else {
2015-07-03 14:15:20 +02:00
PS . log ( " &cPLOT " + id + " in plot_settings does not exist. Please create the plot or remove this entry. " ) ;
2014-10-28 08:54:41 +01:00
}
}
2015-07-04 15:38:47 +02:00
2014-10-28 08:54:41 +01:00
stmt . close ( ) ;
2015-02-19 04:24:05 +01:00
r . close ( ) ;
2015-04-02 10:56:20 +02:00
if ( plots . keySet ( ) . size ( ) > 0 ) {
2015-07-12 21:08:41 +02:00
createEmptySettings ( new ArrayList < Integer > ( plots . keySet ( ) ) , null ) ;
2014-10-28 08:54:41 +01:00
}
2014-11-06 08:23:21 +01:00
boolean invalidPlot = false ;
2014-11-05 04:42:08 +01:00
for ( final String worldname : noExist . keySet ( ) ) {
2014-11-06 08:23:21 +01:00
invalidPlot = true ;
2015-07-03 14:15:20 +02:00
PS . log ( " &c[WARNING] Found " + noExist . get ( worldname ) + " plots in DB for non existant world; ' " + worldname + " '. " ) ;
2014-11-06 08:23:21 +01:00
}
if ( invalidPlot ) {
2015-07-03 14:15:20 +02:00
PS . log ( " &c[WARNING] - Please create the world/s or remove the plots using the purge command " ) ;
2014-11-05 04:42:08 +01:00
}
2014-12-18 03:15:11 +01:00
} catch ( final SQLException e ) {
2015-07-03 14:15:20 +02:00
PS . log ( " &7[WARN] " + " Failed to load plots. " ) ;
2014-11-05 04:42:08 +01:00
e . printStackTrace ( ) ;
}
return newplots ;
}
2015-02-23 02:32:27 +01:00
2014-11-05 04:42:08 +01:00
@Override
2015-07-04 08:37:33 +02:00
public void setMerged ( final Plot plot , final boolean [ ] merged ) {
2014-11-05 04:42:08 +01:00
plot . settings . setMerged ( merged ) ;
2015-02-20 07:34:19 +01:00
TaskManager . runTaskAsync ( new Runnable ( ) {
2014-11-05 04:42:08 +01:00
@Override
public void run ( ) {
try {
int n = 0 ;
for ( int i = 0 ; i < 4 ; + + i ) {
n = ( n < < 1 ) + ( merged [ i ] ? 1 : 0 ) ;
}
2014-12-16 06:03:20 +01:00
final PreparedStatement stmt = SQLManager . this . connection . prepareStatement ( " UPDATE ` " + SQLManager . this . prefix + " plot_settings` SET `merged` = ? WHERE `plot_plot_id` = ? " ) ;
2014-11-05 04:42:08 +01:00
stmt . setInt ( 1 , n ) ;
2015-07-04 08:37:33 +02:00
stmt . setInt ( 2 , getId ( plot . world , plot . id ) ) ;
2014-11-05 04:42:08 +01:00
stmt . execute ( ) ;
stmt . close ( ) ;
2014-12-18 03:15:11 +01:00
} catch ( final SQLException e ) {
2014-11-05 04:42:08 +01:00
e . printStackTrace ( ) ;
2015-07-03 14:15:20 +02:00
PS . log ( " &7[WARN] " + " Could not set merged for plot " + plot . id ) ;
2014-11-05 04:42:08 +01:00
}
}
} ) ;
}
2015-02-23 02:32:27 +01:00
2015-02-10 21:17:30 +01:00
@Override
public void swapPlots ( final Plot p1 , final Plot p2 ) {
2015-02-20 07:34:19 +01:00
TaskManager . runTaskAsync ( new Runnable ( ) {
@Override
public void run ( ) {
/ *
* We don ' t need to actually swap all the rows
* - Just switch the plot_id_x and plot_id_z
* - The other tables reference the ` id ` so it will cascade
* /
try {
final String world = p1 . world ;
final int id1 = getId ( world , p1 . id ) ;
final int id2 = getId ( world , p2 . id ) ;
final PlotId pos1 = p1 . getId ( ) ;
final PlotId pos2 = p2 . getId ( ) ;
PreparedStatement stmt = SQLManager . this . connection . prepareStatement ( " UPDATE ` " + SQLManager . this . prefix + " plot` SET `plot_id_x` = ?, `plot_id_z` = ? WHERE `id` = ? " ) ;
stmt . setInt ( 1 , pos2 . x ) ;
stmt . setInt ( 2 , pos2 . y ) ;
stmt . setInt ( 3 , id1 ) ;
stmt . executeUpdate ( ) ;
stmt . close ( ) ;
stmt = SQLManager . this . connection . prepareStatement ( " UPDATE ` " + SQLManager . this . prefix + " plot` SET `plot_id_x` = ?, `plot_id_z` = ? WHERE `id` = ? " ) ;
stmt . setInt ( 1 , pos1 . x ) ;
stmt . setInt ( 2 , pos1 . y ) ;
stmt . setInt ( 3 , id2 ) ;
stmt . executeUpdate ( ) ;
stmt . close ( ) ;
} catch ( final Exception e ) {
e . printStackTrace ( ) ;
2015-02-15 08:40:55 +01:00
}
2015-02-20 07:34:19 +01:00
}
} ) ;
2015-02-15 08:40:55 +01:00
}
2015-02-23 02:32:27 +01:00
2015-02-15 08:40:55 +01:00
@Override
2015-03-24 10:57:29 +01:00
public void movePlot ( final Plot original , final Plot newPlot ) {
2015-02-20 07:34:19 +01:00
TaskManager . runTaskAsync ( new Runnable ( ) {
@Override
public void run ( ) {
try {
2015-03-24 06:55:38 +01:00
final int id = getId ( original . world , original . id ) ;
2015-02-20 07:34:19 +01:00
final PreparedStatement stmt = SQLManager . this . connection . prepareStatement ( " UPDATE ` " + SQLManager . this . prefix + " plot` SET `plot_id_x` = ?, `plot_id_z` = ? WHERE `id` = ? " ) ;
2015-03-24 06:55:38 +01:00
stmt . setInt ( 1 , newPlot . id . x ) ;
stmt . setInt ( 2 , newPlot . id . y ) ;
2015-02-20 07:34:19 +01:00
stmt . setInt ( 3 , id ) ;
stmt . executeUpdate ( ) ;
stmt . close ( ) ;
} catch ( final Exception e ) {
e . printStackTrace ( ) ;
2015-02-10 21:17:30 +01:00
}
2015-02-20 07:34:19 +01:00
}
} ) ;
2015-02-10 21:17:30 +01:00
}
2015-02-23 02:32:27 +01:00
2014-11-05 04:42:08 +01:00
@Override
2015-07-04 08:37:33 +02:00
public void setFlags ( final Plot plot , final Collection < Flag > flags ) {
2014-11-05 04:42:08 +01:00
final StringBuilder flag_string = new StringBuilder ( ) ;
int i = 0 ;
for ( final Flag flag : flags ) {
if ( i ! = 0 ) {
flag_string . append ( " , " ) ;
}
2015-01-25 05:40:50 +01:00
flag_string . append ( flag . getKey ( ) + " : " + flag . getValueString ( ) . replaceAll ( " : " , " \ u00AF " ) . replaceAll ( " , " , " \ u00B4 " ) ) ;
2014-11-05 04:42:08 +01:00
i + + ;
}
2015-02-20 07:34:19 +01:00
TaskManager . runTaskAsync ( new Runnable ( ) {
2014-11-05 04:42:08 +01:00
@Override
public void run ( ) {
try {
2014-12-16 06:03:20 +01:00
final PreparedStatement stmt = SQLManager . this . connection . prepareStatement ( " UPDATE ` " + SQLManager . this . prefix + " plot_settings` SET `flags` = ? WHERE `plot_plot_id` = ? " ) ;
2014-11-05 04:42:08 +01:00
stmt . setString ( 1 , flag_string . toString ( ) ) ;
2015-07-04 08:37:33 +02:00
stmt . setInt ( 2 , getId ( plot . world , plot . id ) ) ;
2014-11-05 04:42:08 +01:00
stmt . execute ( ) ;
stmt . close ( ) ;
2014-12-18 03:15:11 +01:00
} catch ( final SQLException e ) {
2014-11-05 04:42:08 +01:00
e . printStackTrace ( ) ;
2015-07-03 14:15:20 +02:00
PS . log ( " &7[WARN] " + " Could not set flag for plot " + plot . id ) ;
2014-11-05 04:42:08 +01:00
}
}
} ) ;
}
2015-02-23 02:32:27 +01:00
2015-06-23 23:44:44 +02:00
public void setFlags ( final int id , final Collection < Flag > newflags ) {
2014-11-05 04:42:08 +01:00
final String flag_string = StringUtils . join ( newflags , " , " ) ;
2015-02-20 07:34:19 +01:00
TaskManager . runTaskAsync ( new Runnable ( ) {
2014-10-25 02:16:15 +02:00
@Override
public void run ( ) {
try {
2014-12-16 06:03:20 +01:00
final PreparedStatement stmt = SQLManager . this . connection . prepareStatement ( " UPDATE ` " + SQLManager . this . prefix + " plot_settings` SET `flags` = ? WHERE `plot_plot_id` = ? " ) ;
2014-10-25 02:16:15 +02:00
stmt . setString ( 1 , flag_string ) ;
stmt . setInt ( 2 , id ) ;
stmt . execute ( ) ;
stmt . close ( ) ;
2014-12-18 03:15:11 +01:00
} catch ( final SQLException e ) {
2014-10-25 02:16:15 +02:00
e . printStackTrace ( ) ;
2015-07-03 14:15:20 +02:00
PS . log ( " &7[WARN] " + " Could not set flag for plot " + id ) ;
2014-10-25 02:16:15 +02:00
}
}
} ) ;
}
2015-02-23 02:32:27 +01:00
2014-11-05 04:42:08 +01:00
@Override
2015-07-04 08:37:33 +02:00
public void setAlias ( final Plot plot , final String alias ) {
2015-02-20 07:34:19 +01:00
TaskManager . runTaskAsync ( new Runnable ( ) {
2014-11-05 04:42:08 +01:00
@Override
public void run ( ) {
PreparedStatement stmt = null ;
try {
2014-12-16 06:03:20 +01:00
stmt = SQLManager . this . connection . prepareStatement ( " UPDATE ` " + SQLManager . this . prefix + " plot_settings` SET `alias` = ? WHERE `plot_plot_id` = ? " ) ;
2014-11-05 04:42:08 +01:00
stmt . setString ( 1 , alias ) ;
2015-07-04 08:37:33 +02:00
stmt . setInt ( 2 , getId ( plot . world , plot . id ) ) ;
2014-11-05 04:42:08 +01:00
stmt . executeUpdate ( ) ;
stmt . close ( ) ;
2014-12-18 03:15:11 +01:00
} catch ( final SQLException e ) {
2015-07-03 14:15:20 +02:00
PS . log ( " &7[WARN] " + " Failed to set alias for plot " + plot . id ) ;
2014-11-05 04:42:08 +01:00
e . printStackTrace ( ) ;
}
}
} ) ;
}
2015-02-23 02:32:27 +01:00
2014-11-05 04:42:08 +01:00
/ * *
2015-01-16 08:04:55 +01:00
* Purge all plots with the following database IDs
2014-11-05 04:42:08 +01:00
* /
2015-02-20 07:34:19 +01:00
@Override
2015-01-07 07:44:03 +01:00
public void purgeIds ( final String world , final Set < Integer > uniqueIds ) {
if ( uniqueIds . size ( ) > 0 ) {
try {
2015-01-16 08:04:55 +01:00
String stmt_prefix = " " ;
2015-03-08 02:11:02 +01:00
final StringBuilder idstr2 = new StringBuilder ( " " ) ;
for ( final Integer id : uniqueIds ) {
idstr2 . append ( stmt_prefix + id ) ;
stmt_prefix = " OR `id` = " ;
}
stmt_prefix = " " ;
2015-01-07 07:44:03 +01:00
final StringBuilder idstr = new StringBuilder ( " " ) ;
for ( final Integer id : uniqueIds ) {
2015-01-16 08:04:55 +01:00
idstr . append ( stmt_prefix + id ) ;
stmt_prefix = " OR `plot_plot_id` = " ;
2014-10-22 08:08:55 +02:00
}
2015-01-16 08:04:55 +01:00
PreparedStatement stmt = SQLManager . this . connection . prepareStatement ( " DELETE FROM ` " + this . prefix + " plot_helpers` WHERE `plot_plot_id` = " + idstr + " " ) ;
2015-01-07 07:44:03 +01:00
stmt . executeUpdate ( ) ;
stmt . close ( ) ;
2015-01-16 08:04:55 +01:00
stmt = SQLManager . this . connection . prepareStatement ( " DELETE FROM ` " + this . prefix + " plot_denied` WHERE `plot_plot_id` = " + idstr + " " ) ;
2015-01-07 07:44:03 +01:00
stmt . executeUpdate ( ) ;
stmt . close ( ) ;
2015-01-16 08:04:55 +01:00
stmt = SQLManager . this . connection . prepareStatement ( " DELETE FROM ` " + this . prefix + " plot_settings` WHERE `plot_plot_id` = " + idstr + " " ) ;
2015-01-07 07:44:03 +01:00
stmt . executeUpdate ( ) ;
stmt . close ( ) ;
2015-01-16 08:04:55 +01:00
stmt = SQLManager . this . connection . prepareStatement ( " DELETE FROM ` " + this . prefix + " plot_trusted` WHERE `plot_plot_id` = " + idstr + " " ) ;
2015-01-07 07:44:03 +01:00
stmt . executeUpdate ( ) ;
stmt . close ( ) ;
2015-03-08 02:11:02 +01:00
stmt = SQLManager . this . connection . prepareStatement ( " DELETE FROM ` " + this . prefix + " plot` WHERE `id` = " + idstr2 + " " ) ;
2015-01-07 07:44:03 +01:00
stmt . executeUpdate ( ) ;
stmt . close ( ) ;
} catch ( final SQLException e ) {
e . printStackTrace ( ) ;
2015-07-03 14:15:20 +02:00
PS . log ( " &c[ERROR] " + " FAILED TO PURGE WORLD ' " + world + " '! " ) ;
2015-01-07 07:44:03 +01:00
return ;
}
}
2015-07-03 14:15:20 +02:00
PS . log ( " &6[INFO] " + " SUCCESSFULLY PURGED WORLD ' " + world + " '! " ) ;
2015-01-07 07:44:03 +01:00
}
2015-02-23 02:32:27 +01:00
2015-01-07 07:44:03 +01:00
@Override
2015-02-20 07:34:19 +01:00
public void purge ( final String world , final Set < PlotId > plots ) {
2015-01-07 07:44:03 +01:00
PreparedStatement stmt ;
try {
stmt = SQLManager . this . connection . prepareStatement ( " SELECT `id`, `plot_id_x`, `plot_id_z` FROM ` " + this . prefix + " plot` WHERE `world` = ? " ) ;
stmt . setString ( 1 , world ) ;
2015-02-20 07:34:19 +01:00
final ResultSet r = stmt . executeQuery ( ) ;
2015-01-07 07:44:03 +01:00
PlotId plot_id ;
2015-02-20 07:34:19 +01:00
final Set < Integer > ids = new HashSet < > ( ) ;
2015-01-07 07:44:03 +01:00
while ( r . next ( ) ) {
plot_id = new PlotId ( r . getInt ( " plot_id_x " ) , r . getInt ( " plot_id_z " ) ) ;
if ( plots . contains ( plot_id ) ) {
ids . add ( r . getInt ( " id " ) ) ;
2014-11-05 04:42:08 +01:00
}
}
2015-01-07 07:44:03 +01:00
purgeIds ( world , ids ) ;
2015-02-19 04:24:05 +01:00
stmt . close ( ) ;
r . close ( ) ;
2015-07-03 11:30:26 +02:00
for ( Iterator < PlotId > iter = plots . iterator ( ) ; iter . hasNext ( ) ; ) {
2015-03-08 02:11:02 +01:00
PlotId plotId = iter . next ( ) ;
iter . remove ( ) ;
PlotId id = new PlotId ( plotId . x , plotId . y ) ;
2015-07-03 14:15:20 +02:00
PS . get ( ) . removePlot ( world , new PlotId ( id . x , id . y ) , true ) ;
2015-03-08 02:11:02 +01:00
}
2015-02-20 07:34:19 +01:00
} catch ( final SQLException e ) {
2015-01-07 07:44:03 +01:00
e . printStackTrace ( ) ;
2015-07-03 14:15:20 +02:00
PS . log ( " &c[ERROR] " + " FAILED TO PURGE WORLD ' " + world + " '! " ) ;
2015-01-07 07:44:03 +01:00
}
2014-11-05 04:42:08 +01:00
}
2015-02-23 02:32:27 +01:00
2014-11-05 04:42:08 +01:00
@Override
2015-07-04 08:37:33 +02:00
public void setPosition ( final Plot plot , final String position ) {
2015-02-20 07:34:19 +01:00
TaskManager . runTaskAsync ( new Runnable ( ) {
2014-11-05 04:42:08 +01:00
@Override
public void run ( ) {
PreparedStatement stmt = null ;
try {
2014-12-16 06:03:20 +01:00
stmt = SQLManager . this . connection . prepareStatement ( " UPDATE ` " + SQLManager . this . prefix + " plot_settings` SET `position` = ? WHERE `plot_plot_id` = ? " ) ;
2014-11-05 04:42:08 +01:00
stmt . setString ( 1 , position ) ;
2015-07-04 08:37:33 +02:00
stmt . setInt ( 2 , getId ( plot . world , plot . id ) ) ;
2014-11-05 04:42:08 +01:00
stmt . executeUpdate ( ) ;
stmt . close ( ) ;
2014-12-18 03:15:11 +01:00
} catch ( final SQLException e ) {
2015-07-03 14:15:20 +02:00
PS . log ( " &7[WARN] " + " Failed to set position for plot " + plot . id ) ;
2014-11-05 04:42:08 +01:00
e . printStackTrace ( ) ;
}
}
} ) ;
}
2015-02-23 02:32:27 +01:00
2014-11-05 04:42:08 +01:00
@Override
public HashMap < String , Object > getSettings ( final int id ) {
final HashMap < String , Object > h = new HashMap < String , Object > ( ) ;
PreparedStatement stmt = null ;
try {
2014-12-16 06:03:20 +01:00
stmt = this . connection . prepareStatement ( " SELECT * FROM ` " + this . prefix + " plot_settings` WHERE `plot_plot_id` = ? " ) ;
2014-11-05 04:42:08 +01:00
stmt . setInt ( 1 , id ) ;
final ResultSet r = stmt . executeQuery ( ) ;
String var ;
Object val ;
while ( r . next ( ) ) {
var = " biome " ;
val = r . getObject ( var ) ;
h . put ( var , val ) ;
var = " rain " ;
val = r . getObject ( var ) ;
h . put ( var , val ) ;
var = " custom_time " ;
val = r . getObject ( var ) ;
h . put ( var , val ) ;
var = " time " ;
val = r . getObject ( var ) ;
h . put ( var , val ) ;
var = " deny_entry " ;
val = r . getObject ( var ) ;
h . put ( var , ( short ) 0 ) ;
var = " alias " ;
val = r . getObject ( var ) ;
h . put ( var , val ) ;
var = " position " ;
val = r . getObject ( var ) ;
h . put ( var , val ) ;
var = " flags " ;
val = r . getObject ( var ) ;
h . put ( var , val ) ;
var = " merged " ;
val = r . getObject ( var ) ;
h . put ( var , val ) ;
}
stmt . close ( ) ;
2015-02-19 04:24:05 +01:00
r . close ( ) ;
2014-12-18 03:15:11 +01:00
} catch ( final SQLException e ) {
2015-07-03 14:15:20 +02:00
PS . log ( " &7[WARN] " + " Failed to load settings for plot: " + id ) ;
2014-11-05 04:42:08 +01:00
e . printStackTrace ( ) ;
}
return h ;
}
2015-02-23 02:32:27 +01:00
2014-11-05 04:42:08 +01:00
@Override
2015-07-04 08:37:33 +02:00
public void removeComment ( final Plot plot , final PlotComment comment ) {
2015-02-20 07:34:19 +01:00
TaskManager . runTaskAsync ( new Runnable ( ) {
2014-11-02 04:45:52 +01:00
@Override
public void run ( ) {
try {
2015-02-20 07:34:19 +01:00
PreparedStatement statement ;
if ( plot ! = null ) {
2015-04-06 14:16:24 +02:00
statement = SQLManager . this . connection . prepareStatement ( " DELETE FROM ` " + SQLManager . this . prefix + " plot_comments` WHERE `world` = ? AND `hashcode` = ? AND `comment` = ? AND `inbox` = ? AND `sender` = ? " ) ;
statement . setString ( 1 , plot . world ) ;
statement . setInt ( 2 , plot . id . hashCode ( ) ) ;
statement . setString ( 3 , comment . comment ) ;
statement . setString ( 4 , comment . inbox ) ;
statement . setString ( 5 , comment . senderName ) ;
2015-02-20 07:34:19 +01:00
} else {
2015-04-06 11:59:22 +02:00
statement = SQLManager . this . connection . prepareStatement ( " DELETE FROM ` " + SQLManager . this . prefix + " plot_comments` WHERE `comment` = ? AND `inbox` = ? AND `sender` = ? " ) ;
2015-02-20 07:34:19 +01:00
statement . setString ( 1 , comment . comment ) ;
2015-04-06 11:59:22 +02:00
statement . setString ( 2 , comment . inbox ) ;
2015-02-20 07:34:19 +01:00
statement . setString ( 3 , comment . senderName ) ;
}
2014-11-02 04:45:52 +01:00
statement . executeUpdate ( ) ;
statement . close ( ) ;
2014-12-18 03:15:11 +01:00
} catch ( final SQLException e ) {
2014-11-02 04:45:52 +01:00
e . printStackTrace ( ) ;
2015-07-03 14:15:20 +02:00
PS . log ( " &7[WARN] " + " Failed to remove comment for plot " + plot . id ) ;
2015-04-06 11:59:22 +02:00
}
}
} ) ;
}
2015-07-03 11:30:26 +02:00
2015-04-06 11:59:22 +02:00
@Override
public void clearInbox ( final Plot plot , final String inbox ) {
TaskManager . runTaskAsync ( new Runnable ( ) {
@Override
public void run ( ) {
try {
PreparedStatement statement ;
if ( plot ! = null ) {
2015-04-06 14:16:24 +02:00
statement = SQLManager . this . connection . prepareStatement ( " DELETE FROM ` " + SQLManager . this . prefix + " plot_comments` WHERE `world` = ? AND `hashcode` = ? AND `inbox` = ? " ) ;
statement . setString ( 1 , plot . world ) ;
statement . setInt ( 2 , plot . id . hashCode ( ) ) ;
statement . setString ( 3 , inbox ) ;
2015-04-06 11:59:22 +02:00
} else {
statement = SQLManager . this . connection . prepareStatement ( " DELETE FROM ` " + SQLManager . this . prefix + " plot_comments` `inbox` = ? " ) ;
statement . setString ( 1 , inbox ) ;
}
statement . executeUpdate ( ) ;
statement . close ( ) ;
} catch ( final SQLException e ) {
e . printStackTrace ( ) ;
2015-07-03 14:15:20 +02:00
PS . log ( " &7[WARN] " + " Failed to remove comment for plot " + plot . id ) ;
2014-11-02 04:45:52 +01:00
}
}
} ) ;
}
2015-02-23 02:32:27 +01:00
2014-11-02 04:45:52 +01:00
@Override
2015-07-04 08:37:33 +02:00
public void getComments ( final Plot plot , final String inbox , final RunnableVal whenDone ) {
2015-04-06 14:16:24 +02:00
TaskManager . runTaskAsync ( new Runnable ( ) {
@Override
public void run ( ) {
final ArrayList < PlotComment > comments = new ArrayList < PlotComment > ( ) ;
try {
final PreparedStatement statement ;
if ( plot ! = null ) {
statement = connection . prepareStatement ( " SELECT * FROM ` " + prefix + " plot_comments` WHERE `world` = ? AND `hashcode` = ? AND `inbox` = ? " ) ;
statement . setString ( 1 , plot . world ) ;
statement . setInt ( 2 , plot . id . hashCode ( ) ) ;
statement . setString ( 3 , inbox ) ;
} else {
statement = connection . prepareStatement ( " SELECT * FROM ` " + prefix + " plot_comments` WHERE `inbox` = ? " ) ;
statement . setString ( 1 , inbox ) ;
}
final ResultSet set = statement . executeQuery ( ) ;
PlotComment comment ;
while ( set . next ( ) ) {
final String sender = set . getString ( " sender " ) ;
final String world = set . getString ( " world " ) ;
final int hash = set . getInt ( " hashcode " ) ;
PlotId id ;
if ( hash ! = 0 ) {
id = PlotId . unpair ( hash ) ;
2015-07-03 11:30:26 +02:00
} else {
2015-04-06 14:16:24 +02:00
id = null ;
}
final String msg = set . getString ( " comment " ) ;
final long timestamp = set . getInt ( " timestamp " ) * 1000 ;
comment = new PlotComment ( world , id , msg , sender , inbox , timestamp ) ;
comments . add ( comment ) ;
whenDone . value = comments ;
}
2015-04-06 14:20:24 +02:00
TaskManager . runTask ( whenDone ) ;
2015-04-06 14:16:24 +02:00
statement . close ( ) ;
set . close ( ) ;
} catch ( final SQLException e ) {
2015-07-03 14:15:20 +02:00
PS . log ( " &7[WARN] " + " Failed to fetch comment " ) ;
2015-04-06 14:16:24 +02:00
e . printStackTrace ( ) ;
2015-04-06 11:59:22 +02:00
}
2014-11-02 04:45:52 +01:00
}
2015-04-06 14:16:24 +02:00
} ) ;
2014-11-02 04:45:52 +01:00
}
2015-02-23 02:32:27 +01:00
2014-11-02 04:45:52 +01:00
@Override
2015-07-04 08:37:33 +02:00
public void setComment ( final Plot plot , final PlotComment comment ) {
2015-02-20 07:34:19 +01:00
TaskManager . runTaskAsync ( new Runnable ( ) {
2014-11-02 04:45:52 +01:00
@Override
public void run ( ) {
try {
2015-04-06 14:16:24 +02:00
final PreparedStatement statement = SQLManager . this . connection . prepareStatement ( " INSERT INTO ` " + SQLManager . this . prefix + " plot_comments` (`world`, `hashcode`, `comment`, `inbox`, `timestamp`, `sender`) VALUES(?,?,?,?,?,?) " ) ;
statement . setString ( 1 , plot . world ) ;
statement . setInt ( 2 , plot . id . hashCode ( ) ) ;
statement . setString ( 3 , comment . comment ) ;
statement . setString ( 4 , comment . inbox ) ;
statement . setInt ( 5 , ( int ) ( comment . timestamp / 1000 ) ) ;
statement . setString ( 6 , comment . senderName ) ;
2014-11-02 04:45:52 +01:00
statement . executeUpdate ( ) ;
statement . close ( ) ;
2014-12-18 03:15:11 +01:00
} catch ( final SQLException e ) {
2014-11-05 04:42:08 +01:00
e . printStackTrace ( ) ;
2015-07-03 14:15:20 +02:00
PS . log ( " &7[WARN] " + " Failed to set comment for plot " + plot . id ) ;
2014-11-05 04:42:08 +01:00
}
}
} ) ;
}
2015-02-23 02:32:27 +01:00
2014-11-05 04:42:08 +01:00
@Override
2015-07-04 08:37:33 +02:00
public void removeTrusted ( final Plot plot , final UUID uuid ) {
2015-02-20 07:34:19 +01:00
TaskManager . runTaskAsync ( new Runnable ( ) {
2014-11-05 04:42:08 +01:00
@Override
public void run ( ) {
try {
2014-12-16 06:03:20 +01:00
final PreparedStatement statement = SQLManager . this . connection . prepareStatement ( " DELETE FROM ` " + SQLManager . this . prefix + " plot_helpers` WHERE `plot_plot_id` = ? AND `user_uuid` = ? " ) ;
2015-07-04 08:37:33 +02:00
statement . setInt ( 1 , getId ( plot . world , plot . id ) ) ;
2015-01-18 21:30:32 +01:00
statement . setString ( 2 , uuid . toString ( ) ) ;
2014-11-05 04:42:08 +01:00
statement . executeUpdate ( ) ;
statement . close ( ) ;
2014-12-18 03:15:11 +01:00
} catch ( final SQLException e ) {
2014-11-02 04:45:52 +01:00
e . printStackTrace ( ) ;
2015-07-03 14:15:20 +02:00
PS . log ( " &7[WARN] " + " Failed to remove helper for plot " + plot . id ) ;
2014-11-02 04:45:52 +01:00
}
}
} ) ;
}
2015-02-23 02:32:27 +01:00
2014-11-05 04:42:08 +01:00
@Override
2015-07-04 08:37:33 +02:00
public void removeMember ( final Plot plot , final UUID uuid ) {
2015-02-20 07:34:19 +01:00
TaskManager . runTaskAsync ( new Runnable ( ) {
2014-11-05 04:42:08 +01:00
@Override
public void run ( ) {
try {
2014-12-16 06:03:20 +01:00
final PreparedStatement statement = SQLManager . this . connection . prepareStatement ( " DELETE FROM ` " + SQLManager . this . prefix + " plot_trusted` WHERE `plot_plot_id` = ? AND `user_uuid` = ? " ) ;
2015-07-04 08:37:33 +02:00
statement . setInt ( 1 , getId ( plot . world , plot . id ) ) ;
2015-01-18 21:30:32 +01:00
statement . setString ( 2 , uuid . toString ( ) ) ;
2014-11-05 04:42:08 +01:00
statement . executeUpdate ( ) ;
statement . close ( ) ;
2014-12-18 03:15:11 +01:00
} catch ( final SQLException e ) {
2014-11-05 04:42:08 +01:00
e . printStackTrace ( ) ;
2015-07-03 14:15:20 +02:00
PS . log ( " &7[WARN] " + " Failed to remove trusted user for plot " + plot . id ) ;
2014-11-05 04:42:08 +01:00
}
}
} ) ;
}
2015-02-23 02:32:27 +01:00
2014-11-05 04:42:08 +01:00
@Override
2015-07-04 08:37:33 +02:00
public void setTrusted ( final Plot plot , final UUID uuid ) {
2015-02-20 07:34:19 +01:00
TaskManager . runTaskAsync ( new Runnable ( ) {
2014-11-05 04:42:08 +01:00
@Override
public void run ( ) {
try {
2014-12-16 06:03:20 +01:00
final PreparedStatement statement = SQLManager . this . connection . prepareStatement ( " INSERT INTO ` " + SQLManager . this . prefix + " plot_helpers` (`plot_plot_id`, `user_uuid`) VALUES(?,?) " ) ;
2015-07-04 08:37:33 +02:00
statement . setInt ( 1 , getId ( plot . world , plot . id ) ) ;
2015-01-18 21:30:32 +01:00
statement . setString ( 2 , uuid . toString ( ) ) ;
2014-11-05 04:42:08 +01:00
statement . executeUpdate ( ) ;
statement . close ( ) ;
2014-12-18 03:15:11 +01:00
} catch ( final SQLException e ) {
2015-07-03 14:15:20 +02:00
PS . log ( " &7[WARN] " + " Failed to set helper for plot " + plot . id ) ;
2014-11-05 04:42:08 +01:00
e . printStackTrace ( ) ;
}
}
} ) ;
}
2015-02-23 02:32:27 +01:00
2014-12-21 05:03:59 +01:00
public void setHelper ( final int id , final UUID uuid ) {
2015-02-20 07:34:19 +01:00
TaskManager . runTaskAsync ( new Runnable ( ) {
2014-12-21 05:03:59 +01:00
@Override
public void run ( ) {
try {
final PreparedStatement statement = SQLManager . this . connection . prepareStatement ( " INSERT INTO ` " + SQLManager . this . prefix + " plot_helpers` (`plot_plot_id`, `user_uuid`) VALUES(?,?) " ) ;
statement . setInt ( 1 , id ) ;
statement . setString ( 2 , uuid . toString ( ) ) ;
statement . executeUpdate ( ) ;
statement . close ( ) ;
} catch ( final SQLException e ) {
2015-07-03 14:15:20 +02:00
PS . log ( " &7[WARN] " + " Failed to set helper for id " + id ) ;
2014-12-21 05:03:59 +01:00
e . printStackTrace ( ) ;
}
}
} ) ;
}
2015-02-23 02:32:27 +01:00
2014-11-05 04:42:08 +01:00
@Override
2015-07-04 08:37:33 +02:00
public void setMember ( final Plot plot , final UUID uuid ) {
2015-02-20 07:34:19 +01:00
TaskManager . runTaskAsync ( new Runnable ( ) {
2014-11-05 04:42:08 +01:00
@Override
public void run ( ) {
try {
2014-12-16 06:03:20 +01:00
final PreparedStatement statement = SQLManager . this . connection . prepareStatement ( " INSERT INTO ` " + SQLManager . this . prefix + " plot_trusted` (`plot_plot_id`, `user_uuid`) VALUES(?,?) " ) ;
2015-07-04 08:37:33 +02:00
statement . setInt ( 1 , getId ( plot . world , plot . id ) ) ;
2015-01-18 21:30:32 +01:00
statement . setString ( 2 , uuid . toString ( ) ) ;
2014-11-05 04:42:08 +01:00
statement . executeUpdate ( ) ;
statement . close ( ) ;
2014-12-18 03:15:11 +01:00
} catch ( final SQLException e ) {
2015-07-03 14:15:20 +02:00
PS . log ( " &7[WARN] " + " Failed to set plot trusted for plot " + plot . id ) ;
2014-11-05 04:42:08 +01:00
e . printStackTrace ( ) ;
}
}
} ) ;
}
2015-02-23 02:32:27 +01:00
2014-11-05 04:42:08 +01:00
@Override
2015-07-04 08:37:33 +02:00
public void removeDenied ( final Plot plot , final UUID uuid ) {
2015-02-20 07:34:19 +01:00
TaskManager . runTaskAsync ( new Runnable ( ) {
2014-11-05 04:42:08 +01:00
@Override
public void run ( ) {
try {
2014-12-16 06:03:20 +01:00
final PreparedStatement statement = SQLManager . this . connection . prepareStatement ( " DELETE FROM ` " + SQLManager . this . prefix + " plot_denied` WHERE `plot_plot_id` = ? AND `user_uuid` = ? " ) ;
2015-07-04 08:37:33 +02:00
statement . setInt ( 1 , getId ( plot . world , plot . id ) ) ;
2015-01-18 21:30:32 +01:00
statement . setString ( 2 , uuid . toString ( ) ) ;
2014-11-05 04:42:08 +01:00
statement . executeUpdate ( ) ;
statement . close ( ) ;
2014-12-18 03:15:11 +01:00
} catch ( final SQLException e ) {
2014-11-05 04:42:08 +01:00
e . printStackTrace ( ) ;
2015-07-03 14:15:20 +02:00
PS . log ( " &7[WARN] " + " Failed to remove denied for plot " + plot . id ) ;
2014-11-05 04:42:08 +01:00
}
}
} ) ;
}
2015-02-23 02:32:27 +01:00
2014-11-05 04:42:08 +01:00
@Override
2015-07-04 08:37:33 +02:00
public void setDenied ( final Plot plot , final UUID uuid ) {
2015-02-20 07:34:19 +01:00
TaskManager . runTaskAsync ( new Runnable ( ) {
2014-11-05 04:42:08 +01:00
@Override
public void run ( ) {
try {
2014-12-16 06:03:20 +01:00
final PreparedStatement statement = SQLManager . this . connection . prepareStatement ( " INSERT INTO ` " + SQLManager . this . prefix + " plot_denied` (`plot_plot_id`, `user_uuid`) VALUES(?,?) " ) ;
2015-07-04 08:37:33 +02:00
statement . setInt ( 1 , getId ( plot . world , plot . id ) ) ;
2015-01-18 21:30:32 +01:00
statement . setString ( 2 , uuid . toString ( ) ) ;
2014-11-05 04:42:08 +01:00
statement . executeUpdate ( ) ;
statement . close ( ) ;
2014-12-18 03:15:11 +01:00
} catch ( final SQLException e ) {
2015-07-03 14:15:20 +02:00
PS . log ( " &7[WARN] " + " Failed to set denied for plot " + plot . id ) ;
2014-11-05 04:42:08 +01:00
e . printStackTrace ( ) ;
}
}
} ) ;
}
2015-02-23 02:32:27 +01:00
2014-11-05 04:42:08 +01:00
@Override
2015-06-28 02:54:57 +02:00
public HashMap < UUID , Integer > getRatings ( final Plot plot ) {
HashMap < UUID , Integer > map = new HashMap < UUID , Integer > ( ) ;
2014-11-05 04:42:08 +01:00
try {
2015-06-28 02:54:57 +02:00
final PreparedStatement statement = this . connection . prepareStatement ( " SELECT `rating`, `player` FROM ` " + this . prefix + " plot_rating` WHERE `plot_plot_id` = ? " ) ;
2015-02-20 05:32:40 +01:00
statement . setInt ( 1 , getId ( plot . world , plot . id ) ) ;
2014-11-05 04:42:08 +01:00
final ResultSet set = statement . executeQuery ( ) ;
2015-07-03 11:30:26 +02:00
while ( set . next ( ) ) {
2015-06-28 02:54:57 +02:00
UUID uuid = UUID . fromString ( set . getString ( " player " ) ) ;
int rating = set . getInt ( " rating " ) ;
map . put ( uuid , rating ) ;
2014-11-05 04:42:08 +01:00
}
statement . close ( ) ;
2015-02-19 04:24:05 +01:00
set . close ( ) ;
2014-12-18 03:15:11 +01:00
} catch ( final SQLException e ) {
2015-07-03 14:15:20 +02:00
PS . log ( " &7[WARN] " + " Failed to fetch rating for plot " + plot . getId ( ) . toString ( ) ) ;
2014-11-05 04:42:08 +01:00
e . printStackTrace ( ) ;
}
2015-06-28 02:54:57 +02:00
return map ;
2014-11-05 04:42:08 +01:00
}
2015-05-14 14:55:57 +02:00
@Override
public void setRating ( final Plot plot , final UUID rater , final int value ) {
TaskManager . runTaskAsync ( new Runnable ( ) {
@Override
public void run ( ) {
try {
2015-06-05 12:45:13 +02:00
final PreparedStatement statement = SQLManager . this . connection . prepareStatement ( " INSERT INTO ` " + SQLManager . this . prefix + " plot_rating` (`plot_plot_id`, `rating`, `player`) VALUES(?,?,?) " ) ;
2015-05-14 14:55:57 +02:00
statement . setInt ( 1 , getId ( plot . world , plot . id ) ) ;
statement . setInt ( 2 , value ) ;
statement . setString ( 3 , rater . toString ( ) ) ;
statement . executeUpdate ( ) ;
statement . close ( ) ;
} catch ( final SQLException e ) {
2015-07-03 14:15:20 +02:00
PS . log ( " &7[WARN] " + " Failed to set denied for plot " + plot . id ) ;
2015-05-14 14:55:57 +02:00
e . printStackTrace ( ) ;
}
}
} ) ;
}
2015-02-23 02:32:27 +01:00
2015-02-20 07:34:19 +01:00
@Override
public void delete ( final PlotCluster cluster ) {
ClusterManager . removeCluster ( cluster ) ;
TaskManager . runTaskAsync ( new Runnable ( ) {
2015-01-26 05:16:10 +01:00
@Override
public void run ( ) {
PreparedStatement stmt = null ;
final int id = getClusterId ( cluster . world , ClusterManager . getClusterId ( cluster ) ) ;
try {
stmt = SQLManager . this . connection . prepareStatement ( " DELETE FROM ` " + SQLManager . this . prefix + " cluster_settings` WHERE `cluster_id` = ? " ) ;
stmt . setInt ( 1 , id ) ;
stmt . executeUpdate ( ) ;
stmt . close ( ) ;
stmt = SQLManager . this . connection . prepareStatement ( " DELETE FROM ` " + SQLManager . this . prefix + " cluster_helpers` WHERE `cluster_id` = ? " ) ;
stmt . setInt ( 1 , id ) ;
stmt . executeUpdate ( ) ;
2015-01-29 04:20:29 +01:00
stmt = SQLManager . this . connection . prepareStatement ( " DELETE FROM ` " + SQLManager . this . prefix + " cluster_invited` WHERE `cluster_id` = ? " ) ;
stmt . setInt ( 1 , id ) ;
stmt . executeUpdate ( ) ;
2015-01-26 05:16:10 +01:00
stmt = SQLManager . this . connection . prepareStatement ( " DELETE FROM ` " + SQLManager . this . prefix + " cluster` WHERE `id` = ? " ) ;
stmt . setInt ( 1 , id ) ;
stmt . executeUpdate ( ) ;
stmt . close ( ) ;
} catch ( final SQLException e ) {
e . printStackTrace ( ) ;
2015-07-03 14:15:20 +02:00
PS . log ( " &c[ERROR] " + " Failed to delete plot cluster: " + cluster . getP1 ( ) + " : " + cluster . getP2 ( ) ) ;
2015-01-26 05:16:10 +01:00
}
}
} ) ;
2015-02-20 07:34:19 +01:00
}
2015-02-23 02:32:27 +01:00
2015-02-20 07:34:19 +01:00
@Override
public int getClusterId ( final String world , final PlotClusterId id ) {
PreparedStatement stmt = null ;
2015-01-26 05:16:10 +01:00
try {
2015-01-29 08:45:14 +01:00
stmt = this . connection . prepareStatement ( " SELECT `id` FROM ` " + this . prefix + " cluster` WHERE `pos1_x` = ? AND `pos1_z` = ? AND `pos2_x` = ? AND `pos2_z` = ? AND `world` = ? ORDER BY `timestamp` ASC " ) ;
2015-01-26 05:16:10 +01:00
stmt . setInt ( 1 , id . pos1 . x ) ;
stmt . setInt ( 2 , id . pos1 . y ) ;
2015-01-29 08:45:14 +01:00
stmt . setInt ( 3 , id . pos2 . x ) ;
stmt . setInt ( 4 , id . pos2 . y ) ;
2015-01-26 05:16:10 +01:00
stmt . setString ( 5 , world ) ;
final ResultSet r = stmt . executeQuery ( ) ;
int c_id = Integer . MAX_VALUE ;
while ( r . next ( ) ) {
2015-02-20 07:34:19 +01:00
c_id = r . getInt ( " id " ) ;
2015-01-26 05:16:10 +01:00
}
stmt . close ( ) ;
2015-02-19 04:24:05 +01:00
r . close ( ) ;
2015-01-26 05:16:10 +01:00
return c_id ;
} catch ( final SQLException e ) {
e . printStackTrace ( ) ;
}
return Integer . MAX_VALUE ;
2015-02-20 07:34:19 +01:00
}
2015-02-23 02:32:27 +01:00
2015-02-20 07:34:19 +01:00
@Override
public HashMap < String , HashSet < PlotCluster > > getClusters ( ) {
final LinkedHashMap < String , HashSet < PlotCluster > > newClusters = new LinkedHashMap < > ( ) ;
2015-01-26 06:05:56 +01:00
final HashMap < Integer , PlotCluster > clusters = new HashMap < > ( ) ;
Statement stmt = null ;
try {
Set < String > worlds = new HashSet < > ( ) ;
2015-07-03 14:15:20 +02:00
if ( PS . get ( ) . config . contains ( " worlds " ) ) {
worlds = PS . get ( ) . config . getConfigurationSection ( " worlds " ) . getKeys ( false ) ;
2015-01-26 06:05:56 +01:00
}
final HashMap < String , UUID > uuids = new HashMap < String , UUID > ( ) ;
final HashMap < String , Integer > noExist = new HashMap < String , Integer > ( ) ;
/ *
* Getting clusters
* /
stmt = this . connection . createStatement ( ) ;
ResultSet r = stmt . executeQuery ( " SELECT * FROM ` " + this . prefix + " cluster` " ) ;
PlotId pos1 ;
PlotId pos2 ;
2015-02-20 07:34:19 +01:00
PlotCluster cluster ;
2015-01-26 06:05:56 +01:00
String owner ;
String worldname ;
UUID user ;
int id ;
while ( r . next ( ) ) {
2015-02-20 07:34:19 +01:00
pos1 = new PlotId ( r . getInt ( " pos1_x " ) , r . getInt ( " pos1_z " ) ) ;
pos2 = new PlotId ( r . getInt ( " pos2_x " ) , r . getInt ( " pos2_z " ) ) ;
2015-01-26 06:05:56 +01:00
id = r . getInt ( " id " ) ;
worldname = r . getString ( " world " ) ;
if ( ! worlds . contains ( worldname ) ) {
if ( noExist . containsKey ( worldname ) ) {
noExist . put ( worldname , noExist . get ( worldname ) + 1 ) ;
} else {
noExist . put ( worldname , 1 ) ;
}
}
owner = r . getString ( " owner " ) ;
user = uuids . get ( owner ) ;
if ( user = = null ) {
user = UUID . fromString ( owner ) ;
uuids . put ( owner , user ) ;
}
cluster = new PlotCluster ( worldname , pos1 , pos2 , user ) ;
clusters . put ( id , cluster ) ;
}
/ *
* Getting helpers
* /
r = stmt . executeQuery ( " SELECT `user_uuid`, `cluster_id` FROM ` " + this . prefix + " cluster_helpers` " ) ;
while ( r . next ( ) ) {
2015-01-29 08:45:14 +01:00
id = r . getInt ( " cluster_id " ) ;
2015-01-26 06:05:56 +01:00
owner = r . getString ( " user_uuid " ) ;
user = uuids . get ( owner ) ;
if ( user = = null ) {
user = UUID . fromString ( owner ) ;
uuids . put ( owner , user ) ;
}
cluster = clusters . get ( id ) ;
if ( cluster ! = null ) {
cluster . helpers . add ( user ) ;
} else {
2015-07-03 14:15:20 +02:00
PS . log ( " &cCluster " + id + " in cluster_helpers does not exist. Please create the cluster or remove this entry. " ) ;
2015-01-26 06:05:56 +01:00
}
}
2015-01-29 04:20:29 +01:00
/ *
* Getting invited
* /
r = stmt . executeQuery ( " SELECT `user_uuid`, `cluster_id` FROM ` " + this . prefix + " cluster_invited` " ) ;
while ( r . next ( ) ) {
2015-01-29 08:45:14 +01:00
id = r . getInt ( " cluster_id " ) ;
2015-01-29 04:20:29 +01:00
owner = r . getString ( " user_uuid " ) ;
user = uuids . get ( owner ) ;
if ( user = = null ) {
user = UUID . fromString ( owner ) ;
uuids . put ( owner , user ) ;
}
cluster = clusters . get ( id ) ;
if ( cluster ! = null ) {
cluster . invited . add ( user ) ;
} else {
2015-07-03 14:15:20 +02:00
PS . log ( " &cCluster " + id + " in cluster_invited does not exist. Please create the cluster or remove this entry. " ) ;
2015-01-29 04:20:29 +01:00
}
}
2015-01-26 06:05:56 +01:00
r = stmt . executeQuery ( " SELECT * FROM ` " + this . prefix + " cluster_settings` " ) ;
while ( r . next ( ) ) {
2015-01-29 08:45:14 +01:00
id = r . getInt ( " cluster_id " ) ;
2015-01-26 06:05:56 +01:00
cluster = clusters . get ( id ) ;
if ( cluster ! = null ) {
final String b = r . getString ( " biome " ) ;
if ( b ! = null ) {
for ( final Biome mybiome : Biome . values ( ) ) {
if ( mybiome . toString ( ) . equalsIgnoreCase ( b ) ) {
break ;
}
}
}
final String alias = r . getString ( " alias " ) ;
if ( alias ! = null ) {
cluster . settings . setAlias ( alias ) ;
}
final String pos = r . getString ( " position " ) ;
switch ( pos . toLowerCase ( ) ) {
case " " :
case " default " :
case " 0,0,0 " :
case " center " :
break ;
default :
try {
2015-02-20 07:34:19 +01:00
final String [ ] split = pos . split ( " , " ) ;
final BlockLoc loc = new BlockLoc ( Integer . parseInt ( split [ 0 ] ) , Integer . parseInt ( split [ 1 ] ) , Integer . parseInt ( split [ 2 ] ) ) ;
2015-01-26 06:05:56 +01:00
cluster . settings . setPosition ( loc ) ;
2015-02-20 07:34:19 +01:00
} catch ( final Exception e ) {
2015-01-26 06:05:56 +01:00
}
}
final Integer m = r . getInt ( " merged " ) ;
if ( m ! = null ) {
final boolean [ ] merged = new boolean [ 4 ] ;
for ( int i = 0 ; i < 4 ; i + + ) {
merged [ 3 - i ] = ( ( m ) & ( 1 < < i ) ) ! = 0 ;
}
cluster . settings . setMerged ( merged ) ;
} else {
2015-07-03 11:30:26 +02:00
cluster . settings . setMerged ( new boolean [ ] { false , false , false , false } ) ;
2015-01-26 06:05:56 +01:00
}
String [ ] flags_string ;
final String myflags = r . getString ( " flags " ) ;
if ( myflags = = null ) {
2015-07-03 11:30:26 +02:00
flags_string = new String [ ] { } ;
2015-01-26 06:05:56 +01:00
} else {
if ( myflags . length ( ) > 0 ) {
flags_string = myflags . split ( " , " ) ;
2015-02-20 07:34:19 +01:00
} else {
2015-07-03 11:30:26 +02:00
flags_string = new String [ ] { } ;
2015-01-26 06:05:56 +01:00
}
}
2015-06-23 23:44:44 +02:00
final HashMap < String , Flag > flags = new HashMap < > ( ) ;
2015-01-26 06:05:56 +01:00
boolean exception = false ;
for ( final String element : flags_string ) {
if ( element . contains ( " : " ) ) {
final String [ ] split = element . split ( " : " ) ;
try {
2015-02-20 07:34:19 +01:00
final String flag_str = split [ 1 ] . replaceAll ( " \ u00AF " , " : " ) . replaceAll ( " <EFBFBD> " , " , " ) ;
final Flag flag = new Flag ( FlagManager . getFlag ( split [ 0 ] , true ) , flag_str ) ;
2015-06-23 23:44:44 +02:00
flags . put ( flag . getKey ( ) , flag ) ;
2015-01-26 06:05:56 +01:00
} catch ( final Exception e ) {
e . printStackTrace ( ) ;
exception = true ;
}
} else {
2015-06-23 23:44:44 +02:00
Flag flag = new Flag ( FlagManager . getFlag ( element , true ) , " " ) ;
flags . put ( flag . getKey ( ) , flag ) ;
2015-01-26 06:05:56 +01:00
}
}
if ( exception ) {
2015-07-03 14:15:20 +02:00
PS . log ( " &cCluster " + id + " had an invalid flag. A fix has been attempted. " ) ;
PS . log ( " &c " + myflags ) ;
2015-01-26 06:05:56 +01:00
}
cluster . settings . flags = flags ;
} else {
2015-07-03 14:15:20 +02:00
PS . log ( " &cCluster " + id + " in cluster_settings does not exist. Please create the cluster or remove this entry. " ) ;
2015-01-26 06:05:56 +01:00
}
}
stmt . close ( ) ;
2015-02-19 04:24:05 +01:00
r . close ( ) ;
2015-01-26 06:05:56 +01:00
for ( final PlotCluster c : clusters . values ( ) ) {
final String world = c . world ;
if ( ! newClusters . containsKey ( world ) ) {
2015-02-20 07:34:19 +01:00
newClusters . put ( world , new HashSet < PlotCluster > ( ) ) ;
2015-01-26 06:05:56 +01:00
}
newClusters . get ( world ) . add ( c ) ;
}
boolean invalidPlot = false ;
for ( final String w : noExist . keySet ( ) ) {
invalidPlot = true ;
2015-07-03 14:15:20 +02:00
PS . log ( " &c[WARNING] Found " + noExist . get ( w ) + " clusters in DB for non existant world; ' " + w + " '. " ) ;
2015-01-26 06:05:56 +01:00
}
if ( invalidPlot ) {
2015-07-03 14:15:20 +02:00
PS . log ( " &c[WARNING] - Please create the world/s or remove the clusters using the purge command " ) ;
2015-01-26 06:05:56 +01:00
}
} catch ( final SQLException e ) {
2015-07-03 14:15:20 +02:00
PS . log ( " &7[WARN] " + " Failed to load clusters. " ) ;
2015-01-26 06:05:56 +01:00
e . printStackTrace ( ) ;
}
return newClusters ;
2015-02-20 07:34:19 +01:00
}
2015-02-23 02:32:27 +01:00
2015-02-20 07:34:19 +01:00
@Override
2015-06-23 23:44:44 +02:00
public void setFlags ( final PlotCluster cluster , final Collection < Flag > flags ) {
2015-02-20 07:34:19 +01:00
final StringBuilder flag_string = new StringBuilder ( ) ;
2015-01-26 05:16:10 +01:00
int i = 0 ;
for ( final Flag flag : flags ) {
if ( i ! = 0 ) {
flag_string . append ( " , " ) ;
}
flag_string . append ( flag . getKey ( ) + " : " + flag . getValueString ( ) . replaceAll ( " : " , " \ u00AF " ) . replaceAll ( " , " , " \ u00B4 " ) ) ;
i + + ;
}
2015-02-20 07:34:19 +01:00
TaskManager . runTaskAsync ( new Runnable ( ) {
2015-01-26 05:16:10 +01:00
@Override
public void run ( ) {
try {
final PreparedStatement stmt = SQLManager . this . connection . prepareStatement ( " UPDATE ` " + SQLManager . this . prefix + " cluster_settings` SET `flags` = ? WHERE `cluster_id` = ? " ) ;
stmt . setString ( 1 , flag_string . toString ( ) ) ;
stmt . setInt ( 2 , getClusterId ( cluster . world , ClusterManager . getClusterId ( cluster ) ) ) ;
stmt . execute ( ) ;
stmt . close ( ) ;
} catch ( final SQLException e ) {
e . printStackTrace ( ) ;
2015-07-03 14:15:20 +02:00
PS . log ( " &7[WARN] " + " Could not set flag for plot " + cluster ) ;
2015-01-26 05:16:10 +01:00
}
}
} ) ;
2015-02-20 07:34:19 +01:00
}
2015-02-23 02:32:27 +01:00
2015-02-20 07:34:19 +01:00
@Override
public void setClusterName ( final PlotCluster cluster , final String name ) {
cluster . settings . setAlias ( name ) ;
TaskManager . runTaskAsync ( new Runnable ( ) {
2015-01-26 05:16:10 +01:00
@Override
public void run ( ) {
PreparedStatement stmt = null ;
try {
stmt = SQLManager . this . connection . prepareStatement ( " UPDATE ` " + SQLManager . this . prefix + " cluster_settings` SET `alias` = ? WHERE `cluster_id` = ? " ) ;
stmt . setString ( 1 , name ) ;
stmt . setInt ( 2 , getClusterId ( cluster . world , ClusterManager . getClusterId ( cluster ) ) ) ;
stmt . executeUpdate ( ) ;
stmt . close ( ) ;
} catch ( final SQLException e ) {
2015-07-03 14:15:20 +02:00
PS . log ( " &7[WARN] " + " Failed to set alias for cluster " + cluster ) ;
2015-01-26 05:16:10 +01:00
e . printStackTrace ( ) ;
}
}
} ) ;
2015-02-20 07:34:19 +01:00
}
2015-02-23 02:32:27 +01:00
2015-02-20 07:34:19 +01:00
@Override
public void removeHelper ( final PlotCluster cluster , final UUID uuid ) {
TaskManager . runTaskAsync ( new Runnable ( ) {
2015-01-26 05:16:10 +01:00
@Override
public void run ( ) {
try {
final PreparedStatement statement = SQLManager . this . connection . prepareStatement ( " DELETE FROM ` " + SQLManager . this . prefix + " cluster_helpers` WHERE `cluster_id` = ? AND `user_uuid` = ? " ) ;
statement . setInt ( 1 , getClusterId ( cluster . world , ClusterManager . getClusterId ( cluster ) ) ) ;
statement . setString ( 2 , uuid . toString ( ) ) ;
statement . executeUpdate ( ) ;
statement . close ( ) ;
} catch ( final SQLException e ) {
e . printStackTrace ( ) ;
2015-07-03 14:15:20 +02:00
PS . log ( " &7[WARN] " + " Failed to remove helper for cluster " + cluster ) ;
2015-01-26 05:16:10 +01:00
}
}
} ) ;
2015-02-20 07:34:19 +01:00
}
2015-02-23 02:32:27 +01:00
2015-02-20 07:34:19 +01:00
@Override
public void setHelper ( final PlotCluster cluster , final UUID uuid ) {
TaskManager . runTaskAsync ( new Runnable ( ) {
2015-01-26 05:16:10 +01:00
@Override
public void run ( ) {
try {
final PreparedStatement statement = SQLManager . this . connection . prepareStatement ( " INSERT INTO ` " + SQLManager . this . prefix + " cluster_helpers` (`cluster_id`, `user_uuid`) VALUES(?,?) " ) ;
statement . setInt ( 1 , getClusterId ( cluster . world , ClusterManager . getClusterId ( cluster ) ) ) ;
statement . setString ( 2 , uuid . toString ( ) ) ;
statement . executeUpdate ( ) ;
statement . close ( ) ;
} catch ( final SQLException e ) {
2015-07-03 14:15:20 +02:00
PS . log ( " &7[WARN] " + " Failed to set helper for cluster " + cluster ) ;
2015-01-26 05:16:10 +01:00
e . printStackTrace ( ) ;
}
}
} ) ;
2015-02-20 07:34:19 +01:00
}
2015-02-23 02:32:27 +01:00
2015-02-20 07:34:19 +01:00
@Override
public void createCluster ( final PlotCluster cluster ) {
TaskManager . runTaskAsync ( new Runnable ( ) {
2015-01-26 05:16:10 +01:00
@Override
public void run ( ) {
PreparedStatement stmt = null ;
try {
stmt = SQLManager . this . connection . prepareStatement ( SQLManager . this . CREATE_CLUSTER ) ;
2015-01-26 06:05:56 +01:00
stmt . setInt ( 1 , cluster . getP1 ( ) . x ) ;
stmt . setInt ( 2 , cluster . getP1 ( ) . y ) ;
stmt . setInt ( 3 , cluster . getP2 ( ) . x ) ;
stmt . setInt ( 4 , cluster . getP2 ( ) . y ) ;
2015-01-26 05:16:10 +01:00
stmt . setString ( 5 , cluster . owner . toString ( ) ) ;
stmt . setString ( 6 , cluster . world ) ;
stmt . executeUpdate ( ) ;
stmt . close ( ) ;
2015-02-20 07:34:19 +01:00
final int id = getClusterId ( cluster . world , ClusterManager . getClusterId ( cluster ) ) ;
2015-01-29 04:20:29 +01:00
stmt = SQLManager . this . connection . prepareStatement ( " INSERT INTO ` " + SQLManager . this . prefix + " cluster_settings`(`cluster_id`, `alias`) VALUES(?, ? " + " ) " ) ;
2015-01-26 05:16:10 +01:00
stmt . setInt ( 1 , id ) ;
2015-01-29 04:20:29 +01:00
stmt . setString ( 2 , cluster . settings . getAlias ( ) ) ;
2015-01-26 05:16:10 +01:00
stmt . executeUpdate ( ) ;
stmt . close ( ) ;
} catch ( final Exception e ) {
e . printStackTrace ( ) ;
2015-07-03 14:15:20 +02:00
PS . log ( " &c[ERROR] " + " Failed to save cluster " + cluster ) ;
2015-01-26 05:16:10 +01:00
}
}
} ) ;
2015-02-20 07:34:19 +01:00
}
2015-02-23 02:32:27 +01:00
2015-02-20 07:34:19 +01:00
@Override
public void resizeCluster ( final PlotCluster current , final PlotClusterId resize ) {
final PlotId pos1 = new PlotId ( current . getP1 ( ) . x , current . getP1 ( ) . y ) ;
final PlotId pos2 = new PlotId ( current . getP2 ( ) . x , current . getP2 ( ) . y ) ;
current . setP1 ( resize . pos1 ) ;
current . setP2 ( resize . pos2 ) ;
TaskManager . runTaskAsync ( new Runnable ( ) {
2015-01-26 06:05:56 +01:00
@Override
public void run ( ) {
PreparedStatement stmt = null ;
try {
2015-01-31 08:09:48 +01:00
stmt = SQLManager . this . connection . prepareStatement ( " UPDATE ` " + SQLManager . this . prefix + " cluster` SET `pos1_x` = ?, `pos1_z` = ?, `pos2_x` = ?, `pos2_z` = ? WHERE `id` = ? " ) ;
2015-01-26 06:05:56 +01:00
stmt . setInt ( 1 , pos1 . x ) ;
stmt . setInt ( 2 , pos1 . y ) ;
stmt . setInt ( 3 , pos2 . x ) ;
stmt . setInt ( 4 , pos2 . y ) ;
stmt . setInt ( 5 , getClusterId ( current . world , ClusterManager . getClusterId ( current ) ) ) ;
stmt . executeUpdate ( ) ;
stmt . close ( ) ;
} catch ( final SQLException e ) {
2015-07-03 14:15:20 +02:00
PS . log ( " &7[WARN] " + " Failed to rezize cluster " + current ) ;
2015-01-26 06:05:56 +01:00
e . printStackTrace ( ) ;
}
}
2015-02-20 07:34:19 +01:00
} ) ;
}
2015-02-23 02:32:27 +01:00
2015-02-20 07:34:19 +01:00
@Override
public void setPosition ( final PlotCluster cluster , final String position ) {
TaskManager . runTaskAsync ( new Runnable ( ) {
2015-01-26 05:16:10 +01:00
@Override
public void run ( ) {
PreparedStatement stmt = null ;
try {
stmt = SQLManager . this . connection . prepareStatement ( " UPDATE ` " + SQLManager . this . prefix + " cluster_settings` SET `position` = ? WHERE `cluster_id` = ? " ) ;
stmt . setString ( 1 , position ) ;
stmt . setInt ( 2 , getClusterId ( cluster . world , ClusterManager . getClusterId ( cluster ) ) ) ;
stmt . executeUpdate ( ) ;
stmt . close ( ) ;
} catch ( final SQLException e ) {
2015-07-03 14:15:20 +02:00
PS . log ( " &7[WARN] " + " Failed to set position for cluster " + cluster ) ;
2015-01-26 05:16:10 +01:00
e . printStackTrace ( ) ;
}
}
} ) ;
2015-02-20 07:34:19 +01:00
}
2015-02-23 02:32:27 +01:00
2015-02-20 07:34:19 +01:00
@Override
public HashMap < String , Object > getClusterSettings ( final int id ) {
final HashMap < String , Object > h = new HashMap < String , Object > ( ) ;
2015-01-26 05:16:10 +01:00
PreparedStatement stmt = null ;
try {
stmt = this . connection . prepareStatement ( " SELECT * FROM ` " + this . prefix + " cluster_settings` WHERE `cluster_id` = ? " ) ;
stmt . setInt ( 1 , id ) ;
final ResultSet r = stmt . executeQuery ( ) ;
String var ;
Object val ;
while ( r . next ( ) ) {
var = " biome " ;
val = r . getObject ( var ) ;
h . put ( var , val ) ;
var = " rain " ;
val = r . getObject ( var ) ;
h . put ( var , val ) ;
var = " custom_time " ;
val = r . getObject ( var ) ;
h . put ( var , val ) ;
var = " time " ;
val = r . getObject ( var ) ;
h . put ( var , val ) ;
var = " deny_entry " ;
val = r . getObject ( var ) ;
h . put ( var , ( short ) 0 ) ;
var = " alias " ;
val = r . getObject ( var ) ;
h . put ( var , val ) ;
var = " position " ;
val = r . getObject ( var ) ;
h . put ( var , val ) ;
var = " flags " ;
val = r . getObject ( var ) ;
h . put ( var , val ) ;
var = " merged " ;
val = r . getObject ( var ) ;
h . put ( var , val ) ;
}
stmt . close ( ) ;
2015-02-19 04:24:05 +01:00
r . close ( ) ;
2015-01-26 05:16:10 +01:00
} catch ( final SQLException e ) {
2015-07-03 14:15:20 +02:00
PS . log ( " &7[WARN] " + " Failed to load settings for cluster: " + id ) ;
2015-01-26 05:16:10 +01:00
e . printStackTrace ( ) ;
}
return h ;
2015-02-20 07:34:19 +01:00
}
2015-02-23 02:32:27 +01:00
2015-01-29 04:20:29 +01:00
@Override
2015-01-29 07:02:13 +01:00
public void removeInvited ( final PlotCluster cluster , final UUID uuid ) {
2015-02-20 07:34:19 +01:00
TaskManager . runTaskAsync ( new Runnable ( ) {
2015-01-29 04:20:29 +01:00
@Override
public void run ( ) {
try {
final PreparedStatement statement = SQLManager . this . connection . prepareStatement ( " DELETE FROM ` " + SQLManager . this . prefix + " cluster_invited` WHERE `cluster_id` = ? AND `user_uuid` = ? " ) ;
statement . setInt ( 1 , getClusterId ( cluster . world , ClusterManager . getClusterId ( cluster ) ) ) ;
statement . setString ( 2 , uuid . toString ( ) ) ;
statement . executeUpdate ( ) ;
statement . close ( ) ;
} catch ( final SQLException e ) {
e . printStackTrace ( ) ;
2015-07-03 14:15:20 +02:00
PS . log ( " &7[WARN] " + " Failed to remove invited for cluster " + cluster ) ;
2015-01-29 04:20:29 +01:00
}
}
} ) ;
}
2015-02-23 02:32:27 +01:00
2015-01-29 04:20:29 +01:00
@Override
2015-07-04 08:37:33 +02:00
public void setInvited ( final PlotCluster cluster , final UUID uuid ) {
2015-02-20 07:34:19 +01:00
TaskManager . runTaskAsync ( new Runnable ( ) {
2015-01-29 04:20:29 +01:00
@Override
public void run ( ) {
try {
final PreparedStatement statement = SQLManager . this . connection . prepareStatement ( " INSERT INTO ` " + SQLManager . this . prefix + " cluster_invited` (`cluster_id`, `user_uuid`) VALUES(?,?) " ) ;
statement . setInt ( 1 , getClusterId ( cluster . world , ClusterManager . getClusterId ( cluster ) ) ) ;
statement . setString ( 2 , uuid . toString ( ) ) ;
statement . executeUpdate ( ) ;
statement . close ( ) ;
} catch ( final SQLException e ) {
2015-07-03 14:15:20 +02:00
PS . log ( " &7[WARN] " + " Failed to set helper for cluster " + cluster ) ;
2015-01-29 04:20:29 +01:00
e . printStackTrace ( ) ;
}
}
} ) ;
}
2015-04-27 11:07:42 +02:00
@Override
public boolean deleteTables ( ) {
try {
2015-04-29 15:07:12 +02:00
SQLManager . this . connection . close ( ) ;
2015-07-03 14:15:20 +02:00
SQLManager . this . connection = PS . get ( ) . getDatabase ( ) . forceConnection ( ) ;
2015-04-27 11:07:42 +02:00
final Statement stmt = this . connection . createStatement ( ) ;
stmt . addBatch ( " DROP TABLE ` " + prefix + " cluster_invited` " ) ;
stmt . addBatch ( " DROP TABLE ` " + prefix + " cluster_helpers` " ) ;
stmt . addBatch ( " DROP TABLE ` " + prefix + " cluster` " ) ;
2015-06-05 12:45:13 +02:00
stmt . addBatch ( " DROP TABLE ` " + prefix + " plot_rating` " ) ;
2015-04-27 11:07:42 +02:00
stmt . addBatch ( " DROP TABLE ` " + prefix + " plot_settings` " ) ;
stmt . addBatch ( " DROP TABLE ` " + prefix + " plot_comments` " ) ;
stmt . addBatch ( " DROP TABLE ` " + prefix + " plot_trusted` " ) ;
stmt . addBatch ( " DROP TABLE ` " + prefix + " plot_helpers` " ) ;
stmt . addBatch ( " DROP TABLE ` " + prefix + " plot_denied` " ) ;
stmt . executeBatch ( ) ;
stmt . clearBatch ( ) ;
stmt . close ( ) ;
2015-07-03 11:30:26 +02:00
2015-04-27 11:07:42 +02:00
PreparedStatement statement = connection . prepareStatement ( " DROP TABLE ` " + prefix + " plot` " ) ;
statement . executeUpdate ( ) ;
statement . close ( ) ;
return true ;
2015-07-03 11:30:26 +02:00
} catch ( Exception e ) {
2015-04-27 11:07:42 +02:00
e . printStackTrace ( ) ;
return false ;
}
}
2015-07-03 11:30:26 +02:00
private class UUIDPair {
public final int id ;
public final UUID uuid ;
public UUIDPair ( int id , UUID uuid ) {
this . id = id ;
this . uuid = uuid ;
}
}
private class SettingsPair {
public final int id ;
public final PlotSettings settings ;
public SettingsPair ( int id , PlotSettings settings ) {
this . id = id ;
this . settings = settings ;
}
}
2014-10-22 08:08:55 +02:00
}