123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441 |
- /*
- * Copyright (c) 2006-2011 Chris Smith, Shane Mc Cormack, Gregory Holmes
- *
- * Permission is hereby granted, free of charge, to any person obtaining a copy
- * of this software and associated documentation files (the "Software"), to deal
- * in the Software without restriction, including without limitation the rights
- * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
- * copies of the Software, and to permit persons to whom the Software is
- * furnished to do so, subject to the following conditions:
- *
- * The above copyright notice and this permission notice shall be included in
- * all copies or substantial portions of the Software.
- *
- * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
- * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
- * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
- * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
- * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
- * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
- * SOFTWARE.
- */
-
- package com.dmdirc;
-
- import com.dmdirc.actions.ActionManager;
- import com.dmdirc.actions.CoreActionType;
- import com.dmdirc.logger.ErrorLevel;
- import com.dmdirc.logger.Logger;
- import com.dmdirc.parser.common.AwayState;
- import com.dmdirc.parser.common.CallbackManager;
- import com.dmdirc.parser.common.ParserError;
- import com.dmdirc.parser.interfaces.ChannelInfo;
- import com.dmdirc.parser.interfaces.ClientInfo;
- import com.dmdirc.parser.interfaces.Parser;
- import com.dmdirc.parser.interfaces.callbacks.*; //NOPMD
-
- import java.util.Date;
-
- /**
- * Handles parser events for a Server object.
- */
- public final class ServerEventHandler extends EventHandler implements
- ChannelSelfJoinListener, PrivateMessageListener, PrivateActionListener,
- ErrorInfoListener, PrivateCtcpListener, PrivateCtcpReplyListener,
- SocketCloseListener, PrivateNoticeListener, MotdStartListener,
- MotdLineListener, MotdEndListener, NumericListener, PingFailureListener,
- PingSuccessListener, AwayStateListener, ConnectErrorListener,
- NickInUseListener, AuthNoticeListener, UnknownNoticeListener,
- UserModeChangeListener, InviteListener, WallopListener,
- WalluserListener, WallDesyncListener, NickChangeListener,
- ServerErrorListener, PingSentListener, UserModeDiscoveryListener,
- ServerNoticeListener, UnknownMessageListener, UnknownActionListener,
- ServerReadyListener {
-
- /** The server instance that owns this event handler. */
- private final Server owner;
-
- /**
- * Creates a new instance of ServerEventHandler.
- *
- * @param owner The Server instance that we're handling events for
- */
- public ServerEventHandler(final Server owner) {
- super();
-
- this.owner = owner;
- }
-
- /** {@inheritDoc} */
- @Override
- @SuppressWarnings("unchecked")
- protected <T extends CallbackInterface> void addCallback(
- final CallbackManager cbm, final Class<T> type) {
- cbm.addCallback(type, (T) this);
- }
-
- /** {@inheritDoc} */
- @Override
- protected Server getServer() {
- return owner;
- }
-
- /** {@inheritDoc} */
- @Override
- public void onChannelSelfJoin(final Parser parser, final Date date, final ChannelInfo channel) {
- checkParser(parser);
- owner.addChannel(channel);
- }
-
- /** {@inheritDoc} */
- @Override
- public void onPrivateMessage(final Parser parser, final Date date, final String message,
- final String host) {
- checkParser(parser);
-
- if (!owner.hasQuery(host)) {
- owner.getQuery(host).onPrivateMessage(parser, date, message, host);
- }
- }
-
- /** {@inheritDoc} */
- @Override
- public void onPrivateAction(final Parser parser, final Date date, final String message,
- final String host) {
- checkParser(parser);
-
- if (!owner.hasQuery(host)) {
- owner.getQuery(host).onPrivateAction(parser, date, message, host);
- }
- }
-
- /** {@inheritDoc} */
- @Override
- public void onErrorInfo(final Parser parser, final Date date, final ParserError errorInfo) {
- final ErrorLevel errorLevel = ErrorLevel.UNKNOWN;
-
- final StringBuilder errorString = new StringBuilder();
- errorString.append("Parser exception.\n\n");
-
- errorString.append("\tLast line:\t");
- errorString.append(errorInfo.getLastLine()).append('\n');
-
- errorString.append("\tServer:\t");
- errorString.append(owner.getAddress()).append('\n');
-
- errorString.append("\tAdditional Information:\n");
- for (final String line : parser.getServerInformationLines()) {
- errorString.append("\t\t").append(line).append('\n');
- }
-
- final Exception ex = errorInfo.isException() ? errorInfo.getException()
- : new Exception(errorString.toString()); // NOPMD
-
- if (errorInfo.isUserError()) {
- Logger.userError(errorLevel, errorInfo.getData(), ex);
- } else {
- Logger.appError(errorLevel, errorInfo.getData(), ex);
- }
- }
-
- /** {@inheritDoc} */
- @Override
- public void onPrivateCTCP(final Parser parser, final Date date, final String type,
- final String message, final String host) {
- checkParser(parser);
-
- if (owner.doNotification("privateCTCP", CoreActionType.SERVER_CTCP,
- owner.getParser().getClient(host), type, message)) {
- owner.sendCTCPReply(owner.parseHostmask(host)[0], type, message);
- }
- }
-
- /** {@inheritDoc} */
- @Override
- public void onPrivateCTCPReply(final Parser parser, final Date date, final String type,
- final String message, final String host) {
- checkParser(parser);
-
- owner.doNotification("privateCTCPreply", CoreActionType.SERVER_CTCPR,
- owner.getParser().getClient(host), type, message);
- }
-
- /** {@inheritDoc} */
- @Override
- public void onSocketClosed(final Parser parser, final Date date) {
- if (owner.getParser() == parser) {
- owner.onSocketClosed();
- }
- }
-
- /** {@inheritDoc} */
- @Override
- public void onPrivateNotice(final Parser parser, final Date date,
- final String message, final String host) {
- checkParser(parser);
-
- owner.doNotification("privateNotice", CoreActionType.SERVER_NOTICE,
- owner.getParser().getClient(host), message);
- }
-
- /** {@inheritDoc} */
- @Override
- public void onServerNotice(final Parser parser, final Date date,
- final String message, final String host) {
- checkParser(parser);
-
- owner.doNotification("serverNotice", CoreActionType.SERVER_SERVERNOTICE,
- owner.getParser().getClient(host), message);
- }
-
- /** {@inheritDoc} */
- @Override
- public void onMOTDStart(final Parser parser, final Date date, final String data) {
- checkParser(parser);
-
- owner.doNotification("motdStart", CoreActionType.SERVER_MOTDSTART, data);
- }
-
- /** {@inheritDoc} */
- @Override
- public void onMOTDLine(final Parser parser, final Date date, final String data) {
- checkParser(parser);
-
- owner.doNotification("motdLine", CoreActionType.SERVER_MOTDLINE, data);
- }
-
- /** {@inheritDoc} */
- @Override
- public void onMOTDEnd(final Parser parser, final Date date,
- final boolean noMOTD, final String data) {
- checkParser(parser);
-
- owner.doNotification("motdEnd", CoreActionType.SERVER_MOTDEND, data);
- }
-
- /** {@inheritDoc} */
- @Override
- public void onNumeric(final Parser parser, final Date date, final int numeric,
- final String[] token) {
- checkParser(parser);
- owner.onNumeric(numeric, token);
- }
-
- /** {@inheritDoc} */
- @Override
- public void onPingFailed(final Parser parser, final Date date) {
- checkParser(parser);
- owner.onPingFailed();
- }
-
- /** {@inheritDoc} */
- @Override
- public void onPingSent(final Parser parser, final Date date) {
- checkParser(parser);
-
- ActionManager.getActionManager().triggerEvent(
- CoreActionType.SERVER_PINGSENT, null, owner);
- }
-
- /** {@inheritDoc} */
- @Override
- public void onPingSuccess(final Parser parser, final Date date) {
- checkParser(parser);
-
- ActionManager.getActionManager().triggerEvent(
- CoreActionType.SERVER_GOTPING, null, owner,
- Long.valueOf(owner.getParser().getServerLatency()));
- }
-
- /** {@inheritDoc} */
- @Override
- public void onAwayState(final Parser parser, final Date date, final AwayState oldState,
- final AwayState currentState, final String reason) {
- checkParser(parser);
-
- owner.updateAwayState(currentState == AwayState.AWAY ? reason : null);
-
- if (oldState == AwayState.UNKNOWN) {
- // Ignore discovered self away states
- return;
- }
-
- if (currentState == AwayState.AWAY) {
- owner.doNotification("away", CoreActionType.SERVER_AWAY, reason);
- } else {
- owner.doNotification("back", CoreActionType.SERVER_BACK);
- }
- }
-
- /** {@inheritDoc} */
- @Override
- public void onConnectError(final Parser parser, final Date date, final ParserError errorInfo) {
- checkParser(parser);
- owner.onConnectError(errorInfo);
- }
-
- /** {@inheritDoc} */
- @Override
- public void onNickInUse(final Parser parser, final Date date, final String nickname) {
- owner.onNickInUse(nickname);
- checkParser(parser);
- }
-
- /** {@inheritDoc} */
- @Override
- public void onServerReady(final Parser parser, final Date date) {
- checkParser(parser);
- owner.onPost005();
- }
-
- /** {@inheritDoc} */
- @Override
- public void onNoticeAuth(final Parser parser, final Date date, final String data) {
- checkParser(parser);
-
- owner.doNotification("authNotice", CoreActionType.SERVER_AUTHNOTICE, data);
- }
-
- /** {@inheritDoc} */
- @Override
- public void onUnknownNotice(final Parser parser, final Date date, final String message,
- final String target, final String host) {
- checkParser(parser);
-
- owner.doNotification("unknownNotice", CoreActionType.SERVER_UNKNOWNNOTICE,
- host, target, message);
- }
-
- /** {@inheritDoc} */
- @Override
- public void onUnknownMessage(final Parser parser, final Date date, final String message,
- final String target, final String host) {
- checkParser(parser);
-
- if (parser.getLocalClient().equals(parser.getClient(host))) {
- // Local client
- owner.getQuery(target).doNotification("querySelfExternalMessage",
- CoreActionType.QUERY_SELF_MESSAGE, parser.getLocalClient(), message);
- } else {
- owner.doNotification("unknownMessage", CoreActionType.SERVER_UNKNOWNNOTICE,
- host, target, message);
- }
- }
-
- /** {@inheritDoc} */
- @Override
- public void onUnknownAction(final Parser parser, final Date date, final String message,
- final String target, final String host) {
- checkParser(parser);
-
- if (parser.getLocalClient().equals(parser.getClient(host))) {
- // Local client
- owner.getQuery(target).doNotification("querySelfExternalAction",
- CoreActionType.QUERY_SELF_ACTION, parser.getLocalClient(), message);
- } else {
- owner.doNotification("unknownAction", CoreActionType.SERVER_UNKNOWNACTION,
- host, target, message);
- }
- }
-
- /** {@inheritDoc} */
- @Override
- public void onUserModeChanged(final Parser parser, final Date date,
- final ClientInfo client, final String host, final String modes) {
- checkParser(parser);
-
- owner.doNotification("userModeChanged", CoreActionType.SERVER_USERMODES,
- owner.getParser().getClient(host), modes);
- }
-
- /** {@inheritDoc} */
- @Override
- public void onUserModeDiscovered(final Parser parser, final Date date,
- final ClientInfo client, final String modes) {
- checkParser(parser);
-
- owner.doNotification(modes.isEmpty() || "+".equals(modes)
- ? "userNoModes" : "userModeDiscovered",
- CoreActionType.SERVER_USERMODES, client, modes);
- }
-
- /** {@inheritDoc} */
- @Override
- public void onInvite(final Parser parser, final Date date, final String userHost,
- final String channel) {
- checkParser(parser);
-
- owner.addInvite(new Invite(owner, channel, userHost));
- owner.doNotification("inviteReceived",
- CoreActionType.SERVER_INVITERECEIVED,
- owner.getParser().getClient(userHost), channel);
- }
-
- /** {@inheritDoc} */
- @Override
- public void onWallop(final Parser parser, final Date date, final String message,
- final String host) {
- checkParser(parser);
-
- owner.doNotification("wallop", CoreActionType.SERVER_WALLOPS,
- owner.getParser().getClient(host), message);
-
- }
-
- /** {@inheritDoc} */
- @Override
- public void onWalluser(final Parser parser, final Date date, final String message,
- final String host) {
- checkParser(parser);
-
- owner.doNotification("walluser", CoreActionType.SERVER_WALLUSERS,
- owner.getParser().getClient(host), message);
- }
-
- /** {@inheritDoc} */
- @Override
- public void onWallDesync(final Parser parser, final Date date, final String message,
- final String host) {
- checkParser(parser);
-
- owner.doNotification("walldesync", CoreActionType.SERVER_WALLDESYNC,
- owner.getParser().getClient(host), message);
- }
-
- /** {@inheritDoc} */
- @Override
- public void onNickChanged(final Parser parser, final Date date, final ClientInfo client,
- final String oldNick) {
- checkParser(parser);
-
- if (client.equals(owner.getParser().getLocalClient())) {
- owner.doNotification("selfNickChange", CoreActionType.SERVER_NICKCHANGE,
- oldNick, client.getNickname());
- owner.updateTitle();
- }
- }
-
- /** {@inheritDoc} */
- @Override
- public void onServerError(final Parser parser, final Date date, final String message) {
- checkParser(parser);
-
- owner.doNotification("serverError", CoreActionType.SERVER_ERROR, message);
- }
-
- /** {@inheritDoc} */
- @Override
- protected void checkParser(final Parser parser) {
- super.checkParser(parser);
-
- if (owner.getState() != ServerState.CONNECTED
- && owner.getState() != ServerState.CONNECTING
- && owner.getState() != ServerState.DISCONNECTING) {
- throw new IllegalArgumentException("Event called from a parser (#"
- + owner.getStatus().getParserID(parser) + ") that "
- + "shouldn't be in use.\nState history:\n"
- + owner.getStatus().getTransitionHistory());
- }
- }
-
- }
|