author | chris <chris@marvin> |
Fri, 26 Jun 2009 16:48:50 +0200 | |
changeset 1 | 6fceb66e1ad7 |
child 2 | 1090e2141798 |
permissions | -rw-r--r-- |
chris@1 | 1 |
/* |
chris@1 | 2 |
* SONEWS News Server |
chris@1 | 3 |
* see AUTHORS for the list of contributors |
chris@1 | 4 |
* |
chris@1 | 5 |
* This program is free software: you can redistribute it and/or modify |
chris@1 | 6 |
* it under the terms of the GNU General Public License as published by |
chris@1 | 7 |
* the Free Software Foundation, either version 3 of the License, or |
chris@1 | 8 |
* (at your option) any later version. |
chris@1 | 9 |
* |
chris@1 | 10 |
* This program is distributed in the hope that it will be useful, |
chris@1 | 11 |
* but WITHOUT ANY WARRANTY; without even the implied warranty of |
chris@1 | 12 |
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
chris@1 | 13 |
* GNU General Public License for more details. |
chris@1 | 14 |
* |
chris@1 | 15 |
* You should have received a copy of the GNU General Public License |
chris@1 | 16 |
* along with this program. If not, see <http://www.gnu.org/licenses/>. |
chris@1 | 17 |
*/ |
chris@1 | 18 |
|
chris@1 | 19 |
package org.sonews.daemon; |
chris@1 | 20 |
|
chris@1 | 21 |
import java.sql.Driver; |
chris@1 | 22 |
import java.sql.DriverManager; |
chris@1 | 23 |
import java.sql.SQLException; |
chris@1 | 24 |
import java.util.Enumeration; |
chris@1 | 25 |
import java.util.Date; |
chris@1 | 26 |
import org.sonews.feed.FeedManager; |
chris@1 | 27 |
import org.sonews.mlgw.MailPoller; |
chris@1 | 28 |
import org.sonews.daemon.storage.Database; |
chris@1 | 29 |
import org.sonews.util.Log; |
chris@1 | 30 |
import org.sonews.util.io.Resource; |
chris@1 | 31 |
|
chris@1 | 32 |
/** |
chris@1 | 33 |
* Startup class of the daemon. |
chris@1 | 34 |
* @author Christian Lins |
chris@1 | 35 |
* @since sonews/0.5.0 |
chris@1 | 36 |
*/ |
chris@1 | 37 |
public final class Main |
chris@1 | 38 |
{ |
chris@1 | 39 |
|
chris@1 | 40 |
private Main() |
chris@1 | 41 |
{ |
chris@1 | 42 |
} |
chris@1 | 43 |
|
chris@1 | 44 |
/** Version information of the sonews daemon */ |
chris@1 | 45 |
public static final String VERSION = "sonews/0.5.0"; |
chris@1 | 46 |
public static final Date STARTDATE = new Date(); |
chris@1 | 47 |
|
chris@1 | 48 |
/** |
chris@1 | 49 |
* The main entrypoint. |
chris@1 | 50 |
* @param args |
chris@1 | 51 |
* @throws Exception |
chris@1 | 52 |
*/ |
chris@1 | 53 |
public static void main(String[] args) throws Exception |
chris@1 | 54 |
{ |
chris@1 | 55 |
System.out.println(VERSION); |
chris@1 | 56 |
Thread.currentThread().setName("Mainthread"); |
chris@1 | 57 |
|
chris@1 | 58 |
// Command line arguments |
chris@1 | 59 |
boolean feed = false; // Enable feeding? |
chris@1 | 60 |
boolean mlgw = false; // Enable Mailinglist gateway? |
chris@1 | 61 |
int port = -1; |
chris@1 | 62 |
|
chris@1 | 63 |
for(int n = 0; n < args.length; n++) |
chris@1 | 64 |
{ |
chris@1 | 65 |
if(args[n].equals("-c") || args[n].equals("-config")) |
chris@1 | 66 |
{ |
chris@1 | 67 |
BootstrapConfig.FILE = args[++n]; |
chris@1 | 68 |
System.out.println("Using config file " + args[n]); |
chris@1 | 69 |
} |
chris@1 | 70 |
else if(args[n].equals("-dumpjdbcdriver")) |
chris@1 | 71 |
{ |
chris@1 | 72 |
System.out.println("Available JDBC drivers:"); |
chris@1 | 73 |
Enumeration<Driver> drvs = DriverManager.getDrivers(); |
chris@1 | 74 |
while(drvs.hasMoreElements()) |
chris@1 | 75 |
{ |
chris@1 | 76 |
System.out.println(drvs.nextElement()); |
chris@1 | 77 |
} |
chris@1 | 78 |
return; |
chris@1 | 79 |
} |
chris@1 | 80 |
else if(args[n].equals("-feed")) |
chris@1 | 81 |
{ |
chris@1 | 82 |
feed = true; |
chris@1 | 83 |
} |
chris@1 | 84 |
else if(args[n].equals("-h") || args[n].equals("-help")) |
chris@1 | 85 |
{ |
chris@1 | 86 |
printArguments(); |
chris@1 | 87 |
return; |
chris@1 | 88 |
} |
chris@1 | 89 |
else if(args[n].equals("-mlgw")) |
chris@1 | 90 |
{ |
chris@1 | 91 |
mlgw = true; |
chris@1 | 92 |
} |
chris@1 | 93 |
else if(args[n].equals("-p")) |
chris@1 | 94 |
{ |
chris@1 | 95 |
port = Integer.parseInt(args[++n]); |
chris@1 | 96 |
} |
chris@1 | 97 |
} |
chris@1 | 98 |
|
chris@1 | 99 |
// Try to load the Database; |
chris@1 | 100 |
// Do NOT USE Config or Log classes before this point because they require |
chris@1 | 101 |
// a working Database connection. |
chris@1 | 102 |
try |
chris@1 | 103 |
{ |
chris@1 | 104 |
Database.getInstance(); |
chris@1 | 105 |
|
chris@1 | 106 |
// Make sure some elementary groups are existing |
chris@1 | 107 |
if(!Database.getInstance().isGroupExisting("control")) |
chris@1 | 108 |
{ |
chris@1 | 109 |
Database.getInstance().addGroup("control", 0); |
chris@1 | 110 |
Log.msg("Group 'control' created.", true); |
chris@1 | 111 |
} |
chris@1 | 112 |
} |
chris@1 | 113 |
catch(SQLException ex) |
chris@1 | 114 |
{ |
chris@1 | 115 |
ex.printStackTrace(); |
chris@1 | 116 |
System.err.println("Database initialization failed with " + ex.toString()); |
chris@1 | 117 |
System.err.println("Make sure you have specified the correct database" + |
chris@1 | 118 |
" settings in sonews.conf!"); |
chris@1 | 119 |
return; |
chris@1 | 120 |
} |
chris@1 | 121 |
|
chris@1 | 122 |
ChannelLineBuffers.allocateDirect(); |
chris@1 | 123 |
|
chris@1 | 124 |
// Add shutdown hook |
chris@1 | 125 |
Runtime.getRuntime().addShutdownHook(new ShutdownHook()); |
chris@1 | 126 |
|
chris@1 | 127 |
// Start the listening daemon |
chris@1 | 128 |
if(port <= 0) |
chris@1 | 129 |
{ |
chris@1 | 130 |
port = Config.getInstance().get(Config.PORT, 119); |
chris@1 | 131 |
} |
chris@1 | 132 |
final NNTPDaemon daemon = NNTPDaemon.createInstance(port); |
chris@1 | 133 |
daemon.start(); |
chris@1 | 134 |
|
chris@1 | 135 |
// Start Connections purger thread... |
chris@1 | 136 |
Connections.getInstance().start(); |
chris@1 | 137 |
|
chris@1 | 138 |
// Start mailinglist gateway... |
chris@1 | 139 |
if(mlgw) |
chris@1 | 140 |
{ |
chris@1 | 141 |
new MailPoller().start(); |
chris@1 | 142 |
} |
chris@1 | 143 |
|
chris@1 | 144 |
// Start feeds |
chris@1 | 145 |
if(feed) |
chris@1 | 146 |
{ |
chris@1 | 147 |
FeedManager.startFeeding(); |
chris@1 | 148 |
} |
chris@1 | 149 |
|
chris@1 | 150 |
// Wait for main thread to exit (setDaemon(false)) |
chris@1 | 151 |
daemon.join(); |
chris@1 | 152 |
} |
chris@1 | 153 |
|
chris@1 | 154 |
private static void printArguments() |
chris@1 | 155 |
{ |
chris@1 | 156 |
String usage = Resource.getAsString("helpers/usage", true); |
chris@1 | 157 |
System.out.println(usage); |
chris@1 | 158 |
} |
chris@1 | 159 |
|
chris@1 | 160 |
} |