hal/src/zutil/net/nio/service/chat/ChatService.java

134 lines
3.4 KiB
Java
Raw Normal View History

2011-02-15 19:37:35 +00:00
package zutil.net.nio.service.chat;
2008-11-14 16:38:36 +00:00
import java.nio.channels.SocketChannel;
import java.util.HashMap;
import java.util.LinkedList;
import java.util.logging.Logger;
2008-11-14 16:38:36 +00:00
import zutil.log.LogUtil;
2011-02-15 19:37:35 +00:00
import zutil.net.nio.NioNetwork;
import zutil.net.nio.message.ChatMessage;
import zutil.net.nio.message.Message;
import zutil.net.nio.service.NetworkService;
2008-11-14 16:38:36 +00:00
/**
* A simple chat service with users and rooms
*
* @author Ziver
*/
2008-11-14 16:38:36 +00:00
public class ChatService extends NetworkService{
private static Logger logger = LogUtil.getLogger();
2008-11-14 16:38:36 +00:00
private HashMap<String,LinkedList<SocketChannel>> rooms;
private ChatListener listener;
public ChatService(NioNetwork nio){
super(nio);
rooms = new HashMap<String,LinkedList<SocketChannel>>();
}
@Override
public void handleMessage(Message message, SocketChannel socket) {
try {
// New message
if(message instanceof ChatMessage){
ChatMessage chatmessage = (ChatMessage)message;
//is this a new message
if(chatmessage.type == ChatMessage.ChatMessageType.MESSAGE){
// Is this the server
if(nio.getType() == NioNetwork.NetworkType.SERVER){
if(rooms.containsKey(chatmessage.room)){
LinkedList<SocketChannel> tmpList = rooms.get(chatmessage.room);
2008-11-14 16:38:36 +00:00
// Broadcast the message
for(SocketChannel s : tmpList){
if(s.isConnected()){
nio.send(s, chatmessage);
}
else{
unRegisterUser(chatmessage.room, s);
}
2008-11-14 16:38:36 +00:00
}
}
}
logger.finer("New Chat Message: "+chatmessage.msg);
listener.messageAction(chatmessage.msg, chatmessage.room);
}
// register to a room
else if(chatmessage.type == ChatMessage.ChatMessageType.REGISTER){
registerUser(chatmessage.room, socket);
}
// unregister to a room
else if(chatmessage.type == ChatMessage.ChatMessageType.UNREGISTER){
unRegisterUser(chatmessage.room, socket);
2008-11-14 16:38:36 +00:00
}
}
} catch (Exception e) {
e.printStackTrace();
2008-11-14 16:38:36 +00:00
}
}
/**
* Registers a user to the main room
*
* @param socket The socket to the user
*/
public void registerUser(SocketChannel socket){
registerUser("", socket);
}
/**
* Registers the given user to a specific room
*
* @param room The room
* @param socket The socket to the user
*/
public void registerUser(String room, SocketChannel socket){
addRoom(room);
logger.fine("New Chat User: "+socket);
2008-11-14 16:38:36 +00:00
rooms.get(room).add(socket);
}
/**
* Unregisters a user from a room and removes the room if its empty
*
* @param room The room
* @param socket The socket to the user
*/
public void unRegisterUser(String room, SocketChannel socket){
if(rooms.containsKey(room)){
logger.fine("Remove Chat User: "+socket);
2008-11-14 16:38:36 +00:00
rooms.get(room).remove(socket);
removeRoom(room);
}
}
/**
* Adds a room into the list
*
* @param room The name of the room
*/
public void addRoom(String room){
if(!rooms.containsKey(room)){
logger.fine("New Chat Room: "+room);
2008-11-14 16:38:36 +00:00
rooms.put(room, new LinkedList<SocketChannel>());
}
}
/**
* Removes the given room if its empty
*
* @param room The room
*/
public void removeRoom(String room){
if(rooms.get(room).isEmpty()){
logger.fine("Remove Chat Room: "+room);
2008-11-14 16:38:36 +00:00
rooms.remove(room);
}
}
public static ChatService getInstance(){
return (ChatService)instance;
}
}