2 * XdccDownloader - Main.java - Copyright © 2013 David Roden
4 * This program is free software: you can redistribute it and/or modify
5 * it under the terms of the GNU General Public License as published by
6 * the Free Software Foundation, either version 3 of the License, or
7 * (at your option) any later version.
9 * This program is distributed in the hope that it will be useful,
10 * but WITHOUT ANY WARRANTY; without even the implied warranty of
11 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12 * GNU General Public License for more details.
14 * You should have received a copy of the GNU General Public License
15 * along with this program. If not, see <http://www.gnu.org/licenses/>.
18 package net.pterodactylus.xdcc.main;
21 import java.io.InputStreamReader;
22 import java.io.OutputStreamWriter;
23 import java.util.concurrent.Executors;
24 import java.util.logging.ConsoleHandler;
25 import java.util.logging.Formatter;
26 import java.util.logging.Level;
27 import java.util.logging.LogRecord;
28 import java.util.logging.Logger;
30 import net.pterodactylus.irc.Connection;
31 import net.pterodactylus.xdcc.core.Core;
32 import net.pterodactylus.xdcc.data.Channel;
33 import net.pterodactylus.xdcc.data.Network;
34 import net.pterodactylus.xdcc.data.Network.NetworkBuilder;
35 import net.pterodactylus.xdcc.data.Network.ServerBuilder;
36 import net.pterodactylus.xdcc.ui.stdin.CommandReader;
37 import net.pterodactylus.xdcc.ui.stdin.NetworkAdapter;
39 import com.google.common.eventbus.AsyncEventBus;
40 import com.google.common.eventbus.EventBus;
41 import org.codehaus.jackson.map.ObjectMapper;
46 * @author <a href="mailto:bombe@pterodactylus.net">David ‘Bombe’ Roden</a>
50 private static final String VERSION = "0.1-SNAPSHOT";
52 public static String version() {
56 public static void main(String... arguments) throws Exception {
58 ConsoleHandler consoleHandler = new ConsoleHandler();
59 consoleHandler.setFormatter(new Formatter() {
62 public String format(LogRecord logRecord) {
63 return String.format("%1$tF %1$tT %2$s %3$s\n", logRecord.getMillis(), logRecord.getLoggerName(), logRecord.getMessage());
66 consoleHandler.setLevel(Level.ALL);
67 Logger.getLogger("").removeHandler(Logger.getLogger("").getHandlers()[0]);
68 Logger.getLogger("").addHandler(consoleHandler);
69 Logger.getLogger("").setLevel(Level.ALL);
70 Logger.getLogger(Connection.class.getName()).setLevel(Level.INFO);
71 Logger.getLogger(Core.class.getName()).setLevel(Level.INFO);
73 EventBus eventBus = new AsyncEventBus(Executors.newSingleThreadExecutor());
74 Configuration configuration = new ObjectMapper().readValue(new File("configuration.json"), Configuration.class);
76 Core core = new Core(eventBus, configuration.getTemporaryDirectory(), configuration.getFinalDirectory());
77 eventBus.register(core);
79 for (Configuration.Network network : configuration.getNetworks()) {
80 NetworkBuilder networkBuilder = Network.builder(network.getName());
81 for (Configuration.Network.Server server : network.getServers()) {
82 ServerBuilder serverBuilder = networkBuilder.addServer();
83 serverBuilder.at(server.getHostname());
84 for (int unencryptedPort : server.getUnencryptedPorts()) {
85 serverBuilder.port(unencryptedPort);
87 for (int encryptedPort : server.getEncryptedPorts()) {
88 serverBuilder.sslPort(encryptedPort);
90 serverBuilder.endServer();
92 Network createdNetwork = networkBuilder.build();
93 for (String channel : network.getChannels()) {
94 core.addChannel(new Channel(createdNetwork, channel));
98 CommandReader commandReader = new CommandReader(core, new InputStreamReader(System.in, "UTF-8"), new OutputStreamWriter(System.out, "UTF-8"));
99 commandReader.start();
100 eventBus.register(commandReader);
102 NetworkAdapter networkAcceptor = new NetworkAdapter(eventBus, core, configuration.getTelnetPort());
103 networkAcceptor.start();