finished END_PHASE

This commit is contained in:
Alperen
2022-03-20 20:57:11 +01:00
parent bf90f74b03
commit 1204f952c6
3 changed files with 236 additions and 204 deletions

View File

@@ -3,129 +3,129 @@ import java.time.temporal.ChronoUnit;
public class Game {
private static final int LOGIN_PHASE = 0;
private static final int GAME_PHASE = 1;
private static final int END_PHASE = 2;
WordleServer wordleServer;
User user;
static DatabaseConnector databaseConnector;// Datenbankverbindung aufstellen
private static final int LOGIN_PHASE = 0;
private static final int GAME_PHASE = 1;
private static final int END_PHASE = 2;
WordleServer wordleServer;
User user;
static DatabaseConnector databaseConnector;// Datenbankverbindung aufstellen
private String ip;
private int port;
private String ip;
private int port;
private String wordle;
private String[] words;
private int count;
private int phase;
private String tempLoginName;
private String wordle;
private String[] words;
private int count;
private int phase;
private String tempLoginName;
static {
static {
databaseConnector = new DatabaseConnector(null, 0, "wordle.db", null, null);
if (databaseConnector.getErrorMessage() != null) {
System.err.println(databaseConnector.getErrorMessage());
}
}
databaseConnector = new DatabaseConnector(null, 0, "wordle.db", null, null);
if (databaseConnector.getErrorMessage() != null) {
System.err.println(databaseConnector.getErrorMessage());
}
}
public Game(WordleServer wordleServer, String pClientIP, int pClientPort) {
public Game(WordleServer wordleServer, String pClientIP, int pClientPort) {
this.wordleServer = wordleServer;
this.ip = pClientIP;
this.port = pClientPort;
this.wordleServer = wordleServer;
this.ip = pClientIP;
this.port = pClientPort;
send("+OK Hello there");
}
send("+OK Hello there");
}
public void processMessage(String msg) {
public void processMessage(String msg) {
msg = msg.toLowerCase().trim();
msg = msg.toLowerCase().trim();
if (msg.equals("quit")) {
send("+OK bye");
wordleServer.closeConnection(ip, port);
System.exit(0); // TODO remove: Einfacher zum testen
}
if (msg.equals("quit")) {
send("+OK bye");
wordleServer.closeConnection(ip, port);
System.exit(0); // TODO remove: Einfacher zum testen
}
switch (phase) {
case LOGIN_PHASE:
loginPhase(msg);
break;
case GAME_PHASE:
gamePhase(msg);
break;
case END_PHASE:
endPhase(msg);
break;
}
}
switch (phase) {
case LOGIN_PHASE:
loginPhase(msg);
break;
case GAME_PHASE:
gamePhase(msg);
break;
case END_PHASE:
endPhase(msg);
break;
}
}
private void loginPhase(String msg) {
private void loginPhase(String msg) {
if (msg.startsWith("user ")) {
if (msg.startsWith("user ")) {
if (msg.length() <= 5) {
sendUniversalError();
return;
}
String args = msg.substring(5);
databaseConnector.executeStatement("SELECT * FROM User WHERE name = '" + args + "'");
QueryResult result = databaseConnector.getCurrentQueryResult();
if (result != null && result.getData().length > 0) {
tempLoginName = result.getData()[0][0];
send("+OK");
} else {
send("-ERR User not found.");
}
if (msg.length() <= 5) {
sendUniversalError();
return;
}
String args = msg.substring(5);
databaseConnector.executeStatement("SELECT * FROM User WHERE name = '" + args + "'");
QueryResult result = databaseConnector.getCurrentQueryResult();
if (result != null && result.getData().length > 0) {
tempLoginName = result.getData()[0][0];
send("+OK");
} else {
send("-ERR User not found.");
}
} else if (msg.startsWith("pass ")) {
if (msg.length() <= 5) {
sendUniversalError();
return;
}
String args = msg.substring(5);
int pw = args.hashCode();
databaseConnector.executeStatement("SELECT * FROM User WHERE password = '" + pw + "' AND name = '" + tempLoginName + "'");
QueryResult result = databaseConnector.getCurrentQueryResult();
if (result != null && result.getData().length > 0) {
user = new User(tempLoginName);
send("+OK welcome");
} else {
send("-ERR login not valid");
}
} else if (msg.startsWith("wotd")) {
databaseConnector.executeStatement("SELECT word FROM words WHERE id = " + getWOTDIndex());
QueryResult result = databaseConnector.getCurrentQueryResult();
System.out.println(databaseConnector.getErrorMessage());
if (result != null && result.getData().length > 0) {
wordle = result.getData()[0][0];
phase = GAME_PHASE;
send("+OK game ready");
} else {
send("-ERR fatal error: WOTD could not be generated.");
}
} else if (msg.startsWith("play")) {
if (user == null) {
send("-ERR not logged in.");
} else {
}
} else {
sendUniversalError();
}
}
} else if (msg.startsWith("pass ")) {
if (msg.length() <= 5) {
sendUniversalError();
return;
}
String args = msg.substring(5);
int pw = args.hashCode();
databaseConnector.executeStatement("SELECT * FROM User WHERE password = '" + pw + "' AND name = '" + tempLoginName + "'");
QueryResult result = databaseConnector.getCurrentQueryResult();
if (result != null && result.getData().length > 0) {
user = new User(tempLoginName);
send("+OK welcome");
} else {
send("-ERR login not valid");
}
} else if (msg.startsWith("wotd")) {
databaseConnector.executeStatement("SELECT word FROM words WHERE id = " + getWOTDIndex());
QueryResult result = databaseConnector.getCurrentQueryResult();
System.out.println(databaseConnector.getErrorMessage());
if (result != null && result.getData().length > 0) {
wordle = result.getData()[0][0];
phase = GAME_PHASE;
send("+OK game ready");
} else {
send("-ERR fatal error: WOTD could not be generated.");
}
} else if (msg.startsWith("play")) {
if (user == null) {
send("-ERR not logged in.");
} else {
}
} else {
sendUniversalError();
}
}
private void gamePhase(String msg) {
if (msg.startsWith("send ")) {
private void gamePhase(String msg) {
if (msg.startsWith("send ")) {
String args = msg.substring(5);
@@ -141,7 +141,7 @@ public class Game {
code = input;
send(code);
if (code.equals("11111")) {
if (code.equals("222222")) { // 111111 auf 222222 geändert, 0=falsch 1=falscher ort 2= richtig :)
send("game won");
if (user != null) {
phase = END_PHASE;
@@ -166,24 +166,67 @@ public class Game {
} else {
send("-ERR wrong format.");
}
//vergleichen von wotd mit
//ja = spiel beendet und ausgabe word 11111
//nein = ausgabe 01102 oder so und pr<70>fen ob man noch ein wort eingebn kann
// ja game continues nein = game lost
} else if (msg.startsWith("info")) {
} else if (msg.startsWith("exit")) {
if (user != null) {
phase = END_PHASE;
} else {
send("-ERR not logged in.");
}
}
}
}
private void endPhase(String msg) {
if (msg.startsWith("stat")) {
if (msg.startsWith("stat")) {
databaseConnector.executeStatement("SELECT timesPlayed FROM User Where name like " + tempLoginName + "");
String tP = databaseConnector.getCurrentQueryResult().getData()[0][0];
send("times Played: " + tP);
databaseConnector.executeStatement("SELECT winPercentage FROM User Where name like " + tempLoginName + "");
String wP = databaseConnector.getCurrentQueryResult().getData()[0][0];
send("win Percentage: " + wP);
databaseConnector.executeStatement("SELECT currentStreak FROM User Where name like " + tempLoginName + "");
String cS = databaseConnector.getCurrentQueryResult().getData()[0][0];
send("current Streak: " + cS);
databaseConnector.executeStatement("SELECT maxStreak FROM User Where name like " + tempLoginName + "");
String mS = databaseConnector.getCurrentQueryResult().getData()[0][0];
send("max Streak: " + mS);
databaseConnector.executeStatement("SELECT wonInTurn1 FROM User Where name like " + tempLoginName + "");
String wIT1 = databaseConnector.getCurrentQueryResult().getData()[0][0];
send("won in Turn1: " + wIT1);
databaseConnector.executeStatement("SELECT wonInTurn1 FROM User Where name like " + tempLoginName + "");
String wIT2 = databaseConnector.getCurrentQueryResult().getData()[0][0];
send("won in Turn2: " + wIT2);
databaseConnector.executeStatement("SELECT wonInTurn1 FROM User Where name like " + tempLoginName + "");
String wIT3 = databaseConnector.getCurrentQueryResult().getData()[0][0];
send("won in Turn3: " + wIT3);
databaseConnector.executeStatement("SELECT wonInTurn1 FROM User Where name like " + tempLoginName + "");
String wIT4 = databaseConnector.getCurrentQueryResult().getData()[0][0];
send("won in Turn4: " + wIT4);
databaseConnector.executeStatement("SELECT wonInTurn1 FROM User Where name like " + tempLoginName + "");
String wIT5 = databaseConnector.getCurrentQueryResult().getData()[0][0];
send("won in Turn5: " + wIT5);
databaseConnector.executeStatement("SELECT wonInTurn1 FROM User Where name like " + tempLoginName + "");
String wIT6 = databaseConnector.getCurrentQueryResult().getData()[0][0];
send("won in Turn6: " + wIT6);
} else if (msg.startsWith("play")) {
phase = GAME_PHASE;
}
}