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-09-25 14:29:23 +02:00
|
|
|
import envoy.server.net.*;
|
2020-06-11 12:06:06 +02:00
|
|
|
import envoy.util.EnvoyLog;
|
2020-02-08 15:03:03 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @author Kai S. K. Engelbart
|
|
|
|
* @since Envoy Server Standalone v0.1-alpha
|
|
|
|
*/
|
2020-08-22 13:37:07 +02:00
|
|
|
public final 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
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|