]> arthur.barton.de Git - ngircd-alex.git/blob - src/ngircd/irc-write.c
- externe portab-Header werden nicht mehr benoetigt. Notwendige Teile sind
[ngircd-alex.git] / src / ngircd / irc-write.c
1 /*
2  * ngIRCd -- The Next Generation IRC Daemon
3  * Copyright (c)2001,2002 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 ngIRCd beteiligten Autoren finden Sie in der Datei AUTHORS.
11  *
12  * $Id: irc-write.c,v 1.1 2002/02/27 23:26:21 alex Exp $
13  *
14  * irc-write.c: IRC-Texte und Befehle ueber Netzwerk versenden
15  *
16  * $Log: irc-write.c,v $
17  * Revision 1.1  2002/02/27 23:26:21  alex
18  * - Modul aus irc.c bzw. irc.h ausgegliedert.
19  *
20  */
21
22
23 #include <portab.h>
24 #include "global.h"
25
26 #include <imp.h>
27 #include <assert.h>
28 #include <stdarg.h>
29 #include <stdio.h>
30
31 #include <exp.h>
32 #include "irc-write.h"
33
34
35 CHAR *Get_Prefix( CLIENT *Target, CLIENT *Client );
36
37
38 GLOBAL BOOLEAN IRC_WriteStrClient( CLIENT *Client, CHAR *Format, ... )
39 {
40         CHAR buffer[1000];
41         BOOLEAN ok = CONNECTED;
42         va_list ap;
43
44         assert( Client != NULL );
45         assert( Format != NULL );
46
47         va_start( ap, Format );
48         vsnprintf( buffer, 1000, Format, ap );
49         va_end( ap );
50
51         /* an den Client selber */
52         ok = IRC_WriteStrClientPrefix( Client, Client_ThisServer( ), buffer );
53
54         return ok;
55 } /* IRC_WriteStrClient */
56
57
58 GLOBAL BOOLEAN IRC_WriteStrClientPrefix( CLIENT *Client, CLIENT *Prefix, CHAR *Format, ... )
59 {
60         /* Text an Clients, lokal bzw. remote, senden. */
61
62         CHAR buffer[1000];
63         va_list ap;
64
65         assert( Client != NULL );
66         assert( Format != NULL );
67         assert( Prefix != NULL );
68
69         va_start( ap, Format );
70         vsnprintf( buffer, 1000, Format, ap );
71         va_end( ap );
72
73         return Conn_WriteStr( Client_Conn( Client_NextHop( Client )), ":%s %s", Get_Prefix( Client_NextHop( Client ), Prefix ), buffer );
74 } /* IRC_WriteStrClientPrefix */
75
76
77 GLOBAL BOOLEAN IRC_WriteStrChannel( CLIENT *Client, CHANNEL *Chan, BOOLEAN Remote, CHAR *Format, ... )
78 {
79         CHAR buffer[1000];
80         va_list ap;
81
82         assert( Client != NULL );
83         assert( Format != NULL );
84
85         va_start( ap, Format );
86         vsnprintf( buffer, 1000, Format, ap );
87         va_end( ap );
88
89         return IRC_WriteStrChannelPrefix( Client, Chan, Client_ThisServer( ), Remote, buffer );
90 } /* IRC_WriteStrChannel */
91
92
93 GLOBAL BOOLEAN IRC_WriteStrChannelPrefix( CLIENT *Client, CHANNEL *Chan, CLIENT *Prefix, BOOLEAN Remote, CHAR *Format, ... )
94 {
95         BOOLEAN sock[MAX_CONNECTIONS], is_server[MAX_CONNECTIONS], ok = CONNECTED;
96         CHAR buffer[1000];
97         CL2CHAN *cl2chan;
98         CLIENT *c;
99         INT s, i;
100         va_list ap;
101
102         assert( Client != NULL );
103         assert( Chan != NULL );
104         assert( Prefix != NULL );
105         assert( Format != NULL );
106
107         va_start( ap, Format );
108         vsnprintf( buffer, 1000, Format, ap );
109         va_end( ap );
110
111         for( i = 0; i < MAX_CONNECTIONS; i++ ) sock[i] = FALSE;
112
113         /* An alle Clients, die in den selben Channels sind.
114          * Dabei aber nur einmal je Remote-Server */
115         cl2chan = Channel_FirstMember( Chan );
116         while( cl2chan )
117         {
118                 c = Channel_GetClient( cl2chan );
119                 if( ! Remote )
120                 {
121                         if( Client_Conn( c ) <= NONE ) c = NULL;
122                         else if( Client_Type( c ) == CLIENT_SERVER ) c = NULL;
123                 }
124                 if( c ) c = Client_NextHop( c );
125                         
126                 if( c && ( c != Client ))
127                 {
128                         /* Ok, anderer Client */
129                         s = Client_Conn( c );
130                         assert( s >= 0 );
131                         assert( s < MAX_CONNECTIONS );
132                         sock[s] = TRUE;
133                         if( Client_Type( c ) == CLIENT_SERVER ) is_server[s] = TRUE;
134                         else is_server[s] = FALSE;
135                 }
136                 cl2chan = Channel_NextMember( Chan, cl2chan );
137         }
138
139         /* Senden ... */
140         for( i = 0; i < MAX_CONNECTIONS; i++ )
141         {
142                 if( sock[i] )
143                 {
144                         if( is_server[i] ) ok = Conn_WriteStr( i, ":%s %s", Client_ID( Prefix ), buffer );
145                         else ok = Conn_WriteStr( i, ":%s %s", Client_Mask( Prefix ), buffer );
146                         if( ! ok ) break;
147                 }
148         }
149         return ok;
150 } /* IRC_WriteStrChannelPrefix */
151
152
153 GLOBAL VOID IRC_WriteStrServers( CLIENT *ExceptOf, CHAR *Format, ... )
154 {
155         CHAR buffer[1000];
156         va_list ap;
157
158         assert( Format != NULL );
159
160         va_start( ap, Format );
161         vsnprintf( buffer, 1000, Format, ap );
162         va_end( ap );
163
164         /* an den Client selber */
165         return IRC_WriteStrServersPrefix( ExceptOf, Client_ThisServer( ), buffer );
166 } /* IRC_WriteStrServers */
167
168
169 GLOBAL VOID IRC_WriteStrServersPrefix( CLIENT *ExceptOf, CLIENT *Prefix, CHAR *Format, ... )
170 {
171         CHAR buffer[1000];
172         CLIENT *c;
173         va_list ap;
174         
175         assert( Format != NULL );
176         assert( Prefix != NULL );
177
178         va_start( ap, Format );
179         vsnprintf( buffer, 1000, Format, ap );
180         va_end( ap );
181         
182         c = Client_First( );
183         while( c )
184         {
185                 if(( Client_Type( c ) == CLIENT_SERVER ) && ( Client_Conn( c ) > NONE ) && ( c != Client_ThisServer( )) && ( c != ExceptOf ))
186                 {
187                         /* Ziel-Server gefunden */
188                         IRC_WriteStrClientPrefix( c, Prefix, buffer );
189                 }
190                 c = Client_Next( c );
191         }
192 } /* IRC_WriteStrServersPrefix */
193
194
195 GLOBAL BOOLEAN IRC_WriteStrRelatedPrefix( CLIENT *Client, CLIENT *Prefix, BOOLEAN Remote, CHAR *Format, ... )
196 {
197         BOOLEAN sock[MAX_CONNECTIONS], is_server[MAX_CONNECTIONS], ok = CONNECTED;
198         CL2CHAN *chan_cl2chan, *cl2chan;
199         CHAR buffer[1000];
200         CHANNEL *chan;
201         va_list ap;
202         CLIENT *c;
203         INT i, s;
204
205         assert( Client != NULL );
206         assert( Prefix != NULL );
207         assert( Format != NULL );
208
209         va_start( ap, Format );
210         vsnprintf( buffer, 1000, Format, ap );
211         va_end( ap );
212
213         /* initialisieren */
214         for( i = 0; i < MAX_CONNECTIONS; i++ ) sock[i] = FALSE;
215
216         /* An alle Clients, die in einem Channel mit dem "Ausloeser" sind,
217          * den Text schicken. An Remote-Server aber jeweils nur einmal. */
218         chan_cl2chan = Channel_FirstChannelOf( Client );
219         while( chan_cl2chan )
220         {
221                 /* Channel des Users durchsuchen */
222                 chan = Channel_GetChannel( chan_cl2chan );
223                 cl2chan = Channel_FirstMember( chan );
224                 while( cl2chan )
225                 {
226                         c = Channel_GetClient( cl2chan );
227                         if( ! Remote )
228                         {
229                                 if( Client_Conn( c ) <= NONE ) c = NULL;
230                                 else if( Client_Type( c ) == CLIENT_SERVER ) c = NULL;
231                         }
232                         if( c ) c = Client_NextHop( c );
233
234                         if( c && ( c != Client ))
235                         {
236                                 /* Ok, anderer Client */
237                                 s = Client_Conn( c );
238                                 assert( s >= 0 );
239                                 assert( s < MAX_CONNECTIONS );
240                                 sock[s] = TRUE;
241                                 if( Client_Type( c ) == CLIENT_SERVER ) is_server[s] = TRUE;
242                                 else is_server[s] = FALSE;
243                         }
244                         cl2chan = Channel_NextMember( chan, cl2chan );
245                 }
246                 
247                 /* naechsten Channel */
248                 chan_cl2chan = Channel_NextChannelOf( Client, chan_cl2chan );
249         }
250
251         /* Senden ... */
252         for( i = 0; i < MAX_CONNECTIONS; i++ )
253         {
254                 if( sock[i] )
255                 {
256                         if( is_server[i] ) ok = Conn_WriteStr( i, ":%s %s", Client_ID( Prefix ), buffer );
257                         else ok = Conn_WriteStr( i, ":%s %s", Client_Mask( Prefix ), buffer );
258                         if( ! ok ) break;
259                 }
260         }
261         return ok;
262 } /* IRC_WriteStrRelatedPrefix */
263
264
265 CHAR *Get_Prefix( CLIENT *Target, CLIENT *Client )
266 {
267         assert( Target != NULL );
268         assert( Client != NULL );
269
270         if( Client_Type( Target ) == CLIENT_SERVER ) return Client_ID( Client );
271         else return Client_Mask( Client );
272 } /* Get_Prefix */
273
274
275 /* -eof- */