forked from IF-LK-2020/wordle
(Properly) added push and pull Stats
This commit is contained in:
parent
e4037082bd
commit
6c863aa7fc
49
Query.java
49
Query.java
|
@ -1,24 +1,41 @@
|
|||
public class Query {
|
||||
DatabaseConnector db;
|
||||
DatabaseConnector db;
|
||||
|
||||
Query(){
|
||||
db = new DatabaseConnector("", 0, "wordle.db", "", "");
|
||||
}
|
||||
public void pullStats(User user){
|
||||
String[][] r;
|
||||
db.executeStatement("SELECT * FROM user WHERE user LIKE" + user.username);
|
||||
r = db.getCurrentQueryResult().getData();
|
||||
}
|
||||
Query() {
|
||||
db = new DatabaseConnector("", 0, "wordle.db", "", "");
|
||||
}
|
||||
|
||||
public void pushStats(User user){
|
||||
public void pullStats(User user) {
|
||||
String[][] r;
|
||||
db.executeStatement("SELECT * FROM user WHERE user LIKE" + user.username);
|
||||
r = db.getCurrentQueryResult().getData();
|
||||
user.currentStreak = Integer.parseInt(r[1][0]);
|
||||
user.maxStreak = Integer.parseInt(r[2][0]);
|
||||
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 boolean checkLogin(String username, String password) {
|
||||
return false;
|
||||
}
|
||||
|
||||
public String getWord(){
|
||||
return "";
|
||||
}
|
||||
public String getWord() {
|
||||
return "";
|
||||
}
|
||||
}
|
||||
|
|
|
@ -5,79 +5,79 @@ import java.util.HashMap;
|
|||
*/
|
||||
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 ) {
|
||||
new WordleServer();
|
||||
}
|
||||
public static void main(String[] args) {
|
||||
new WordleServer();
|
||||
}
|
||||
|
||||
private DatabaseConnector db;
|
||||
|
||||
private DatabaseConnector db;
|
||||
private HashMap<String, User> users;
|
||||
private Query query;
|
||||
|
||||
private HashMap<String,User>users;
|
||||
private Query query;
|
||||
public WordleServer() {
|
||||
this(DEFAULT_PORT);
|
||||
}
|
||||
|
||||
public WordleServer(int pPort) {
|
||||
super(pPort);
|
||||
query = new Query();
|
||||
db = new DatabaseConnector("", 0, "wordle.db", "", "");
|
||||
users = new HashMap<>();
|
||||
}
|
||||
|
||||
public WordleServer() {
|
||||
this(DEFAULT_PORT);
|
||||
}
|
||||
@Override
|
||||
public void processNewConnection(String pClientIP, int pClientPort) {
|
||||
String connectionID = pClientIP + ":" + Integer.toString(pClientPort);
|
||||
User u = new User(connectionID);
|
||||
users.put(connectionID, u);
|
||||
send(pClientIP, pClientPort, "+OK Verbindung zum Wordle Server erfolgreich aufgebaut");
|
||||
u.setState(1);
|
||||
|
||||
public WordleServer( int pPort ) {
|
||||
super(pPort);
|
||||
query = new Query();
|
||||
db = new DatabaseConnector("", 0, "wordle.db", "", "");
|
||||
users = new HashMap<>();
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
public void processNewConnection( String pClientIP, int pClientPort ) {
|
||||
String connectionID= pClientIP +":"+ Integer.toString(pClientPort);
|
||||
User u = new User(connectionID);
|
||||
users.put(connectionID,u);
|
||||
send(pClientIP,pClientPort,"+OK Verbindung zum Wordle Server erfolgreich aufgebaut");
|
||||
u.setState(1);
|
||||
@Override
|
||||
public void processClosingConnection(String pClientIP, int pClientPort) {
|
||||
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
public void processClosingConnection( String pClientIP, int pClientPort ) {
|
||||
@Override
|
||||
public void processMessage(String pClientIP, int pClientPort, String pMessage) {
|
||||
String conectionID = pClientIP + ":" + Integer.toString(pClientPort);
|
||||
User u = users.get(conectionID);
|
||||
|
||||
if (pMessage.equals("QUIT")) {
|
||||
send(pClientIP, pClientPort, "+OK Bye");
|
||||
close();
|
||||
} else {
|
||||
send(pClientIP, pClientPort, "-ERR Command not valid in this state");
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
@Override
|
||||
public void processMessage( String pClientIP, int pClientPort, String pMessage ) {
|
||||
String conectionID = pClientIP + ":" + Integer.toString(pClientPort);
|
||||
User u = users.get(conectionID);
|
||||
|
||||
if(pMessage.equals("QUIT")) {
|
||||
send(pClientIP, pClientPort, "+OK Bye");
|
||||
close();
|
||||
} else {
|
||||
send(pClientIP,pClientPort,"-ERR Command not valid in this state");
|
||||
}
|
||||
|
||||
switch(u.getState()){
|
||||
case 1:
|
||||
//Anmeldephase
|
||||
String m = pMessage.substring(0,3);
|
||||
if(m.equalsIgnoreCase("USER")){
|
||||
m = pMessage.substring(6,pMessage.length()-1);
|
||||
u.setUsername(m);
|
||||
} else if(m.equalsIgnoreCase("PASS")){
|
||||
m = pMessage.substring(6,pMessage.length()-1);
|
||||
u.setPassword(m);
|
||||
}
|
||||
break;
|
||||
case 2:
|
||||
//Spielphase
|
||||
break;
|
||||
case 3:
|
||||
//Zwischenphase(Angemeldet)
|
||||
break;
|
||||
|
||||
}
|
||||
}
|
||||
switch (u.getState()) {
|
||||
case 1:
|
||||
// Anmeldephase
|
||||
String m = pMessage.substring(0, 3);
|
||||
if (m.equalsIgnoreCase("USER")) {
|
||||
m = pMessage.substring(6, pMessage.length() - 1);
|
||||
u.setUsername(m);
|
||||
send(pClientIP, pClientPort, "+OK Bye");
|
||||
} else if (m.equalsIgnoreCase("PASS")) {
|
||||
m = pMessage.substring(6, pMessage.length() - 1);
|
||||
u.setPassword(m);
|
||||
if (u.getPassword() != null && u.getUsername() != null) {
|
||||
query.checkLogin(u.getUsername(), u.getPassword());
|
||||
}
|
||||
}
|
||||
break;
|
||||
case 2:
|
||||
// Spielphase
|
||||
break;
|
||||
case 3:
|
||||
// Zwischenphase(Angemeldet)
|
||||
break;
|
||||
|
||||
}
|
||||
}
|
||||
|
||||
}
|
||||
|
|
Loading…
Reference in New Issue