org.pircbotx.hooks.events.VersionEvent Maven / Gradle / Ivy
/**
* Copyright (C) 2010 Leon Blakey
*
* 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 .
*/
package org.pircbotx.hooks.events;
import org.pircbotx.Channel;
import org.pircbotx.User;
import lombok.Data;
import lombok.EqualsAndHashCode;
import org.pircbotx.hooks.Event;
import org.pircbotx.hooks.CoreHooks;
import org.pircbotx.PircBotX;
import org.pircbotx.hooks.types.GenericCTCPCommand;
/**
* This event is dispatched whenever we receive a VERSION request.
*
* {@link CoreHooks} automatically responds correctly. Unless {@link CoreHooks}
* is removed from the {@link PircBotX#getListenerManager() bot's ListenerManager},
* Listeners of this event should not send a response as the user will get
* two responses
* @author Leon Blakey
*/
@Data
@EqualsAndHashCode(callSuper = true)
public class VersionEvent extends Event implements GenericCTCPCommand {
protected final User user;
protected final Channel channel;
/**
* Default constructor to setup object. Timestamp is automatically set
* to current time as reported by {@link System#currentTimeMillis() }
* @param user The nick of the user that sent the VERSION request.
* @param channel The target channel of the VERSION request. A value of null
* means that that the target is us.
*/
public VersionEvent(T bot, User user, Channel channel) {
super(bot);
this.user = user;
this.channel = channel;
}
/**
* Respond with a CTCP response to the user
* @param response The response to send
*/
@Override
public void respond(String response) {
getBot().sendCTCPResponse(getUser(), response);
}
}