aboutsummaryrefslogtreecommitdiffstats
path: root/src/net/java/sip/communicator/impl/protocol
diff options
context:
space:
mode:
Diffstat (limited to 'src/net/java/sip/communicator/impl/protocol')
-rw-r--r--src/net/java/sip/communicator/impl/protocol/irc/ChatRoomIrcImpl.java43
-rw-r--r--src/net/java/sip/communicator/impl/protocol/irc/IdentityManager.java63
-rw-r--r--src/net/java/sip/communicator/impl/protocol/irc/IrcStack.java41
-rw-r--r--src/net/java/sip/communicator/impl/protocol/irc/MessageManager.java2
4 files changed, 83 insertions, 66 deletions
diff --git a/src/net/java/sip/communicator/impl/protocol/irc/ChatRoomIrcImpl.java b/src/net/java/sip/communicator/impl/protocol/irc/ChatRoomIrcImpl.java
index 3bca2b7..720160d 100644
--- a/src/net/java/sip/communicator/impl/protocol/irc/ChatRoomIrcImpl.java
+++ b/src/net/java/sip/communicator/impl/protocol/irc/ChatRoomIrcImpl.java
@@ -340,6 +340,10 @@ public class ChatRoomIrcImpl
{
final IrcConnection connection =
this.parentProvider.getIrcStack().getConnection();
+ if (connection == null)
+ {
+ return;
+ }
connection.getChannelManager().join(this, password.toString());
}
@@ -349,16 +353,20 @@ public class ChatRoomIrcImpl
* contains a user with this nickname, the method would throw an
* OperationFailedException with code IDENTIFICATION_CONFLICT.
*
+ * The provided nick name is ignored, since IRC does not support nick
+ * changes limited to a single chat room.
+ *
* @param nickname the nickname to use.
* @throws OperationFailedException with the corresponding code if an error
* occurs while joining the room.
*/
public void joinAs(final String nickname) throws OperationFailedException
{
- // TODO consider not supporting setting a nickname here, and re-enabling
- // set nick name option such that it is still possible to change nick on
- // demand.
- this.setUserNickname(nickname);
+ if (LOGGER.isDebugEnabled())
+ {
+ LOGGER.debug("Not setting nick name upon chat room join, since a "
+ + "nick change is not limited to a single chat room.");
+ }
this.join();
}
@@ -368,6 +376,9 @@ public class ChatRoomIrcImpl
* already contains a user with this nickname, the method would throw an
* OperationFailedException with code IDENTIFICATION_CONFLICT.
*
+ * The provided nick name is ignored, since IRC does not support nick
+ * changes limited to a single chat room.
+ *
* @param nickname the nickname to use.
* @param password a password necessary to authenticate when joining the
* room.
@@ -377,10 +388,11 @@ public class ChatRoomIrcImpl
public void joinAs(final String nickname, final byte[] password)
throws OperationFailedException
{
- // TODO consider not supporting setting a nickname here, and re-enabling
- // set nick name option such that it is still possible to change nick on
- // demand.
- this.setUserNickname(nickname);
+ if (LOGGER.isDebugEnabled())
+ {
+ LOGGER.debug("Not setting nick name upon chat room join, since a "
+ + "nick change is not limited to a single chat room.");
+ }
this.join(password);
}
@@ -707,14 +719,13 @@ public class ChatRoomIrcImpl
public void setUserNickname(final String nickName)
throws OperationFailedException
{
- // TODO Joining a chat room fails altogether if we throw an
- // OperationFailedException here.
- LOGGER.info("Setting a nick name for an individual chat room is not "
- + "supported for IRC.");
- // throw new OperationFailedException(
- // "Nick names are managed by the connection to the IRC server. They "
- // + "cannot be changed on the level of an invididual chat room.",
- // OperationFailedException.NOT_SUPPORTED_OPERATION);
+ final IrcConnection connection =
+ this.parentProvider.getIrcStack().getConnection();
+ if (connection == null)
+ {
+ return;
+ }
+ connection.getIdentityManager().setNick(nickName);
}
/**
diff --git a/src/net/java/sip/communicator/impl/protocol/irc/IdentityManager.java b/src/net/java/sip/communicator/impl/protocol/irc/IdentityManager.java
index 1ae842e..d5ba905 100644
--- a/src/net/java/sip/communicator/impl/protocol/irc/IdentityManager.java
+++ b/src/net/java/sip/communicator/impl/protocol/irc/IdentityManager.java
@@ -6,6 +6,8 @@
*/
package net.java.sip.communicator.impl.protocol.irc;
+import java.util.*;
+
import net.java.sip.communicator.util.*;
import com.ircclouds.irc.api.*;
@@ -33,6 +35,22 @@ public class IdentityManager
.getLogger(IdentityManager.class);
/**
+ * Reserved symbols. These symbols have special meaning and cannot be
+ * used to start nick names.
+ */
+ private static final Set<Character> RESERVED;
+
+ /**
+ * Initialize RESERVED symbols set.
+ */
+ static {
+ final HashSet<Character> reserved = new HashSet<Character>();
+ reserved.add('#');
+ reserved.add('&');
+ RESERVED = Collections.unmodifiableSet(reserved);
+ }
+
+ /**
* The IRCApi instance.
*
* Instance must be thread-safe!
@@ -93,6 +111,41 @@ public class IdentityManager
}
/**
+ * Set a new nick name.
+ *
+ * TODO Check ISUPPORT 'NICKLEN' for maximum nick length.
+ *
+ * @param nick new nick
+ */
+ public void setNick(final String nick)
+ {
+ this.irc.changeNick(checkNick(nick));
+ }
+
+ /**
+ * Verify nick name.
+ *
+ * @param nick nick name
+ * @return returns nick name
+ */
+ public static String checkNick(final String nick)
+ {
+ if (nick == null)
+ {
+ throw new IllegalArgumentException(
+ "a nick name must be provided");
+ }
+ // TODO Add '+' and '!' to reserved symbols too?
+ if (RESERVED.contains(nick.charAt(0)))
+ {
+ throw new IllegalArgumentException(
+ "the nick name must not start with '#' or '&' "
+ + "since this is reserved for IRC channels");
+ }
+ return nick;
+ }
+
+ /**
* Get the current identity string, based on nick, user and host of local
* user.
*
@@ -213,16 +266,6 @@ public class IdentityManager
private String host = null;
/**
- * Constructor.
- *
- * @param user user
- * @param host host
- */
- private Identity()
- {
- }
-
- /**
* Set user.
*
* @param user the new user
diff --git a/src/net/java/sip/communicator/impl/protocol/irc/IrcStack.java b/src/net/java/sip/communicator/impl/protocol/irc/IrcStack.java
index f3a2ec7..0c1571c 100644
--- a/src/net/java/sip/communicator/impl/protocol/irc/IrcStack.java
+++ b/src/net/java/sip/communicator/impl/protocol/irc/IrcStack.java
@@ -259,22 +259,6 @@ public class IrcStack
private static final int NUM_INCREMENTS_FOR_ALTERNATIVES = 10;
/**
- * Reserved symbols. These symbols have special meaning and cannot be
- * used to start nick names.
- */
- private static final Set<Character> RESERVED;
-
- /**
- * Initialize RESERVED symbols set.
- */
- static {
- final HashSet<Character> reserved = new HashSet<Character>();
- reserved.add('#');
- reserved.add('&');
- RESERVED = Collections.unmodifiableSet(reserved);
- }
-
- /**
* Nick name.
*/
private String nick;
@@ -309,7 +293,7 @@ public class IrcStack
private ServerParameters(final String nickName, final String realName,
final String ident, final IRCServer server)
{
- this.nick = checkNick(nickName);
+ this.nick = IdentityManager.checkNick(nickName);
this.alternativeNicks.add(nickName + "_");
this.alternativeNicks.add(nickName + "__");
this.alternativeNicks.add(nickName + "___");
@@ -335,29 +319,6 @@ public class IrcStack
}
/**
- * Verify nick name.
- *
- * @param nick nick name
- * @return returns nick name
- */
- private static String checkNick(final String nick)
- {
- if (nick == null)
- {
- throw new IllegalArgumentException(
- "a nick name must be provided");
- }
- // TODO Add '+' and '!' to reserved symbols too?
- if (RESERVED.contains(nick.charAt(0)))
- {
- throw new IllegalArgumentException(
- "the nick name must not start with '#' or '&' "
- + "since this is reserved for IRC channels");
- }
- return nick;
- }
-
- /**
* Get alternative nick names.
*
* @return returns list of alternatives
diff --git a/src/net/java/sip/communicator/impl/protocol/irc/MessageManager.java b/src/net/java/sip/communicator/impl/protocol/irc/MessageManager.java
index 2f3c025..9559411 100644
--- a/src/net/java/sip/communicator/impl/protocol/irc/MessageManager.java
+++ b/src/net/java/sip/communicator/impl/protocol/irc/MessageManager.java
@@ -175,6 +175,8 @@ public class MessageManager
}
else
{
+ // FIXME don't send as normal message just in case it contains
+ // valuable/vulnerable information (or if simply wasn't intended)
this.irc.message(source, message);
}
}