forked from MagicBane/Server
				
			
				 5 changed files with 89 additions and 45 deletions
			
			
		@ -0,0 +1,77 @@
				@@ -0,0 +1,77 @@
					 | 
				
			||||
// • ▌ ▄ ·.  ▄▄▄·  ▄▄ • ▪   ▄▄· ▄▄▄▄·  ▄▄▄·  ▐▄▄▄  ▄▄▄ .
 | 
				
			||||
// ·██ ▐███▪▐█ ▀█ ▐█ ▀ ▪██ ▐█ ▌▪▐█ ▀█▪▐█ ▀█ •█▌ ▐█▐▌·
 | 
				
			||||
// ▐█ ▌▐▌▐█·▄█▀▀█ ▄█ ▀█▄▐█·██ ▄▄▐█▀▀█▄▄█▀▀█ ▐█▐ ▐▌▐▀▀▀
 | 
				
			||||
// ██ ██▌▐█▌▐█ ▪▐▌▐█▄▪▐█▐█▌▐███▌██▄▪▐█▐█ ▪▐▌██▐ █▌▐█▄▄▌
 | 
				
			||||
// ▀▀  █▪▀▀▀ ▀  ▀ ·▀▀▀▀ ▀▀▀·▀▀▀ ·▀▀▀▀  ▀  ▀ ▀▀  █▪ ▀▀▀
 | 
				
			||||
//      Magicbane Emulator Project © 2013 - 2022
 | 
				
			||||
//                www.magicbane.com
 | 
				
			||||
 | 
				
			||||
 | 
				
			||||
package engine.db.handlers; | 
				
			||||
 | 
				
			||||
import engine.Enum; | 
				
			||||
import engine.gameManager.DbManager; | 
				
			||||
import engine.objects.Petition; | 
				
			||||
import org.pmw.tinylog.Logger; | 
				
			||||
 | 
				
			||||
import java.sql.Connection; | 
				
			||||
import java.sql.PreparedStatement; | 
				
			||||
import java.sql.SQLException; | 
				
			||||
 | 
				
			||||
public class dbPetitionHandler extends dbHandlerBase { | 
				
			||||
 | 
				
			||||
    public dbPetitionHandler() { | 
				
			||||
 | 
				
			||||
    } | 
				
			||||
 | 
				
			||||
    public void CREATE_PETITION_TABLE() { | 
				
			||||
 | 
				
			||||
        try (Connection connection = DbManager.getConnection(); | 
				
			||||
             PreparedStatement preparedStatement = connection.prepareStatement("SET sql_notes = 0; CREATE TABLE IF NOT EXISTS dyn_petition (\n" + | 
				
			||||
                     "   petitionNumber INT AUTO_INCREMENT NOT NULL,\n" + | 
				
			||||
                     "   petitionTime DATETIME,\n" + | 
				
			||||
                     "   primaryType VARCHAR(50),\n" + | 
				
			||||
                     "   subType VARCHAR(50),\n" + | 
				
			||||
                     "   message VARCHAR(255),\n" + | 
				
			||||
                     "   accountID INT,\n" + | 
				
			||||
                     "   account VARCHAR(255),\n" + | 
				
			||||
                     "   characterID INT,\n" + | 
				
			||||
                     "   `character` VARCHAR(255),\n" + | 
				
			||||
                     "   location VARCHAR(255),\n" + | 
				
			||||
                     "  PRIMARY KEY (petitionNumber)\n" + | 
				
			||||
                     ") ENGINE = innodb ROW_FORMAT = DEFAULT; SET sql_notes = 1;")) { | 
				
			||||
 | 
				
			||||
            preparedStatement.executeQuery(); | 
				
			||||
 | 
				
			||||
        } catch (SQLException e) { | 
				
			||||
            Logger.error(e); | 
				
			||||
        } | 
				
			||||
    } | 
				
			||||
 | 
				
			||||
    public void WRITE_PETITION_TO_TABLE(Petition petition) { | 
				
			||||
 | 
				
			||||
        try (Connection connection = DbManager.getConnection(); | 
				
			||||
 | 
				
			||||
             //check that table exists
 | 
				
			||||
 | 
				
			||||
             PreparedStatement preparedStatement = connection.prepareStatement("INSERT INTO `dyn_petition` (`petitionTime`, `primaryType`, `subType`, `accountID`, `account`, `characterID`, `character`, `location`, `message`)" + | 
				
			||||
                     " VALUES (?,?,?,?,?,?,?,?,?);")) { | 
				
			||||
 | 
				
			||||
            preparedStatement.setTimestamp(1, new java.sql.Timestamp(System.currentTimeMillis())); | 
				
			||||
            preparedStatement.setString(2, Enum.PetitionType.values()[petition.primaryType].name()); | 
				
			||||
            preparedStatement.setString(3, Enum.PetitionSubType.values()[petition.subType].name()); | 
				
			||||
            preparedStatement.setInt(4, petition.reportAccount.getObjectUUID()); | 
				
			||||
            preparedStatement.setString(5, petition.reportAccount.getUname()); | 
				
			||||
            preparedStatement.setInt(6, petition.reportPlayer.getObjectUUID()); | 
				
			||||
            preparedStatement.setString(7, petition.reportPlayer.getFirstName()); | 
				
			||||
            preparedStatement.setString(8, petition.playerLocation.toString()); | 
				
			||||
            preparedStatement.setString(9, petition.message); | 
				
			||||
 | 
				
			||||
            preparedStatement.executeUpdate(); | 
				
			||||
 | 
				
			||||
        } catch (SQLException e) { | 
				
			||||
            Logger.error("CREATE PETITION FAILED: " + e); | 
				
			||||
        } | 
				
			||||
    } | 
				
			||||
 | 
				
			||||
} | 
				
			||||
					Loading…
					
					
				
		Reference in new issue