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.DownloadFailure;
38 import net.pterodactylus.xdcc.ui.stdin.DownloadFailures;
39 import net.pterodactylus.xdcc.ui.stdin.NetworkAdapter;
41 import com.google.common.eventbus.AsyncEventBus;
42 import com.google.common.eventbus.EventBus;
43 import org.codehaus.jackson.map.ObjectMapper;
48 * @author <a href="mailto:bombe@pterodactylus.net">David ‘Bombe’ Roden</a>
52 private static final String VERSION = "0.1-SNAPSHOT";
54 public static String version() {
58 public static void main(String... arguments) throws Exception {
60 ConsoleHandler consoleHandler = new ConsoleHandler();
61 consoleHandler.setFormatter(new Formatter() {
64 public String format(LogRecord logRecord) {
65 return String.format("%1$tF %1$tT %2$s %3$s\n", logRecord.getMillis(), logRecord.getLoggerName(), logRecord.getMessage());
68 consoleHandler.setLevel(Level.ALL);
69 Logger.getLogger("").removeHandler(Logger.getLogger("").getHandlers()[0]);
70 Logger.getLogger("").addHandler(consoleHandler);
71 Logger.getLogger("").setLevel(Level.ALL);
72 Logger.getLogger(Connection.class.getName()).setLevel(Level.INFO);
73 Logger.getLogger(Core.class.getName()).setLevel(Level.INFO);
75 EventBus eventBus = new AsyncEventBus(Executors.newSingleThreadExecutor());
76 Configuration configuration = new ObjectMapper().readValue(new File("configuration.json"), Configuration.class);
78 Core core = new Core(eventBus, configuration.getTemporaryDirectory(), configuration.getFinalDirectory());
79 eventBus.register(core);
81 for (Configuration.Network network : configuration.getNetworks()) {
82 NetworkBuilder networkBuilder = Network.builder(network.getName());
83 for (Configuration.Network.Server server : network.getServers()) {
84 ServerBuilder serverBuilder = networkBuilder.addServer();
85 serverBuilder.at(server.getHostname());
86 for (int unencryptedPort : server.getUnencryptedPorts()) {
87 serverBuilder.port(unencryptedPort);
89 for (int encryptedPort : server.getEncryptedPorts()) {
90 serverBuilder.sslPort(encryptedPort);
92 serverBuilder.endServer();
94 Network createdNetwork = networkBuilder.build();
95 for (String channel : network.getChannels()) {
96 core.addChannel(new Channel(createdNetwork, channel));
100 DownloadFailures downloadFailures = new DownloadFailures();
102 CommandReader commandReader = new CommandReader(core, new InputStreamReader(System.in, "UTF-8"), new OutputStreamWriter(System.out, "UTF-8"), downloadFailures);
103 commandReader.start();
104 eventBus.register(commandReader);
106 NetworkAdapter networkAcceptor = new NetworkAdapter(eventBus, (reader, writer) -> new CommandReader(core, reader, writer, downloadFailures), configuration.getTelnetPort());
107 networkAcceptor.start();