2011-02-15 19:37:35 +00:00
|
|
|
package zutil.net.nio.service.sync;
|
2008-11-14 16:38:36 +00:00
|
|
|
|
|
|
|
|
import java.nio.channels.SocketChannel;
|
|
|
|
|
import java.util.HashMap;
|
2010-05-18 21:06:40 +00:00
|
|
|
import java.util.logging.Logger;
|
2008-11-14 16:38:36 +00:00
|
|
|
|
2010-05-18 21:06:40 +00:00
|
|
|
import zutil.log.LogUtil;
|
2011-02-15 19:37:35 +00:00
|
|
|
import zutil.net.nio.NioNetwork;
|
|
|
|
|
import zutil.net.nio.message.Message;
|
|
|
|
|
import zutil.net.nio.message.SyncMessage;
|
|
|
|
|
import zutil.net.nio.service.NetworkService;
|
2008-11-14 16:38:36 +00:00
|
|
|
|
|
|
|
|
public class SyncService extends NetworkService{
|
2010-05-18 21:06:40 +00:00
|
|
|
private static Logger logger = LogUtil.getLogger();
|
2008-11-14 16:38:36 +00:00
|
|
|
// list of objects to sync
|
|
|
|
|
private HashMap<String, ObjectSync> sync;
|
|
|
|
|
|
|
|
|
|
public SyncService(NioNetwork nio){
|
|
|
|
|
super(nio);
|
|
|
|
|
sync = new HashMap<String, ObjectSync>();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Adds a SyncObject to the sync list
|
|
|
|
|
* @param os The object to sync
|
|
|
|
|
*/
|
|
|
|
|
public void addSyncObject(ObjectSync os){
|
|
|
|
|
sync.put(os.id, os);
|
2010-05-18 21:06:40 +00:00
|
|
|
logger.fine("New Sync object: "+os);
|
2008-11-14 16:38:36 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public void handleMessage(Message message, SocketChannel socket){
|
|
|
|
|
if(message instanceof SyncMessage){
|
|
|
|
|
SyncMessage syncMessage = (SyncMessage)message;
|
|
|
|
|
if(syncMessage.type == SyncMessage.MessageType.SYNC){
|
|
|
|
|
ObjectSync obj = sync.get(syncMessage.id);
|
|
|
|
|
if(obj != null){
|
2010-05-18 21:06:40 +00:00
|
|
|
logger.finer("Syncing Message...");
|
2008-11-14 16:38:36 +00:00
|
|
|
obj.syncObject(syncMessage);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
else if(syncMessage.type == SyncMessage.MessageType.REMOVE){
|
|
|
|
|
sync.remove(syncMessage.id).remove();
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Syncs all the objects whit the server
|
|
|
|
|
*/
|
|
|
|
|
public void sync(){
|
|
|
|
|
for(String id : sync.keySet()){
|
|
|
|
|
sync.get(id).sendSync();
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public static SyncService getInstance(){
|
|
|
|
|
return (SyncService)instance;
|
|
|
|
|
}
|
|
|
|
|
}
|