]> arthur.barton.de Git - ngircd-alex.git/blob - src/ngircd/ngircd.c
e630ea7078a96269fbb3f9d6a1ad32057932501b
[ngircd-alex.git] / src / ngircd / ngircd.c
1 /*
2  * ngIRCd -- The Next Generation IRC Daemon
3  * Copyright (c)2001 by Alexander Barton (alex@barton.de)
4  *
5  * Dieses Programm ist freie Software. Sie koennen es unter den Bedingungen
6  * der GNU General Public License (GPL), wie von der Free Software Foundation
7  * herausgegeben, weitergeben und/oder modifizieren, entweder unter Version 2
8  * der Lizenz oder (wenn Sie es wuenschen) jeder spaeteren Version.
9  * Naehere Informationen entnehmen Sie bitter der Datei COPYING. Eine Liste
10  * der an comBase beteiligten Autoren finden Sie in der Datei AUTHORS.
11  *
12  * $Id: ngircd.c,v 1.13 2001/12/30 11:42:00 alex Exp $
13  *
14  * ngircd.c: Hier beginnt alles ;-)
15  *
16  * $Log: ngircd.c,v $
17  * Revision 1.13  2001/12/30 11:42:00  alex
18  * - der Server meldet nun eine ordentliche "Start-Zeit".
19  *
20  * Revision 1.12  2001/12/29 03:07:36  alex
21  * - einige Loglevel geaendert.
22  *
23  * Revision 1.11  2001/12/26 14:45:37  alex
24  * - "Code Cleanups".
25  *
26  * Revision 1.10  2001/12/24 01:34:38  alex
27  * - Signal-Handler aufgeraeumt; u.a. SIGPIPE wird nun korrekt ignoriert.
28  *
29  * Revision 1.9  2001/12/21 22:24:50  alex
30  * - neues Modul "parse" wird initialisiert und abgemeldet.
31  *
32  * Revision 1.8  2001/12/14 08:15:26  alex
33  * - neue Module (irc, client, channel) werden an- und abgemeldet.
34  * - zweiter Listen-Socket wird zu Testzwecken konfiguriert.
35  *
36  * Revision 1.7  2001/12/13 01:31:46  alex
37  * - Conn_Handler() wird nun mit einem Timeout aufgerufen.
38  *
39  * Revision 1.6  2001/12/12 23:30:42  alex
40  * - Log-Meldungen an syslog angepasst.
41  * - NGIRCd_Quit ist nun das Flag zum Beenden des ngircd.
42  *
43  * Revision 1.5  2001/12/12 17:21:21  alex
44  * - mehr Unterfunktionen eingebaut, Modul besser strukturiert & dokumentiert.
45  * - Anpassungen an neue Module.
46  *
47  * Revision 1.4  2001/12/12 01:58:53  alex
48  * - Test auf socklen_t verbessert.
49  *
50  * Revision 1.3  2001/12/12 01:40:39  alex
51  * - ein paar mehr Kommentare; Variablennamen verstaendlicher gemacht.
52  * - fehlenden Header <arpa/inet.h> ergaenz.
53  * - SIGINT und SIGQUIT werden nun ebenfalls behandelt.
54  *
55  * Revision 1.2  2001/12/11 22:04:21  alex
56  * - Test auf stdint.h (HAVE_STDINT_H) hinzugefuegt.
57  *
58  * Revision 1.1.1.1  2001/12/11 21:53:04  alex
59  * - Imported sources to CVS.
60  */
61
62
63 #define PORTAB_CHECK_TYPES              /* Prueffunktion einbinden, s.u. */
64
65
66 #include <portab.h>
67 #include "global.h"
68
69 #include <imp.h>
70
71 #include <assert.h>
72 #include <stdio.h>
73 #include <signal.h>
74 #include <time.h>
75
76 #include "channel.h"
77 #include "client.h"
78 #include "conf.h"
79 #include "conn.h"
80 #include "irc.h"
81 #include "log.h"
82 #include "parse.h"
83
84 #include <exp.h>
85 #include "ngircd.h"
86
87
88 LOCAL VOID Initialize_Signal_Handler( VOID );
89 LOCAL VOID Signal_Handler( INT Signal );
90
91
92 GLOBAL INT main( INT argc, CONST CHAR *argv[] )
93 {
94         /* Datentypen der portab-Library ueberpruefen */
95         portab_check_types( );
96
97         /* Globale Variablen initialisieren */
98         NGIRCd_Start = time( NULL );
99         strftime( NGIRCd_StartStr, 64, "%a %b %d %Y at %H:%M:%S (%Z)", localtime( &NGIRCd_Start ));
100         NGIRCd_Quit = FALSE;
101
102         /* Module initialisieren */
103         Log_Init( );
104         Conf_Init( );
105         Parse_Init( );
106         IRC_Init( );
107         Channel_Init( );
108         Client_Init( );
109         Conn_Init( );
110
111         /* Signal-Handler initialisieren */
112         Initialize_Signal_Handler( );
113         
114         if( ! Conn_NewListener( 6668 )) exit( 1 );
115         if( ! Conn_NewListener( 6669 )) Log( LOG_WARNING, "Can't create second listening socket!" );
116         
117         /* Hauptschleife */
118         while( ! NGIRCd_Quit )
119         {
120                 Conn_Handler( 5 );
121         }
122         
123         /* Alles abmelden */
124         Conn_Exit( );
125         Client_Exit( );
126         Channel_Exit( );
127         IRC_Exit( );
128         Parse_Exit( );
129         Conf_Exit( );
130         Log_Exit( );
131         
132         return 0;
133 } /* main */
134
135
136 LOCAL VOID Initialize_Signal_Handler( VOID )
137 {
138         /* Signal-Handler initialisieren: einige Signale
139          * werden ignoriert, andere speziell behandelt. */
140
141         struct sigaction saction;
142
143         /* Signal-Struktur initialisieren */
144         memset( &saction, 0, sizeof( saction ));
145
146         /* Signal-Handler einhaengen */
147         saction.sa_handler = Signal_Handler;
148         sigaction( SIGINT, &saction, NULL );
149         sigaction( SIGQUIT, &saction, NULL );
150         sigaction( SIGTERM, &saction, NULL);
151
152         /* einige Signale ignorieren */
153         saction.sa_handler = SIG_IGN;
154         sigaction( SIGPIPE, &saction, NULL );
155 } /* Initialize_Signal_Handler */
156
157
158 LOCAL VOID Signal_Handler( INT Signal )
159 {
160         /* Signal-Handler. Dieser wird aufgerufen, wenn eines der Signale eintrifft,
161          * fuer das wir uns registriert haben (vgl. Initialize_Signal_Handler). Die
162          * Nummer des eingetroffenen Signals wird der Funktion uebergeben. */
163
164         switch( Signal )
165         {
166                 case SIGTERM:
167                 case SIGINT:
168                 case SIGQUIT:
169                         /* wir soll(t)en uns wohl beenden ... */
170                         Log( LOG_WARNING, "Got signal %d, terminating now ...", Signal );
171                         NGIRCd_Quit = TRUE;
172                         break;
173                 default:
174                         /* unbekanntes bzw. unbehandeltes Signal */
175                         Log( LOG_NOTICE, "Got signal %d! Ignored.", Signal );
176         }
177 } /* Signal_Handler */
178
179
180 /* -eof- */