(Properly) added push and pull Stats

This commit is contained in:
Maxim Derksen
2022-03-03 11:20:18 +01:00
parent e4037082bd
commit 6c863aa7fc
2 changed files with 94 additions and 77 deletions

View File

@@ -1,24 +1,41 @@
public class Query { public class Query {
DatabaseConnector db; DatabaseConnector db;
Query(){ Query() {
db = new DatabaseConnector("", 0, "wordle.db", "", ""); db = new DatabaseConnector("", 0, "wordle.db", "", "");
} }
public void pullStats(User user){
public void pullStats(User user) {
String[][] r; String[][] r;
db.executeStatement("SELECT * FROM user WHERE user LIKE" + user.username); db.executeStatement("SELECT * FROM user WHERE user LIKE" + user.username);
r = db.getCurrentQueryResult().getData(); r = db.getCurrentQueryResult().getData();
} user.currentStreak = Integer.parseInt(r[1][0]);
user.maxStreak = Integer.parseInt(r[2][0]);
public void pushStats(User user){ user.wins = Integer.parseInt(r[3][0]);
user.timesPlayed = Integer.parseInt(r[4][0]);
user.wonInTurn[0] = Integer.parseInt(r[5][0]);
user.wonInTurn[1] = Integer.parseInt(r[6][0]);
user.wonInTurn[2] = Integer.parseInt(r[7][0]);
user.wonInTurn[3] = Integer.parseInt(r[8][0]);
user.wonInTurn[4] = Integer.parseInt(r[9][0]);
user.wonInTurn[5] = Integer.parseInt(r[10][0]);
user.lastDayWOTDFinished = Integer.parseInt(r[11][0]);
} }
public void checkLogin(String username, String password){ public void pushStats(User user) {
db.executeStatement("UPDATE INTO Stats (current_streak," + " max_streak, " + "wins, " + "times_played, "
+ "won_on_1, " + "won_on_2, " + "won_on_3, " + "won_on_4, " + "won_on_5, " + "won_on_6, "
+ "last_day_WOTD_finished) " + "VALUES (" + user.currentStreak + user.maxStreak + user.wins
+ user.timesPlayed + user.wonInTurn[0] + user.wonInTurn[1] + user.wonInTurn[2] + user.wonInTurn[3]
+ user.wonInTurn[4] + user.wonInTurn[5] + user.lastDayWOTDFinished + ")");
} }
public String getWord(){ public boolean checkLogin(String username, String password) {
return false;
}
public String getWord() {
return ""; return "";
} }
} }

View File

@@ -7,22 +7,20 @@ public class WordleServer extends Server {
public static final int DEFAULT_PORT = 1000; public static final int DEFAULT_PORT = 1000;
public static void main( String[] args ) { public static void main(String[] args) {
new WordleServer(); new WordleServer();
} }
private DatabaseConnector db; private DatabaseConnector db;
private HashMap<String,User>users; private HashMap<String, User> users;
private Query query; private Query query;
public WordleServer() { public WordleServer() {
this(DEFAULT_PORT); this(DEFAULT_PORT);
} }
public WordleServer( int pPort ) { public WordleServer(int pPort) {
super(pPort); super(pPort);
query = new Query(); query = new Query();
db = new DatabaseConnector("", 0, "wordle.db", "", ""); db = new DatabaseConnector("", 0, "wordle.db", "", "");
@@ -30,54 +28,56 @@ public class WordleServer extends Server {
} }
@Override @Override
public void processNewConnection( String pClientIP, int pClientPort ) { public void processNewConnection(String pClientIP, int pClientPort) {
String connectionID= pClientIP +":"+ Integer.toString(pClientPort); String connectionID = pClientIP + ":" + Integer.toString(pClientPort);
User u = new User(connectionID); User u = new User(connectionID);
users.put(connectionID,u); users.put(connectionID, u);
send(pClientIP,pClientPort,"+OK Verbindung zum Wordle Server erfolgreich aufgebaut"); send(pClientIP, pClientPort, "+OK Verbindung zum Wordle Server erfolgreich aufgebaut");
u.setState(1); u.setState(1);
} }
@Override @Override
public void processClosingConnection( String pClientIP, int pClientPort ) { public void processClosingConnection(String pClientIP, int pClientPort) {
} }
@Override @Override
public void processMessage( String pClientIP, int pClientPort, String pMessage ) { public void processMessage(String pClientIP, int pClientPort, String pMessage) {
String conectionID = pClientIP + ":" + Integer.toString(pClientPort); String conectionID = pClientIP + ":" + Integer.toString(pClientPort);
User u = users.get(conectionID); User u = users.get(conectionID);
if(pMessage.equals("QUIT")) { if (pMessage.equals("QUIT")) {
send(pClientIP, pClientPort, "+OK Bye"); send(pClientIP, pClientPort, "+OK Bye");
close(); close();
} else { } else {
send(pClientIP,pClientPort,"-ERR Command not valid in this state"); send(pClientIP, pClientPort, "-ERR Command not valid in this state");
} }
switch(u.getState()){ switch (u.getState()) {
case 1: case 1:
//Anmeldephase // Anmeldephase
String m = pMessage.substring(0,3); String m = pMessage.substring(0, 3);
if(m.equalsIgnoreCase("USER")){ if (m.equalsIgnoreCase("USER")) {
m = pMessage.substring(6,pMessage.length()-1); m = pMessage.substring(6, pMessage.length() - 1);
u.setUsername(m); u.setUsername(m);
} else if(m.equalsIgnoreCase("PASS")){ send(pClientIP, pClientPort, "+OK Bye");
m = pMessage.substring(6,pMessage.length()-1); } else if (m.equalsIgnoreCase("PASS")) {
m = pMessage.substring(6, pMessage.length() - 1);
u.setPassword(m); u.setPassword(m);
if (u.getPassword() != null && u.getUsername() != null) {
query.checkLogin(u.getUsername(), u.getPassword());
}
} }
break; break;
case 2: case 2:
//Spielphase // Spielphase
break; break;
case 3: case 3:
//Zwischenphase(Angemeldet) // Zwischenphase(Angemeldet)
break; break;
} }
} }
} }