1
0
mirror of https://github.com/moparisthebest/Yaaic synced 2025-01-07 19:58:10 -05:00

Bugfix: Only automatically change nickname on server code 433 if not already registered with server

This commit is contained in:
Sebastian Kaspari 2011-04-12 22:23:51 +02:00
parent aa5a081c02
commit dd07bd358a
2 changed files with 37 additions and 2 deletions

View File

@ -139,6 +139,7 @@ public abstract class PircBot implements ReplyConstants {
* @throws NickAlreadyInUseException if our nick is already in use on the server.
*/
public final synchronized void connect(String hostname, int port, String password) throws IOException, IrcException, NickAlreadyInUseException {
_registered = false;
_server = hostname;
_port = port;
@ -876,7 +877,7 @@ public abstract class PircBot implements ReplyConstants {
String errorStr = token;
String response = line.substring(line.indexOf(errorStr, senderInfo.length()) + 4, line.length());
if (code == 433) {
if (code == 433 && !_registered) {
if (_autoNickChange) {
List<String> aliases = getAliases();
_autoNickTries++;
@ -1068,6 +1069,17 @@ public abstract class PircBot implements ReplyConstants {
*/
protected void onConnect() {}
/**
* This method is called once the client is registered with the server -
* meaning the client recieved server code 004.
*
* @since Yaaic
*/
protected void onRegister()
{
_registered = true;
}
/**
* This method carries out the actions to be performed when the PircBot
@ -1087,7 +1099,10 @@ public abstract class PircBot implements ReplyConstants {
* The implementation of this method in the PircBot abstract class
* performs no actions and may be overridden as required.
*/
protected void onDisconnect() {}
protected void onDisconnect()
{
_registered = false;
}
/**
@ -2460,6 +2475,18 @@ public abstract class PircBot implements ReplyConstants {
return _inputThread != null && _inputThread.isConnected();
}
/**
* Returns wether or not the client is registered with the server.
*
* @since Yaaic
*
* @return True if server code 004 has been received. False otherwise.
*/
public final synchronized boolean isRegistered()
{
return _registered;
}
/**
* Sets the number of milliseconds to delay between consecutive
@ -3082,6 +3109,7 @@ public abstract class PircBot implements ReplyConstants {
private boolean _autoNickChange = false;
private int _autoNickTries = 1;
private boolean _useSSL = false;
private boolean _registered = false;
private String _name = "PircBot";
private final List<String> _aliases = new ArrayList<String>();

View File

@ -160,8 +160,12 @@ public class IRCConnection extends PircBot
/**
* On register
*/
@Override
public void onRegister()
{
// Call parent method to ensure "register" status is tracked
super.onRegister();
// execute commands
CommandParser parser = CommandParser.getInstance();
@ -1047,6 +1051,9 @@ public class IRCConnection extends PircBot
@Override
public void onDisconnect()
{
// Call parent method to ensure "register" status is tracked
super.onDisconnect();
if (service.getSettings().isReconnectEnabled() && server.getStatus() != Status.DISCONNECTED) {
setAutojoinChannels(server.getCurrentChannelNames());