Yaaic/src/org/yaaic/irc/IRCConnection.java

599 lines
17 KiB
Java
Raw Normal View History

2009-12-17 15:27:57 -05:00
/*
2010-03-12 14:35:25 -05:00
Yaaic - Yet Another Android IRC Client
2009-12-17 15:27:57 -05:00
2010-03-13 10:52:20 -05:00
Copyright 2009-2010 Sebastian Kaspari
2009-12-17 15:27:57 -05:00
This file is part of Yaaic.
Yaaic is free software: you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation, either version 3 of the License, or
(at your option) any later version.
Yaaic is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with Yaaic. If not, see <http://www.gnu.org/licenses/>.
*/
package org.yaaic.irc;
2010-03-09 15:58:05 -05:00
import java.util.Vector;
2009-12-17 15:27:57 -05:00
import android.content.Intent;
2010-03-02 12:42:44 -05:00
import android.util.Log;
2009-12-17 15:27:57 -05:00
import org.jibble.pircbot.Colors;
2009-12-17 15:27:57 -05:00
import org.jibble.pircbot.PircBot;
2010-03-02 12:42:44 -05:00
import org.jibble.pircbot.User;
2009-12-17 15:27:57 -05:00
2010-03-06 13:15:27 -05:00
import org.yaaic.R;
2009-12-17 15:27:57 -05:00
import org.yaaic.Yaaic;
import org.yaaic.model.Broadcast;
2010-03-02 13:40:05 -05:00
import org.yaaic.model.Channel;
2010-03-10 15:34:20 -05:00
import org.yaaic.model.Conversation;
2010-03-06 11:52:22 -05:00
import org.yaaic.model.Message;
2010-03-10 15:34:20 -05:00
import org.yaaic.model.Query;
2009-12-17 15:27:57 -05:00
import org.yaaic.model.Server;
2010-03-10 17:06:40 -05:00
import org.yaaic.model.ServerInfo;
2009-12-17 15:27:57 -05:00
import org.yaaic.model.Status;
public class IRCConnection extends PircBot
{
private IRCService service;
private Server server;
2010-03-02 12:42:44 -05:00
// XXX: Print all IRC events to the debug console
private static final boolean DEBUG_EVENTS = true;
public static final String TAG = "Yaaic/IRCConnection";
/**
* Create a new connection
*
* @param service
* @param serverId
*/
2009-12-17 15:27:57 -05:00
public IRCConnection(IRCService service, int serverId)
{
this.server = Yaaic.getInstance().getServerById(serverId);
this.service = service;
this.setAutoNickChange(true);
}
2010-03-13 08:58:01 -05:00
/**
* Set the nickname of the user
*
* @param nickname The nickname to use
*/
public void setNickname(String nickname)
{
this.setName(nickname);
}
public void setRealName(String realname)
{
// XXX: Pircbot uses the version for "real name" and "version".
// The real "version" value is provided by onVersion()
this.setVersion(realname);
}
/**
* On version (CTCP version)
*
* This is a fix for pircbot as pircbot uses the version as "real name" and as "version"
*/
@Override
protected void onVersion(String sourceNick, String sourceLogin, String sourceHostname, String target) {
this.sendRawLine(
"NOTICE " + sourceNick + " :\u0001VERSION " +
"Yaaic - Yet another Android IRC client - http://www.yaaic.org" +
"\u0001"
);
}
2010-03-13 08:58:01 -05:00
/**
* Set the ident of the user
*
* @param ident The ident to use
*/
public void setIdent(String ident)
{
this.setLogin(ident);
}
2009-12-17 15:27:57 -05:00
/**
* On connect
*/
@Override
public void onConnect()
{
2010-03-02 13:40:05 -05:00
debug("Connect", "");
2009-12-17 15:27:57 -05:00
server.setStatus(Status.CONNECTED);
service.sendBroadcast(new Intent(Broadcast.SERVER_UPDATE));
2010-03-10 17:57:31 -05:00
Message message = new Message("Connected to " + server.getTitle());
message.setColor(Message.COLOR_GREEN);
server.getConversation(ServerInfo.DEFAULT_NAME).addMessage(message);
Intent intent = new Intent(Broadcast.CONVERSATION_MESSAGE);
2010-03-10 17:57:31 -05:00
intent.putExtra(Broadcast.EXTRA_SERVER, server.getId());
intent.putExtra(Broadcast.EXTRA_CONVERSATION, ServerInfo.DEFAULT_NAME);
2010-03-10 17:57:31 -05:00
service.sendBroadcast(intent);
2009-12-17 15:27:57 -05:00
}
2010-03-02 12:42:44 -05:00
/**
* On channel action
*/
@Override
protected void onAction(String sender, String login, String hostname, String target, String action)
{
debug("Action", target + " " + sender + " " + action);
// Strip mIRC colors and formatting
action = Colors.removeFormattingAndColors(action);
Message message = new Message(sender + " " + action);
message.setIcon(R.drawable.action);
if (target.equals(this.getNick())) {
// We are the target - this is an action in a query
Conversation conversation = server.getConversation(sender);
if (conversation == null) {
// Open a query if there's none yet
conversation = new Query(sender);
server.addConversationl(conversation);
conversation.addMessage(message);
Intent intent = new Intent(Broadcast.CONVERSATION_NEW);
intent.putExtra(Broadcast.EXTRA_CONVERSATION, sender);
intent.putExtra(Broadcast.EXTRA_SERVER, server.getId());
service.sendBroadcast(intent);
} else {
Intent intent = new Intent(Broadcast.CONVERSATION_MESSAGE);
intent.putExtra(Broadcast.EXTRA_SERVER, server.getId());
intent.putExtra(Broadcast.EXTRA_CONVERSATION, sender);
service.sendBroadcast(intent);
}
} else {
// A action in a channel
server.getConversation(target).addMessage(message);
Intent intent = new Intent(Broadcast.CONVERSATION_MESSAGE);
intent.putExtra(Broadcast.EXTRA_SERVER, server.getId());
intent.putExtra(Broadcast.EXTRA_CONVERSATION, target);
service.sendBroadcast(intent);
}
2010-03-02 12:42:44 -05:00
}
/**
* On Channel Info
*/
@Override
protected void onChannelInfo(String channel, int userCount, String topic)
{
debug("ChannelInfo", channel + " " + userCount);
}
/**
* On Deop
*/
@Override
protected void onDeop(String target, String sourceNick, String sourceLogin, String sourceHostname, String recipient)
2010-03-02 12:42:44 -05:00
{
debug("Deop", target + " " + recipient + "(" + sourceNick + ")");
2010-03-06 11:52:22 -05:00
Message message = new Message(sourceNick + " deoped " + recipient);
2010-03-06 13:15:27 -05:00
message.setIcon(R.drawable.op);
2010-03-06 14:58:53 -05:00
message.setColor(Message.COLOR_BLUE);
server.getConversation(target).addMessage(message);
Intent intent = new Intent(Broadcast.CONVERSATION_MESSAGE);
2010-03-05 13:47:19 -05:00
intent.putExtra(Broadcast.EXTRA_SERVER, server.getId());
intent.putExtra(Broadcast.EXTRA_CONVERSATION, target);
service.sendBroadcast(intent);
2010-03-02 12:42:44 -05:00
}
/**
* On DeVoice
*/
@Override
protected void onDeVoice(String target, String sourceNick, String sourceLogin, String sourceHostname, String recipient)
2010-03-02 12:42:44 -05:00
{
debug("DeVoice", target + " " + recipient + "(" + sourceNick + ")");
2010-03-06 11:52:22 -05:00
Message message = new Message(sourceNick + " devoiced " + recipient);
2010-03-06 14:58:53 -05:00
message.setColor(Message.COLOR_BLUE);
2010-03-06 13:15:27 -05:00
message.setIcon(R.drawable.voice);
server.getConversation(target).addMessage(message);
Intent intent = new Intent(Broadcast.CONVERSATION_MESSAGE);
2010-03-05 13:47:19 -05:00
intent.putExtra(Broadcast.EXTRA_SERVER, server.getId());
intent.putExtra(Broadcast.EXTRA_CONVERSATION, target);
service.sendBroadcast(intent);
2010-03-02 12:42:44 -05:00
}
/**
* On Invite
*/
@Override
protected void onInvite(String targetNick, String sourceNick, String sourceLogin, String sourceHostname, String target)
2010-03-02 12:42:44 -05:00
{
debug("Invite", target + " " + targetNick + "(" + sourceNick + ")");
2010-03-06 11:52:22 -05:00
Message message = new Message(sourceNick + " invited " + targetNick);
server.getConversation(target).addMessage(message);
Intent intent = new Intent(Broadcast.CONVERSATION_MESSAGE);
2010-03-05 13:47:19 -05:00
intent.putExtra(Broadcast.EXTRA_SERVER, server.getId());
intent.putExtra(Broadcast.EXTRA_CONVERSATION, target);
service.sendBroadcast(intent);
2010-03-02 12:42:44 -05:00
}
/**
* On Join
*/
@Override
2010-03-02 13:43:27 -05:00
protected void onJoin(String target, String sender, String login, String hostname)
2010-03-02 12:42:44 -05:00
{
2010-03-02 13:43:27 -05:00
debug("Join", target + " " + sender);
2010-03-02 13:40:05 -05:00
if (sender.equals(getNick())) {
// We joined a new channel
server.addConversationl(new Channel(target));
Intent intent = new Intent(Broadcast.CONVERSATION_NEW);
intent.putExtra(Broadcast.EXTRA_CONVERSATION, target);
2010-03-05 13:47:19 -05:00
intent.putExtra(Broadcast.EXTRA_SERVER, server.getId());
service.sendBroadcast(intent);
2010-03-02 13:43:27 -05:00
} else {
2010-03-06 11:52:22 -05:00
Message message = new Message(sender + " joined");
2010-03-06 13:15:27 -05:00
message.setIcon(R.drawable.join);
2010-03-06 14:58:53 -05:00
message.setColor(Message.COLOR_GREEN);
server.getConversation(target).addMessage(message);
Intent intent = new Intent(Broadcast.CONVERSATION_MESSAGE);
2010-03-05 13:47:19 -05:00
intent.putExtra(Broadcast.EXTRA_SERVER, server.getId());
intent.putExtra(Broadcast.EXTRA_CONVERSATION, target);
service.sendBroadcast(intent);
2010-03-02 13:40:05 -05:00
}
2010-03-02 12:42:44 -05:00
}
/**
* On Kick
*/
@Override
2010-03-02 13:47:43 -05:00
protected void onKick(String target, String kickerNick, String kickerLogin, String kickerHostname, String recipientNick, String reason)
2010-03-02 12:42:44 -05:00
{
2010-03-02 13:47:43 -05:00
debug("Kick", target + " " + recipientNick + "(" + kickerNick + ")");
if (recipientNick.equals(getNick())) {
// We are kicked
server.removeConversation(target);
Intent intent = new Intent(Broadcast.CONVERSATION_REMOVE);
2010-03-05 13:47:19 -05:00
intent.putExtra(Broadcast.EXTRA_SERVER, server.getId());
intent.putExtra(Broadcast.EXTRA_CONVERSATION, target);
service.sendBroadcast(intent);
2010-03-02 13:47:43 -05:00
} else {
2010-03-06 11:52:22 -05:00
Message message = new Message(kickerNick + " kicked " + recipientNick);
2010-03-06 14:58:53 -05:00
message.setColor(Message.COLOR_GREEN);
server.getConversation(target).addMessage(message);
Intent intent = new Intent(Broadcast.CONVERSATION_MESSAGE);
2010-03-05 13:47:19 -05:00
intent.putExtra(Broadcast.EXTRA_SERVER, server.getId());
intent.putExtra(Broadcast.EXTRA_CONVERSATION, target);
service.sendBroadcast(intent);
2010-03-02 13:47:43 -05:00
}
2010-03-02 12:42:44 -05:00
}
/**
* On Message
*/
@Override
2010-03-06 11:52:22 -05:00
protected void onMessage(String target, String sender, String login, String hostname, String text)
2010-03-02 12:42:44 -05:00
{
2010-03-06 11:52:22 -05:00
debug("Message", target + " " + sender + " " + text);
// Strip mIRC colors and formatting
text = Colors.removeFormattingAndColors(text);
2010-03-02 13:48:12 -05:00
2010-03-06 11:52:22 -05:00
Message message = new Message("<" + sender + "> " + text);
server.getConversation(target).addMessage(message);
Intent intent = new Intent(Broadcast.CONVERSATION_MESSAGE);
2010-03-05 13:47:19 -05:00
intent.putExtra(Broadcast.EXTRA_SERVER, server.getId());
intent.putExtra(Broadcast.EXTRA_CONVERSATION, target);
service.sendBroadcast(intent);
2010-03-02 12:42:44 -05:00
}
/**
* On Mode
*/
@Override
2010-03-02 13:48:59 -05:00
protected void onMode(String target, String sourceNick, String sourceLogin, String sourceHostname, String mode)
2010-03-02 12:42:44 -05:00
{
2010-03-02 13:48:59 -05:00
debug("Mode", target + " " + sourceNick + " " + mode);
/*//Disabled as it doubles events (e.g. onOp and onMode will be called)
2010-03-06 11:52:22 -05:00
Message message = new Message(sourceNick + " sets mode " + mode);
server.getChannel(target).addMessage(message);
Intent intent = new Intent(Broadcast.CHANNEL_MESSAGE);
2010-03-05 13:47:19 -05:00
intent.putExtra(Broadcast.EXTRA_SERVER, server.getId());
intent.putExtra(Broadcast.EXTRA_CHANNEL, target);
service.sendBroadcast(intent);
*/
2010-03-02 12:42:44 -05:00
}
/**
* On Nick Change
*/
@Override
protected void onNickChange(String oldNick, String login, String hostname, String newNick)
{
debug("Nick", oldNick + " " + newNick);
2010-03-06 11:52:22 -05:00
2010-03-09 15:58:05 -05:00
for (String target : getChannelsByNickname(newNick)) {
Message message = new Message(oldNick + " is now known as " + newNick);
message.setColor(Message.COLOR_GREEN);
server.getConversation(target).addMessage(message);
2010-03-09 15:58:05 -05:00
Intent intent = new Intent(Broadcast.CONVERSATION_MESSAGE);
2010-03-09 15:58:05 -05:00
intent.putExtra(Broadcast.EXTRA_SERVER, server.getId());
intent.putExtra(Broadcast.EXTRA_CONVERSATION, target);
2010-03-09 15:58:05 -05:00
service.sendBroadcast(intent);
}
2010-03-02 12:42:44 -05:00
}
/**
* On Notice
*/
@Override
protected void onNotice(String sourceNick, String sourceLogin, String sourceHostname, String target, String notice)
{
debug("Notice", sourceNick + " " + notice);
2010-03-06 11:52:22 -05:00
// Strip mIRC colors and formatting
notice = Colors.removeFormattingAndColors(notice);
2010-03-10 17:06:40 -05:00
// Post notice to currently selected conversation
Conversation conversation = server.getConversation(server.getSelectedConversation());
if (conversation == null) {
// Fallback: Use ServerInfo view
conversation = server.getConversation(ServerInfo.DEFAULT_NAME);
}
Message message = new Message("-" + sourceNick + "- " + notice);
message.setIcon(R.drawable.info);
conversation.addMessage(message);
Intent intent = new Intent(Broadcast.CONVERSATION_MESSAGE);
2010-03-10 17:06:40 -05:00
intent.putExtra(Broadcast.EXTRA_SERVER, server.getId());
intent.putExtra(Broadcast.EXTRA_CONVERSATION, conversation.getName());
2010-03-10 17:06:40 -05:00
service.sendBroadcast(intent);
2010-03-02 12:42:44 -05:00
}
/**
* On Op
*/
@Override
2010-03-02 13:52:49 -05:00
protected void onOp(String target, String sourceNick, String sourceLogin, String sourceHostname, String recipient)
2010-03-02 12:42:44 -05:00
{
2010-03-02 13:52:49 -05:00
debug("Op", target + " " + recipient + "(" + sourceNick + ")");
2010-03-06 11:52:22 -05:00
Message message = new Message(sourceNick + " oped " + recipient);
2010-03-06 14:58:53 -05:00
message.setColor(Message.COLOR_BLUE);
2010-03-06 13:15:27 -05:00
message.setIcon(R.drawable.op);
server.getConversation(target).addMessage(message);
Intent intent = new Intent(Broadcast.CONVERSATION_MESSAGE);
2010-03-05 13:47:19 -05:00
intent.putExtra(Broadcast.EXTRA_SERVER, server.getId());
intent.putExtra(Broadcast.EXTRA_CONVERSATION, target);
service.sendBroadcast(intent);
2010-03-02 12:42:44 -05:00
}
/**
* On Part
*/
@Override
2010-03-02 13:54:34 -05:00
protected void onPart(String target, String sender, String login, String hostname)
2010-03-02 12:42:44 -05:00
{
2010-03-02 13:54:34 -05:00
debug("Part", target + " " + sender);
if (sender.equals(getNick())) {
2010-03-10 19:10:21 -05:00
// We parted a channel
server.removeConversation(target);
Intent intent = new Intent(Broadcast.CONVERSATION_REMOVE);
2010-03-05 13:47:19 -05:00
intent.putExtra(Broadcast.EXTRA_SERVER, server.getId());
intent.putExtra(Broadcast.EXTRA_CONVERSATION, target);
service.sendBroadcast(intent);
2010-03-02 13:54:34 -05:00
} else {
2010-03-06 11:52:22 -05:00
Message message = new Message(sender + " parted");
2010-03-06 14:58:53 -05:00
message.setColor(Message.COLOR_GREEN);
2010-03-06 13:15:27 -05:00
message.setIcon(R.drawable.part);
server.getConversation(target).addMessage(message);
Intent intent = new Intent(Broadcast.CONVERSATION_MESSAGE);
2010-03-05 13:47:19 -05:00
intent.putExtra(Broadcast.EXTRA_SERVER, server.getId());
intent.putExtra(Broadcast.EXTRA_CONVERSATION, target);
service.sendBroadcast(intent);
2010-03-02 13:54:34 -05:00
}
2010-03-02 12:42:44 -05:00
}
/**
* On Private Message
*/
@Override
2010-03-10 15:34:20 -05:00
protected void onPrivateMessage(String sender, String login, String hostname, String text)
2010-03-02 12:42:44 -05:00
{
2010-03-10 15:34:20 -05:00
debug("PrivateMessage", sender + " " + text);
2010-03-06 13:15:27 -05:00
// Strip mIRC colors and formatting
2010-03-10 15:34:20 -05:00
text = Colors.removeFormattingAndColors(text);
Message message = new Message("<" + sender + "> " + text);
2010-03-10 15:34:20 -05:00
Conversation conversation = server.getConversation(sender);
if (conversation == null) {
// Open a query if there's none yet
conversation = new Query(sender);
conversation.addMessage(message);
server.addConversationl(conversation);
2010-03-10 15:34:20 -05:00
Intent intent = new Intent(Broadcast.CONVERSATION_NEW);
intent.putExtra(Broadcast.EXTRA_CONVERSATION, sender);
2010-03-10 15:34:20 -05:00
intent.putExtra(Broadcast.EXTRA_SERVER, server.getId());
service.sendBroadcast(intent);
} else {
conversation.addMessage(message);
Intent intent = new Intent(Broadcast.CONVERSATION_MESSAGE);
2010-03-10 15:34:20 -05:00
intent.putExtra(Broadcast.EXTRA_SERVER, server.getId());
intent.putExtra(Broadcast.EXTRA_CONVERSATION, sender);
2010-03-10 15:34:20 -05:00
service.sendBroadcast(intent);
}
2010-03-02 12:42:44 -05:00
}
/**
* On Quit
*/
@Override
protected void onQuit(String sourceNick, String sourceLogin, String sourceHostname, String reason)
{
debug("Quit", sourceNick);
2010-03-08 13:55:32 -05:00
if (!sourceNick.equals(this.getNick())) {
for (String target : getChannelsByNickname(sourceNick)) {
2010-03-11 16:58:01 -05:00
Message message = new Message(sourceNick + " quitted (" + reason + ")");
message.setColor(Message.COLOR_GREEN);
message.setIcon(R.drawable.quit);
server.getConversation(target).addMessage(message);
Intent intent = new Intent(Broadcast.CONVERSATION_MESSAGE);
intent.putExtra(Broadcast.EXTRA_SERVER, server.getId());
intent.putExtra(Broadcast.EXTRA_CONVERSATION, target);
service.sendBroadcast(intent);
}
} else {
// XXX: We quitted
}
2010-03-02 12:42:44 -05:00
}
/**
* On Topic
*/
@Override
public void onTopic(String target, String topic, String setBy, long date, boolean changed)
2010-03-02 12:42:44 -05:00
{
2010-03-02 13:59:37 -05:00
debug("Topic", target + " " + setBy + " " + topic);
if (changed) {
2010-03-06 11:52:22 -05:00
Message message = new Message(setBy + " sets topic: " + topic);
2010-03-06 14:58:53 -05:00
message.setColor(Message.COLOR_YELLOW);
server.getConversation(target).addMessage(message);
2010-03-02 13:59:37 -05:00
} else {
2010-03-06 11:52:22 -05:00
Message message = new Message("Topic: " + topic);
2010-03-06 14:58:53 -05:00
message.setColor(Message.COLOR_YELLOW);
server.getConversation(target).addMessage(message);
2010-03-02 13:59:37 -05:00
}
// remember channel's topic
((Channel) server.getConversation(target)).setTopic(topic);
Intent intent = new Intent(Broadcast.CONVERSATION_MESSAGE);
2010-03-05 13:47:19 -05:00
intent.putExtra(Broadcast.EXTRA_SERVER, server.getId());
intent.putExtra(Broadcast.EXTRA_CONVERSATION, target);
service.sendBroadcast(intent);
2010-03-02 12:42:44 -05:00
}
/**
* On User List
*/
@Override
protected void onUserList(String channel, User[] users)
{
debug("UserList", channel + " (" + users.length + ")");
2010-03-06 11:52:22 -05:00
// XXX: Store user list somewhere and keep it updated or just broadcast some event?
2010-03-02 12:42:44 -05:00
}
/**
* On Voice
*/
@Override
protected void onVoice(String target, String sourceNick, String sourceLogin, String sourceHostname, String recipient)
2010-03-02 12:42:44 -05:00
{
debug("Voice", target + " " + recipient + "(" + sourceNick + ")");
2010-03-06 11:52:22 -05:00
Message message = new Message(sourceNick + " voiced " + recipient);
2010-03-06 13:15:27 -05:00
message.setIcon(R.drawable.voice);
2010-03-06 14:58:53 -05:00
message.setColor(Message.COLOR_BLUE);
server.getConversation(target).addMessage(message);
Intent intent = new Intent(Broadcast.CONVERSATION_MESSAGE);
2010-03-05 13:47:19 -05:00
intent.putExtra(Broadcast.EXTRA_SERVER, server.getId());
intent.putExtra(Broadcast.EXTRA_CONVERSATION, target);
service.sendBroadcast(intent);
2010-03-02 12:42:44 -05:00
}
2009-12-17 15:27:57 -05:00
/**
* On disconnect
*/
@Override
public void onDisconnect()
{
server.setStatus(Status.DISCONNECTED);
service.sendBroadcast(new Intent(Broadcast.SERVER_UPDATE));
}
2010-03-02 12:42:44 -05:00
/**
* Print an event to the debug console
*/
private void debug(String event, String params)
{
if (DEBUG_EVENTS) {
2010-03-02 13:40:05 -05:00
Log.d(TAG, "(" + server.getTitle() + ") [" + event + "]: " + params);
2010-03-02 12:42:44 -05:00
}
}
2010-03-09 15:58:05 -05:00
/**
* Get all channels where the user with the given nickname is online
*
* @param nickname
* @return Array of channel names
*/
private Vector<String> getChannelsByNickname(String nickname)
{
Vector<String> channels = new Vector<String>();
for (String channel : this.getChannels()) {
for (User user : this.getUsers(channel)) {
if (user.getNick().equals(nickname)) {
channels.add(channel);
break;
}
}
}
Log.d(TAG, "Found " + channels.size() + " channels for nickname " + nickname);
return channels;
}
2009-12-17 15:27:57 -05:00
/**
* Quits from the IRC server with default reason.
*/
@Override
public void quitServer()
{
quitServer("Yaaic - Yet another Android IRC client - http://www.yaaic.org");
}
}