wordle richtigkeits check

This commit is contained in:
Asecave
2022-03-23 20:08:09 +01:00
parent 1204f952c6
commit e64344b5a2

View File

@@ -1,131 +1,141 @@
import java.time.LocalDate; import java.time.LocalDate;
import java.time.temporal.ChronoUnit; import java.time.temporal.ChronoUnit;
import java.util.Iterator;
public class Game { public class Game {
private static final int LOGIN_PHASE = 0; private static final int LOGIN_PHASE = 0;
private static final int GAME_PHASE = 1; private static final int GAME_PHASE = 1;
private static final int END_PHASE = 2; private static final int END_PHASE = 2;
WordleServer wordleServer; WordleServer wordleServer;
User user; User user;
static DatabaseConnector databaseConnector;// Datenbankverbindung aufstellen static DatabaseConnector databaseConnector;// Datenbankverbindung aufstellen
private String ip; private String ip;
private int port; private int port;
private String wordle; private String wordle;
private String[] words; private String[] words;
private int count; private int count;
private int phase; private int phase;
private String tempLoginName; private String tempLoginName;
static { static {
databaseConnector = new DatabaseConnector(null, 0, "wordle.db", null, null); databaseConnector = new DatabaseConnector(null, 0, "wordle.db", null, null);
if (databaseConnector.getErrorMessage() != null) { if (databaseConnector.getErrorMessage() != null) {
System.err.println(databaseConnector.getErrorMessage()); 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.wordleServer = wordleServer;
this.ip = pClientIP; this.ip = pClientIP;
this.port = pClientPort; 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")) { if (msg.equals("quit")) {
send("+OK bye"); send("+OK bye");
wordleServer.closeConnection(ip, port); wordleServer.closeConnection(ip, port);
System.exit(0); // TODO remove: Einfacher zum testen System.exit(0); // TODO remove: Einfacher zum testen
} }
switch (phase) { switch (phase) {
case LOGIN_PHASE: case LOGIN_PHASE:
loginPhase(msg); loginPhase(msg);
break; break;
case GAME_PHASE: case GAME_PHASE:
gamePhase(msg); gamePhase(msg);
break; break;
case END_PHASE: case END_PHASE:
endPhase(msg); endPhase(msg);
break; break;
} }
} }
private void loginPhase(String msg) { private void loginPhase(String msg) {
if (msg.startsWith("user ")) { if (msg.startsWith("user ")) {
if (msg.length() <= 5) { if (msg.length() <= 5) {
sendUniversalError(); sendUniversalError();
return; return;
} }
String args = msg.substring(5); String args = msg.substring(5);
databaseConnector.executeStatement("SELECT * FROM User WHERE name = '" + args + "'"); databaseConnector.executeStatement("SELECT * FROM User WHERE name = '" + args + "'");
QueryResult result = databaseConnector.getCurrentQueryResult(); QueryResult result = databaseConnector.getCurrentQueryResult();
if (result != null && result.getData().length > 0) { if (result != null && result.getData().length > 0) {
tempLoginName = result.getData()[0][0]; tempLoginName = result.getData()[0][0];
send("+OK"); send("+OK");
} else { } else {
send("-ERR User not found."); send("-ERR User not found.");
} }
} else if (msg.startsWith("pass ")) { } else if (msg.startsWith("pass ")) {
if (msg.length() <= 5) { if (msg.length() <= 5) {
sendUniversalError(); sendUniversalError();
return; return;
} }
String args = msg.substring(5); String args = msg.substring(5);
int pw = args.hashCode(); int pw = args.hashCode();
databaseConnector.executeStatement("SELECT * FROM User WHERE password = '" + pw + "' AND name = '" + tempLoginName + "'"); databaseConnector.executeStatement(
QueryResult result = databaseConnector.getCurrentQueryResult(); "SELECT * FROM User WHERE password = '" + pw + "' AND name = '" + tempLoginName + "'");
if (result != null && result.getData().length > 0) { QueryResult result = databaseConnector.getCurrentQueryResult();
user = new User(tempLoginName); if (result != null && result.getData().length > 0) {
send("+OK welcome"); user = new User(tempLoginName);
} else { send("+OK welcome");
send("-ERR login not valid"); } else {
} send("-ERR login not valid");
} else if (msg.startsWith("wotd")) { }
} else if (msg.startsWith("wotd")) {
databaseConnector.executeStatement("SELECT word FROM words WHERE id = " + getWOTDIndex()); databaseConnector.executeStatement("SELECT word FROM words WHERE id = " + getWOTDIndex());
QueryResult result = databaseConnector.getCurrentQueryResult(); QueryResult result = databaseConnector.getCurrentQueryResult();
System.out.println(databaseConnector.getErrorMessage()); if (result != null && result.getData().length > 0) {
if (result != null && result.getData().length > 0) { wordle = result.getData()[0][0].toLowerCase();
wordle = result.getData()[0][0]; phase = GAME_PHASE;
phase = GAME_PHASE; send("+OK game ready");
send("+OK game ready"); } else {
} else { send("-ERR fatal error: WOTD could not be generated.");
send("-ERR fatal error: WOTD could not be generated."); }
}
} else if (msg.startsWith("play")) { } else if (msg.startsWith("play")) {
if (user == null) { if (user == null) {
send("-ERR not logged in."); send("-ERR not logged in.");
} else { } else {
databaseConnector.executeStatement("SELECT word FROM words WHERE id = " + (int) (Math.random() * 950));
QueryResult result = databaseConnector.getCurrentQueryResult();
if (result != null && result.getData().length > 0) {
wordle = result.getData()[0][0].toLowerCase();
phase = GAME_PHASE;
send("+OK game ready");
} else {
send("-ERR fatal error: Wordle could not be generated.");
}
}
} else {
sendUniversalError();
}
}
} private void gamePhase(String msg) {
} else {
sendUniversalError();
}
}
private void gamePhase(String msg) { if (msg.startsWith("send ")) {
if (msg.startsWith("send ")) {
String args = msg.substring(5); String args = msg.substring(5);
@@ -135,13 +145,26 @@ public class Game {
QueryResult result = databaseConnector.getCurrentQueryResult(); QueryResult result = databaseConnector.getCurrentQueryResult();
if (result.getData().length > 0) { if (result.getData().length > 0) {
String input = result.getData()[0][0]; String input = result.getData()[0][0].toLowerCase();
String code = ""; String code = "";
code = input; outer: for (int i = 0; i < input.length(); i++) {
char c = input.charAt(i);
if (c == wordle.charAt(i)) {
code += "2";
} else {
for (int j = 0; j < wordle.length(); j++) {
if (c == wordle.charAt(j)) {
code += "1";
continue outer;
}
}
code += "0";
}
}
send(code); send(code);
if (code.equals("222222")) { // 111111 auf 222222 geändert, 0=falsch 1=falscher ort 2= richtig :) if (code.equals("22222")) { // und ein wordle ist 5 Buchstaben lang :D
send("game won"); send("game won");
if (user != null) { if (user != null) {
phase = END_PHASE; phase = END_PHASE;
@@ -171,92 +194,102 @@ public class Game {
} else if (msg.startsWith("exit")) { } else if (msg.startsWith("exit")) {
if (user != null) { if (user != null) {
phase = END_PHASE; phase = END_PHASE;
} else { } else {
send("-ERR not logged in."); send("-ERR not logged in.");
} }
} } else {
sendUniversalError();
}
} }
private void endPhase(String msg) { private void endPhase(String msg) {
if (msg.startsWith("stat")) { if (msg.startsWith("stat")) {
databaseConnector.executeStatement("SELECT timesPlayed FROM User Where name like " + tempLoginName + ""); databaseConnector.executeStatement("SELECT timesPlayed FROM User Where name like " + tempLoginName + "");
String tP = databaseConnector.getCurrentQueryResult().getData()[0][0]; String tP = databaseConnector.getCurrentQueryResult().getData()[0][0];
send("times Played: " + tP); send("times Played: " + tP);
databaseConnector.executeStatement("SELECT winPercentage FROM User Where name like " + tempLoginName + ""); databaseConnector.executeStatement("SELECT winPercentage FROM User Where name like " + tempLoginName + "");
String wP = databaseConnector.getCurrentQueryResult().getData()[0][0]; String wP = databaseConnector.getCurrentQueryResult().getData()[0][0];
send("win Percentage: " + wP); send("win Percentage: " + wP);
databaseConnector.executeStatement("SELECT currentStreak FROM User Where name like " + tempLoginName + ""); databaseConnector.executeStatement("SELECT currentStreak FROM User Where name like " + tempLoginName + "");
String cS = databaseConnector.getCurrentQueryResult().getData()[0][0]; String cS = databaseConnector.getCurrentQueryResult().getData()[0][0];
send("current Streak: " + cS); send("current Streak: " + cS);
databaseConnector.executeStatement("SELECT maxStreak FROM User Where name like " + tempLoginName + ""); databaseConnector.executeStatement("SELECT maxStreak FROM User Where name like " + tempLoginName + "");
String mS = databaseConnector.getCurrentQueryResult().getData()[0][0]; String mS = databaseConnector.getCurrentQueryResult().getData()[0][0];
send("max Streak: " + mS); send("max Streak: " + mS);
databaseConnector.executeStatement("SELECT wonInTurn1 FROM User Where name like " + tempLoginName + ""); databaseConnector.executeStatement("SELECT wonInTurn1 FROM User Where name like " + tempLoginName + "");
String wIT1 = databaseConnector.getCurrentQueryResult().getData()[0][0]; String wIT1 = databaseConnector.getCurrentQueryResult().getData()[0][0];
send("won in Turn1: " + wIT1); send("won in Turn1: " + wIT1);
databaseConnector.executeStatement("SELECT wonInTurn1 FROM User Where name like " + tempLoginName + ""); databaseConnector.executeStatement("SELECT wonInTurn1 FROM User Where name like " + tempLoginName + "");
String wIT2 = databaseConnector.getCurrentQueryResult().getData()[0][0]; String wIT2 = databaseConnector.getCurrentQueryResult().getData()[0][0];
send("won in Turn2: " + wIT2); send("won in Turn2: " + wIT2);
databaseConnector.executeStatement("SELECT wonInTurn1 FROM User Where name like " + tempLoginName + ""); databaseConnector.executeStatement("SELECT wonInTurn1 FROM User Where name like " + tempLoginName + "");
String wIT3 = databaseConnector.getCurrentQueryResult().getData()[0][0]; String wIT3 = databaseConnector.getCurrentQueryResult().getData()[0][0];
send("won in Turn3: " + wIT3); send("won in Turn3: " + wIT3);
databaseConnector.executeStatement("SELECT wonInTurn1 FROM User Where name like " + tempLoginName + ""); databaseConnector.executeStatement("SELECT wonInTurn1 FROM User Where name like " + tempLoginName + "");
String wIT4 = databaseConnector.getCurrentQueryResult().getData()[0][0]; String wIT4 = databaseConnector.getCurrentQueryResult().getData()[0][0];
send("won in Turn4: " + wIT4); send("won in Turn4: " + wIT4);
databaseConnector.executeStatement("SELECT wonInTurn1 FROM User Where name like " + tempLoginName + ""); databaseConnector.executeStatement("SELECT wonInTurn1 FROM User Where name like " + tempLoginName + "");
String wIT5 = databaseConnector.getCurrentQueryResult().getData()[0][0]; String wIT5 = databaseConnector.getCurrentQueryResult().getData()[0][0];
send("won in Turn5: " + wIT5); send("won in Turn5: " + wIT5);
databaseConnector.executeStatement("SELECT wonInTurn1 FROM User Where name like " + tempLoginName + ""); databaseConnector.executeStatement("SELECT wonInTurn1 FROM User Where name like " + tempLoginName + "");
String wIT6 = databaseConnector.getCurrentQueryResult().getData()[0][0]; String wIT6 = databaseConnector.getCurrentQueryResult().getData()[0][0];
send("won in Turn6: " + wIT6); send("won in Turn6: " + wIT6);
} else if (msg.startsWith("play")) { } else if (msg.startsWith("play")) {
phase = GAME_PHASE; phase = GAME_PHASE;
} }
} }
private void send(String msg) { private void send(String msg) {
wordleServer.send(ip, port, msg); wordleServer.send(ip, port, msg);
} }
private void sendUniversalError() { private void sendUniversalError() {
send("-ERR command not valid in this state"); send("-ERR command not valid in this state");
} }
private int getWOTDIndex() { private int getWOTDIndex() {
long days = ChronoUnit.DAYS.between(LocalDate.ofEpochDay(0), LocalDate.now()); long days = ChronoUnit.DAYS.between(LocalDate.ofEpochDay(0), LocalDate.now());
int hash = ("" + days).hashCode(); int hash = ("" + days).hashCode();
return hash % 949 + 1; return hash % 949 + 1;
} }
public String getIp() { public String getIp() {
return ip; return ip;
} }
public void setIp(String ip) { public void setIp(String ip) {
this.ip = ip; this.ip = ip;
} }
public int getPort() { public int getPort() {
return port; return port;
} }
public void setPort(int port) { public void setPort(int port) {
this.port = port; this.port = port;
} }
} }