geforkt von SteamWar/BungeeCore
WIP GDPR query processor
Signed-off-by: Lixfel <agga-games@gmx.de>
Dieser Commit ist enthalten in:
Ursprung
f192deaeea
Commit
866d57f8dc
@ -128,6 +128,7 @@ public class BungeeCore extends Plugin {
|
|||||||
new ListCommand();
|
new ListCommand();
|
||||||
new StatCommand();
|
new StatCommand();
|
||||||
new VerifyCommand();
|
new VerifyCommand();
|
||||||
|
new GDPRQuery();
|
||||||
|
|
||||||
// Punishment Commands:
|
// Punishment Commands:
|
||||||
new PunishmentCommand("ban", Punishment.PunishmentType.Ban);
|
new PunishmentCommand("ban", Punishment.PunishmentType.Ban);
|
||||||
|
239
src/de/steamwar/bungeecore/commands/GDPRQuery.java
Normale Datei
239
src/de/steamwar/bungeecore/commands/GDPRQuery.java
Normale Datei
@ -0,0 +1,239 @@
|
|||||||
|
package de.steamwar.bungeecore.commands;
|
||||||
|
|
||||||
|
import de.steamwar.bungeecore.sql.Statement;
|
||||||
|
import de.steamwar.bungeecore.sql.SteamwarUser;
|
||||||
|
import net.md_5.bungee.api.CommandSender;
|
||||||
|
import net.md_5.bungee.api.connection.ProxiedPlayer;
|
||||||
|
|
||||||
|
import java.io.*;
|
||||||
|
import java.sql.SQLException;
|
||||||
|
import java.util.zip.ZipEntry;
|
||||||
|
import java.util.zip.ZipOutputStream;
|
||||||
|
|
||||||
|
public class GDPRQuery extends BasicCommand {
|
||||||
|
|
||||||
|
public GDPRQuery() {
|
||||||
|
super("gdprquery", null);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void execute(CommandSender sender, String[] args) {
|
||||||
|
if(!(sender instanceof ProxiedPlayer))
|
||||||
|
return;
|
||||||
|
ProxiedPlayer player = (ProxiedPlayer) sender;
|
||||||
|
SteamwarUser user = SteamwarUser.get(player.getUniqueId());
|
||||||
|
|
||||||
|
try {
|
||||||
|
createZip(user);
|
||||||
|
} catch (IOException e) {
|
||||||
|
throw new SecurityException("Could not create zip", e);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private void createZip(SteamwarUser user) throws IOException {
|
||||||
|
ZipOutputStream out = new ZipOutputStream(new FileOutputStream("test.zip")); //TODO
|
||||||
|
|
||||||
|
//TODO: Bauweltenurheberrecht
|
||||||
|
//TODO: Erklärung Art, Umfang (& Dauer?)
|
||||||
|
|
||||||
|
copyBauwelt(user, out, "/home/minecraft/userworlds/" + user.getUuid().toString(), "BuildWorld12");
|
||||||
|
copyBauwelt(user, out, "/home/minecraft/userworlds15/" + user.getId(), "BuildWorld15");
|
||||||
|
copyPlayerdata(user, out, "/home/minecraft/userworlds", "BuildInventories12");
|
||||||
|
copyPlayerdata(user, out, "/home/minecraft/userworlds15", "BuildInventories15");
|
||||||
|
//TODO: Simulatoren von allen Bauwelten
|
||||||
|
|
||||||
|
sqlCSV(user, out, bannedIPs, "BannedIPs.csv");
|
||||||
|
sqlCSV(user, out, bauweltMember, "BuildMember.csv");
|
||||||
|
sqlCSV(user, out, bauweltMembers, "BuildMembers.csv");
|
||||||
|
sqlCSV(user, out, checkedSchems, "SchematicChecksessions.csv");
|
||||||
|
sqlCSV(user, out, elo, "Elo.csv");
|
||||||
|
sqlCSV(user, out, fights, "Fights.csv");
|
||||||
|
sqlCSV(user, out, ignoredPlayers, "IgnoredPlayers.csv");
|
||||||
|
sqlCSV(user, out, ignoringPlayers, "IgnoringPlayers.csv");
|
||||||
|
sqlCSV(user, out, schematicMember, "SchematicMember.csv");
|
||||||
|
sqlCSV(user, out, schematicMembers, "SchematicMembers.csv");
|
||||||
|
sqlCSV(user, out, pollAnswers, "PollAnswers.csv");
|
||||||
|
sqlCSV(user, out, punishments, "Punishments.csv");
|
||||||
|
sqlCSV(user, out, sessions, "Sessions.csv");
|
||||||
|
sqlCSV(user, out, userData, "UserData.csv");
|
||||||
|
sqlCSV(user, out, personalKits, "PersonalKits.csv");
|
||||||
|
sqlCSV(user, out, schematics, "Schematics.csv");
|
||||||
|
|
||||||
|
personalKits(user, out);
|
||||||
|
schematics(user, out);
|
||||||
|
userConfig(user, out);
|
||||||
|
|
||||||
|
//TODO: Logs: Lobby & Bungeelogpos!
|
||||||
|
//TODO: Website
|
||||||
|
|
||||||
|
out.close();
|
||||||
|
}
|
||||||
|
|
||||||
|
private static final Statement bannedIPs = new Statement("SELECT Timestamp, IP FROM BannedUserIPs WHERE UserID = ?");
|
||||||
|
private static final Statement bauweltMember = new Statement("SELECT BauweltID AS Bauwelt, WorldEdit, World FROM BauweltMember WHERE MemberID = ?");
|
||||||
|
private static final Statement bauweltMembers = new Statement("SELECT u.UserName AS 'User', m.WorldEdit AS WorldEdit, m.World AS World FROM BauweltMember m INNER JOIN UserData u ON m.MemberID = u.id WHERE m.BauweltID = ?");
|
||||||
|
private static final Statement checkedSchems = new Statement("SELECT NodeName AS Schematic, StartTime, EndTime, DeclineReason AS Result FROM CheckedSchematic WHERE NodeOwner = ? ORDER BY StartTime ASC");
|
||||||
|
private static final Statement elo = new Statement("SELECT GameMode, Elo FROM Elo WHERE UserID = ?");
|
||||||
|
private static final Statement fights = new Statement("SELECT p.Team AS Team, p.Kit AS Kit, p.Kills AS Kills, p.IsOut AS Died, f.GameMode AS GameMode, f.Server AS Server, f.Arena AS Arena, f.StartTime AS StartTime, f.Duration AS Duration, (f.BlueLeader = p.UserID) AS IsBlueLeader, (f.RedLeader = p.UserID) AS IsRedLeader, f.Win AS Winner, f.WinCondition AS WinCondition FROM Fight f INNER JOIN FightPlayer p ON f.FightID = p.FightID WHERE p.UserID = ? ORDER BY StartTime ASC");
|
||||||
|
private static final Statement ignoredPlayers = new Statement("SELECT u.UserName AS IgnoredPlayer FROM IgnoredPlayers i INNER JOIN UserData u ON i.Ignored = u.id WHERE Ignorer = ?");
|
||||||
|
private static final Statement ignoringPlayers = new Statement("SELECT Ignorer AS IgnoringPlayers FROM IgnoredPlayers WHERE Ignored = ?");
|
||||||
|
private static final Statement schematicMember = new Statement("SELECT s.NodeName AS SchematicName, u.UserName AS SchematicOwner FROM NodeMember m INNER JOIN SchematicNode s ON m.NodeId = s.NodeId INNER JOIN UserData u ON s.NodeOwner = u.id WHERE m.UserId = ?");
|
||||||
|
private static final Statement schematicMembers = new Statement("SELECT s.NodeName AS SchematicName, u.UserName AS Member FROM NodeMember m INNER JOIN SchematicNode s ON m.NodeId = s.NodeId INNER JOIN UserData u ON m.UserId = u.id WHERE s.NodeOwner = ?");
|
||||||
|
private static final Statement pollAnswers = new Statement("SELECT Question, Answer FROM PollAnswer WHERE UserID = ?");
|
||||||
|
private static final Statement punishments = new Statement("SELECT Type, StartTime, EndTime, Perma, Reason FROM Punishments WHERE UserId = ?");
|
||||||
|
private static final Statement sessions = new Statement("SELECT StartTime, EndTime FROM Session WHERE UserID = ?");
|
||||||
|
private static final Statement userData = new Statement("SELECT * FROM UserData WHERE id = ?");
|
||||||
|
private static final Statement personalKits = new Statement("SELECT GameMode, Name, InUse FROM PersonalKit WHERE UserID = ?");
|
||||||
|
private static final Statement personalKitData = new Statement("SELECT GameMode, Name, Inventory, Armor FROM PersonalKit WHERE UserID = ?");
|
||||||
|
private static final Statement schematics = new Statement("SELECT NodeName AS SchematicName, ParentNode, LastUpdate, NodeItem, NodeType, NodeRank FROM SchematicNode WHERE NodeOwner = ?");
|
||||||
|
private static final Statement schematicData = new Statement("SELECT NodeName, ParentNode, NodeFormat, NodeData FROM SchematicNode WHERE NodeOwner = ?");
|
||||||
|
private static final Statement userConfig = new Statement("SELECT * FROM UserConfig WHERE User = ?");
|
||||||
|
|
||||||
|
private void sqlCSV(SteamwarUser user, ZipOutputStream out, Statement statement, String path) throws IOException {
|
||||||
|
write(stream -> {
|
||||||
|
PrintWriter writer = new PrintWriter(stream);
|
||||||
|
statement.select(rs -> {
|
||||||
|
int columns = rs.getMetaData().getColumnCount();
|
||||||
|
|
||||||
|
for(int i = 1; i <= columns; i++) {
|
||||||
|
writer.write(rs.getMetaData().getColumnName(1));
|
||||||
|
writer.write(";");
|
||||||
|
}
|
||||||
|
writer.println();
|
||||||
|
|
||||||
|
while(rs.next()) {
|
||||||
|
for(int i = 1; i <= columns; i++) {
|
||||||
|
try {
|
||||||
|
writer.write(rs.getString(i));
|
||||||
|
} catch (NullPointerException e) {
|
||||||
|
// ignored
|
||||||
|
}
|
||||||
|
writer.write(";");
|
||||||
|
}
|
||||||
|
writer.println();
|
||||||
|
}
|
||||||
|
return null;
|
||||||
|
}, user.getId());
|
||||||
|
}, out, path);
|
||||||
|
}
|
||||||
|
|
||||||
|
private void personalKits(SteamwarUser user, ZipOutputStream out) {
|
||||||
|
personalKitData.select(rs -> {
|
||||||
|
while(rs.next()) {
|
||||||
|
try {
|
||||||
|
write(stream -> {
|
||||||
|
try {
|
||||||
|
new PrintWriter(stream).print(rs.getString("Inventory"));
|
||||||
|
} catch (SQLException e) {
|
||||||
|
throw new SecurityException("Could not export PersonalKits", e);
|
||||||
|
}
|
||||||
|
}, out, "PersonalKit/" + rs.getString("GameMode") + "/" + rs.getString("Name") + ".Inventory.yml");
|
||||||
|
write(stream -> {
|
||||||
|
try {
|
||||||
|
new PrintWriter(stream).print(rs.getString("Armor"));
|
||||||
|
} catch (SQLException e) {
|
||||||
|
throw new SecurityException("Could not export PersonalKits", e);
|
||||||
|
}
|
||||||
|
}, out, "PersonalKit/" + rs.getString("GameMode") + "/" + rs.getString("Name") + ".Armor.yml");
|
||||||
|
} catch (IOException e) {
|
||||||
|
throw new SecurityException("Could not export PersonalKits", e);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return null;
|
||||||
|
}, user.getId());
|
||||||
|
}
|
||||||
|
|
||||||
|
private void schematics(SteamwarUser user, ZipOutputStream out) {
|
||||||
|
schematicData.select(rs -> {
|
||||||
|
while(rs.next()) {
|
||||||
|
String name = (rs.getString("ParentNode") != null ? rs.getString("ParentNode") : "") + ":" + rs.getString("NodeName");
|
||||||
|
boolean format = rs.getBoolean("NodeFormat");
|
||||||
|
try(InputStream data = rs.getBinaryStream("NodeData")) {
|
||||||
|
copy(data, out, "Schematics/" + name + (format ? ".schem" : ".schematic"));
|
||||||
|
} catch (IOException e) {
|
||||||
|
throw new SecurityException("Could not export Schematic", e);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return null;
|
||||||
|
}, user.getId());
|
||||||
|
}
|
||||||
|
|
||||||
|
private void userConfig(SteamwarUser user, ZipOutputStream out) {
|
||||||
|
userConfig.select(rs -> {
|
||||||
|
while(rs.next()) {
|
||||||
|
String name = rs.getString("Config");
|
||||||
|
try(InputStream data = rs.getBinaryStream("Value")) {
|
||||||
|
copy(data, out, name + ".yapion");
|
||||||
|
} catch (IOException e) {
|
||||||
|
throw new SecurityException("Could not export UserConfig", e);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return null;
|
||||||
|
}, user.getId());
|
||||||
|
}
|
||||||
|
|
||||||
|
private void copyBauwelt(SteamwarUser user, ZipOutputStream out, String inDir, String outDir) throws IOException {
|
||||||
|
//TODO: Überhaupt nötig wegen Urheberrecht?
|
||||||
|
File world = new File(inDir);
|
||||||
|
if(!world.exists())
|
||||||
|
return;
|
||||||
|
|
||||||
|
copy(new File(world, "level.dat"), out, outDir + "/level.dat");
|
||||||
|
|
||||||
|
File region = new File(world, "region");
|
||||||
|
for(File regionfile : region.listFiles()) {
|
||||||
|
copy(regionfile, out, outDir + "/region/" + regionfile.getName());
|
||||||
|
}
|
||||||
|
|
||||||
|
File poi = new File(world, "poi");
|
||||||
|
if(poi.exists()) {
|
||||||
|
for(File regionfile : poi.listFiles()) {
|
||||||
|
copy(regionfile, out, outDir + "/poi/" + regionfile.getName());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
File playerdata = new File(world, "playerdata/" + user.getUuid().toString() + ".dat");
|
||||||
|
if(playerdata.exists())
|
||||||
|
copy(playerdata, out, outDir + "/playerdata/" + user.getUuid().toString() + ".dat");
|
||||||
|
}
|
||||||
|
|
||||||
|
private void copyPlayerdata(SteamwarUser user, ZipOutputStream out, String inDir, String outDir) throws IOException {
|
||||||
|
File worlds = new File(inDir);
|
||||||
|
String path = "playerdata/" + user.getUuid().toString() + ".dat";
|
||||||
|
|
||||||
|
int i = 0;
|
||||||
|
for(File world : worlds.listFiles()) {
|
||||||
|
File playerdata = new File(world, path);
|
||||||
|
if(!playerdata.exists())
|
||||||
|
continue;
|
||||||
|
|
||||||
|
copy(playerdata, out, outDir + "/" + (i++) + "/" + user.getUuid().toString() + ".dat");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private static void copy(File file, ZipOutputStream out, String path) throws IOException {
|
||||||
|
try(FileInputStream in = new FileInputStream(file)) {
|
||||||
|
copy(in, out, path);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private static void copy(InputStream in, ZipOutputStream out, String path) throws IOException {
|
||||||
|
write(stream -> {
|
||||||
|
int bytes;
|
||||||
|
for(byte[] buf = new byte[8192]; (bytes = in.read(buf)) > 0; ) {
|
||||||
|
out.write(buf, 0, bytes);
|
||||||
|
}
|
||||||
|
}, out, path);
|
||||||
|
}
|
||||||
|
|
||||||
|
private static void write(Writer writer, ZipOutputStream out, String path) throws IOException {
|
||||||
|
ZipEntry entry = new ZipEntry(path);
|
||||||
|
out.putNextEntry(entry);
|
||||||
|
writer.accept(out);
|
||||||
|
out.closeEntry();
|
||||||
|
}
|
||||||
|
|
||||||
|
private interface Writer {
|
||||||
|
void accept(OutputStream stream) throws IOException;
|
||||||
|
}
|
||||||
|
}
|
@ -88,7 +88,7 @@ public class Statement {
|
|||||||
private final String sql;
|
private final String sql;
|
||||||
private PreparedStatement st;
|
private PreparedStatement st;
|
||||||
|
|
||||||
Statement(String sql) {
|
public Statement(String sql) {
|
||||||
this.sql = sql;
|
this.sql = sql;
|
||||||
statements.add(this);
|
statements.add(this);
|
||||||
try {
|
try {
|
||||||
@ -102,7 +102,7 @@ public class Statement {
|
|||||||
st = con.prepareStatement(sql);
|
st = con.prepareStatement(sql);
|
||||||
}
|
}
|
||||||
|
|
||||||
<T> T select(ResultSetUser<T> user, Object... objects) {
|
public <T> T select(ResultSetUser<T> user, Object... objects) {
|
||||||
synchronized (statements) {
|
synchronized (statements) {
|
||||||
return prepare(() -> {
|
return prepare(() -> {
|
||||||
ResultSet rs = st.executeQuery();
|
ResultSet rs = st.executeQuery();
|
||||||
@ -113,7 +113,7 @@ public class Statement {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void update(Object... objects) {
|
public void update(Object... objects) {
|
||||||
synchronized (statements) {
|
synchronized (statements) {
|
||||||
prepare(st::executeUpdate, objects);
|
prepare(st::executeUpdate, objects);
|
||||||
}
|
}
|
||||||
@ -135,7 +135,7 @@ public class Statement {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
interface ResultSetUser<T> {
|
public interface ResultSetUser<T> {
|
||||||
T use(ResultSet rs) throws SQLException;
|
T use(ResultSet rs) throws SQLException;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
In neuem Issue referenzieren
Einen Benutzer sperren