Replaced handler with if else way.

This commit is contained in:
Christian P. MOMON 2017-12-14 22:54:06 +01:00
parent ca0f25afb2
commit 84365660e0
2 changed files with 173 additions and 424 deletions

View File

@ -1,37 +0,0 @@
/**
* Copyright (C) 2011-2013,2017 Nicolas Vinot <aeris@imirhil.fr>
* Copyright (C) 2017 Christian Pierre MOMON <cmomon@april.org>
*
* This file is part of (April) Hebdobot.
*
* Hebdobot is free software: you can redistribute it and/or modify
* it under the terms of the GNU Affero General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* Hebdobot 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 Affero General Public License for more details.
*
* You should have received a copy of the GNU Affero General Public License
* along with Hebdobot. If not, see <http://www.gnu.org/licenses/>
*/
package org.april.hebdobot.irc;
/**
* The Class Handler.
*/
public abstract class Handler
{
/**
* Handle.
*
* @param sender
* the sender
* @param message
* the message
* @return true, if successful
*/
public abstract boolean handle(String sender, String message);
}

View File

@ -20,9 +20,7 @@
package org.april.hebdobot.irc; package org.april.hebdobot.irc;
import java.util.Collection; import java.util.Collection;
import java.util.Iterator;
import java.util.LinkedList; import java.util.LinkedList;
import java.util.List;
import org.apache.commons.collections.CollectionUtils; import org.apache.commons.collections.CollectionUtils;
import org.apache.commons.lang.StringUtils; import org.apache.commons.lang.StringUtils;
@ -48,7 +46,6 @@ public class Hebdobot extends PircBot
private final String channel; private final String channel;
private Review review = null; private Review review = null;
private final Collection<ReviewListener> listeners; private final Collection<ReviewListener> listeners;
private final List<Handler> handlers;
/** /**
* Instantiates a new bot. * Instantiates a new bot.
@ -70,7 +67,6 @@ public class Hebdobot extends PircBot
this.setName(name); this.setName(name);
this.listeners = new LinkedList<ReviewListener>(); this.listeners = new LinkedList<ReviewListener>();
this.handlers = new LinkedList<Handler>();
} }
/** /**
@ -103,410 +99,200 @@ public class Hebdobot extends PircBot
{ {
this.connect(this.host, this.port); this.connect(this.host, this.port);
this.joinChannel(this.channel); this.joinChannel(this.channel);
this.registerHandlers();
} }
/* (non-Javadoc) /* (non-Javadoc)
* @see org.jibble.pircbot.PircBot#onMessage(java.lang.String, java.lang.String, java.lang.String, java.lang.String, java.lang.String) * @see org.jibble.pircbot.PircBot#onMessage(java.lang.String, java.lang.String, java.lang.String, java.lang.String, java.lang.String)
*/ */
@Override @Override
protected void onMessage(final String channel, final String sender, final String login, final String hostname, String message) protected void onMessage(final String channel, final String sender, final String login, final String hostname, final String message)
{ {
logger.debug("Message received - channel : {}, sender : {}, message : {}", channel, sender, message); logger.debug("Message received - channel : {}, sender : {}, message : {}", channel, sender, message);
if (channel.equalsIgnoreCase(this.channel)) if (channel.equalsIgnoreCase(this.channel))
{ {
message = message.trim(); String text = message.trim();
boolean ended = false; if (StringUtils.equalsIgnoreCase(text, "!help"))
Iterator<Handler> iterator = this.handlers.iterator();
while (!ended)
{ {
if (iterator.hasNext()) // Help.
{ sendMessage(sender, "Bienvenue " + sender);
Handler currentHandler = iterator.next(); sendMessage(sender, "Je suis " + getName() + ", le robot de gestion des revues hebdomadaires de l'APRIL");
sendMessage(sender, "Voici les commandes que je comprend :");
if (currentHandler.handle(sender, message)) sendMessage(sender, " ");
{ sendMessage(sender, "— !debut : commencer une nouvelle revue");
ended = true; sendMessage(sender, "— !fin : terminer la revue en cours");
sendMessage(sender, "— # titre : démarrer un sujet individuel");
sendMessage(sender, "— ## titre : démarrer un sujet collectif");
sendMessage(sender, "— !courant : affiche le sujet en cours");
sendMessage(sender, "— !manquants : affiche les participants qui n'ont pas répondu sur le dernier sujet");
sendMessage(sender, "— % message : un commentaire");
} }
} else if (StringUtils.equalsIgnoreCase(text, "!stop"))
else
{ {
ended = true; // Die.
} if (this.review == null)
}
}
}
/**
* Register handlers.
*/
private void registerHandlers()
{
// Help
this.handlers.add(new Handler()
{
/* (non-Javadoc)
* @see org.april.hebdobot.irc.Bot.Handler#handle(java.lang.String, java.lang.String)
*/
@Override
public boolean handle(final String sender, final String message)
{
boolean result;
if (StringUtils.equalsIgnoreCase(message, "!help"))
{
Hebdobot.this.sendMessage(sender, "Bienvenue " + sender);
Hebdobot.this.sendMessage(sender,
"Je suis " + Hebdobot.this.getName() + ", le robot de gestion des revues hebdomadaires de l'APRIL");
Hebdobot.this.sendMessage(sender, "Voici les commandes que je comprend :");
Hebdobot.this.sendMessage(sender, " ");
Hebdobot.this.sendMessage(sender, "— !debut : commencer une nouvelle revue");
Hebdobot.this.sendMessage(sender, "— !fin : terminer la revue en cours");
Hebdobot.this.sendMessage(sender, "— # titre : démarrer un sujet individuel");
Hebdobot.this.sendMessage(sender, "— ## titre : démarrer un sujet collectif");
Hebdobot.this.sendMessage(sender, "— !courant : affiche le sujet en cours");
Hebdobot.this.sendMessage(sender, "— !manquants : affiche les participants qui n'ont pas répondu sur le dernier sujet");
Hebdobot.this.sendMessage(sender, "— % message : un commentaire");
result = true;
}
else
{
result = false;
}
//
return result;
}
});
// Die
this.handlers.add(new Handler()
{
/* (non-Javadoc)
* @see org.april.hebdobot.irc.Bot.Handler#handle(java.lang.String, java.lang.String)
*/
@Override
public boolean handle(final String sender, final String message)
{
boolean result;
if (!StringUtils.equalsIgnoreCase(message, "!stop"))
{
result = false;
}
else if (Hebdobot.this.review != null)
{
Hebdobot.this.sendMessage("% Une revue est en cours, arrêt impossible");
result = false;
}
else
{ {
Context.close(); Context.close();
result = true;
}
//
return result;
}
});
// Start
this.handlers.add(new Handler()
{
/* (non-Javadoc)
* @see org.april.hebdobot.irc.Bot.Handler#handle(java.lang.String, java.lang.String)
*/
@Override
public boolean handle(final String sender, final String message)
{
boolean result;
if (!StringUtils.equalsIgnoreCase(message, "!debut"))
{
result = false;
} }
else else
{ {
Hebdobot.this.review = new Review(sender); sendMessage("% Une revue est en cours, arrêt impossible");
Hebdobot.this.sendMessage(sender, "Vous êtes le conducteur de réunion");
Hebdobot.this.sendMessage(sender, "Pour terminer la réunion, tapez \"!fin\"");
Hebdobot.this.sendMessage("% Début de la réunion hebdomadaire");
Hebdobot.this.sendMessage(
"% rappel : toute ligne commençant par % sera considérée comme un commentaire et non prise en compte dans la synthèse");
result = true;
} }
//
return result;
} }
}); else if ((StringUtils.equalsIgnoreCase(text, "!debut")) || (StringUtils.equalsIgnoreCase(text, "!début")))
// Stop
this.handlers.add(new Handler()
{ {
/* (non-Javadoc) // Start.
* @see org.april.hebdobot.irc.Bot.Handler#handle(java.lang.String, java.lang.String) this.review = new Review(sender);
*/ sendMessage(sender, "Vous êtes le conducteur de réunion");
@Override sendMessage(sender, "Pour terminer la réunion, tapez \"!fin\"");
public boolean handle(final String sender, final String message) sendMessage("% Début de la réunion hebdomadaire");
sendMessage("% rappel : toute ligne commençant par % sera considérée comme un commentaire et non prise en compte dans la synthèse");
}
else if (StringUtils.equalsIgnoreCase(text, "!fin"))
{ {
boolean result; // Stop.
if (this.review != null)
if (Hebdobot.this.review == null || !StringUtils.equalsIgnoreCase(message, "!fin"))
{ {
result = false; sendMessage(sender + ", pas de revue en cours.");
}
else if (!this.review.isOwner(sender))
{
sendMessage(sender + ", vous n'êtes pas le conducteur de la réunion");
} }
else else
{ {
if (!Hebdobot.this.review.isOwner(sender)) for (final ReviewListener listener : this.listeners)
{ {
Hebdobot.this.sendMessage(sender + ", vous n'êtes pas le conducteur de la réunion"); listener.onEnd(this.review);
result = false;
}
else
{
for (final ReviewListener listener : Hebdobot.this.listeners)
{
listener.onEnd(Hebdobot.this.review);
} }
Hebdobot.this.sendMessage("% " + Hebdobot.this.review.getOwner() sendMessage("% " + this.review.getOwner()
+ ", ne pas oublier d'ajouter le compte-rendu de la revue sur https://agir.april.org/issues/135"); + ", ne pas oublier d'ajouter le compte-rendu de la revue sur https://agir.april.org/issues/135");
final String participants = StringUtils.join(Hebdobot.this.review.getParticipants(), " "); String participants = StringUtils.join(this.review.getParticipants(), " ");
Hebdobot.this.sendMessage("% " + participants + ", pensez à noter votre bénévalo : http://www.april.org/my?action=benevalo"); sendMessage("% " + participants + ", pensez à noter votre bénévalo : http://www.april.org/my?action=benevalo");
Hebdobot.this.sendMessage("% Fin de la revue hebdomadaire"); sendMessage("% Fin de la revue hebdomadaire");
Hebdobot.this.review = null; this.review = null;
result = true;
} }
} }
else if (text.matches("\\s*##.*"))
//
return result;
}
});
// Collective topic, must be before individual topic
this.handlers.add(new Handler()
{ {
/* (non-Javadoc) // Collective topic, must be before individual topic.
* @see org.april.hebdobot.irc.Bot.Handler#handle(java.lang.String, java.lang.String) if (this.review != null)
*/
@Override
public boolean handle(final String sender, final String message)
{ {
boolean result; if (this.review.isOwner(sender))
if (Hebdobot.this.review == null || !message.matches("\\s*##.*"))
{ {
result = false; CollectiveTopic topic = new CollectiveTopic(text.replaceFirst("##", "").trim());
} this.review.begin(topic);
else sendMessage("Sujet collectif : " + topic.getTitle());
{
if (Hebdobot.this.review.isOwner(sender))
{
final CollectiveTopic topic = new CollectiveTopic(message.replaceFirst("##", "").trim());
Hebdobot.this.review.begin(topic);
Hebdobot.this.sendMessage("Sujet collectif : " + topic.getTitle());
if (topic.getTitle().toLowerCase().contains("bloquage")) if (topic.getTitle().toLowerCase().contains("bloquage"))
{ {
Hebdobot.this.sendMessage("% si rien à dire vous pouvez dire %ras"); sendMessage("% si rien à dire vous pouvez dire %ras");
} }
else else
{ {
Hebdobot.this.sendMessage("% 1 minute max"); sendMessage("% 1 minute max");
} }
result = true;
} }
else else
{ {
Hebdobot.this.sendMessage(sender + ", vous n'êtes pas le conducteur de la réunion"); sendMessage(sender + ", vous n'êtes pas le conducteur de la réunion");
result = false;
} }
} }
//
return result;
} }
}); else if (text.matches("\\s*#[^#].*"))
// Individual topic
this.handlers.add(new Handler()
{ {
/* (non-Javadoc) // Individual topic.
* @see org.april.hebdobot.irc.Bot.Handler#handle(java.lang.String, java.lang.String) if (this.review == null)
*/
@Override
public boolean handle(final String sender, final String message)
{ {
boolean result; if (this.review.isOwner(sender))
if (Hebdobot.this.review == null || !message.matches("\\s*#[^#].*"))
{ {
result = false; sendMessage(sender + ", vous n'êtes pas le conducteur de la réunion");
} }
else else
{ {
if (Hebdobot.this.review.isOwner(sender)) IndividualTopic topic = new IndividualTopic(text.replaceFirst("#", "").trim());
this.review.begin(topic);
sendMessage("Sujet individuel : " + topic.getTitle());
sendMessage("% quand vous avez fini vous le dites par % fini");
}
}
else if (StringUtils.equalsIgnoreCase(text, "!manquants"))
{ {
Hebdobot.this.sendMessage(sender + ", vous n'êtes pas le conducteur de la réunion"); // Missing.
result = false; if (this.review == null)
{
sendMessage("Pas de revue en cours.");
} }
else else
{ {
final IndividualTopic topic = new IndividualTopic(message.replaceFirst("#", "").trim()); Topic topic = this.review.getCurrentTopic();
Hebdobot.this.review.begin(topic);
Hebdobot.this.sendMessage("Sujet individuel : " + topic.getTitle());
Hebdobot.this.sendMessage("% quand vous avez fini vous le dites par % fini");
result = true;
}
}
//
return result;
}
});
// Missing
this.handlers.add(new Handler()
{
/* (non-Javadoc)
* @see org.april.hebdobot.irc.Bot.Handler#handle(java.lang.String, java.lang.String)
*/
@Override
public boolean handle(final String sender, final String message)
{
boolean result;
if (Hebdobot.this.review == null || !StringUtils.equalsIgnoreCase(message, "!manquants"))
{
result = false;
}
else
{
final Topic topic = Hebdobot.this.review.getCurrentTopic();
if (topic == null) if (topic == null)
{ {
Hebdobot.this.sendMessage("Aucun sujet traité"); sendMessage("Aucun sujet traité");
result = true;
} }
else else
{ {
final Collection<String> participants = Hebdobot.this.review.getParticipants(); Collection<String> participants = this.review.getParticipants();
final Collection<String> currentParticipants = topic.getParticipants(); Collection<String> currentParticipants = topic.getParticipants();
final Collection<String> missing = CollectionUtils.subtract(participants, currentParticipants); Collection<String> missing = CollectionUtils.subtract(participants, currentParticipants);
if (missing.isEmpty()) if (missing.isEmpty())
{ {
Hebdobot.this.sendMessage("Aucun participant manquant \\o/"); sendMessage("Aucun participant manquant \\o/");
result = true;
} }
else else
{ {
Hebdobot.this sendMessage(String.format("Les participants suivants sont manquants : %1s", StringUtils.join(missing, ", ")));
.sendMessage(String.format("Les participants suivants sont manquants : %1s", StringUtils.join(missing, ", ")));
result = true;
} }
} }
} }
//
return result;
} }
}); else if (StringUtils.equalsIgnoreCase(text, "!courant"))
// Current
this.handlers.add(new Handler()
{ {
/* (non-Javadoc) // Current.
* @see org.april.hebdobot.irc.Bot.Handler#handle(java.lang.String, java.lang.String) if (this.review == null)
*/
@Override
public boolean handle(final String sender, final String message)
{ {
boolean result; sendMessage("Pas de revue en cours.");
if (Hebdobot.this.review == null || !StringUtils.equalsIgnoreCase(message, "!courant"))
{
result = false;
} }
else else
{ {
final Topic current = Hebdobot.this.review.getCurrentTopic(); Topic current = this.review.getCurrentTopic();
if (current == null) if (current == null)
{ {
Hebdobot.this.sendMessage("% Pas de sujet en cours"); sendMessage("% Pas de sujet en cours");
} }
else if (current instanceof IndividualTopic) else if (current instanceof IndividualTopic)
{ {
Hebdobot.this.sendMessage("% Sujet individuel en cours : " + current.getTitle()); sendMessage("% Sujet individuel en cours : " + current.getTitle());
} }
else if (current instanceof CollectiveTopic) else if (current instanceof CollectiveTopic)
{ {
Hebdobot.this.sendMessage("% Sujet collectif en cours : " + current.getTitle()); sendMessage("% Sujet collectif en cours : " + current.getTitle());
} }
result = true;
} }
//
return result;
} }
}); else if (text.startsWith("%"))
// Topic message
this.handlers.add(new Handler()
{ {
/* (non-Javadoc) // Topic message.
* @see org.april.hebdobot.irc.Bot.Handler#handle(java.lang.String, java.lang.String) if (this.review == null)
*/
@Override
public boolean handle(final String sender, final String message)
{ {
boolean result; sendMessage("Pas de revue en cours.");
if (Hebdobot.this.review == null || message.startsWith("%"))
{
result = false;
} }
else else
{ {
Hebdobot.this.review.add(new Message(sender, message)); this.review.add(new Message(sender, text));
result = true;
} }
//
return result;
}
});
// All the other
this.handlers.add(new Handler()
{
/* (non-Javadoc)
* @see org.april.hebdobot.irc.Bot.Handler#handle(java.lang.String, java.lang.String)
*/
@Override
public boolean handle(final String sender, final String message)
{
boolean result;
if (Hebdobot.this.review == null)
{
result = false;
} }
else else
{ {
Hebdobot.this.review.addRaw(new Message(sender, message)); // All the other.
result = true; if (this.review != null)
{
this.review.addRaw(new Message(sender, text));
}
}
} }
//
return result;
} }
});
} }
/** /**