2020-02-08 15:03:03 +01:00
|
|
|
package envoy.server.processors;
|
|
|
|
|
2020-06-11 12:06:06 +02:00
|
|
|
import java.util.logging.Logger;
|
2020-02-08 15:03:03 +01:00
|
|
|
|
2020-06-09 17:05:52 +02:00
|
|
|
import envoy.event.ElementOperation;
|
2020-06-20 09:57:54 +02:00
|
|
|
import envoy.event.contact.ContactOperation;
|
2020-02-15 22:43:20 +01:00
|
|
|
import envoy.server.data.PersistenceManager;
|
2020-02-12 22:01:32 +01:00
|
|
|
import envoy.server.net.ConnectionManager;
|
2020-02-08 15:03:03 +01:00
|
|
|
import envoy.server.net.ObjectWriteProxy;
|
2020-06-11 12:06:06 +02:00
|
|
|
import envoy.util.EnvoyLog;
|
2020-02-08 15:03:03 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Project: <strong>envoy-server-standalone</strong><br>
|
|
|
|
* File: <strong>ContactOperationProcessor.java</strong><br>
|
|
|
|
* Created: <strong>08.02.2020</strong><br>
|
2020-02-10 22:29:34 +01:00
|
|
|
*
|
2020-02-08 15:03:03 +01:00
|
|
|
* @author Kai S. K. Engelbart
|
|
|
|
* @since Envoy Server Standalone v0.1-alpha
|
|
|
|
*/
|
2020-06-20 09:57:54 +02:00
|
|
|
public class ContactOperationProcessor implements ObjectProcessor<ContactOperation> {
|
2020-02-08 15:03:03 +01:00
|
|
|
|
2020-02-11 17:44:58 +01:00
|
|
|
private static final ConnectionManager connectionManager = ConnectionManager.getInstance();
|
2020-06-11 12:06:06 +02:00
|
|
|
private static final Logger logger = EnvoyLog.getLogger(ContactOperationProcessor.class);
|
2020-02-11 17:44:58 +01:00
|
|
|
|
2020-02-08 15:03:03 +01:00
|
|
|
@Override
|
2020-07-06 11:40:13 +02:00
|
|
|
public void process(ContactOperation evt, long socketId, ObjectWriteProxy writeProxy) {
|
2020-02-11 17:44:58 +01:00
|
|
|
switch (evt.getOperationType()) {
|
|
|
|
case ADD:
|
2020-07-06 11:40:13 +02:00
|
|
|
final long userID = ConnectionManager.getInstance().getUserIDBySocketID(socketId);
|
2020-03-26 16:06:55 +01:00
|
|
|
final long contactId = evt.get().getID();
|
2020-02-11 17:44:58 +01:00
|
|
|
|
2020-06-11 12:06:06 +02:00
|
|
|
logger.fine(String.format("Adding user %s to the contact list of user %d.%n", evt.get(), userID));
|
2020-06-14 16:40:51 +02:00
|
|
|
PersistenceManager.getInstance().addContactBidirectional(userID, contactId);
|
2020-02-11 17:44:58 +01:00
|
|
|
|
2020-02-11 18:15:19 +01:00
|
|
|
// Notify the contact if online
|
2020-06-09 17:05:52 +02:00
|
|
|
if (ConnectionManager.getInstance().isOnline(contactId))
|
2020-06-14 16:40:51 +02:00
|
|
|
writeProxy.write(connectionManager.getSocketID(contactId),
|
2020-06-20 09:57:54 +02:00
|
|
|
new ContactOperation(PersistenceManager.getInstance().getUserByID(userID).toCommon(), ElementOperation.ADD));
|
2020-02-11 17:44:58 +01:00
|
|
|
break;
|
|
|
|
default:
|
2020-07-06 11:40:13 +02:00
|
|
|
logger.warning(String.format("Received %s with an unsupported operation.", evt));
|
2020-02-08 15:03:03 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|