]> arthur.barton.de Git - ngircd-alex.git/blob - src/ngircd/ngircd.c
- Conn_Handler() wird nun mit einem Timeout aufgerufen.
[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.7 2001/12/13 01:31:46 alex Exp $
13  *
14  * ngircd.c: Hier beginnt alles ;-)
15  *
16  * $Log: ngircd.c,v $
17  * Revision 1.7  2001/12/13 01:31:46  alex
18  * - Conn_Handler() wird nun mit einem Timeout aufgerufen.
19  *
20  * Revision 1.6  2001/12/12 23:30:42  alex
21  * - Log-Meldungen an syslog angepasst.
22  * - NGIRCd_Quit ist nun das Flag zum Beenden des ngircd.
23  *
24  * Revision 1.5  2001/12/12 17:21:21  alex
25  * - mehr Unterfunktionen eingebaut, Modul besser strukturiert & dokumentiert.
26  * - Anpassungen an neue Module.
27  *
28  * Revision 1.4  2001/12/12 01:58:53  alex
29  * - Test auf socklen_t verbessert.
30  *
31  * Revision 1.3  2001/12/12 01:40:39  alex
32  * - ein paar mehr Kommentare; Variablennamen verstaendlicher gemacht.
33  * - fehlenden Header <arpa/inet.h> ergaenz.
34  * - SIGINT und SIGQUIT werden nun ebenfalls behandelt.
35  *
36  * Revision 1.2  2001/12/11 22:04:21  alex
37  * - Test auf stdint.h (HAVE_STDINT_H) hinzugefuegt.
38  *
39  * Revision 1.1.1.1  2001/12/11 21:53:04  alex
40  * Imported sources to CVS.
41  */
42
43
44 #define PORTAB_CHECK_TYPES              /* Prueffunktion einbinden, s.u. */
45
46
47 #include <portab.h>
48 #include "global.h"
49
50 #include <imp.h>
51
52 #include <assert.h>
53 #include <stdio.h>
54 #include <signal.h>
55
56 #include "conf.h"
57 #include "conn.h"
58 #include "log.h"
59
60 #include <exp.h>
61 #include "ngircd.h"
62
63
64 LOCAL VOID Initialize_Signal_Handler( VOID );
65 LOCAL VOID Signal_Handler( INT Signal );
66
67
68 GLOBAL INT main( INT argc, CONST CHAR *argv[] )
69 {
70         /* Datentypen der portab-Library ueberpruefen */
71         portab_check_types( );
72
73         /* Globale Variablen initialisieren */
74         NGIRCd_Quit = FALSE;
75
76         /* Module initialisieren */
77         Log_Init( );
78         Conf_Init( );
79         Conn_Init( );
80
81         Initialize_Signal_Handler( );
82         
83         if( ! Conn_New_Listener( 6668 )) exit( 1 );
84
85         
86         /* Hauptschleife */
87         while( ! NGIRCd_Quit )
88         {
89                 Conn_Handler( 5 );
90         }
91         
92         /* Alles abmelden */
93         Conn_Exit( );
94         Conf_Exit( );
95         Log_Exit( );
96         
97         return 0;
98 } /* main */
99
100
101 LOCAL VOID Initialize_Signal_Handler( VOID )
102 {
103         /* Signal-Handler initialisieren: Strukturen anlegen und einhaengen :-) */
104
105         struct sigaction saction;
106
107         /* Signal-Struktur initialisieren */
108         memset( &saction, 0, sizeof( saction ));
109         saction.sa_handler = Signal_Handler;
110
111         /* Signal-Handler einhaengen */
112         sigaction( SIGALRM, &saction, NULL );
113         sigaction( SIGHUP, &saction, NULL);
114         sigaction( SIGINT, &saction, NULL );
115         sigaction( SIGQUIT, &saction, NULL );
116         sigaction( SIGTERM, &saction, NULL);
117         sigaction( SIGUSR1, &saction, NULL);
118         sigaction( SIGUSR2, &saction, NULL);
119 } /* Initialize_Signal_Handler */
120
121
122 LOCAL VOID Signal_Handler( INT Signal )
123 {
124         /* Signal-Handler. Dieser wird aufgerufen, wenn eines der Signale eintrifft,
125          * fuer das wir uns registriert haben (vgl. Initialize_Signal_Handler). Die
126          * Nummer des eingetroffenen Signals wird der Funktion uebergeben. */
127
128         switch( Signal )
129         {
130                 case SIGTERM:
131                 case SIGINT:
132                 case SIGQUIT:
133                         /* wir soll(t)en uns wohl beenden ... */
134                         Log( LOG_NOTICE, "Got signal %d, terminating now ...", Signal );
135                         NGIRCd_Quit = TRUE;
136                         break;
137                 default:
138                         /* unbekanntes bzw. unbehandeltes Signal */
139                         Log( LOG_NOTICE, "Got signal %d! Ignored.", Signal );
140         }
141 } /* Signal_Handler */
142
143
144 /* -eof- */