Compare commits

..

10 Commits

Author SHA1 Message Date
Asecave
fc8d803d32 Update wordle.db 2022-03-26 00:38:09 +01:00
Asecave
68549bbc8b IT'S DONE! I think... 2022-03-25 20:45:13 +01:00
Asecave
92d4f15e75 fixed wrong game start message 2022-03-25 20:44:28 +01:00
Asecave
a78fac1baf added info <n> 2022-03-25 20:43:58 +01:00
Asecave
84a81bf2b4 info und saveGame funkt 2022-03-25 20:19:29 +01:00
Asecave
37736dbfad wotd finished requirement to play 2022-03-25 16:27:54 +01:00
Asecave
09ea7ea01e Spielstand wird gespeichert (und gelesen) 2022-03-25 15:42:22 +01:00
Tim Tersch
4d01389e2e working stats 2022-03-24 11:30:17 +01:00
Tim Tersch
f212bed8de fixed sql requests in user and replaced requests 2022-03-24 10:51:19 +01:00
Tim Tersch
93a419f10c removed unused DatabaseConnector 2022-03-24 10:18:31 +01:00
4 changed files with 317 additions and 220 deletions

View File

@@ -1,6 +1,5 @@
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 {
@@ -38,6 +37,8 @@ public class Game {
this.ip = pClientIP; this.ip = pClientIP;
this.port = pClientPort; this.port = pClientPort;
words = new String[5];
send("+OK Hello there"); send("+OK Hello there");
} }
@@ -46,9 +47,11 @@ public class Game {
msg = msg.toLowerCase().trim(); msg = msg.toLowerCase().trim();
if (msg.equals("quit")) { if (msg.equals("quit")) {
if (user != null) {
saveGame();
}
send("+OK bye"); send("+OK bye");
wordleServer.closeConnection(ip, port); wordleServer.closeConnection(ip, port);
System.exit(0); // TODO remove: Einfacher zum testen
} }
switch (phase) { switch (phase) {
@@ -108,7 +111,11 @@ public class Game {
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].toLowerCase();
phase = GAME_PHASE; phase = GAME_PHASE;
if (user != null) {
loadGame();
} else {
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.");
} }
@@ -118,14 +125,15 @@ public class Game {
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)); databaseConnector
.executeStatement("SELECT lastFinishedWotdDay FROM User WHERE name = '" + user.getName() + "'");
QueryResult result = databaseConnector.getCurrentQueryResult(); QueryResult result = databaseConnector.getCurrentQueryResult();
if (result != null && result.getData().length > 0) { if (result != null && result.getData().length > 0) {
wordle = result.getData()[0][0].toLowerCase(); if (result.getData()[0][0] != null && Integer.parseInt(result.getData()[0][0]) == currentDay()) {
phase = GAME_PHASE; playRandomWordle();
send("+OK game ready");
} else { } else {
send("-ERR fatal error: Wordle could not be generated."); send("-ERR WOTD not finished.");
}
} }
} }
} else { } else {
@@ -146,8 +154,180 @@ public class Game {
if (result.getData().length > 0) { if (result.getData().length > 0) {
String input = result.getData()[0][0].toLowerCase(); String input = result.getData()[0][0].toLowerCase();
String code = ""; String code = generateCode(input);
send("+OK " + code);
if (code.equals("22222")) { // und ein wordle ist 5 Buchstaben lang :D
send("game won");
wordle = null;
if (user != null) {
setLastPlayedTimestamp();
user.increaseCurrentStreak();
if (user.getMaxStreak() < user.getCurrentStreak()) {
user.setMaxStreak(user.getCurrentStreak());
}
user.increaseWonInTurn(count + 1);
updateStats();
phase = END_PHASE;
} else {
phase = LOGIN_PHASE;
}
count = 0;
clearWords();
} else if (count == 5) {
send("game lost");
wordle = null;
if (user != null) {
setLastPlayedTimestamp();
user.setCurrentStreak(0);
updateStats();
phase = END_PHASE;
} else {
phase = LOGIN_PHASE;
}
count = 0;
clearWords();
} else {
words[count] = input;
send("game continues");
count++;
}
} else {
send("-ERR word not in dictionary.");
}
} else {
send("-ERR wrong format.");
}
} else if (msg.startsWith("info")) {
if (msg.length() == 4) {
send("+OK");
for (int i = 0; i < words.length; i++) {
if (words[i] == null) {
break;
}
send(words[i] + " " + generateCode(words[i]));
}
send(".");
} else if (msg.length() == 6) {
String rawLine = msg.substring(5);
int line = -1;
try {
line = Integer.parseInt(rawLine) - 1;
} catch (NumberFormatException e) {
send("-ERR wrong argument.");
}
if (line >= 0 && line < 5) {
if (words[line] != null) {
send("+OK " + words[line] + " " + generateCode(words[line]));
} else {
send("-ERR game hasn't progressed to this line yet.");
}
} else {
send("-ERR couldn't parse line.");
}
} else {
sendUniversalError();
}
} else if (msg.startsWith("exit")) {
if (user != null) {
saveGame();
phase = END_PHASE;
send("+OK");
} else {
send("-ERR not logged in.");
}
} else {
sendUniversalError();
}
}
private void endPhase(String msg) {
if (msg.startsWith("stat")) {
send("+OK");
send("times Played: " + user.getTimesPlayed());
send("win Percentage: " + (int) user.getWinPercentage() + "%");
send("current Streak: " + user.getCurrentStreak());
send("max Streak: " + user.getMaxStreak());
for (int i = 1; i <= 6; i++) {
send("won in Turn" + i + ": " + user.getWonInTurn(i));
}
send(".");
} else if (msg.startsWith("play")) {
if (wordle == null) {
playRandomWordle();
} else {
loadGame();
phase = GAME_PHASE;
}
} else {
sendUniversalError();
}
}
private void saveGame() {
databaseConnector.executeStatement("SELECT * FROM Spielstand WHERE Username LIKE '" + user.getName() + "'");
QueryResult result = databaseConnector.getCurrentQueryResult();
if (result == null || result.getData().length == 0) {
databaseConnector.executeStatement("INSERT INTO Spielstand (Username) VALUES('" + user.getName() + "')");
}
for (int i = 0; i < words.length; i++) {
databaseConnector.executeStatement("UPDATE Spielstand SET word" + (i + 1) + " = '" + words[i]
+ "' WHERE Username LIKE '" + user.getName() + "'");
}
}
private void loadGame() {
databaseConnector.executeStatement("SELECT * FROM Spielstand WHERE Username = '" + user.getName() + "'");
QueryResult result = databaseConnector.getCurrentQueryResult();
if (result != null && result.getData().length > 0 && !result.getData()[0][0].equals("null")) {
boolean foundEnd = false;
for (int i = 0; i < 5; i++) {
if (!result.getData()[0][i].equals("null")) {
words[i] = result.getData()[0][i];
} else if (!foundEnd) {
count = i;
foundEnd = true;
}
}
send("+OK game running");
} else {
send("+OK game ready");
}
}
private void setLastPlayedTimestamp() {
databaseConnector.executeStatement(
"UPDATE User SET lastFinishedWotdDay = " + currentDay() + " WHERE name LIKE '" + user.getName() + "'");
}
private void clearWords() {
for (int i = 0; i < words.length; i++) {
words[i] = null;
}
}
private String generateCode(String input) {
String code = "";
outer: for (int i = 0; i < input.length(); i++) { outer: for (int i = 0; i < input.length(); i++) {
char c = input.charAt(i); char c = input.charAt(i);
if (c == wordle.charAt(i)) { if (c == wordle.charAt(i)) {
@@ -162,97 +342,32 @@ public class Game {
code += "0"; code += "0";
} }
} }
return code;
send(code);
if (code.equals("22222")) { // und ein wordle ist 5 Buchstaben lang :D
send("game won");
if (user != null) {
phase = END_PHASE;
} else {
phase = LOGIN_PHASE;
}
} else if (count == 6) {
send("game lost");
if (user != null) {
phase = END_PHASE;
} else {
phase = LOGIN_PHASE;
}
} else {
send("game continues");
} }
} else { private void updateStats() {
send("-ERR word not in dictionary.");
user.increaseTimesPlayed();
int totalWins = 0;
for (int i = 1; i <= 6; i++) {
totalWins += user.getWonInTurn(i);
}
float winP = (float) totalWins / user.getTimesPlayed();
user.setWinPercentage(Math.round(winP * 100));
} }
} else { private void playRandomWordle() {
send("-ERR wrong format.");
}
} else if (msg.startsWith("info")) {
} else if (msg.startsWith("exit")) {
if (user != null) {
phase = END_PHASE;
} else {
send("-ERR not logged in.");
}
} else {
sendUniversalError();
}
}
private void endPhase(String msg) {
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")) {
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; phase = GAME_PHASE;
send("+OK game ready");
} else {
send("-ERR fatal error: Wordle could not be generated.");
} }
} }
@@ -268,11 +383,16 @@ public class Game {
private int getWOTDIndex() { private int getWOTDIndex() {
long days = ChronoUnit.DAYS.between(LocalDate.ofEpochDay(0), LocalDate.now()); int days = currentDay();
int hash = ("" + days).hashCode(); int hash = ("" + days).hashCode();
return hash % 949 + 1; return hash % 949 + 1;
} }
private int currentDay() {
return (int) ChronoUnit.DAYS.between(LocalDate.ofEpochDay(0), LocalDate.now());
}
public String getIp() { public String getIp() {
return ip; return ip;

View File

@@ -5,150 +5,133 @@ public class User {
/** /**
* Konstruktor für Objekte der Klasse User * Konstruktor für Objekte der Klasse User
*/ */
public User(String name) public User(String name) {
{ this.name = name;
setName(name);
} }
public void setPassword(String password) {
Game.databaseConnector
public void setPassword(String password) .executeStatement("UPDATE User SET password = " + password + " Where name LIKE '" + this.name + "'");
{
Game.databaseConnector.executeStatement("UPDATE User SET password = " + password + " Where name = " + this.name);
} }
public String getPassword() {
public String getPassword() Game.databaseConnector.executeStatement("SELECT password FROM User Where name LIKE '" + this.name + "'");
{
Game.databaseConnector.executeStatement("SELECT password FROM User Where name =" + this.name);
String result = Game.databaseConnector.getCurrentQueryResult().getData()[0][0]; String result = Game.databaseConnector.getCurrentQueryResult().getData()[0][0];
return result; return result;
} }
public void setName(String name) {
Game.databaseConnector
public void setName(String name) .executeStatement("UPDATE User SET name = " + name + " Where name LIKE '" + this.name + "'");
{
Game.databaseConnector.executeStatement("UPDATE User SET name = " + name + " Where name = " + this.name);
} }
public String getName() {
public String getName()
{
return name; return name;
} }
public void setWinPercentage(float winPercentage) {
Game.databaseConnector.executeStatement(
public void setWinPercentage(float winPercentage) "UPDATE User SET winPercentage = " + winPercentage + " Where name LIKE '" + this.name + "'");
{
Game.databaseConnector.executeStatement("UPDATE User SET winPercentage = " + winPercentage + " Where name = " + this.name);
} }
public float getWinPercentage() {
public float getWinPercentage() Game.databaseConnector.executeStatement("SELECT winPercentage FROM User Where name LIKE '" + this.name + "'");
{
Game.databaseConnector.executeStatement("SELECT winPercentage FROM User Where name =" + this.name);
String result = Game.databaseConnector.getCurrentQueryResult().getData()[0][0]; String result = Game.databaseConnector.getCurrentQueryResult().getData()[0][0];
if (result == null) {
return 0f;
} else {
return Float.parseFloat(result); return Float.parseFloat(result);
} }
public void setTimesPlayed(int timesPlayed)
{
Game.databaseConnector.executeStatement("UPDATE User SET timesPlayed = " + timesPlayed + " Where name = " + this.name);
} }
public void setTimesPlayed(int timesPlayed) {
Game.databaseConnector.executeStatement(
"UPDATE User SET timesPlayed = " + timesPlayed + " Where name LIKE '" + this.name + "'");
}
public int getTimesPlayed() public int getTimesPlayed() {
{ Game.databaseConnector.executeStatement("SELECT timesPlayed FROM User Where name LIKE '" + this.name + "'");
Game.databaseConnector.executeStatement("SELECT timesPlayed FROM User Where name =" + this.name);
String result = Game.databaseConnector.getCurrentQueryResult().getData()[0][0]; String result = Game.databaseConnector.getCurrentQueryResult().getData()[0][0];
if (result == null) {
return 0;
} else {
return Integer.parseInt(result); return Integer.parseInt(result);
} }
}
public void increaseTimesPlayed() {
public void increaseTimesPlayed()
{
int temp = getTimesPlayed(); int temp = getTimesPlayed();
temp++; temp++;
setTimesPlayed(temp); setTimesPlayed(temp);
} }
public void setCurrentStreak(int currentStreak) {
Game.databaseConnector.executeStatement(
public void setCurrentStreak(int currentStreak) "UPDATE User SET currentStreak = " + currentStreak + " Where name LIKE '" + this.name + "'");
{
Game.databaseConnector.executeStatement("UPDATE User SET currentStreak = " + currentStreak + " Where name = " + this.name);
} }
public int getCurrentStreak() {
public int getCurrentStreak() Game.databaseConnector.executeStatement("SELECT currentStreak FROM User Where name LIKE '" + this.name + "'");
{
Game.databaseConnector.executeStatement("SELECT currentStreak FROM User Where name =" + this.name);
String result = Game.databaseConnector.getCurrentQueryResult().getData()[0][0]; String result = Game.databaseConnector.getCurrentQueryResult().getData()[0][0];
if (result == null) {
return 0;
} else {
return Integer.parseInt(result); return Integer.parseInt(result);
} }
}
public void increaseCurrentStreak() {
public void increaseCurrentStreak()
{
int temp = getCurrentStreak(); int temp = getCurrentStreak();
temp++; temp++;
setCurrentStreak(temp); setCurrentStreak(temp);
} }
public void setMaxStreak(int maxStreak) {
Game.databaseConnector
public void setMaxStreak(int maxStreak) .executeStatement("UPDATE User SET maxStreak = " + maxStreak + " Where name LIKE '" + this.name + "'");
{
Game.databaseConnector.executeStatement("UPDATE User SET maxStreak = " + maxStreak + " Where name = " + this.name);
} }
public int getMaxStreak() {
public int getMaxStreak() Game.databaseConnector.executeStatement("SELECT maxStreak FROM User Where name LIKE '" + this.name + "'");
{
Game.databaseConnector.executeStatement("SELECT maxStreak FROM User Where name =" + this.name);
String result = Game.databaseConnector.getCurrentQueryResult().getData()[0][0]; String result = Game.databaseConnector.getCurrentQueryResult().getData()[0][0];
if (result == null) {
return 0;
} else {
return Integer.parseInt(result); return Integer.parseInt(result);
} }
}
public void increaseMaxStreak() {
public void increaseMaxStreak()
{
int temp = getMaxStreak(); int temp = getMaxStreak();
temp++; temp++;
setMaxStreak(temp); setMaxStreak(temp);
} }
public void setWonInTurn(int row, int value) {
Game.databaseConnector.executeStatement(
public void setWonInTurn(int row, int value) "UPDATE User SET wonInTurn" + row + " = " + value + " Where name LIKE '" + this.name + "'");
{
Game.databaseConnector.executeStatement("UPDATE User SET wonInTurn" + row + " = " + value + " Where name = " + this.name);
} }
public int getWonInTurn(int row) {
public int getWonInTurn(int row) Game.databaseConnector
{ .executeStatement("SELECT wonInTurn" + row + " FROM User Where name LIKE '" + this.name + "'");
Game.databaseConnector.executeStatement("SELECT wonInTurn" + row + " FROM User Where name =" + this.name);
String result = Game.databaseConnector.getCurrentQueryResult().getData()[0][0]; String result = Game.databaseConnector.getCurrentQueryResult().getData()[0][0];
if (result == null) {
return 0;
} else {
return Integer.parseInt(result); return Integer.parseInt(result);
} }
}
public void increaseWonInTurn(int row) public void increaseWonInTurn(int row) {
{
int temp = getWonInTurn(row) + 1; int temp = getWonInTurn(row) + 1;
setWonInTurn(row, temp); setWonInTurn(row, temp);
} }
public int[] getWonInTurnFull() public int[] getWonInTurnFull() {
{ int[] result = { getWonInTurn(1), getWonInTurn(2), getWonInTurn(3), getWonInTurn(4), getWonInTurn(5),
int[] result = {getWonInTurn(1),getWonInTurn(2),getWonInTurn(3),getWonInTurn(4),getWonInTurn(5),getWonInTurn(6)}; getWonInTurn(6) };
return result; return result;
} }
} }

View File

@@ -11,10 +11,6 @@ public class WordleServer extends Server {
new WordleServer(); new WordleServer();
} }
private DatabaseConnector db;
public WordleServer() { public WordleServer() {
this(DEFAULT_PORT); this(DEFAULT_PORT);
} }
@@ -22,8 +18,6 @@ public class WordleServer extends Server {
public WordleServer( int pPort ) { public WordleServer( int pPort ) {
super(pPort); super(pPort);
db = new DatabaseConnector("", 0, "wordle.db", "", "");
games = new List<>(); games = new List<>();
} }

BIN
wordle.db

Binary file not shown.