Start refactoring ClientConnectionHandler.java
ERROR UnsupportedOperationException in ClientMessageList
This commit is contained in:
parent
88d4493cfb
commit
ad13445978
|
@ -6,6 +6,7 @@ import ch.zhaw.pm2.multichat.protocol.NetworkHandler;
|
||||||
import javafx.application.Platform;
|
import javafx.application.Platform;
|
||||||
import javafx.beans.value.ChangeListener;
|
import javafx.beans.value.ChangeListener;
|
||||||
import javafx.beans.value.ObservableValue;
|
import javafx.beans.value.ObservableValue;
|
||||||
|
import javafx.collections.ListChangeListener;
|
||||||
import javafx.event.EventHandler;
|
import javafx.event.EventHandler;
|
||||||
import javafx.fxml.FXML;
|
import javafx.fxml.FXML;
|
||||||
import javafx.scene.control.Button;
|
import javafx.scene.control.Button;
|
||||||
|
@ -41,14 +42,14 @@ public class ChatWindowController {
|
||||||
public void initialize() {
|
public void initialize() {
|
||||||
serverAddressField.setText(NetworkHandler.DEFAULT_ADDRESS.getCanonicalHostName());
|
serverAddressField.setText(NetworkHandler.DEFAULT_ADDRESS.getCanonicalHostName());
|
||||||
serverPortField.setText(String.valueOf(NetworkHandler.DEFAULT_PORT));
|
serverPortField.setText(String.valueOf(NetworkHandler.DEFAULT_PORT));
|
||||||
}
|
this.messages = new ClientMessageList();
|
||||||
|
|
||||||
public void chatWindowController(ClientMessageList messages,ClientConnectionHandler connectionHandler) {
|
messages.getChangedProperty().addListener(new ChangeListener<Boolean>() {
|
||||||
this.connectionHandler = connectionHandler;
|
@Override
|
||||||
this.messages = messages;
|
public void changed(ObservableValue<? extends Boolean> observable, Boolean oldValue, Boolean newValue) {
|
||||||
|
setMessageField(messages.getMessages());
|
||||||
//register changelistener
|
}
|
||||||
startChangeListener();
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
private void applicationClose() {
|
private void applicationClose() {
|
||||||
|
@ -67,23 +68,22 @@ public class ChatWindowController {
|
||||||
private void connect() {
|
private void connect() {
|
||||||
try {
|
try {
|
||||||
messages.clear(); // clear message list
|
messages.clear(); // clear message list
|
||||||
redrawMessageList();
|
|
||||||
startConnectionHandler();
|
startConnectionHandler();
|
||||||
connectionHandler.connect();
|
connectionHandler.connect();
|
||||||
} catch(ChatProtocolException | IOException e) {
|
} catch(ChatProtocolException | IOException e) {
|
||||||
addError(e.getMessage());
|
messages.addMessage(null,null, e.getMessage(), Message.MessageType.ERROR);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private void disconnect() {
|
private void disconnect() {
|
||||||
if (connectionHandler == null) {
|
if (connectionHandler == null) {
|
||||||
addError("No connection handler");
|
messages.addMessage(null,null,"No connection handler", Message.MessageType.ERROR);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
try {
|
try {
|
||||||
connectionHandler.disconnect();
|
connectionHandler.disconnect();
|
||||||
} catch (ChatProtocolException e) {
|
} catch (ChatProtocolException e) {
|
||||||
addError(e.getMessage());
|
messages.addMessage(null,null, e.getMessage(), Message.MessageType.ERROR);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -92,29 +92,33 @@ public class ChatWindowController {
|
||||||
String messageString = messageField.getText().strip();
|
String messageString = messageField.getText().strip();
|
||||||
try {
|
try {
|
||||||
if (connectionHandler == null) {
|
if (connectionHandler == null) {
|
||||||
addError("No connection handler");
|
messages.addMessage(null,null,"No connection handler", Message.MessageType.ERROR);
|
||||||
} else if (!connectionHandler.message(messageString)) {
|
} else if (!connectionHandler.message(messageString)) {
|
||||||
addError("Not a valid message format.");
|
messages.addMessage(null,null,"Not a valid message format.", Message.MessageType.ERROR);
|
||||||
} else {
|
} else {
|
||||||
messageField.clear();
|
messageField.clear();
|
||||||
}
|
}
|
||||||
} catch (ChatProtocolException e) {
|
} catch (ChatProtocolException e) {
|
||||||
addError(e.getMessage());
|
messages.addMessage(null,null, e.getMessage(), Message.MessageType.ERROR);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
//TODO: TEST
|
||||||
@FXML
|
@FXML
|
||||||
private void applyFilter( ) {
|
private void applyFilter( ) {
|
||||||
this.redrawMessageList();
|
messages.getFilteredMessages(filterValue.getText().strip());
|
||||||
}
|
}
|
||||||
|
|
||||||
private void startConnectionHandler() throws IOException {
|
private void startConnectionHandler() throws IOException {
|
||||||
String userName = userNameField.getText();
|
String userName = userNameField.getText();
|
||||||
String serverAddress = serverAddressField.getText();
|
String serverAddress = serverAddressField.getText();
|
||||||
int serverPort = Integer.parseInt(serverPortField.getText());
|
int serverPort = Integer.parseInt(serverPortField.getText());
|
||||||
connectionHandler.openConnection(serverAddress,serverPort,userName);
|
connectionHandler = new ClientConnectionHandler(messages,serverAddress,serverPort,userName);
|
||||||
new Thread(connectionHandler).start();
|
new Thread(connectionHandler).start();
|
||||||
|
|
||||||
|
//register changelistener
|
||||||
|
startChangeListener();
|
||||||
|
|
||||||
// register window close handler
|
// register window close handler
|
||||||
rootPane.getScene().getWindow().addEventHandler(WindowEvent.WINDOW_CLOSE_REQUEST, windowCloseHandler);
|
rootPane.getScene().getWindow().addEventHandler(WindowEvent.WINDOW_CLOSE_REQUEST, windowCloseHandler);
|
||||||
}
|
}
|
||||||
|
@ -175,6 +179,15 @@ public class ChatWindowController {
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public void setMessageField(String message) {
|
||||||
|
Platform.runLater(new Runnable() {
|
||||||
|
@Override
|
||||||
|
public void run() {
|
||||||
|
messageField.setText(message);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
public void setUserName(String userName) {
|
public void setUserName(String userName) {
|
||||||
Platform.runLater(new Runnable() {
|
Platform.runLater(new Runnable() {
|
||||||
@Override
|
@Override
|
||||||
|
@ -202,21 +215,7 @@ public class ChatWindowController {
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
public void addMessage(String sender, String receiver, String message) {
|
//TODO: MAKE ChangeListener
|
||||||
messages.addMessage(new Message(Message.MessageType.MESSAGE, sender, receiver, message));
|
|
||||||
this.redrawMessageList();
|
|
||||||
}
|
|
||||||
|
|
||||||
public void addInfo(String message) {
|
|
||||||
messages.addMessage(new Message(Message.MessageType.INFO, null, null, message));
|
|
||||||
this.redrawMessageList();
|
|
||||||
}
|
|
||||||
|
|
||||||
public void addError(String message) {
|
|
||||||
messages.addMessage(new Message(Message.MessageType.ERROR, null, null, message));
|
|
||||||
this.redrawMessageList();
|
|
||||||
}
|
|
||||||
|
|
||||||
private void redrawMessageList() {
|
private void redrawMessageList() {
|
||||||
this.messageArea.clear();
|
this.messageArea.clear();
|
||||||
Platform.runLater(() -> this.messageArea.setText(messages.getFilteredMessages(filterValue.getText().strip())));
|
Platform.runLater(() -> this.messageArea.setText(messages.getFilteredMessages(filterValue.getText().strip())));
|
||||||
|
|
|
@ -15,6 +15,7 @@ import java.util.regex.Matcher;
|
||||||
import java.util.regex.Pattern;
|
import java.util.regex.Pattern;
|
||||||
|
|
||||||
import static ch.zhaw.pm2.multichat.client.ClientConnectionHandler.State.*;
|
import static ch.zhaw.pm2.multichat.client.ClientConnectionHandler.State.*;
|
||||||
|
import static ch.zhaw.pm2.multichat.client.Message.MessageType.*;
|
||||||
|
|
||||||
public class ClientConnectionHandler implements Runnable {
|
public class ClientConnectionHandler implements Runnable {
|
||||||
private NetworkHandler.NetworkConnection<String> connection;
|
private NetworkHandler.NetworkConnection<String> connection;
|
||||||
|
@ -40,18 +41,13 @@ public class ClientConnectionHandler implements Runnable {
|
||||||
NEW, CONFIRM_CONNECT, CONNECTED, CONFIRM_DISCONNECT, DISCONNECTED;
|
NEW, CONFIRM_CONNECT, CONNECTED, CONFIRM_DISCONNECT, DISCONNECTED;
|
||||||
}
|
}
|
||||||
|
|
||||||
public ClientConnectionHandler(ClientMessageList messageList) {
|
public ClientConnectionHandler(ClientMessageList messageList,String serverAddress,int serverPort,String userName) throws IOException {
|
||||||
this.stateObjectProperty = new SimpleObjectProperty<>(NEW);
|
this.stateObjectProperty = new SimpleObjectProperty<>(NEW);
|
||||||
connection = null;
|
this.userName = new SimpleStringProperty((userName == null || userName.isBlank())? USER_NONE : userName);
|
||||||
userName = new SimpleStringProperty(USER_NONE);
|
this.serverPort = new SimpleIntegerProperty();
|
||||||
serverPort = new SimpleIntegerProperty();
|
this.serverAddress = new SimpleStringProperty();
|
||||||
serverAddress = new SimpleStringProperty();
|
|
||||||
this.messageList = messageList;
|
this.messageList = messageList;
|
||||||
}
|
this.connection = NetworkHandler.openConnection(serverAddress,serverPort);
|
||||||
|
|
||||||
public void openConnection(String serverAddress, int serverPort, String userName) throws IOException{
|
|
||||||
connection = NetworkHandler.openConnection(serverAddress,serverPort);
|
|
||||||
this.userName.set((userName == null || userName.isBlank())? USER_NONE : userName);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public ObjectProperty<State> getStateObjectProperty() {
|
public ObjectProperty<State> getStateObjectProperty() {
|
||||||
|
@ -115,6 +111,7 @@ public class ClientConnectionHandler implements Runnable {
|
||||||
System.out.println("Closed Connection Handler to Server");
|
System.out.println("Closed Connection Handler to Server");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
private void processData(String data) {
|
private void processData(String data) {
|
||||||
try {
|
try {
|
||||||
// parse data content
|
// parse data content
|
||||||
|
@ -147,15 +144,13 @@ public class ClientConnectionHandler implements Runnable {
|
||||||
} else if (type.equals(DATA_TYPE_CONFIRM)) {
|
} else if (type.equals(DATA_TYPE_CONFIRM)) {
|
||||||
if (stateObjectProperty.get() == CONFIRM_CONNECT) {
|
if (stateObjectProperty.get() == CONFIRM_CONNECT) {
|
||||||
this.userName.set(reciever);
|
this.userName.set(reciever);
|
||||||
controller.addInfo(payload);//TODO: Make Changelistener
|
this.serverAddress.set(connection.getRemoteHost());
|
||||||
messageList.addMessage(ClientMessageList.MessageType.INFO,sender,reciever,payload);
|
this.serverPort.set(connection.getRemotePort());
|
||||||
|
messageList.addMessage(sender,reciever,payload,INFO);
|
||||||
System.out.println("CONFIRM: " + payload);
|
System.out.println("CONFIRM: " + payload);
|
||||||
this.setState(CONNECTED);
|
this.setState(CONNECTED);
|
||||||
} else if (stateObjectProperty.get() == CONFIRM_DISCONNECT) {
|
} else if (stateObjectProperty.get() == CONFIRM_DISCONNECT) {
|
||||||
controller.addInfo(payload);//TODO: Make Changelistener
|
messageList.addMessage(sender,reciever,payload,INFO);
|
||||||
messageList.addMessage(ClientMessageList.MessageType.INFO,sender,reciever,payload);
|
|
||||||
|
|
||||||
System.out.println("CONFIRM: " + payload);
|
System.out.println("CONFIRM: " + payload);
|
||||||
this.setState(DISCONNECTED);
|
this.setState(DISCONNECTED);
|
||||||
} else {
|
} else {
|
||||||
|
@ -166,9 +161,7 @@ public class ClientConnectionHandler implements Runnable {
|
||||||
System.out.println("DISCONNECT: Already in disconnected: " + payload);
|
System.out.println("DISCONNECT: Already in disconnected: " + payload);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
controller.addInfo(payload);
|
messageList.addMessage(sender,reciever,payload,INFO);
|
||||||
messageList.addMessage(ClientMessageList.MessageType.INFO,sender,reciever,payload);
|
|
||||||
|
|
||||||
System.out.println("DISCONNECT: " + payload);
|
System.out.println("DISCONNECT: " + payload);
|
||||||
this.setState(DISCONNECTED);
|
this.setState(DISCONNECTED);
|
||||||
} else if (type.equals(DATA_TYPE_MESSAGE)) {
|
} else if (type.equals(DATA_TYPE_MESSAGE)) {
|
||||||
|
@ -176,14 +169,10 @@ public class ClientConnectionHandler implements Runnable {
|
||||||
System.out.println("MESSAGE: Illegal state " + stateObjectProperty.get() + " for message: " + payload);
|
System.out.println("MESSAGE: Illegal state " + stateObjectProperty.get() + " for message: " + payload);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
controller.addMessage(sender, reciever, payload);
|
messageList.addMessage(sender,reciever,payload,MESSAGE);
|
||||||
messageList.addMessage(ClientMessageList.MessageType.MESSAGE,sender,reciever,payload);
|
|
||||||
|
|
||||||
System.out.println("MESSAGE: From " + sender + " to " + reciever + ": "+ payload);
|
System.out.println("MESSAGE: From " + sender + " to " + reciever + ": "+ payload);
|
||||||
} else if (type.equals(DATA_TYPE_ERROR)) {
|
} else if (type.equals(DATA_TYPE_ERROR)) {
|
||||||
controller.addError(payload);
|
messageList.addMessage(sender,reciever,payload,ERROR);
|
||||||
messageList.addMessage(ClientMessageList.MessageType.ERROR,sender,reciever,payload);
|
|
||||||
|
|
||||||
System.out.println("ERROR: " + payload);
|
System.out.println("ERROR: " + payload);
|
||||||
} else {
|
} else {
|
||||||
System.out.println("Unknown data type received: " + type);
|
System.out.println("Unknown data type received: " + type);
|
||||||
|
@ -227,11 +216,8 @@ public class ClientConnectionHandler implements Runnable {
|
||||||
this.setState(CONFIRM_DISCONNECT);
|
this.setState(CONFIRM_DISCONNECT);
|
||||||
}
|
}
|
||||||
|
|
||||||
public void message(String receiver, String message) throws ChatProtocolException {
|
|
||||||
if (stateObjectProperty.get() != CONNECTED) throw new ChatProtocolException("Illegal state for message: " + stateObjectProperty.get());
|
|
||||||
this.sendData(userName.get(), receiver, DATA_TYPE_MESSAGE,message);
|
|
||||||
public boolean message(String messageString) throws ChatProtocolException {
|
public boolean message(String messageString) throws ChatProtocolException {
|
||||||
if (state != CONNECTED) throw new ChatProtocolException("Illegal state for message: " + state);
|
if (stateObjectProperty.get() != CONNECTED) throw new ChatProtocolException("Illegal state for message: " + stateObjectProperty.get());
|
||||||
|
|
||||||
Matcher matcher = messagePattern.matcher(messageString);
|
Matcher matcher = messagePattern.matcher(messageString);
|
||||||
if (matcher.find()) {
|
if (matcher.find()) {
|
||||||
|
@ -241,7 +227,7 @@ public class ClientConnectionHandler implements Runnable {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
if (receiver == null || receiver.isBlank()) receiver = ClientConnectionHandler.USER_ALL;
|
if (receiver == null || receiver.isBlank()) receiver = ClientConnectionHandler.USER_ALL;
|
||||||
this.sendData(userName, receiver, DATA_TYPE_MESSAGE,message);
|
this.sendData(userName.get(), receiver, DATA_TYPE_MESSAGE,message);
|
||||||
return true;
|
return true;
|
||||||
} else {
|
} else {
|
||||||
return false;
|
return false;
|
||||||
|
|
|
@ -1,14 +1,34 @@
|
||||||
package ch.zhaw.pm2.multichat.client;
|
package ch.zhaw.pm2.multichat.client;
|
||||||
|
|
||||||
|
import javafx.beans.property.SimpleBooleanProperty;
|
||||||
|
import javafx.beans.property.SimpleListProperty;
|
||||||
|
import javafx.collections.FXCollections;
|
||||||
|
import javafx.collections.ObservableList;
|
||||||
|
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
|
||||||
|
import static ch.zhaw.pm2.multichat.client.ClientConnectionHandler.USER_NONE;
|
||||||
|
|
||||||
public class ClientMessageList {
|
public class ClientMessageList {
|
||||||
private List<Message> messages = new ArrayList<>();
|
private List<Message> messages;
|
||||||
|
private SimpleBooleanProperty changed;
|
||||||
|
|
||||||
|
public ClientMessageList() {
|
||||||
|
messages = new ArrayList<>();
|
||||||
|
changed = new SimpleBooleanProperty(true);
|
||||||
|
}
|
||||||
|
|
||||||
public void addMessage(Message message) {
|
public SimpleBooleanProperty getChangedProperty() {
|
||||||
messages.add(message);
|
return changed;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void addMessage(String sender, String receiver, String message, Message.MessageType type) {
|
||||||
|
if(sender == null) {
|
||||||
|
sender = USER_NONE;
|
||||||
|
}
|
||||||
|
messages.add(new Message(type, sender, receiver, message));
|
||||||
|
changed.set(!changed.get());
|
||||||
}
|
}
|
||||||
|
|
||||||
public String getFilteredMessages(String filter) {
|
public String getFilteredMessages(String filter) {
|
||||||
|
@ -28,8 +48,21 @@ public class ClientMessageList {
|
||||||
return result.toString();
|
return result.toString();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public String getMessages() {
|
||||||
|
StringBuilder result = new StringBuilder();
|
||||||
|
for(Message message : messages) {
|
||||||
|
switch (message.getType()) {
|
||||||
|
case MESSAGE -> result.append(String.format("[%s -> %s] %s\n", message.getSender(), message.getReceiver(), message.getText()));
|
||||||
|
case ERROR -> result.append(String.format("[ERROR] %s\n", message.getText()));
|
||||||
|
case INFO -> result.append(String.format("[INFO] %s\n", message.getText()));
|
||||||
|
default -> result.append(String.format("[ERROR] %s\n", "Unexpected message type: " + message.getType()));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return result.toString();
|
||||||
|
}
|
||||||
|
|
||||||
public void clear() {
|
public void clear() {
|
||||||
messages = new ArrayList<>();
|
messages = new SimpleListProperty<>();
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -18,18 +18,8 @@ public class ClientUI extends Application {
|
||||||
try {
|
try {
|
||||||
FXMLLoader loader = new FXMLLoader(getClass().getResource("ChatWindow.fxml"));
|
FXMLLoader loader = new FXMLLoader(getClass().getResource("ChatWindow.fxml"));
|
||||||
|
|
||||||
// set up Controller
|
|
||||||
|
|
||||||
ChatWindowController controller = loader.getController();
|
|
||||||
ClientMessageList messageList = new ClientMessageList(controller);
|
|
||||||
ClientConnectionHandler connectionHandler = new ClientConnectionHandler(messageList);
|
|
||||||
controller.chatWindowController(messageList,connectionHandler);
|
|
||||||
|
|
||||||
Pane rootPane = loader.load();
|
Pane rootPane = loader.load();
|
||||||
|
|
||||||
ChatWindowController chatWindowController = loader.getController();
|
|
||||||
chatWindowController.setMessages(clientMessageList);
|
|
||||||
|
|
||||||
// fill in scene and stage setup
|
// fill in scene and stage setup
|
||||||
Scene scene = new Scene(rootPane);
|
Scene scene = new Scene(rootPane);
|
||||||
//scene.getStylesheets().add(getClass().getResource("application.css").toExternalForm());
|
//scene.getStylesheets().add(getClass().getResource("application.css").toExternalForm());
|
||||||
|
|
Loading…
Reference in New Issue