2 ngIRCd - Next Generation IRC Server
4 (c)2001-2003 by Alexander Barton,
5 alex@barton.de, http://www.barton.de/
7 ngIRCd ist freie Software und steht unter
8 der GNU General Public License.
10 -- ChangeLog / Aenderungen --
15 - New signal handler (more secure, actions are executed outside).
16 - GCC: the compiler is now called with more warning options enabled.
17 - Replaced a lot of str[n]cpy(), str[n]cat() and sprintf() calls with the
18 more secure functions strlcpy(), strlcat() and snprintf(). On systems
19 that don't support strlcpy() and strlcat(), these functions are included
20 in the libngportab now (with prototypes in portab.h).
21 - Fixed KILL: you can't crash the server by killing yourself any more,
22 ngIRCd no longer sends a QUIT to other servers after the KILL, and you
23 can kill only valid users now.
24 - If the server can't close a socket, it panics now. This is an error that
25 can't occure during normal operation so there is something broken.
26 - The order of log messages during disconnects is more "natural" now ;-)
27 - Cleaned up handling of server configuration structures: modifying and
28 removing servers during runtime works more reliable now.
29 - Compression code from "conn.[ch]" is now found in new "conn-zip.[ch]"
30 - Moved some connection functions from "conn.[ch]" to "conn-func.[ch]".
31 - New command CONNECT to enable and add server links. The syntax is not
32 RFC-compatible: use "CONNECT <name> <port>" to enable and connect an
33 configured server and "CONNECT <name> <port> <host> <mypwd> <peerpwd>"
34 to add a new server (ngIRCd tries to connect new servers only once!).
35 - Added DISCONNECT command ("DISCONNECT <name>") to disable servers.
36 - The server no longer forwards commands to ordinary users, instead it
37 answers with the correct error message ("no such server") now.
38 - WHOIS commands weren't always forwarded as requested.
41 Older changes (sorry, only available in german language):
43 ngIRCd 0.6.0, 2002-12-24
45 ngIRCd 0.6.0-pre2, 2002-12-23
46 - neuer Numeric 005 ("Features") beim Connect.
47 - LUSERS erweitert: nun wird die maximale Anzahl der lokalen und globalen
48 Clients, die dem Server bzw. im Netzwerk seit dem letzten (Re-)Start
49 dem Server gleichzeitig bekannt waren, angezeigt.
51 ngIRCd 0.6.0-pre1, 2002-12-18
52 - beim Schliessen einer Verbindung zeigt der Server nun vor dem ERROR
53 noch eine Statistik ueber die empfangene und gesendete Datenmenge an.
54 - der Server wartet bei einer eingehenden Verbindung nun laenger auf den
55 Resolver (4 Sekunden), wenn das Ergebnis eintrifft setzt er aber den
56 Login sofort fort (bisher wurde immer mind. 1 Sekunde gewartet).
57 - Connection-Strukturen werden nun "pool-weise" verwaltet; der Pool wird
58 bei Bedarf bis zu einem konfigurierten Limit vergroessert.
59 - Mit der neuen Konfigurationsvariable "MaxConnections" (Sektion "Global")
60 kann die maximale Anzahl gleichzeitiger Verbindungen begrenzt werden.
61 Der Default ist -1, "unlimitiert".
62 - der Server erkennt nun, ob bereits eine eingehende Verbindung von einem
63 Peer-Server besteht und versucht dann nicht mehr, selber eine eigene
64 ausgehende Verbindung zu diesem auufzubauen. Dadurch kann nun auf beiden
65 Servern in der Konfiguration ein Port fuer den Connect konfiguriert
66 werden (beide Server versuchen sich dann gegenseitig zu connectieren).
67 - Test-Suite und Dokumentation an A/UX angepasst.
68 - unter HP-UX definiert das configure-Script nun _XOPEN_SOURCE_EXTENDED.
69 - Server identifizieren sich nun mit asyncronen Passwoertern, d.h. das
70 Passwort, welches A an B schickt, kann ein anderes sein als das, welches
71 B als Antwort an A sendet. In der Konfig.-Datei, Abschnitt "Server",
72 wurde "Password" dazu durch "MyPassword" und "PeerPassword" ersetzt.
73 - Der Server kann nun zur Laufzeit die Konfiguration neu einlesen: dies
74 macht er nach dem Befehl REHASH oder wenn ein HUP-Signal empfangen wird.
75 - Channel-Mode "P" ("persistent") kann nur noch von IRC-Operatoren gesetzt
76 werden. Grund: User koennen den Server sonst leicht "Channel-Flooden".
77 - MOTD kann nun an andere Server geforwarded werden.
78 - IRC-Befehl "TIME" implementiert.
79 - Server-Server-Links koennen nun komprimiert werden, dazu wird die zlib
80 (www.zlib.org) benoetigt. Unterstuetzt die Gegenseite die Komprimierung
81 nicht, wird automatisch unkomprimiert kommuniziert. Das Verfahren ist
82 kompatibel mit dem Original-ircd 2.10.3, d.h. beide Server koennen
83 miteinander ueber komprimiert Links kommunizieren.
84 - Handling der Schreibpuffer umgestellt: Server sollte schneller arbeiten.
85 - Prefix-Fehler werden besser protokolliert (mit verursachendem Befehl).
86 - SQUIT wird nicht mehr doppelt an andere Server weitergeleitet.
87 - Der Server versucht nun vor dem Schliessen einer Verbindung Daten, die
88 noch im Schreibpuffer stehen, zu senden.
89 - Source in weiteres Modul "irc-info" aufgespalten.
90 - Konfigurationsvariablen werden besser validiert: Laengen, Zahlen, ...
91 - neuen Befehl STATS begonnen: bisher unterstuetzt wird "l" und "m".
92 - bei ISON und USERHOST fehlte im Ergebnis-String der korrekte Absender.
93 - IRC Operatoren koennen nun mit KILL User toeten. Achtung: ein Grund muss
94 zwingend als zweiter Parameter angegeben werden!
95 - neue Konfigurations-Variable "MaxJoins": Hiermit kann die maximale Zahl
96 der Channels, in denen ein User Mitglied sein kann, begrent werden.
97 - neuer, deutlich flexiblerer Parser fuer den MODE Befehl.
98 - neue Channel-Modes l (User-Limit) und k (Channel-Key) implementiert.
100 ngIRCd 0.5.4, 24.11.2002
102 - Fehler-Handling von connect() gefixed: der Server kann sich nun auch
103 unter A/UX wieder zu anderen verbinden.
104 - in den Konfigurationsvariablen ServerUID und ServerGID kann nun nicht
105 nur die numerische ID, sondern auch der Name des Users bzw. der Gruppe
106 verwendet werden. Beim Start des Daemons wird nun beides angezeigt.
107 - Besseres Logging von Prefix-Fehlern.
108 - angenommene Sockets werden nun korrekt auf "non-blocking" konfiguriert,
109 beim Senden und Empfangen werden Blockierungen besser abgefangen.
110 - RPL_UMODEIS hat Code 221, nicht 211 ... *argl*
111 - select() in Try_Write() hat falschen (keinen!) Timeout verwendet;
112 die "Zeit-Aufloesung" des Servers sind zudem nun 2 Sekunden (TIME_RES).
113 Insgesamt sollte die Reaktionszeit des Server nun besser sein.
115 ngIRCd 0.5.3, 08.11.2002
117 - NOTICE liefert nun wirklich nie mehr einen Fehler, auch dann nicht,
118 wenn der sendende Client noch gar nicht registriert ist.
119 - ein "schneller Server-Reconnect" wird nur noch dann versucht, wenn die
120 Verbindung zuvor ordentlich (="lange genug") in Ordnung war; somit also
121 nicht meht, wenn der Peer-Server gleich beim Connect ein ERROR liefert.
122 Das vermeidet "Connect-Orgien".
123 - einige Datentypen aufgeraumt: z.B. sind viele INT32s nun LONGs. Das ist
124 auf Platformen mit 8-Byte-Integern kompatibler.
125 - RPL_YOURHOST_MSG ist nun ircII- und RFC-kompatibel ;-)
126 - Segfault unter hoher Netzaktivitaet behoben: in Conn_Close() wird die
127 Connection-Struktur nun frueher als "ungueltig" markiert.
129 ngIRCd 0.5.2, 04.10.2002
131 - Buffer Overflow in Read_Resolver_Result() behoben.
132 - Format-String-Bugs, die zum Abbruch des Servers fuehrten, behoben.
133 - Maximale Laenge eines IRC-Prefix wurde falsch berechnet.
135 ngIRCd 0.5.1, 03.10.2002
137 - in RPL_YOURHOST_MSG wurde ein fehlerhafter Versionsstring geliefert.
138 - Test-Suite: start-server.sh, stop-server.sh und stress-server.sh koennen
139 nun "manuell" von der Kommandozeile gestartet werden, stress-server.sh
140 startet per Default nur noch 5 Sessions, eine andere Zahl kann auf der
141 Kommandozeile uebergeben werden (Syntax: "stress-server.sh <count>").
142 - In bestimmten Faellen hat der Server versucht auf einen bereits wieder
143 geschlossenen Socket Daten zu schreiben; das fuehrte zu einem Abbruch des
144 Servers durch ein assert(). Nun wird geprueft, ob der Socket noch ok ist.
145 - im "contrib"-Verzeichnis befindet sich nun eine RPM-Spec-Datei, aus den
146 .tar.gz's koennen nun mit "rpm -ta <archiv>" RPM's erzeugt werden. Danke
147 an Sean Reifschneider <jafo@tummy.com>!
148 - Syntax von RPL_MYINFO_MSG korrigiert: liefert nun vier Parameter.
150 ngIRCd 0.5.0, 20.09.2002
152 - Dokumentation aktualisiert.
153 - Fehler bei Validierung von "AdminInfo2" behoben.
154 - Test der Flags fuer "ps" in der Testsuite verbessert, ist nun zu mehr
155 Plattformen kompatibler.
157 ngIRCd 0.5.0-pre2, 17.09.2002
158 - Fix in IRC_WriteStrServersPrefix() war "badly broken" -- behoben.
160 ngIRCd 0.5.0-pre1, 16.09.2002
161 - Manual-Pages ngircd.8 und ngircd.conf.5 begonnen.
162 - Wird der Netzwerk-Sniffer aktiviert (--sniffer), so schaltet der
163 ngIRCd nun automatisch in den Debug-Modus.
164 - auf Systemen, die inet_aton() nicht kennen (wie z.B. A/UX), kann der
165 ngIRCd nun dennoch auch aktiv Server-Links aufbauen.
166 - h_errno wird auf Systemen, die das nicht kennen (wie z.B. HP-UX 10.20)
167 nicht mehr verwendet. Somit compiliert der ngIRCd nun auch dort :-)
168 - um auf dem Ziel-System nicht vorhandene Funktionen nachzubilden wird nun
169 die "libngportab" erzeugt; genutzt wird dies bisher fuer vsnprintf().
170 Nun compiliert der ngIRCd auch unter Solaris 2.5.1.
171 - "persistente Channels" (Mode 'P') implementiert: diese koennen in der
172 Konfigurationsdatei definiert werden (Sektion "Channel", vgl. Beispiel-
173 Konfiguration "sample-ngircd.conf") und bleiben auch dann bestehen,
174 wenn kein User mehr im Channel ist. Zu Channel-Operatoren werden bisher
175 nur IRC-Operatoren, die den Channel betreten. Die persistenten Channels
176 werden durch das Flag "P" gelennzeichnet, welches normal durch Channel-
177 Op's gesetzt und geloescht werden kann.
178 - bei "--configtest" werden keine leere Abschnitte mehr ausgegeben.
179 - Source in weitere Module aufgespalten: lists, irc-op und resolve.
180 - #include's aufgeraeumt: Header includieren keine anderen mehr.
181 - KICK implementiert (bisher kann nur ein User aus einem Channel geckicked
182 werden, Listen, wir im RFC vorgesehen, werden bisher nicht unterstuetzt).
183 - INVITE, den Channel-Mode "i" sowie Invite-Lists ueber den MODE-Befehl
184 (setzen, erfragen und loeschen) implementiert.
185 - Source an ansi2knr fuer pre-ANSI-Compiler angepasst; ansi2knr in Source-
186 Tree aufgenommen und in Build-System integriert; der ngIRCd compiliert
187 nun z.B. unter A/UX mit dem nativen Compiler von Apple.
188 - TOPIC lieferte bei unbekanntem Channel einen falschen Fehlercode.
189 - LIST versteht nun Wildcards und kann an andere Server geforwarded werden.
190 - wurde ein KILL fuer nicht-lokale Clients empfangen, so wurden die
191 Verwaltungs-Strukturen nicht korrekt freigegeben.
192 - empfangene NJOIN's wurden "zerhackt" an andere Server weitergegeben.
193 - neue Konfigurationsoption "OperCanUseMode" (Sektion "Global"):
194 ist sie aktiv, koennen IRC-Operatoren immer Channel-Modes setzen.
195 - Dokumentation des neuen IRC+-Protokolls begonnen: doc/Protocol.txt
196 - Protokoll- und Server-ID bei PASS-Befehlen auf neues Format umgestellt;
197 bei empfangenen PASS-Befehlen werden diese zudem nun auch ausgewertet.
198 Die unterstuetzten Flags sind in doc/Protocol.txt beschrieben.
199 - mit dem neuen Befehl CHANINFO syncronisieren Server, die das IRC+-
200 Protokoll unterstuetzen, Channel-Modes und Topics.
201 - neue Option "--disable-ircplus" fuer das configure-Script, um das
202 IRC+-Protokoll abzuschalten (per Default ist es aktiviert).
203 - Ban-Lists (setzen, erfragen und loeschen) implementiert.
204 - wird der Server mit "-n"/"--nodaemon" gestartet, so werden keine Mel-
205 dungen mehr ueber Syslog ausgegeben, sondern nur noch auf der Konsole.
206 - "Test-Suite" begonnen (in "make check" integriert): Dabei wird ein
207 speziell konfigurierter Server auf Port 6789 gestartet, mit dem dann
208 einige Tests durchgefuehrt werden (u.a. "Stress-Test" mit 50 Clients).
209 - zu lange Operator-Namen in der Konfiguration wurden falsch gekuerzt.
210 - kleine Anpassung an AIX 3.2.5: nun laeuft der ngIRCd auch dort :-)
211 - ADMIN-Befehl implementiert. Die Daten hierzu werden in der Konfig-Datei
212 im [Global]-Abschnitt mit den Variablen "AdminInfo1", "AdminInfo2" und
213 "AdminEMail" konfiguriert.
215 ngIRCd 0.4.3, 11.06.2002
217 - Bei PRIVMSG und NOTICE hat der ngIRCd nicht ueberpruft, ob das Ziel
218 ueberhaupt ein User ist. War es keiner, so fuehrte dies zu einem
219 Abbruch des Servers [es wurde assert() aufgerufen].
221 ngIRCd 0.4.2, 29.04.2002
223 - LUSERS verzaehlt sich bei eigenen Server-Links nicht mehr.
224 - QUIT wird nun auch von noch nicht registrierten Clients akzeptiert.
225 - IRC-Funktion LIST implementiert; bisher werden allerdings noch keine
226 Wildcards (bis auf "*") unterstuetzt.
228 ngIRCd 0.4.1, 08.04.2002
230 - Bei Server-Links wird nicht mehr an Hand der Anzahl der Parameter
231 eines empfangenen SERVER-Befehls, sondern "intern" erkannt, ob es
232 sich um eine ein- oder ausgehende Verbindung handelt und somit das
233 eigene PASS-SERVER-Paar gesendet werden muss oder nicht. Da sich
234 verschiedene Versionen des Original-ircd's anders verhalten, schlug
235 die Anmeldung je nach Gehenseite evtl. fehl.
236 - Bei einem NICK-Befehl eines lokalen Client konnte der Server ab-
237 stuerzen, da ein Format-String einer Log-Meldung fehlerhaft war.
239 ngIRCd 0.4.0, 01.04.2002
241 - IRC-Befehle nochmal auf weitere Source-Dateien aufgespalten.
242 - WHO implementiert (bisher ohne komplette Unterstuetzung von Masks).
243 - Der AWAY-Mode wurde nicht ueber mehrere Server-Links weitergegeben.
244 - stderr wird nun in eine Datei umgelenkt (/tmp/ngircd-<PID>.err).
245 Laeuft der Server nicht im Debug-Modus, so wird diese bei Programm-
246 ende geloescht. Sollte der Server abstuerzen, finden sich hier evtl.
247 zusaetzliche Informationen.
248 - In Nicknames wird das Zeichen "-" nun als zulaessig erkannt.
249 - die Beispiel-Konfigurationsdatei (doc/sample-ngircd.conf) wird als
250 ngircd.conf installiert, wenn noch keine "echte" Konfigurationsdatei
252 - bei WHO, WHOIS und NAMES wird nun nur noch der Status "Operator" oder
253 "voiced" geliefert -- nicht mehr beides.
254 - Server-Gruppen implementiert: es wird immer nur zu einem Server in
255 einer Gruppe eine Verbindung aufgebaut, klappt es beim ersten Server
256 nicht, so wird der naechste probiert (Variable "Group" in der Kon-
257 figurationsdatei, Sektion [Server]).
258 - IRC_PING() ist, wenn nicht im "strict RFC"-Mode, toleranter und ak-
259 zeptiert beliebig viele Parameter (z.B. BitchX sendet soetwas).
260 - die "Portab-Header" werden nicht mehr benoetigt, die System-Erkennung
261 wird nun ausschliesslich vom configure-Script durchgefuehrt. System-
262 abhaengige Definitionen finden sich nun unter src/portrab/.
263 - Clients und Channels werden nicht mehr ueber ihren Namen, sondern
264 einen Hash-Wert gesucht: sollte deutlich schneller sein.
265 - neuer Kommandozeilen-Parameter "--configtest": die Konfiguration wird
266 gelesen und dann die verwendeten Werte angezeigt.
267 - Client-Mode "s" (Server Notices) implementiert.
268 - mit dem neuen Kommandozeilen-Parameter "--config"/"-f" kann eine
269 alternative Konfigurationsdatei angegeben werden.
270 - nach dem Start kann der ngIRCd, wenn er mit root-Rechten laeuft,
271 zu einer anderen User-ID und Group-ID wechseln.
272 - URL der Homepage wird u.a. bei "--version" mit angezeigt.
274 ngIRCd 0.3.0, 02.03.2002
276 - bekommt der Server ein HUP-Signal, so startet er neu -- genau so, wie
277 er auf den IRC-Befehl RESTART reagiert.
278 - FAQ um Hinweise auf den Bugtracker erweitert.
279 - neuer Kommandozeilen-Schalter "--passive" (-p): wird er angegeben, so
280 verbindet sich der ngIRCd nicht mehr automatisch zu anderen Servern.
281 Zum Debuggen manchmal ganz praktisch :-)
282 - direkt nach dem Start schreibt der ngIRCd nun die aktiven Kommando-
283 zeilenschalter in's Logfile (Passive, Debug, Sniffer ...).
284 - das Signal-Flag SA_RESTART wird nur noch gesetzt, wenn es auf dem
285 jeweiligen System auch definiert ist.
286 - bei ausgehenden Verbindungen wird nun der Ziel-Port protokolliert.
287 - neue Befehle VERSION und KILL implementiert.
288 - make-Target "check" (und "distcheck") mit Sinn erfuellt :-)
289 (die Tests sind aber bisher nicht all zu tiefgehend ...)
290 - Durch einen Ueberlauf konnte die Idle-Time bei WHOIS negativ werden ...
291 - Anpassungen an A/UX: gehoert nun auch zu den unterstuetzten Platformen.
292 - WHOIS wird nicht mehr automatisch an den "Original-Server" weiterge-
293 leitet: war eh nicht RFC-konform und machte mit Clients Probleme.
294 - an User wird nun immer ein "komplettes" Prefix (mit Host-Mask) ver-
295 schickt, Server bekommen nach wie vor kurze: das "Original" hat bei
296 bestimmten Befehlen (PRIVMSG) ansonsten evtl. Probleme ...
297 - NAMES korrigiert und vollstaendig implementiert.
298 - SQUIT wird auf jeden Fall geforwarded, zudem besseres Logging.
299 - Ist ein Nick bei der User-Registrierung bereits belegt, nimmt der
300 Server nun korrekt weitere NICK-Befehle an und verwendet diese.
301 - PRIVMSG beachtet nun die Channel-Modes "n" und "m".
302 - AWAY implementiert. PRIVMSG, MODE, USERHOST und WHOIS angepasst.
303 - der ngIRCd unterstuetzt nun Channel-Topics (TOPIC-Befehl).
304 - ausgehende Server-Verbindungen werden nun asyncron connectiert und
305 blockieren nicht mehr den ganzen Server, wenn die Gegenseite nicht
306 erreicht werden kann (bis zum Timeout konnten Minuten vergehen!).
307 - Wert der Konfigurations-Variable "ConnectRetry" wird besser beachtet.
308 - Channel- und Nicknames werden nun ordentlich validiert.
310 ngIRCd 0.2.1, 17.02.2002
312 - NICK korrigiert: es werden nun auch alle "betroffenen" User informiert.
313 - configure-Script erweitert, u.a. bessere Anpassung an BeOS: dort wird
314 nun die "libbe" zum ngIRCd gelinkt, somit funktioniert auch syslog.
315 - Fehlerhafte bzw. noch nicht verstandene Modes werden nun ausfuehrlicher
316 an den Client geliefert.
318 ngIRCd 0.2.0, 15.02.2002
320 - Nicknames und Channel-Namen werden etwas besser auf Gueltigkeit ueber-
321 prueft; ist aber nach wie vor noch nicht ausreichend.
322 - NJOINS von Servern wurden nicht an andere Server weitergeleitet.
323 - Begonnen Channel-Modes und User-Channel-Modes zu implementieren: der
324 Server versteht an User-Modes o und v, beachtet letzteres allerdings
325 noch nirgends. Bekannte (aber nicht beachtete!) Channel-Modes sind
326 bisher a, m, n, p, q, s und t. Diese Modes werden von Usern ange-
327 nommen, von anderen Servern werden auch unbekannte Modes uebernommen.
328 - Benutzer von connectierenden Servern wurden nicht in den Channels ange-
329 kuendigt, es wurden nur die internen Strukturen angepasst.
330 - Nach dem Connect eines Users werden LUSERS-Informationen angezeigt.
332 ngIRCd 0.1.0, 29.01.2002
334 - User-Modes bei User-Registrierungen von andere Servern (NICK-Befehl)
335 wurden falsch uebernommen. Zudem wurden die Modes falsch gekuerzt.
336 - Server-Verbindungen werden nun nach dem Start erst nach einer kurzen
337 Pause aufgebaut (zur Zeit drei Sekunden).
338 - Hilfetext korrigiert: --help und --version waren vertauscht, die
339 Option --sniffer wurde gar nicht erwaehnt.
340 - FAQ.txt in doc/ begonnen.
341 - der IRC-Sniffer wird nur noch aktiviert, wenn die Option auf der
342 Kommandozeile angegeben wurde (bei entsprechend compiliertem Server).
343 - Channels implementiert, bisher jedoch noch ohne Channel-Modes, d.h.
344 es gibt keine Channel-Ops, kein Topic, kein "topic lock" etc. pp.
345 Chatten in Channels ist aber natuerlich moeglich ;-)
346 - neue Befehle fuer Channles: JOIN, PART und NJOIN.
347 - durch die Channels einige Aenderungen an PRIVMSG, WHOIS, MODE etc.
348 - neu connectierenden Servern werden nun Channels mit NJOIN angekuendigt.
349 - Signal-Hander geaendert: die Fehlermeldung "interrupted system call"
350 sollte so nicht mehr auftreten.
351 - "spaeter" neu connectierende Server werden nun im Netz angekuendigt.
352 - SERVER-Meldungen an andere Server sind nun korrekt sortiert.
353 - Clients werden nun korrekt sowohl nur ueber den Nickname als auch die
354 komplette "Host Mask" erkannt.
356 ngIRCd 0.0.3, 16.01.2002
358 - Server-Links vollstaendig implementiert: der ngIRCd kann nun auch
359 "Sub-Server" haben, also sowohl als Leaf-Node als auch Hub in einem
360 IRC-Netzwerk arbeiten.
361 - MODE und NICK melden nun die Aenderungen an andere Server, ebenso
362 die Befehle QUIT und SQUIT.
363 - WHOIS wird nun immer an den "Original-Server" weitergeleitet.
364 - Parses handhabt Leerzeichen zw. Parametern nun etwas "lockerer".
365 - Status-Codes an den Server selber werden ignorier.
366 - Log-Meldungen und Log-Level ueberarbeitet und korrigiert.
367 - Kommandozeilen-Parser: Debug- und No-Daemon-Modus, Hilfe.
368 - ngIRCd wandelt sich nun in einen Daemon (Hintergrundprozess) um.
369 - WHOIS korrigiert: Anfrage wurde u.U. an User geforwarded anstatt vom
370 Server beantwortet zu werden.
371 - neue Befehle: LUSERS, LINKS
372 - Client-Modes von Remote-Servern wurden nicht korrekt uerbernommen.
374 ngIRCd 0.0.2, 06.01.2002
376 - Struktur der Konfigurationsdatei geaendert: sie ist nun "Samba like",
377 d.h. sie besteht aus Abschnitten (siehe "doc/sample-ngircd.conf").
378 - Es koennen mehrere IRC-Server-Opertatoren konfiguriert werden.
379 - Zombies der Resolver-Prozesse werden nun ordentlich "getoetet".
380 - NICK kann nun die Gross- und Kleinschreibung eines Nicks aendern.
381 - ein Server-Passwort ist nun konfigurierbar.
382 - neue Befehle: ERROR, SERVER, NJOIN (nur als "Fake"), SQUIT.
383 - Asyncroner Resolver Hostname->IP implementiert.
384 - Server-Links teilweise implementiert: bisher kann der ngIRCd jedoch
385 nur "leafed server" sein, d.h. keine "Client-Server" haben. Einige
386 Befehle sind auch noch nicht (optimal) angepasst: PRIVMSG funktioniert
387 aber bereits, ebenso wie WHOIS (letzterer wird immer an den Server,
388 auf dem der User registriert ist, weitergegeben).
389 - "arpa/inet.h" wird nur noch includiert, wenn vorhanden.
390 - Fehler bei select() fuerhen nun zum Abbruch von ngIRCd, bisher landete
391 der Server zumeist in einer Endlosschleife.
392 - Logmeldungen und Level an vielen Stellen verbessert.
393 - lokalen Usernamen wird nun ein "~" vorangestellt, da bisher noch keine
394 Ident-Anfragen gemacht werden.
396 ngIRCd 0.0.1, 31.12.2001
398 - erste oeffentliche Version von ngIRCd als "public preview" :-)
402 $Id: ChangeLog,v 1.162 2003/01/01 13:32:47 alex Exp $