ZU VIEL gemacht

Mein Brain ist kaputt
This commit is contained in:
2022-03-25 19:06:43 +01:00
parent 018ffd987d
commit 556ae98e3b
5 changed files with 205 additions and 129 deletions

141
Game.java
View File

@@ -1,15 +1,15 @@
public class Game { public class Game {
private String word; private String word;
private String[] guesses; private String[] guesses;
private int guessCount;
// 0 wenn es keinen Wert gibt, 1 wenn das letzte Spiel gewonnen wurde und 2 wenn // 0 wenn es keinen Wert gibt, 1 wenn das letzte Spiel gewonnen wurde und 2 wenn
// es verloren wurde // es verloren wurde
private int won; private int won;
// TODO:
Game() { Game() {
word = ""; word = "";
won = 0; won = 0;
guesses = new String[4]; guesses = new String[5];
} }
/** /**
@@ -23,106 +23,131 @@ public class Game {
* @return Eine Zahlenfolge mit der Korrektheit des Worts * @return Eine Zahlenfolge mit der Korrektheit des Worts
*/ */
public String giveGuess(String g) { public String giveGuess(String g) {
StringBuilder guess = new StringBuilder(g); String[] guess = transformToArray(g);
StringBuilder word = new StringBuilder(this.word); String[] word = transformToArray(this.word);
String s = ""; String s = "";
for (int i = 0; i < this.word.length(); i++) { if (word.length == 5 && guess.length == 5) {
if (guess.charAt(0) == word.charAt(0)) { for (int i = 0; i < this.word.length(); i++) {
word.deleteCharAt(0); if (guess[i].equalsIgnoreCase(word[i])) {
s += "2"; word[i] = null;
} else { s += "2";
boolean found = false; } else {
for (int r = 1; r < word.length(); r++) { boolean found = false;
if (guess.charAt(0) == word.charAt(r)) { for (int r = 0; r < word.length; r++) {
s += "1"; if (guess[i].equalsIgnoreCase(word[r]) && (guess[r] == null || !guess[r].equals(word[r]))) {
found = true; s += "1";
word.deleteCharAt(r); found = true;
break; word[r] = null;
break;
}
}
if (!found) {
s += "0";
} }
} }
if (!found) { guess[i] = null;
s += "0"; }
} guessCount++;
storeInArray(g);
if (s.contains("22222")) {
won = 1;
stopGame();
} else if (guessCount >= 6) {
won = 2;
stopGame();
} }
guess.deleteCharAt(0);
}
if (word.isEmpty()) {
won = 1;
stopGame();
} else if (storeInArray(guess.toString())) {
won = 2;
stopGame();
} }
return s; return s;
} }
private String[] transformToArray(String s) {
String[] temp = new String[s.length()];
for (int i = 0; i < s.length(); i++) {
temp[i] = "" + s.charAt(i);
}
return temp;
}
public String checkGuess(String g) { public String checkGuess(String g) {
StringBuilder guess = new StringBuilder(g); String[] guess = transformToArray(g);
StringBuilder word = new StringBuilder(this.word); String[] word = transformToArray(this.word);
String s = ""; String s = "";
for (int i = 0; i < this.word.length(); i++) { if (word.length == 5 && guess.length == 5) {
if (guess.charAt(0) == word.charAt(0)) { for (int i = 0; i < this.word.length(); i++) {
word.deleteCharAt(0); if (guess[i].equalsIgnoreCase(word[i])) {
s += "2"; word[i] = null;
} else { s += "2";
boolean found = false; } else {
for (int r = 1; r < word.length(); r++) { boolean found = false;
if (guess.charAt(0) == word.charAt(r)) { for (int r = 0; r < word.length; r++) {
s += "1"; if (guess[i].equalsIgnoreCase(word[r]) && (guess[r] == null || !guess[r].equals(word[r]))) {
found = true; s += "1";
word.deleteCharAt(r); found = true;
break; word[r] = null;
break;
}
}
if (!found) {
s += "0";
} }
} }
if (!found) { guess[i] = null;
s += "0";
}
} }
guess.deleteCharAt(0);
} }
return s; return s;
} }
/** /**
* Speichert das Wort in der nächsten freien Stelle im Array und gibt danach * Speichert das Wort in der nächsten freien Stelle im Array und gibt danach
* zurück, ob das Array voll ist * zurück, ob das Array voll ist, d.h. das Spiel beendet werden muss
* *
* @param word * @param word
* @return Boolean * @return Boolean
*/ */
private boolean storeInArray(String word) { private void storeInArray(String word) {
for (int i = 0; i < guesses.length; i++) { for (int i = 0; i < guesses.length; i++) {
if (guesses[i] == null) { if (guesses[i] == null) {
guesses[i] = word; guesses[i] = word;
return false; break;
} }
} }
return true;
} }
public void startGame(String word) { public void startGame(String word) {
System.out.println(word);
guessCount = 0;
this.word = word; this.word = word;
} }
public boolean isGameRunning() {
return !word.equals("") || !word.equals(null);
}
public void stopGame() { public void stopGame() {
word = ""; word = "";
guesses = new String[guesses.length - 1]; guesses = new String[guesses.length];
} }
public String[] getGuesses() { public String[] getGuesses() {
return guesses; return guesses;
} }
public void setGuesses(String[] guesses) { public String getGuessIndex(int index) {
this.guesses = guesses; return guesses[index];
}
public void setGuessesIndex(String guess, int index) {
guesses[index] = guess;
} }
public void setWord(String word) { public void setWord(String word) {
this.word = word; if (word != null) {
this.word = word;
}
}
public String getWord() {
return word;
}
public int getGuessesCount() {
return guessCount;
} }
/** /**

View File

@@ -1,3 +1,7 @@
import java.time.LocalDate;
import java.time.temporal.ChronoUnit;
import java.util.Random;
public class Query { public class Query {
DatabaseConnector db; DatabaseConnector db;
@@ -12,24 +16,36 @@ public class Query {
*/ */
public void pullStats(User user) { public void pullStats(User user) {
String[][] r; String[][] r;
db.executeStatement("SELECT * FROM user WHERE user LIKE '"+ user.getUsername() + "'"); db.executeStatement("SELECT * FROM Stats " + "INNER JOIN won_on_n " + "ON Stats.ID = won_on_n.Stats_ID "
+ "INNER JOIN last_Game " + "ON Stats.ID = last_Game.Stats_ID " + "WHERE user_username = '"
+ user.getUsername() + "'");
r = db.getCurrentQueryResult().getData(); r = db.getCurrentQueryResult().getData();
user.setCurrentStreak(Integer.parseInt(r[1][0])); if (r != null && r.length != 0 && r[0].length == 21) {
user.setMaxStreak(Integer.parseInt(r[2][0])); user.setCurrentStreak(Integer.parseInt(r[0][2]));
user.setWins(Integer.parseInt(r[3][0])); user.setMaxStreak(Integer.parseInt(r[0][3]));
user.setTimesPlayed(Integer.parseInt(r[4][0])); user.setWinPercentage(Float.parseFloat(r[0][4]));
user.setTimesPlayed(Integer.parseInt(r[0][5]));
user.setLastDayWOTDPlayed(Integer.parseInt(r[0][6]));
int wonInTurn[] = new int[6]; for (int i = 0; i < 6; i++) {
wonInTurn[0] = Integer.parseInt(r[5][0]); try {
wonInTurn[1] = Integer.parseInt(r[6][0]); user.setWonInTurnIndex(Integer.parseInt(r[0][8 + i]), i);
wonInTurn[2] = Integer.parseInt(r[7][0]); } catch (NumberFormatException e) {
wonInTurn[3] = Integer.parseInt(r[8][0]); user.setWonInTurnIndex(0, i);
wonInTurn[4] = Integer.parseInt(r[9][0]); }
wonInTurn[5] = Integer.parseInt(r[10][0]); }
user.setWonInTurn(wonInTurn);
user.setLastDayWOTDPlayed(Integer.parseInt(r[11][0]));
for (int i = 0; i < 5; i++) {
try {
user.setWonInTurnIndex(Integer.parseInt(r[0][8 + i]), i);
} catch (NumberFormatException e) {
user.getGame().setGuessesIndex(r[0][15 + i], i);
}
}
user.getGame().setWord(r[0][20]);
} else {
System.out.println("Fehler beim Abfragen der Daten für den User " + user.getUsername());
}
} }
/** /**
@@ -38,16 +54,22 @@ public class Query {
* @param user * @param user
*/ */
public void pushStats(User user) { public void pushStats(User user) {
// TODO: Testen und vllt korrigieren db.executeStatement("UPDATE Stats SET current_streak = " + user.getCurrentStreak() + ", max_streak = "
db.executeStatement("UPDATE INTO Stats (current_streak," + " max_streak, " + "wins, " + "times_played, " + user.getMaxStreak() + ", win_percentage = " + user.getWinPercentage() + ", times_played = "
+ "won_on_1, " + "won_on_2, " + "won_on_3, " + "won_on_4, " + "won_on_5, " + "won_on_6, " + user.getTimesPlayed() + ", last_day_WOTD_finished = " + user.getLastDayWOTDPlayed()
+ "last_day_WOTD_finished) " + "VALUES (" + Integer.toString(user.getCurrentStreak()) + " WHERE user_username LIKE '" + user.getUsername() + "'");
+ Integer.toString(user.getMaxStreak()) + Integer.toString(user.getWins()) db.executeStatement("UPDATE won_on_n SET won_on_1 = " + user.getWonInTurnIndex(0) + ", won_on_2 = "
+ Integer.toString(user.getTimesPlayed()) + Integer.toString(user.getWonInTurnIndex(0)) + user.getWonInTurnIndex(1) + ", won_on_3 = " + user.getWonInTurnIndex(2) + ", won_on_4 = "
+ Integer.toString(user.getWonInTurnIndex(1)) + Integer.toString(user.getWonInTurnIndex(2)) + user.getWonInTurnIndex(3) + ", won_on_5 = " + user.getWonInTurnIndex(4) + ", won_on_6 = "
+ Integer.toString(user.getWonInTurnIndex(3)) + Integer.toString(user.getWonInTurnIndex(4)) + user.getWonInTurnIndex(5)
+ Integer.toString(user.getWonInTurnIndex(5)) + Integer.toString(user.getLastDayWOTDPlayed()) + ")" + " WHERE Stats_ID IN( SELECT user_username FROM Stats WHERE user_username LIKE '" + user.getUsername()
+ "WHERE user_username LIKE \"" + user.getUsername() + "\""); + "')");
db.executeStatement("UPDATE last_Game SET last_guess_1 = " + user.getGame().getGuessIndex(0) + ", last_guess_2 = "
+ user.getGame().getGuessIndex(1) + ", last_guess_3 = " + user.getGame().getGuessIndex(2)
+ ", last_guess_4 = " + user.getGame().getGuessIndex(3) + ", last_guess_5 = "
+ user.getGame().getGuessIndex(4) + ", word = " + user.getGame().getWord()
+ " WHERE Stats_ID IN( SELECT user_username FROM Stats WHERE user_username LIKE '" + user.getUsername()
+ "')");
} }
/** /**
@@ -63,7 +85,6 @@ public class Query {
db.executeStatement("SELECT 1 FROM user WHERE username LIKE \"" + username + "\" " + "AND passwort LIKE \"" db.executeStatement("SELECT 1 FROM user WHERE username LIKE \"" + username + "\" " + "AND passwort LIKE \""
+ password + "\""); + password + "\"");
QueryResult r = db.getCurrentQueryResult(); QueryResult r = db.getCurrentQueryResult();
System.out.println(db.getErrorMessage());
if (r != null && r.getRowCount() == 1) { if (r != null && r.getRowCount() == 1) {
return true; return true;
} else { } else {
@@ -77,19 +98,27 @@ public class Query {
* @return Ein Word als String * @return Ein Word als String
*/ */
public String getWord() { public String getWord() {
// TODO: Methode fertigstellen db.executeStatement("SELECT word FROM words ORDER BY random() LIMIT 1");
return "12345"; String[][] s = db.getCurrentQueryResult().getData();
return s[0][0];
} }
/** /**
* Gibt das Wordle des Tages, welches aus der Datenbank stammt, zur�ck. Ergibt * Gibt das Wordle des Tages, welches aus der Datenbank stammt, zur�ck. Ergibt
* pro Tag immer das gleiche Wordle. * pro Tag immer das gleiche Wordle, aber trotzdem für jeden neuen Tag ein anderes Wort
* *
* @return Das Wort als String * @return Das Wort als String
*/ */
public String getWOTD() { public String getWOTD() {
// TODO: Methode fertigstellen db.executeStatement("SELECT COUNT(*) FROM words");
return "abcde"; String [][] r = db.getCurrentQueryResult().getData();
int words = Integer.parseInt(r[0][0]);
Random random = new Random();
random.setSeed((int) ChronoUnit.DAYS.between(LocalDate.ofEpochDay(0), LocalDate.now()));
int randNumber = random.nextInt() % words;
db.executeStatement("SELECT word FROM words WHERE ID LIKE '" + randNumber + "'");
r = db.getCurrentQueryResult().getData();
return r[0][0];
} }
/** /**
@@ -99,7 +128,8 @@ public class Query {
* @return Boolean * @return Boolean
*/ */
public boolean checkWord(String word) { public boolean checkWord(String word) {
// TODO: Methode fertigstellen db.executeStatement("SELECT 1 FROM words WHERE word LIKE '" + word + "'");
return true; String[][] r = db.getCurrentQueryResult().getData();
return r.length != 0;
} }
} }

View File

@@ -6,18 +6,18 @@ public class User {
private String username; private String username;
private String password; private String password;
private int timesPlayed; private int timesPlayed;
private int winPercentage; private float winPercentage;
private int currentStreak; private int currentStreak;
private int maxStreak; private int maxStreak;
private int lastDayWOTDPlayed; private int lastDayWOTDPlayed;
private int state; private int state;
private int wins;
private int[] wonInTurn; private int[] wonInTurn;
private Game game; private Game game;
public User(String pConnectionID) { public User(String pConnectionID) {
connectionID = pConnectionID; connectionID = pConnectionID;
game = new Game(); game = new Game();
wonInTurn = new int[6];
} }
public Game getGame() { public Game getGame() {
@@ -48,11 +48,7 @@ public class User {
return state; return state;
} }
public void setWins(int wins) { public float getWinPercentage() {
this.wins = wins;
}
public int getWinPercentage() {
return winPercentage; return winPercentage;
} }
@@ -72,10 +68,6 @@ public class User {
return username; return username;
} }
public int getWins() {
return wins;
}
public void setConnectionID(String connectionID) { public void setConnectionID(String connectionID) {
this.connectionID = connectionID; this.connectionID = connectionID;
} }
@@ -108,29 +100,29 @@ public class User {
this.username = username; this.username = username;
} }
public void setWinPercentage(int winPercentage) { public void setWinPercentage(float winPercentage) {
this.winPercentage = winPercentage; this.winPercentage = winPercentage;
} }
public void setWonInTurnIndex(int index, int content) { public void setWonInTurnIndex(int content, int index) {
this.wonInTurn[index] = content; wonInTurn[index] = content;
} }
public void setWonInTurn(int[] wonInTurn) { public void increaseWonInTurnIndex(int index) {
this.wonInTurn = wonInTurn; wonInTurn[index]++;
} }
public boolean loggedIn() { public boolean loggedIn() {
return password != null && username != null; if (password != null && username != null) {
return (!password.equals("") && !username.equals(""));
} else {
return false;
}
} }
public String[] getLastGuesses() { public String[] getLastGuesses() {
return game.getGuesses(); return game.getGuesses();
} }
public void setLastGuesses(String[] guesses) {
game.setGuesses(guesses);
}
public void setLastDayWOTDPlayed(int time) { public void setLastDayWOTDPlayed(int time) {
lastDayWOTDPlayed = time; lastDayWOTDPlayed = time;

View File

@@ -1,4 +1,3 @@
import java.time.Instant;
import java.time.LocalDate; import java.time.LocalDate;
import java.time.temporal.ChronoUnit; import java.time.temporal.ChronoUnit;
import java.util.HashMap; import java.util.HashMap;
@@ -63,11 +62,11 @@ public class WordleServer extends Server {
switch (u.getState()) { switch (u.getState()) {
case 1: case 1:
// Anmeldephase // Anmeldephase
if (m.equalsIgnoreCase("USER")) { if (m.equalsIgnoreCase("USER") && !u.loggedIn()) {
m = pMessage.substring(5, pMessage.length()); m = pMessage.substring(5, pMessage.length());
u.setUsername(m); u.setUsername(m);
send(pClientIP, pClientPort, "+OK"); send(pClientIP, pClientPort, "+OK");
} else if (m.equalsIgnoreCase("PASS")) { } else if (m.equalsIgnoreCase("PASS") && !u.loggedIn()) {
m = pMessage.substring(5, pMessage.length()); m = pMessage.substring(5, pMessage.length());
u.setPassword(m); u.setPassword(m);
if (u.getPassword() != null && u.getUsername() != null) { if (u.getPassword() != null && u.getUsername() != null) {
@@ -93,6 +92,14 @@ public class WordleServer extends Server {
} else { } else {
send(pClientIP, pClientPort, "-ERR game finished"); send(pClientIP, pClientPort, "-ERR game finished");
} }
} else if (m.equalsIgnoreCase("PLAY")) {
if (isToday(u.getLastDayWOTDPlayed()) && u.getGame().getGameStatus() != 1) {
u.getGame().startGame(query.getWord());
u.setState(2);
send(pClientIP, pClientPort, "+OK Game ready");
} else {
send(pClientIP, pClientPort, "-ERR wotd not finished");
}
} else { } else {
send(pClientIP, pClientPort, "-ERR Command not valid in this state"); send(pClientIP, pClientPort, "-ERR Command not valid in this state");
} }
@@ -110,12 +117,15 @@ public class WordleServer extends Server {
break; break;
case (2): case (2):
a += " game won"; a += " game won";
u.increaseWonInTurnIndex(u.getGame().getGuessesCount() - 1);
u.setState(3); u.setState(3);
break; break;
case (3): case (3):
a += " game lost"; a += " game lost";
u.setState(3); u.setState(3);
break; break;
default:
a += " what";
} }
send(pClientIP, pClientPort, a); send(pClientIP, pClientPort, a);
} else { } else {
@@ -125,27 +135,35 @@ public class WordleServer extends Server {
send(pClientIP, pClientPort, "-ERR wrong format"); send(pClientIP, pClientPort, "-ERR wrong format");
} }
} else if (m.equalsIgnoreCase("INFO")) { } else if (m.equalsIgnoreCase("INFO")) {
bruh();
String substring = "0"; String substring = "0";
if (m.length() > 4) { if (pMessage.length() > 4) {
substring += pMessage.substring(5, pMessage.length()).replaceAll(" ", ""); substring += pMessage.substring(4, pMessage.length()).replaceAll(" ", "");
} }
int n = Integer.parseInt("0" + substring); int n = Integer.parseInt("0" + substring);
String[] guesses = u.getGame().getGuesses(); String[] guesses = u.getGame().getGuesses();
if (6 >= n && n >= 1) { if (6 >= n && n >= 1) {
String guess = guesses[n]; //TODO:
send(pClientIP, pClientPort, "+OK " + guess + " " + u.getGame().checkGuess(guess)); if (guesses[n - 1] != null) {
String guess = guesses[n - 1];
send(pClientIP, pClientPort, "+OK " + guess + " " + u.getGame().checkGuess(guess));
} else {
send(pClientIP, pClientPort, "-ERR word not typed yet");
}
} else if (n == 0) { } else if (n == 0) {
String a = "+OK "; String a = "+OK ";
for (int i = 0; i < 6; i++) { for (int i = 0; i < 5; i++) {
if (guesses[i] == null) { if (guesses[i] != null) {
a += guesses[i] + " " + u.getGame().checkGuess(guesses[i]); a += " " + guesses[i] + " " + u.getGame().checkGuess(guesses[i]);
} }
} }
send(pClientIP, pClientPort, a); send(pClientIP, pClientPort, a);
} }
} else if (m.equalsIgnoreCase("EXIT")) { } else if (m.equalsIgnoreCase("EXIT")) {
u.updateLastDayWOTDPlayed();
u.getGame().stopGame(); u.getGame().stopGame();
u.setState(3); u.setState(3);
send(pClientIP, pClientPort, "+OK");
} else { } else {
send(pClientIP, pClientPort, "-ERR Command not valid in this state"); send(pClientIP, pClientPort, "-ERR Command not valid in this state");
} }
@@ -154,13 +172,13 @@ public class WordleServer extends Server {
// Zwischenphase(Angemeldet) // Zwischenphase(Angemeldet)
if (m.equalsIgnoreCase("STAT")) { if (m.equalsIgnoreCase("STAT")) {
send(pClientIP, pClientPort, send(pClientIP, pClientPort,
"+OK" + '\n' + "times played: " + u.getTimesPlayed() + '\n' + "win percentage: " "+OK" + '\n' + "times played: " + u.getTimesPlayed() + "\n" + "win percentage: "
+ u.getWinPercentage() + '\n' + "current streak: " + u.getCurrentStreak() + '\n' + u.getWinPercentage() + "\n" + "current streak: " + u.getCurrentStreak() + "\n"
+ "max streak: " + u.getMaxStreak() + '\n' + "won in 1 turn: " + "max streak: " + u.getMaxStreak() + "\n" + "won in 1 turn: "
+ u.getWonInTurnIndex(1) + '\n' + "won in 2 turn: " + u.getWonInTurnIndex(2) + '\n' + u.getWonInTurnIndex(0) + "\n" + "won in 2 turn: " + u.getWonInTurnIndex(1) + "\n"
+ "won in 3 turn: " + u.getWonInTurnIndex(3) + '\n' + "won in 4 turn: " + "won in 3 turn: " + u.getWonInTurnIndex(2) + "\n" + "won in 4 turn: "
+ u.getWonInTurnIndex(4) + '\n' + "won in 5 turn: " + u.getWonInTurnIndex(5) + '\n' + u.getWonInTurnIndex(3) + "\n" + "won in 5 turn: " + u.getWonInTurnIndex(4) + "\n"
+ "won in 6 turn: " + u.getWonInTurnIndex(6) + '\n' + "."); + "won in 6 turn: " + u.getWonInTurnIndex(5) + "\n" + ".");
} else if (m.equalsIgnoreCase("PLAY")) { } else if (m.equalsIgnoreCase("PLAY")) {
if (isToday(u.getLastDayWOTDPlayed()) && u.getGame().getGameStatus() != 1) { if (isToday(u.getLastDayWOTDPlayed()) && u.getGame().getGameStatus() != 1) {
u.getGame().startGame(query.getWord()); u.getGame().startGame(query.getWord());
@@ -178,7 +196,18 @@ public class WordleServer extends Server {
} }
/**
* Gibt zurück ob es sich bei dem im Parameter angegebenen Tag um den heutigen
* handelt
*
* @param pDay ,die Anzahl der Tage seit dem Epoch-Day
* @return true oder false
*/
public boolean isToday(int pDay) { public boolean isToday(int pDay) {
return pDay == (int) ChronoUnit.DAYS.between(LocalDate.ofEpochDay(0), LocalDate.now()); return pDay == (int) ChronoUnit.DAYS.between(LocalDate.ofEpochDay(0), LocalDate.now());
} }
public void bruh() {
}
} }

BIN
wordle.db

Binary file not shown.