Current working status
This commit is contained in:
		@@ -3,7 +3,9 @@ package envoy.client.net;
 | 
			
		||||
import java.io.Closeable;
 | 
			
		||||
import java.io.IOException;
 | 
			
		||||
import java.net.Socket;
 | 
			
		||||
import java.util.Map;
 | 
			
		||||
import java.util.concurrent.TimeoutException;
 | 
			
		||||
import java.util.function.Consumer;
 | 
			
		||||
import java.util.logging.Level;
 | 
			
		||||
import java.util.logging.Logger;
 | 
			
		||||
 | 
			
		||||
@@ -38,6 +40,8 @@ public class Client implements Closeable {
 | 
			
		||||
	private Receiver	receiver;
 | 
			
		||||
	private boolean		online;
 | 
			
		||||
 | 
			
		||||
	private Map<Class<?>, Cache<?>> cacheMap;
 | 
			
		||||
 | 
			
		||||
	// Asynchronously initialized during handshake
 | 
			
		||||
	private volatile User		sender;
 | 
			
		||||
	private volatile boolean	rejected;
 | 
			
		||||
@@ -53,33 +57,14 @@ public class Client implements Closeable {
 | 
			
		||||
	 * will block for up to 5 seconds. If the handshake does exceed this time limit,
 | 
			
		||||
	 * an exception is thrown.
 | 
			
		||||
	 *
 | 
			
		||||
	 * @param credentials                           the login credentials of the
 | 
			
		||||
	 *                                              user
 | 
			
		||||
	 * @param receivedMessageCache                  a message cache containing all
 | 
			
		||||
	 *                                              unread messages from the server
 | 
			
		||||
	 *                                              that can be relayed after
 | 
			
		||||
	 *                                              initialization
 | 
			
		||||
	 * @param receivedGroupMessageCache             a groupMessage cache containing
 | 
			
		||||
	 *                                              all unread groupMessages from
 | 
			
		||||
	 *                                              the server that can be relayed
 | 
			
		||||
	 *                                              after initialization
 | 
			
		||||
	 * @param receivedMessageStatusChangeCache      an event cache containing all
 | 
			
		||||
	 *                                              received
 | 
			
		||||
	 *                                              messageStatusChangeEvents from
 | 
			
		||||
	 *                                              the server that can be relayed
 | 
			
		||||
	 *                                              after initialization
 | 
			
		||||
	 * @param receivedGroupMessageStatusChangeCache an event cache containing all
 | 
			
		||||
	 *                                              received
 | 
			
		||||
	 *                                              groupMessageStatusChangeEvents
 | 
			
		||||
	 *                                              from the server that can be
 | 
			
		||||
	 *                                              relayed after initialization
 | 
			
		||||
	 * @param credentials the login credentials of the user
 | 
			
		||||
	 * @param cacheMap    the map of all caches needed
 | 
			
		||||
	 * @throws TimeoutException     if the server could not be reached
 | 
			
		||||
	 * @throws IOException          if the login credentials could not be written
 | 
			
		||||
	 * @throws InterruptedException if the current thread is interrupted while
 | 
			
		||||
	 *                              waiting for the handshake response
 | 
			
		||||
	 */
 | 
			
		||||
	public void performHandshake(LoginCredentials credentials, Cache<Message> receivedMessageCache, Cache<GroupMessage> receivedGroupMessageCache,
 | 
			
		||||
			Cache<MessageStatusChange> receivedMessageStatusChangeCache, Cache<GroupMessageStatusChange> receivedGroupMessageStatusChangeCache)
 | 
			
		||||
	public void performHandshake(LoginCredentials credentials, Map<Class<?>, Cache<?>> cacheMap)
 | 
			
		||||
			throws TimeoutException, IOException, InterruptedException {
 | 
			
		||||
		if (online) throw new IllegalStateException("Handshake has already been performed successfully");
 | 
			
		||||
 | 
			
		||||
@@ -93,10 +78,7 @@ public class Client implements Closeable {
 | 
			
		||||
 | 
			
		||||
		// Register user creation processor, contact list processor and message cache
 | 
			
		||||
		receiver.registerProcessor(User.class, sender -> this.sender = sender);
 | 
			
		||||
		receiver.registerProcessor(Message.class, receivedMessageCache);
 | 
			
		||||
		receiver.registerProcessor(GroupMessage.class, receivedGroupMessageCache);
 | 
			
		||||
		receiver.registerProcessor(MessageStatusChange.class, receivedMessageStatusChangeCache);
 | 
			
		||||
		receiver.registerProcessor(GroupMessageStatusChange.class, receivedGroupMessageStatusChangeCache);
 | 
			
		||||
		cacheMap.forEach((inputclass, cache) -> receiver.registerProcessor(inputclass, cache));
 | 
			
		||||
		receiver.registerProcessor(HandshakeRejection.class, evt -> { rejected = true; eventBus.dispatch(evt); });
 | 
			
		||||
 | 
			
		||||
		rejected = false;
 | 
			
		||||
@@ -135,43 +117,14 @@ public class Client implements Closeable {
 | 
			
		||||
	 * Initializes the {@link Receiver} used to process data sent from the server to
 | 
			
		||||
	 * this client.
 | 
			
		||||
	 *
 | 
			
		||||
	 * @param localDB                               the local database used to
 | 
			
		||||
	 *                                              persist
 | 
			
		||||
	 *                                              the current
 | 
			
		||||
	 *                                              {@link IDGenerator}
 | 
			
		||||
	 * @param receivedMessageCache                  a message cache containing all
 | 
			
		||||
	 *                                              unread
 | 
			
		||||
	 *                                              messages
 | 
			
		||||
	 *                                              from the server that can be
 | 
			
		||||
	 *                                              relayed
 | 
			
		||||
	 *                                              after
 | 
			
		||||
	 *                                              initialization
 | 
			
		||||
	 * @param receivedGroupMessageCache             a groupMessage cache containing
 | 
			
		||||
	 *                                              all
 | 
			
		||||
	 *                                              unread
 | 
			
		||||
	 *                                              groupMessages
 | 
			
		||||
	 *                                              from the server that can be
 | 
			
		||||
	 *                                              relayed
 | 
			
		||||
	 *                                              after
 | 
			
		||||
	 *                                              initialization
 | 
			
		||||
	 * @param receivedMessageStatusChangeCache      an event cache containing all
 | 
			
		||||
	 *                                              received
 | 
			
		||||
	 *                                              messageStatusChangeEvents
 | 
			
		||||
	 *                                              from the server that can be
 | 
			
		||||
	 *                                              relayed
 | 
			
		||||
	 *                                              after initialization
 | 
			
		||||
	 * @param receivedGroupMessageStatusChangeCache an event cache containing all
 | 
			
		||||
	 *                                              received
 | 
			
		||||
	 *                                              groupMessageStatusChangeEvents
 | 
			
		||||
	 *                                              from the server that can be
 | 
			
		||||
	 *                                              relayed after initialization
 | 
			
		||||
	 * @param localDB  the local database used to persist the current
 | 
			
		||||
	 *                 {@link IDGenerator}
 | 
			
		||||
	 * @param cacheMap the map of all caches needed
 | 
			
		||||
	 * @throws IOException if no {@link IDGenerator} is present and none could be
 | 
			
		||||
	 *                     requested from the server
 | 
			
		||||
	 * @since Envoy Client v0.2-alpha
 | 
			
		||||
	 */
 | 
			
		||||
	public void initReceiver(LocalDB localDB, Cache<Message> receivedMessageCache, Cache<GroupMessage> receivedGroupMessageCache,
 | 
			
		||||
			Cache<MessageStatusChange> receivedMessageStatusChangeCache, Cache<GroupMessageStatusChange> receivedGroupMessageStatusChangeCache)
 | 
			
		||||
			throws IOException {
 | 
			
		||||
	public void initReceiver(LocalDB localDB, Map<Class<?>, Cache<?>> cacheMap) throws IOException {
 | 
			
		||||
		checkOnline();
 | 
			
		||||
 | 
			
		||||
		// Process incoming messages
 | 
			
		||||
@@ -188,12 +141,11 @@ public class Client implements Closeable {
 | 
			
		||||
 | 
			
		||||
		receiver.registerProcessor(GroupMessageStatusChange.class, groupMessageStatusChangeProcessor);
 | 
			
		||||
		// Relay cached unread messages and unread groupMessages
 | 
			
		||||
		receivedMessageCache.setProcessor(receivedMessageProcessor);
 | 
			
		||||
		receivedGroupMessageCache.setProcessor(receivedGroupMessageProcessor);
 | 
			
		||||
 | 
			
		||||
		cacheMap.get(Message.class).setProcessor((Consumer<?>) receivedMessageProcessor);
 | 
			
		||||
		cacheMap.get(GroupMessage.class).setProcessor((Consumer<?>) receivedGroupMessageProcessor);
 | 
			
		||||
		// Process message status changes
 | 
			
		||||
		receivedMessageStatusChangeCache.setProcessor(messageStatusChangeProcessor);
 | 
			
		||||
		receivedGroupMessageStatusChangeCache.setProcessor(groupMessageStatusChangeProcessor);
 | 
			
		||||
		cacheMap.get(MessageStatusChange.class).setProcessor((Consumer<?>) messageStatusChangeProcessor);
 | 
			
		||||
		cacheMap.get(GroupMessageStatusChange.class).setProcessor((Consumer<?>) groupMessageStatusChangeProcessor);
 | 
			
		||||
 | 
			
		||||
		// Process user status changes
 | 
			
		||||
		receiver.registerProcessor(UserStatusChange.class, eventBus::dispatch);
 | 
			
		||||
 
 | 
			
		||||
@@ -2,6 +2,7 @@ package envoy.client.ui;
 | 
			
		||||
 | 
			
		||||
import java.io.File;
 | 
			
		||||
import java.io.IOException;
 | 
			
		||||
import java.util.HashMap;
 | 
			
		||||
import java.util.Properties;
 | 
			
		||||
import java.util.logging.Level;
 | 
			
		||||
import java.util.logging.Logger;
 | 
			
		||||
@@ -42,12 +43,8 @@ public final class Startup extends Application {
 | 
			
		||||
	 */
 | 
			
		||||
	public static final String VERSION = "0.1-beta";
 | 
			
		||||
 | 
			
		||||
	private LocalDB						localDB;
 | 
			
		||||
	private Client						client;
 | 
			
		||||
	private Cache<Message>				messageCache;
 | 
			
		||||
	private Cache<GroupMessage>			groupMessageCache;
 | 
			
		||||
	private Cache<MessageStatusChange>	messageStatusCache;
 | 
			
		||||
	private Cache<GroupMessageStatusChange>	groupMessageStatusCache;
 | 
			
		||||
	private LocalDB	localDB;
 | 
			
		||||
	private Client	client;
 | 
			
		||||
 | 
			
		||||
	private static final ClientConfig	config	= ClientConfig.getInstance();
 | 
			
		||||
	private static final Logger			logger	= EnvoyLog.getLogger(Startup.class);
 | 
			
		||||
@@ -101,19 +98,20 @@ public final class Startup extends Application {
 | 
			
		||||
		}
 | 
			
		||||
 | 
			
		||||
		// Initialize client and unread message cache
 | 
			
		||||
		client				= new Client();
 | 
			
		||||
		messageCache		= new Cache<>();
 | 
			
		||||
		groupMessageCache	= new Cache<>();
 | 
			
		||||
		messageStatusCache	= new Cache<>();
 | 
			
		||||
		groupMessageStatusCache	= new Cache<>();
 | 
			
		||||
		client = new Client();
 | 
			
		||||
 | 
			
		||||
		final var cacheMap = new HashMap<Class<?>, Cache<?>>();
 | 
			
		||||
		cacheMap.put(Message.class, new Cache<Message>());
 | 
			
		||||
		cacheMap.put(GroupMessage.class, new Cache<GroupMessage>());
 | 
			
		||||
		cacheMap.put(MessageStatusChange.class, new Cache<MessageStatusChange>());
 | 
			
		||||
		cacheMap.put(GroupMessageStatusChange.class, new Cache<GroupMessageStatusChange>());
 | 
			
		||||
 | 
			
		||||
		stage.setTitle("Envoy");
 | 
			
		||||
		stage.getIcons().add(IconUtil.loadIcon("envoy_logo"));
 | 
			
		||||
 | 
			
		||||
		final var sceneContext = new SceneContext(stage);
 | 
			
		||||
		sceneContext.load(SceneInfo.LOGIN_SCENE);
 | 
			
		||||
		sceneContext.<LoginScene>getController()
 | 
			
		||||
			.initializeData(client, localDB, messageCache, groupMessageCache, messageStatusCache, groupMessageStatusCache, sceneContext);
 | 
			
		||||
		sceneContext.<LoginScene>getController().initializeData(client, localDB, cacheMap, sceneContext);
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	/**
 | 
			
		||||
 
 | 
			
		||||
@@ -2,6 +2,7 @@ package envoy.client.ui.controller;
 | 
			
		||||
 | 
			
		||||
import java.io.FileNotFoundException;
 | 
			
		||||
import java.io.IOException;
 | 
			
		||||
import java.util.Map;
 | 
			
		||||
import java.util.concurrent.TimeoutException;
 | 
			
		||||
import java.util.logging.Level;
 | 
			
		||||
import java.util.logging.Logger;
 | 
			
		||||
@@ -16,9 +17,11 @@ import envoy.client.net.Client;
 | 
			
		||||
import envoy.client.ui.ClearableTextField;
 | 
			
		||||
import envoy.client.ui.SceneContext;
 | 
			
		||||
import envoy.client.ui.Startup;
 | 
			
		||||
import envoy.data.*;
 | 
			
		||||
import envoy.data.LoginCredentials;
 | 
			
		||||
import envoy.data.User;
 | 
			
		||||
import envoy.data.User.UserStatus;
 | 
			
		||||
import envoy.event.*;
 | 
			
		||||
import envoy.event.EventBus;
 | 
			
		||||
import envoy.event.HandshakeRejection;
 | 
			
		||||
import envoy.exception.EnvoyException;
 | 
			
		||||
import envoy.util.Bounds;
 | 
			
		||||
import envoy.util.EnvoyLog;
 | 
			
		||||
@@ -52,13 +55,10 @@ public final class LoginScene {
 | 
			
		||||
	@FXML
 | 
			
		||||
	private Label connectionLabel;
 | 
			
		||||
 | 
			
		||||
	private Client						client;
 | 
			
		||||
	private LocalDB						localDB;
 | 
			
		||||
	private Cache<Message>				receivedMessageCache;
 | 
			
		||||
	private Cache<GroupMessage>			receivedGroupMessageCache;
 | 
			
		||||
	private Cache<MessageStatusChange>	receivedMessageStatusChangeCache;
 | 
			
		||||
	private Cache<GroupMessageStatusChange>	receivedGroupMessageStatusChangeCache;
 | 
			
		||||
	private SceneContext				sceneContext;
 | 
			
		||||
	private Client					client;
 | 
			
		||||
	private LocalDB					localDB;
 | 
			
		||||
	private Map<Class<?>, Cache<?>>	cacheMap;
 | 
			
		||||
	private SceneContext			sceneContext;
 | 
			
		||||
 | 
			
		||||
	private static final Logger			logger		= EnvoyLog.getLogger(LoginScene.class);
 | 
			
		||||
	private static final EventBus		eventBus	= EventBus.getInstance();
 | 
			
		||||
@@ -75,41 +75,17 @@ public final class LoginScene {
 | 
			
		||||
	/**
 | 
			
		||||
	 * Loads the login dialog using the FXML file {@code LoginDialog.fxml}.
 | 
			
		||||
	 *
 | 
			
		||||
	 * @param client                                the client used to perform the
 | 
			
		||||
	 *                                              handshake
 | 
			
		||||
	 * @param localDB                               the local database used for
 | 
			
		||||
	 *                                              offline
 | 
			
		||||
	 *                                              login
 | 
			
		||||
	 * @param receivedMessageCache                  the cache storing messages
 | 
			
		||||
	 *                                              received
 | 
			
		||||
	 *                                              during
 | 
			
		||||
	 *                                              the handshake
 | 
			
		||||
	 * @param receivedGroupMessageCache             the cache storing groupMessages
 | 
			
		||||
	 *                                              received during the handshake
 | 
			
		||||
	 * @param receivedMessageStatusChangeCache      the cache storing
 | 
			
		||||
	 *                                              messageStatusChangeEvents
 | 
			
		||||
	 *                                              received
 | 
			
		||||
	 *                                              during handshake
 | 
			
		||||
	 * @param receivedGroupMessageStatusChangeCache the cache storing
 | 
			
		||||
	 *                                              groupMessageStatusChangeEvents
 | 
			
		||||
	 *                                              received
 | 
			
		||||
	 *                                              during handshake
 | 
			
		||||
	 * @param sceneContext                          the scene context used to
 | 
			
		||||
	 *                                              initialize
 | 
			
		||||
	 *                                              the chat
 | 
			
		||||
	 *                                              scene
 | 
			
		||||
	 * @param client       the client used to perform the handshake
 | 
			
		||||
	 * @param localDB      the local database used for offline login
 | 
			
		||||
	 * @param cacheMap     the map of all caches needed
 | 
			
		||||
	 * @param sceneContext the scene context used to initialize the chat scene
 | 
			
		||||
	 * @since Envoy Client v0.1-beta
 | 
			
		||||
	 */
 | 
			
		||||
	public void initializeData(Client client, LocalDB localDB, Cache<Message> receivedMessageCache, Cache<GroupMessage> receivedGroupMessageCache,
 | 
			
		||||
			Cache<MessageStatusChange> receivedMessageStatusChangeCache, Cache<GroupMessageStatusChange> receivedGroupMessageStatusChangeCache,
 | 
			
		||||
			SceneContext sceneContext) {
 | 
			
		||||
		this.client								= client;
 | 
			
		||||
		this.localDB							= localDB;
 | 
			
		||||
		this.receivedMessageCache				= receivedMessageCache;
 | 
			
		||||
		this.receivedGroupMessageCache			= receivedGroupMessageCache;
 | 
			
		||||
		this.receivedMessageStatusChangeCache	= receivedMessageStatusChangeCache;
 | 
			
		||||
		this.receivedGroupMessageStatusChangeCache	= receivedGroupMessageStatusChangeCache;
 | 
			
		||||
		this.sceneContext						= sceneContext;
 | 
			
		||||
	public void initializeData(Client client, LocalDB localDB, Map<Class<?>, Cache<?>> cacheMap, SceneContext sceneContext) {
 | 
			
		||||
		this.client			= client;
 | 
			
		||||
		this.localDB		= localDB;
 | 
			
		||||
		this.cacheMap		= cacheMap;
 | 
			
		||||
		this.sceneContext	= sceneContext;
 | 
			
		||||
 | 
			
		||||
		// Prepare handshake
 | 
			
		||||
		localDB.loadIDGenerator();
 | 
			
		||||
@@ -157,17 +133,9 @@ public final class LoginScene {
 | 
			
		||||
 | 
			
		||||
	private void performHandshake(LoginCredentials credentials) {
 | 
			
		||||
		try {
 | 
			
		||||
			client.performHandshake(credentials,
 | 
			
		||||
					receivedMessageCache,
 | 
			
		||||
					receivedGroupMessageCache,
 | 
			
		||||
					receivedMessageStatusChangeCache,
 | 
			
		||||
					receivedGroupMessageStatusChangeCache);
 | 
			
		||||
			client.performHandshake(credentials, cacheMap);
 | 
			
		||||
			if (client.isOnline()) {
 | 
			
		||||
				client.initReceiver(localDB,
 | 
			
		||||
						receivedMessageCache,
 | 
			
		||||
						receivedGroupMessageCache,
 | 
			
		||||
						receivedMessageStatusChangeCache,
 | 
			
		||||
						receivedGroupMessageStatusChangeCache);
 | 
			
		||||
				client.initReceiver(localDB, cacheMap);
 | 
			
		||||
				loadChatScene();
 | 
			
		||||
			}
 | 
			
		||||
		} catch (IOException | InterruptedException | TimeoutException e) {
 | 
			
		||||
@@ -230,9 +198,6 @@ public final class LoginScene {
 | 
			
		||||
		sceneContext.<ChatScene>getController().initializeData(sceneContext, localDB, client, writeProxy);
 | 
			
		||||
 | 
			
		||||
		// Relay unread messages from cache
 | 
			
		||||
		if (receivedMessageCache != null && client.isOnline()) receivedMessageCache.relay();
 | 
			
		||||
		if (receivedGroupMessageCache != null && client.isOnline()) receivedGroupMessageCache.relay();
 | 
			
		||||
		if (receivedMessageStatusChangeCache != null && client.isOnline()) receivedMessageStatusChangeCache.relay();
 | 
			
		||||
		if (receivedGroupMessageStatusChangeCache != null && client.isOnline()) receivedGroupMessageStatusChangeCache.relay();
 | 
			
		||||
		if (client.isOnline()) cacheMap.values().forEach(cache -> { if (cache != null) cache.relay(); });
 | 
			
		||||
	}
 | 
			
		||||
}
 | 
			
		||||
 
 | 
			
		||||
		Reference in New Issue
	
	Block a user