Send event when a bot is added.
[xudocci.git] / src / main / java / net / pterodactylus / xdcc / core / Core.java
index 58afb8e..c59c9d5 100644 (file)
@@ -32,6 +32,7 @@ import net.pterodactylus.irc.event.ChannelMessageReceived;
 import net.pterodactylus.irc.event.ConnectionEstablished;
 import net.pterodactylus.irc.util.MessageCleaner;
 import net.pterodactylus.irc.util.RandomNickname;
+import net.pterodactylus.xdcc.core.event.BotAdded;
 import net.pterodactylus.xdcc.core.event.CoreStarted;
 import net.pterodactylus.xdcc.data.Bot;
 import net.pterodactylus.xdcc.data.Channel;
@@ -179,20 +180,23 @@ public class Core extends AbstractIdleService {
                        return;
                }
 
-               Bot bot;
-               synchronized (networkBots) {
-                       if (!networkBots.contains(network.get(), channelMessageReceived.source().nick().get())) {
-                               networkBots.put(network.get(), channelMessageReceived.source().nick().get(), new Bot(network.get()).name(channelMessageReceived.source().nick().get()));
-                       }
-                       bot = networkBots.get(network.get(), channelMessageReceived.source().nick().get());
-               }
-
                /* parse pack information. */
                Optional<Pack> pack = parsePack(message);
                if (!pack.isPresent()) {
                        return;
                }
 
+               Bot bot;
+               synchronized (networkBots) {
+                       if (!networkBots.contains(network.get(), channelMessageReceived.source().nick().get())) {
+                               bot = new Bot(network.get()).name(channelMessageReceived.source().nick().get());
+                               networkBots.put(network.get(), channelMessageReceived.source().nick().get(), bot);
+                               eventBus.post(new BotAdded(bot));
+                       } else {
+                               bot = networkBots.get(network.get(), channelMessageReceived.source().nick().get());
+                       }
+               }
+
                /* add pack. */
                bot.addPack(pack.get());
                logger.fine(String.format("Bot %s now has %d packs.", bot, bot.packs().size()));