/**
* Copyright (C) 2010-2014 Leon Blakey <lord.quackstar at gmail.com>
*
* This file is part of PircBotX.
*
* PircBotX 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.
*
* PircBotX 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
* PircBotX. If not, see <http://www.gnu.org/licenses/>.
*/
package org.pircbotx.hooks.events;
import javax.annotation.Nullable;
import lombok.Data;
import lombok.EqualsAndHashCode;
import lombok.Getter;
import org.pircbotx.hooks.Event;
import org.pircbotx.PircBotX;
import org.pircbotx.hooks.types.GenericSnapshotEvent;
import org.pircbotx.snapshot.UserChannelDaoSnapshot;
/**
* This event is dispatched when we get disconnected. It is meant for the bot to
* carry out actions upon disconnection. This may happen if the PircBotX quits
* from the server, or if the connection is unexpectedly lost.
* <p>
* Disconnection from the IRC server is detected immediately if either we or the
* server close the connection normally. If the connection to the server is
* lost, but neither we nor the server have explicitly closed the connection,
* then it may take a few minutes to detect (this is commonly referred to as a
* "ping timeout").
*
* @author Leon Blakey
*/
@Data
@EqualsAndHashCode(callSuper = true)
public class DisconnectEvent extends Event implements GenericSnapshotEvent {
@Getter(onMethod = @_(
@Override))
protected final UserChannelDaoSnapshot userChannelDaoSnapshot;
/**
* Exception encountered during disconnection, if any
*/
protected final Exception disconnectException;
public DisconnectEvent(PircBotX bot, UserChannelDaoSnapshot userChannelDaoSnapshot, Exception disconnectException) {
super(bot);
this.userChannelDaoSnapshot = userChannelDaoSnapshot;
this.disconnectException = disconnectException;
}
/**
* @see #getUserChannelDaoSnapshot()
* @see GenericSnapshotEvent
* @deprecated Use {@link #getUserChannelDaoSnapshot() } from
* {@link GenericSnapshotEvent}
*/
@Deprecated
public UserChannelDaoSnapshot getDaoSnapshot() {
return userChannelDaoSnapshot;
}
/**
* Does NOT respond to the server! This will throw an
* {@link UnsupportedOperationException} since we can't respond to a server
* we just disconnected from.
*
* @param response The response to send
*/
@Override
@Deprecated
public void respond(String response) {
throw new UnsupportedOperationException("Attepting to respond to a disconnected server");
}
}