Merge branch 'Mick'
* Mick: Abbreviated Connect function into the listen function on the sessionController
This commit is contained in:
@@ -6,8 +6,6 @@ import netwerkprog.game.server.data.DataParser;
|
|||||||
import netwerkprog.game.util.Controller;
|
import netwerkprog.game.util.Controller;
|
||||||
import netwerkprog.game.util.ServerData;
|
import netwerkprog.game.util.ServerData;
|
||||||
|
|
||||||
import java.io.DataInputStream;
|
|
||||||
import java.io.DataOutputStream;
|
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
import java.net.ServerSocket;
|
import java.net.ServerSocket;
|
||||||
import java.net.Socket;
|
import java.net.Socket;
|
||||||
@@ -19,43 +17,44 @@ public class SessionController extends Controller {
|
|||||||
private DataParser parser;
|
private DataParser parser;
|
||||||
private ArrayList<ServerClient> clients = new ArrayList<>();
|
private ArrayList<ServerClient> clients = new ArrayList<>();
|
||||||
private HashMap<String, Thread> clientThreads = new HashMap<>();
|
private HashMap<String, Thread> clientThreads = new HashMap<>();
|
||||||
|
private boolean listening;
|
||||||
|
|
||||||
public SessionController() {
|
public SessionController() {
|
||||||
|
this.listening = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
public void connect() {
|
// public void connect() {
|
||||||
try {
|
// try {
|
||||||
this.serverSocket = new ServerSocket(ServerData.port());
|
// this.serverSocket = new ServerSocket(ServerData.port());
|
||||||
System.out.println("[SERVER] listening on port " + ServerData.port());
|
// System.out.println("[SERVER] listening on port " + ServerData.port());
|
||||||
Socket socket = serverSocket.accept();
|
// Socket socket = serverSocket.accept();
|
||||||
|
//
|
||||||
System.out.println("[SERVER] got new client on " + socket.getInetAddress().getHostAddress());
|
// System.out.println("[SERVER] got new client on " + socket.getInetAddress().getHostAddress());
|
||||||
DataOutputStream outputStream = new DataOutputStream(socket.getOutputStream());
|
// DataOutputStream outputStream = new DataOutputStream(socket.getOutputStream());
|
||||||
DataInputStream inputStream = new DataInputStream(socket.getInputStream());
|
// DataInputStream inputStream = new DataInputStream(socket.getInputStream());
|
||||||
|
//
|
||||||
outputStream.writeUTF("Enter username: ");
|
// outputStream.writeUTF("Enter username: ");
|
||||||
String username = inputStream.readUTF();
|
// String username = inputStream.readUTF();
|
||||||
|
//
|
||||||
System.out.println("[SERVER] got username " + username);
|
// System.out.println("[SERVER] got username " + username);
|
||||||
ServerClient serverClient = new ServerClient(username, socket, this);
|
// ServerClient serverClient = new ServerClient(username, socket, this);
|
||||||
|
//
|
||||||
Thread t = new Thread(serverClient);
|
// Thread t = new Thread(serverClient);
|
||||||
t.start();
|
// t.start();
|
||||||
|
//
|
||||||
clientThreads.put(username, t);
|
// clientThreads.put(username, t);
|
||||||
this.clients.add(serverClient);
|
// this.clients.add(serverClient);
|
||||||
|
//
|
||||||
sendMessage(username, "--- Welcome! ---\nPeople online : " + clients.size());
|
// sendMessage(username, "--- Welcome! ---\nPeople online : " + clients.size());
|
||||||
|
//
|
||||||
clients.forEach(yeet -> sendToEveryoneExcept(username, username + " joined the server! [" + socket.getInetAddress().getHostAddress() + "]"));
|
// clients.forEach(yeet -> sendToEveryoneExcept(username, username + " joined the server! [" + socket.getInetAddress().getHostAddress() + "]"));
|
||||||
|
//
|
||||||
|
//
|
||||||
this.serverSocket.close();
|
// this.serverSocket.close();
|
||||||
} catch (IOException e) {
|
// } catch (IOException e) {
|
||||||
e.printStackTrace();
|
// e.printStackTrace();
|
||||||
}
|
// }
|
||||||
}
|
// }
|
||||||
|
|
||||||
public void sendToEveryone(String text) {
|
public void sendToEveryone(String text) {
|
||||||
for (ServerClient serverClient : clients) {
|
for (ServerClient serverClient : clients) {
|
||||||
@@ -92,21 +91,21 @@ public class SessionController extends Controller {
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void run() {
|
public void run() {
|
||||||
boolean running = true;
|
while (listening) {
|
||||||
while (running) {
|
listen();
|
||||||
System.out.println("Session thread active.");
|
|
||||||
connect();
|
|
||||||
|
|
||||||
try {
|
|
||||||
Thread.sleep(1000);
|
|
||||||
} catch (InterruptedException e) {
|
|
||||||
e.printStackTrace();
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public void listen() {
|
public void listen() {
|
||||||
|
try {
|
||||||
|
this.serverSocket = new ServerSocket(ServerData.port());
|
||||||
|
System.out.println("[SERVER] listening on port " + ServerData.port());
|
||||||
|
Socket socket = serverSocket.accept();
|
||||||
|
this.serverSocket.close();
|
||||||
|
|
||||||
|
} catch (IOException ex) {
|
||||||
|
ex.printStackTrace();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
//will most likely be removed.
|
//will most likely be removed.
|
||||||
|
|||||||
Reference in New Issue
Block a user