Merge pull request #28 from informatik-ag-ngl/b/db_received_date
Fixed missing message received dates in database
This commit is contained in:
commit
866c8c1a48
@ -7,7 +7,7 @@ import java.util.Set;
|
|||||||
import com.jenkov.nioserver.Server;
|
import com.jenkov.nioserver.Server;
|
||||||
|
|
||||||
import envoy.server.data.ConfigItem;
|
import envoy.server.data.ConfigItem;
|
||||||
import envoy.server.database.PersistenceManager;
|
import envoy.server.data.PersistenceManager;
|
||||||
import envoy.server.net.ConnectionManager;
|
import envoy.server.net.ConnectionManager;
|
||||||
import envoy.server.net.ObjectMessageProcessor;
|
import envoy.server.net.ObjectMessageProcessor;
|
||||||
import envoy.server.net.ObjectMessageReader;
|
import envoy.server.net.ObjectMessageReader;
|
||||||
|
@ -5,7 +5,6 @@ import java.util.Date;
|
|||||||
import javax.persistence.*;
|
import javax.persistence.*;
|
||||||
|
|
||||||
import envoy.data.MessageBuilder;
|
import envoy.data.MessageBuilder;
|
||||||
import envoy.server.database.PersistenceManager;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* This class serves as a way to let Hibernate communicate with the server
|
* This class serves as a way to let Hibernate communicate with the server
|
||||||
@ -53,14 +52,15 @@ public class Message {
|
|||||||
private byte[] attachment;
|
private byte[] attachment;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The constructor for a database object
|
* The constructor for a database object.
|
||||||
*
|
*
|
||||||
* @since Envoy Server Standalone v0.1-alpha
|
* @since Envoy Server Standalone v0.1-alpha
|
||||||
*/
|
*/
|
||||||
public Message() {}
|
public Message() {}
|
||||||
|
|
||||||
// TODO: everything except ID
|
|
||||||
/**
|
/**
|
||||||
|
* Constructs a database message from a common message.
|
||||||
|
*
|
||||||
* @param message the {@link envoy.data.Message} to convert into a database
|
* @param message the {@link envoy.data.Message} to convert into a database
|
||||||
* {@link Message}
|
* {@link Message}
|
||||||
* @since Envoy Server Standalone v0.1-alpha
|
* @since Envoy Server Standalone v0.1-alpha
|
||||||
@ -71,19 +71,29 @@ public class Message {
|
|||||||
status = message.getStatus();
|
status = message.getStatus();
|
||||||
text = message.getText();
|
text = message.getText();
|
||||||
creationDate = message.getCreationDate();
|
creationDate = message.getCreationDate();
|
||||||
|
receivedDate = message.getReceivedDate();
|
||||||
|
readDate = message.getReadDate();
|
||||||
sender = persMan.getUserById(message.getSenderId());
|
sender = persMan.getUserById(message.getSenderId());
|
||||||
recipient = persMan.getUserById(message.getRecipientId());
|
recipient = persMan.getUserById(message.getRecipientId());
|
||||||
// attachment = message.getAttachment().toByteArray();DOES NOT WORK YET
|
// TODO: attachment = message.getAttachment().toByteArray();DOES NOT WORK YET
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @return a database {@link Message} converted into an
|
* Converts this message into an instance of {@link envoy.data.Message}.
|
||||||
* {@link envoy.data.Message}
|
*
|
||||||
|
* @return a {@link envoy.data.Message} containing the same values as this
|
||||||
|
* message
|
||||||
* @since Envoy Server Standalone v0.1-alpha
|
* @since Envoy Server Standalone v0.1-alpha
|
||||||
*/
|
*/
|
||||||
public envoy.data.Message toCommonMessage() {
|
public envoy.data.Message toCommonMessage() {
|
||||||
// TODO: Attachment, dates
|
// TODO: Attachment
|
||||||
return new MessageBuilder(sender.getId(), recipient.getId(), id).setText(text).setDate(creationDate).setStatus(status).build();
|
envoy.data.Message message = new MessageBuilder(sender.getId(), recipient.getId(), id).setText(text)
|
||||||
|
.setDate(creationDate)
|
||||||
|
.setStatus(status)
|
||||||
|
.build();
|
||||||
|
message.setReceivedDate(receivedDate);
|
||||||
|
message.setReadDate(readDate);
|
||||||
|
return message;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
package envoy.server.database;
|
package envoy.server.data;
|
||||||
|
|
||||||
import java.util.Date;
|
import java.util.Date;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
@ -8,9 +8,6 @@ import javax.persistence.EntityTransaction;
|
|||||||
import javax.persistence.Persistence;
|
import javax.persistence.Persistence;
|
||||||
|
|
||||||
import envoy.data.User.UserStatus;
|
import envoy.data.User.UserStatus;
|
||||||
import envoy.server.data.ConfigItem;
|
|
||||||
import envoy.server.data.Message;
|
|
||||||
import envoy.server.data.User;
|
|
||||||
import envoy.server.net.ConnectionManager;
|
import envoy.server.net.ConnectionManager;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -34,13 +31,13 @@ public class PersistenceManager {
|
|||||||
* @since Envoy Server Standalone v0.1-alpha
|
* @since Envoy Server Standalone v0.1-alpha
|
||||||
*/
|
*/
|
||||||
private PersistenceManager() {
|
private PersistenceManager() {
|
||||||
transaction.begin();
|
|
||||||
Runtime.getRuntime().addShutdownHook(new Thread(() -> {
|
Runtime.getRuntime().addShutdownHook(new Thread(() -> {
|
||||||
|
transaction.begin();
|
||||||
ConnectionManager.getInstance()
|
ConnectionManager.getInstance()
|
||||||
.getOnlineUsers()
|
.getOnlineUsers()
|
||||||
.stream()
|
.stream()
|
||||||
.map(this::getUserById)
|
.map(this::getUserById)
|
||||||
.forEach(user -> { user.setStatus(UserStatus.OFFLINE); user.setLastSeen(new Date()); updateUser(user); });
|
.forEach(user -> { user.setStatus(UserStatus.OFFLINE); user.setLastSeen(new Date()); entityManager.merge(user); });
|
||||||
transaction.commit();
|
transaction.commit();
|
||||||
}));
|
}));
|
||||||
}
|
}
|
||||||
@ -54,13 +51,10 @@ public class PersistenceManager {
|
|||||||
/**
|
/**
|
||||||
* Adds a {@link User} to the database.
|
* Adds a {@link User} to the database.
|
||||||
*
|
*
|
||||||
* @param User the {@link User} to add to the database
|
* @param user the {@link User} to add to the database
|
||||||
* @since Envoy Server Standalone v0.1-alpha
|
* @since Envoy Server Standalone v0.1-alpha
|
||||||
*/
|
*/
|
||||||
public void addUser(User User) {
|
public void addUser(User user) { persist(user); }
|
||||||
entityManager.persist(User);
|
|
||||||
entityManager.flush();
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Adds a {@link Message} to the database.
|
* Adds a {@link Message} to the database.
|
||||||
@ -68,10 +62,7 @@ public class PersistenceManager {
|
|||||||
* @param message the {@link Message} to add to the database
|
* @param message the {@link Message} to add to the database
|
||||||
* @since Envoy Server Standalone v0.1-alpha
|
* @since Envoy Server Standalone v0.1-alpha
|
||||||
*/
|
*/
|
||||||
public void addMessage(Message message) {
|
public void addMessage(Message message) { persist(message); }
|
||||||
entityManager.persist(message);
|
|
||||||
entityManager.flush();
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Adds a {@link ConfigItem} to the database.
|
* Adds a {@link ConfigItem} to the database.
|
||||||
@ -79,10 +70,7 @@ public class PersistenceManager {
|
|||||||
* @param configItem the {@link ConfigItem} to add to the database
|
* @param configItem the {@link ConfigItem} to add to the database
|
||||||
* @since Envoy Server Standalone v0.1-alpha
|
* @since Envoy Server Standalone v0.1-alpha
|
||||||
*/
|
*/
|
||||||
public void addConfigItem(ConfigItem configItem) {
|
public void addConfigItem(ConfigItem configItem) { persist(configItem); }
|
||||||
entityManager.persist(configItem);
|
|
||||||
entityManager.flush();
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Updates a {@link User} in the database
|
* Updates a {@link User} in the database
|
||||||
@ -90,10 +78,7 @@ public class PersistenceManager {
|
|||||||
* @param user the {@link User} to add to the database
|
* @param user the {@link User} to add to the database
|
||||||
* @since Envoy Server Standalone v0.1-alpha
|
* @since Envoy Server Standalone v0.1-alpha
|
||||||
*/
|
*/
|
||||||
public void updateUser(User user) {
|
public void updateUser(User user) { merge(user); }
|
||||||
entityManager.merge(user);
|
|
||||||
entityManager.flush();
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Updates a {@link Message} in the database.
|
* Updates a {@link Message} in the database.
|
||||||
@ -101,10 +86,7 @@ public class PersistenceManager {
|
|||||||
* @param message the message to update
|
* @param message the message to update
|
||||||
* @since Envoy Server Standalone v0.1-alpha
|
* @since Envoy Server Standalone v0.1-alpha
|
||||||
*/
|
*/
|
||||||
public void updateMessage(Message message) {
|
public void updateMessage(Message message) { merge(message); }
|
||||||
entityManager.merge(message);
|
|
||||||
entityManager.flush();
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Updates a {@link ConfigItem} in the database.
|
* Updates a {@link ConfigItem} in the database.
|
||||||
@ -112,10 +94,7 @@ public class PersistenceManager {
|
|||||||
* @param configItem the configItem to update
|
* @param configItem the configItem to update
|
||||||
* @since Envoy Server Standalone v0.1-alpha
|
* @since Envoy Server Standalone v0.1-alpha
|
||||||
*/
|
*/
|
||||||
public void updateConfigItem(ConfigItem configItem) {
|
public void updateConfigItem(ConfigItem configItem) { merge(configItem); }
|
||||||
entityManager.merge(configItem);
|
|
||||||
entityManager.flush();
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Deletes a {@link User} in the database.
|
* Deletes a {@link User} in the database.
|
||||||
@ -123,10 +102,7 @@ public class PersistenceManager {
|
|||||||
* @param user the {@link User} to delete
|
* @param user the {@link User} to delete
|
||||||
* @since Envoy Server Standalone v0.1-alpha
|
* @since Envoy Server Standalone v0.1-alpha
|
||||||
*/
|
*/
|
||||||
public void deleteUser(User user) {
|
public void deleteUser(User user) { remove(user); }
|
||||||
entityManager.remove(user);
|
|
||||||
entityManager.flush();
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Deletes a {@link Message} in the database.
|
* Deletes a {@link Message} in the database.
|
||||||
@ -134,10 +110,7 @@ public class PersistenceManager {
|
|||||||
* @param message the {@link Message} to delete
|
* @param message the {@link Message} to delete
|
||||||
* @since Envoy Server Standalone v0.1-alpha
|
* @since Envoy Server Standalone v0.1-alpha
|
||||||
*/
|
*/
|
||||||
public void deleteMessage(Message message) {
|
public void deleteMessage(Message message) { remove(message); }
|
||||||
entityManager.remove(message);
|
|
||||||
entityManager.flush();
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Searches for a {@link User} with a specific id.
|
* Searches for a {@link User} with a specific id.
|
||||||
@ -211,12 +184,20 @@ public class PersistenceManager {
|
|||||||
* @since Envoy Server Standalone v0.1-alpha
|
* @since Envoy Server Standalone v0.1-alpha
|
||||||
*/
|
*/
|
||||||
public void addContact(long userId1, long userId2) {
|
public void addContact(long userId1, long userId2) {
|
||||||
|
|
||||||
|
// Get users by ID
|
||||||
User u1 = getUserById(userId1);
|
User u1 = getUserById(userId1);
|
||||||
User u2 = getUserById(userId2);
|
User u2 = getUserById(userId2);
|
||||||
|
|
||||||
|
// Add users to each others contact lists
|
||||||
u1.getContacts().add(u2);
|
u1.getContacts().add(u2);
|
||||||
u2.getContacts().add(u1);
|
u2.getContacts().add(u1);
|
||||||
updateUser(u1);
|
|
||||||
updateUser(u2);
|
// Synchronize changes with the database
|
||||||
|
transaction.begin();
|
||||||
|
entityManager.merge(u1);
|
||||||
|
entityManager.merge(u2);
|
||||||
|
transaction.commit();
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -227,4 +208,22 @@ public class PersistenceManager {
|
|||||||
public List<User> getContacts(User user) {
|
public List<User> getContacts(User user) {
|
||||||
return entityManager.createNamedQuery("getContactsOfUser").setParameter("user", user).getResultList();
|
return entityManager.createNamedQuery("getContactsOfUser").setParameter("user", user).getResultList();
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
private void persist(Object obj) {
|
||||||
|
transaction.begin();
|
||||||
|
entityManager.persist(obj);
|
||||||
|
transaction.commit();
|
||||||
|
}
|
||||||
|
|
||||||
|
private void merge(Object obj) {
|
||||||
|
transaction.begin();
|
||||||
|
entityManager.merge(obj);
|
||||||
|
transaction.commit();
|
||||||
|
}
|
||||||
|
|
||||||
|
private void remove(Object obj) {
|
||||||
|
transaction.begin();
|
||||||
|
entityManager.remove(obj);
|
||||||
|
transaction.commit();
|
||||||
|
}
|
||||||
|
}
|
@ -5,7 +5,7 @@ import java.util.*;
|
|||||||
import com.jenkov.nioserver.ISocketIdListener;
|
import com.jenkov.nioserver.ISocketIdListener;
|
||||||
|
|
||||||
import envoy.data.User.UserStatus;
|
import envoy.data.User.UserStatus;
|
||||||
import envoy.server.database.PersistenceManager;
|
import envoy.server.data.PersistenceManager;
|
||||||
import envoy.server.processors.UserStatusChangeProcessor;
|
import envoy.server.processors.UserStatusChangeProcessor;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -38,7 +38,12 @@ public class ObjectMessageProcessor implements IMessageProcessor {
|
|||||||
public void process(Message message, WriteProxy writeProxy) {
|
public void process(Message message, WriteProxy writeProxy) {
|
||||||
try (ObjectInputStream in = new ObjectInputStream(new ByteArrayInputStream(message.sharedArray, message.offset + 4, message.length - 4))) {
|
try (ObjectInputStream in = new ObjectInputStream(new ByteArrayInputStream(message.sharedArray, message.offset + 4, message.length - 4))) {
|
||||||
Object obj = in.readObject();
|
Object obj = in.readObject();
|
||||||
System.out.println("Read object: " + obj.toString());
|
if (obj == null) {
|
||||||
|
System.out.println("received a null object");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
System.out.println("Read object: " + obj);
|
||||||
|
|
||||||
// Process object
|
// Process object
|
||||||
processors.stream().filter(p -> p.getInputClass().isInstance(obj)).forEach((@SuppressWarnings("rawtypes") ObjectProcessor p) -> {
|
processors.stream().filter(p -> p.getInputClass().isInstance(obj)).forEach((@SuppressWarnings("rawtypes") ObjectProcessor p) -> {
|
||||||
|
@ -6,7 +6,7 @@ import java.util.Arrays;
|
|||||||
import envoy.data.Contacts;
|
import envoy.data.Contacts;
|
||||||
import envoy.event.ContactOperationEvent;
|
import envoy.event.ContactOperationEvent;
|
||||||
import envoy.server.ObjectProcessor;
|
import envoy.server.ObjectProcessor;
|
||||||
import envoy.server.database.PersistenceManager;
|
import envoy.server.data.PersistenceManager;
|
||||||
import envoy.server.net.ConnectionManager;
|
import envoy.server.net.ConnectionManager;
|
||||||
import envoy.server.net.ObjectWriteProxy;
|
import envoy.server.net.ObjectWriteProxy;
|
||||||
|
|
||||||
|
@ -7,8 +7,8 @@ import envoy.data.Contacts;
|
|||||||
import envoy.event.ContactSearchRequest;
|
import envoy.event.ContactSearchRequest;
|
||||||
import envoy.event.ContactSearchResult;
|
import envoy.event.ContactSearchResult;
|
||||||
import envoy.server.ObjectProcessor;
|
import envoy.server.ObjectProcessor;
|
||||||
|
import envoy.server.data.PersistenceManager;
|
||||||
import envoy.server.data.User;
|
import envoy.server.data.User;
|
||||||
import envoy.server.database.PersistenceManager;
|
|
||||||
import envoy.server.net.ConnectionManager;
|
import envoy.server.net.ConnectionManager;
|
||||||
import envoy.server.net.ObjectWriteProxy;
|
import envoy.server.net.ObjectWriteProxy;
|
||||||
|
|
||||||
|
@ -6,7 +6,7 @@ import envoy.data.IdGenerator;
|
|||||||
import envoy.event.IdGeneratorRequest;
|
import envoy.event.IdGeneratorRequest;
|
||||||
import envoy.server.ObjectProcessor;
|
import envoy.server.ObjectProcessor;
|
||||||
import envoy.server.data.ConfigItem;
|
import envoy.server.data.ConfigItem;
|
||||||
import envoy.server.database.PersistenceManager;
|
import envoy.server.data.PersistenceManager;
|
||||||
import envoy.server.net.ObjectWriteProxy;
|
import envoy.server.net.ObjectWriteProxy;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -14,7 +14,7 @@ import envoy.data.User.UserStatus;
|
|||||||
import envoy.event.HandshakeRejectionEvent;
|
import envoy.event.HandshakeRejectionEvent;
|
||||||
import envoy.server.ObjectProcessor;
|
import envoy.server.ObjectProcessor;
|
||||||
import envoy.server.data.Message;
|
import envoy.server.data.Message;
|
||||||
import envoy.server.database.PersistenceManager;
|
import envoy.server.data.PersistenceManager;
|
||||||
import envoy.server.net.ConnectionManager;
|
import envoy.server.net.ConnectionManager;
|
||||||
import envoy.server.net.ObjectWriteProxy;
|
import envoy.server.net.ObjectWriteProxy;
|
||||||
|
|
||||||
|
@ -6,7 +6,7 @@ import java.util.Date;
|
|||||||
import envoy.data.Message;
|
import envoy.data.Message;
|
||||||
import envoy.event.MessageStatusChangeEvent;
|
import envoy.event.MessageStatusChangeEvent;
|
||||||
import envoy.server.ObjectProcessor;
|
import envoy.server.ObjectProcessor;
|
||||||
import envoy.server.database.PersistenceManager;
|
import envoy.server.data.PersistenceManager;
|
||||||
import envoy.server.net.ConnectionManager;
|
import envoy.server.net.ConnectionManager;
|
||||||
import envoy.server.net.ObjectWriteProxy;
|
import envoy.server.net.ObjectWriteProxy;
|
||||||
|
|
||||||
@ -22,9 +22,6 @@ import envoy.server.net.ObjectWriteProxy;
|
|||||||
*/
|
*/
|
||||||
public class MessageProcessor implements ObjectProcessor<Message> {
|
public class MessageProcessor implements ObjectProcessor<Message> {
|
||||||
|
|
||||||
@Override
|
|
||||||
public Class<Message> getInputClass() { return Message.class; }
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void process(Message message, long socketId, ObjectWriteProxy writeProxy) {
|
public void process(Message message, long socketId, ObjectWriteProxy writeProxy) {
|
||||||
|
|
||||||
@ -44,4 +41,7 @@ public class MessageProcessor implements ObjectProcessor<Message> {
|
|||||||
}
|
}
|
||||||
PersistenceManager.getInstance().addMessage(new envoy.server.data.Message(message));
|
PersistenceManager.getInstance().addMessage(new envoy.server.data.Message(message));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public Class<Message> getInputClass() { return Message.class; }
|
||||||
}
|
}
|
||||||
|
@ -6,7 +6,7 @@ import envoy.data.Message.MessageStatus;
|
|||||||
import envoy.event.MessageStatusChangeEvent;
|
import envoy.event.MessageStatusChangeEvent;
|
||||||
import envoy.exception.EnvoyException;
|
import envoy.exception.EnvoyException;
|
||||||
import envoy.server.ObjectProcessor;
|
import envoy.server.ObjectProcessor;
|
||||||
import envoy.server.database.PersistenceManager;
|
import envoy.server.data.PersistenceManager;
|
||||||
import envoy.server.net.ConnectionManager;
|
import envoy.server.net.ConnectionManager;
|
||||||
import envoy.server.net.ObjectWriteProxy;
|
import envoy.server.net.ObjectWriteProxy;
|
||||||
|
|
||||||
@ -20,26 +20,28 @@ import envoy.server.net.ObjectWriteProxy;
|
|||||||
*/
|
*/
|
||||||
public class MessageStatusChangeProcessor implements ObjectProcessor<MessageStatusChangeEvent> {
|
public class MessageStatusChangeProcessor implements ObjectProcessor<MessageStatusChangeEvent> {
|
||||||
|
|
||||||
@Override
|
private final PersistenceManager persistenceManager = PersistenceManager.getInstance();
|
||||||
public Class<MessageStatusChangeEvent> getInputClass() { return MessageStatusChangeEvent.class; }
|
private final ConnectionManager connectionManager = ConnectionManager.getInstance();
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void process(MessageStatusChangeEvent input, long socketId, ObjectWriteProxy writeProxy) throws IOException {
|
public void process(MessageStatusChangeEvent input, long socketId, ObjectWriteProxy writeProxy) throws IOException {
|
||||||
try {
|
try {
|
||||||
// any other status than read is not supposed to be sent to the server
|
// any other status than read is not supposed to be sent to the server
|
||||||
if (input.get() != MessageStatus.READ) throw new EnvoyException("Message" + input.getId() + "has an invalid status");
|
if (input.get() != MessageStatus.READ) throw new EnvoyException("Message " + input + " has an invalid status");
|
||||||
} catch (EnvoyException e) {
|
} catch (EnvoyException e) {
|
||||||
throw new IOException(e);
|
throw new IOException(e);
|
||||||
}
|
}
|
||||||
ConnectionManager conMan = ConnectionManager.getInstance();
|
|
||||||
PersistenceManager perMan = PersistenceManager.getInstance();
|
|
||||||
|
|
||||||
envoy.server.data.Message msg = perMan.getMessageById(input.getId());
|
envoy.server.data.Message msg = persistenceManager.getMessageById(input.getId());
|
||||||
msg.setStatus(input.get());
|
msg.setStatus(input.get());
|
||||||
msg.setReadDate(input.getDate());
|
msg.setReadDate(input.getDate());
|
||||||
perMan.updateMessage(msg);
|
persistenceManager.updateMessage(msg);
|
||||||
|
|
||||||
// Notifies the sender of the message about the status-update to READ
|
// Notifies the sender of the message about the status-update to READ
|
||||||
if (conMan.isOnline(msg.getSender().getId())) writeProxy.write(conMan.getSocketId(msg.getSender().getId()), input);
|
final long senderId = msg.getSender().getId();
|
||||||
|
if (connectionManager.isOnline(senderId)) writeProxy.write(connectionManager.getSocketId(senderId), input);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public Class<MessageStatusChangeEvent> getInputClass() { return MessageStatusChangeEvent.class; }
|
||||||
}
|
}
|
||||||
|
@ -5,8 +5,8 @@ import java.io.IOException;
|
|||||||
import envoy.data.User.UserStatus;
|
import envoy.data.User.UserStatus;
|
||||||
import envoy.event.UserStatusChangeEvent;
|
import envoy.event.UserStatusChangeEvent;
|
||||||
import envoy.server.ObjectProcessor;
|
import envoy.server.ObjectProcessor;
|
||||||
|
import envoy.server.data.PersistenceManager;
|
||||||
import envoy.server.data.User;
|
import envoy.server.data.User;
|
||||||
import envoy.server.database.PersistenceManager;
|
|
||||||
import envoy.server.net.ConnectionManager;
|
import envoy.server.net.ConnectionManager;
|
||||||
import envoy.server.net.ObjectWriteProxy;
|
import envoy.server.net.ObjectWriteProxy;
|
||||||
|
|
||||||
|
Reference in New Issue
Block a user