org/sonews/daemon/Main.java
author chris <chris@marvin>
Fri Jun 26 16:48:50 2009 +0200 (2009-06-26)
changeset 1 6fceb66e1ad7
child 2 1090e2141798
permissions -rw-r--r--
Hooray... sonews/0.5.0 final

HG: Enter commit message. Lines beginning with 'HG:' are removed.
HG: Remove all lines to abort the collapse operation.
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
}