2 ngIRCd - Next Generation IRC Server
4 (c)2001,2002 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 - beim Schlie§en einer Verbindung zeigt der Server nun vor dem ERROR
16 noch eine Statistik ueber die empfangene und gesendete Datenmenge an.
17 - Clients werden beim Connect mit NOTICEs ueber den Status der Resolver-
18 Subprozesse informiert.
19 - NOTICE liefert nun wirklich nie mehr einen Fehler, auch dann nicht,
20 wenn der sendende Client noch gar nicht registriert ist.
21 - NOTICEs vom Server selber (z.B. Verbindungsstatistik oder s-Mode)
22 haben nun ein "Text-Prefix": "*** ".
23 - ein "schneller Server-Reconnect" wird nur noch dann versucht, wenn die
24 Verbindung zuvor ordentlich (="lange genug") in Ordnung war; somit also
25 nicht meht, wenn der Peer-Server gleich beim Connect ein ERROR liefert.
26 - einige Datentypen aufgeraumt: z.B. sind viele INT32s nun LONGs. Das ist
27 auf Platformen mit 8-Byte-Integern kompatibler.
30 ngIRCd 0.5.2, 04.10.2002
32 - Buffer Overflow in Read_Resolver_Result() behoben.
33 - Format-String-Bugs, die zum Abbruch des Servers fuehrten, behoben.
34 - Maximale Laenge eines IRC-Prefix wurde falsch berechnet.
36 ngIRCd 0.5.1, 03.10.2002
38 - in RPL_YOURHOST_MSG wurde ein fehlerhafter Versionsstring geliefert.
39 - Test-Suite: start-server.sh, stop-server.sh und stress-server.sh koennen
40 nun "manuell" von der Kommandozeile gestartet werden, stress-server.sh
41 startet per Default nur noch 5 Sessions, eine andere Zahl kann auf der
42 Kommandozeile uebergeben werden (Syntax: "stress-server.sh <count>").
43 - In bestimmten Faellen hat der Server versucht auf einen bereits wieder
44 geschlossenen Socket Daten zu schreiben; das fuehrte zu einem Abbruch des
45 Servers durch ein assert(). Nun wird geprueft, ob der Socket noch ok ist.
46 - im "contrib"-Verzeichnis befindet sich nun eine RPM-Spec-Datei, aus den
47 .tar.gz's koennen nun mit "rpm -ta <archiv>" RPM's erzeugt werden. Danke
48 an Sean Reifschneider <jafo@tummy.com>!
49 - Syntax von RPL_MYINFO_MSG korrigiert: liefert nun vier Parameter.
51 ngIRCd 0.5.0, 20.09.2002
53 - Dokumentation aktualisiert.
54 - Fehler bei Validierung von "AdminInfo2" behoben.
55 - Test der Flags fuer "ps" in der Testsuite verbessert, ist nun zu mehr
56 Plattformen kompatibler.
58 ngIRCd 0.5.0-pre2, 17.09.2002
59 - Fix in IRC_WriteStrServersPrefix() war "badly broken" -- behoben.
61 ngIRCd 0.5.0-pre1, 16.09.2002
62 - Manual-Pages ngircd.8 und ngircd.conf.5 begonnen.
63 - Wird der Netzwerk-Sniffer aktiviert (--sniffer), so schaltet der
64 ngIRCd nun automatisch in den Debug-Modus.
65 - auf Systemen, die inet_aton() nicht kennen (wie z.B. A/UX), kann der
66 ngIRCd nun dennoch auch aktiv Server-Links aufbauen.
67 - h_errno wird auf Systemen, die das nicht kennen (wie z.B. HP-UX 10.20)
68 nicht mehr verwendet. Somit compiliert der ngIRCd nun auch dort :-)
69 - um auf dem Ziel-System nicht vorhandene Funktionen nachzubilden wird nun
70 die "libngportab" erzeugt; genutzt wird dies bisher fuer vsnprintf().
71 Nun compiliert der ngIRCd auch unter Solaris 2.5.1.
72 - "persistente Channels" (Mode 'P') implementiert: diese koennen in der
73 Konfigurationsdatei definiert werden (Sektion "Channel", vgl. Beispiel-
74 Konfiguration "sample-ngircd.conf") und bleiben auch dann bestehen,
75 wenn kein User mehr im Channel ist. Zu Channel-Operatoren werden bisher
76 nur IRC-Operatoren, die den Channel betreten. Die persistenten Channels
77 werden durch das Flag "P" gelennzeichnet, welches normal durch Channel-
78 Op's gesetzt und geloescht werden kann.
79 - bei "--configtest" werden keine leere Abschnitte mehr ausgegeben.
80 - Source in weitere Module aufgespalten: lists, irc-op und resolve.
81 - #include's aufgeraeumt: Header includieren keine anderen mehr.
82 - KICK implementiert (bisher kann nur ein User aus einem Channel geckicked
83 werden, Listen, wir im RFC vorgesehen, werden bisher nicht unterstuetzt).
84 - INVITE, den Channel-Mode "i" sowie Invite-Lists ueber den MODE-Befehl
85 (setzen, erfragen und loeschen) implementiert.
86 - Source an ansi2knr fuer pre-ANSI-Compiler angepasst; ansi2knr in Source-
87 Tree aufgenommen und in Build-System integriert; der ngIRCd compiliert
88 nun z.B. unter A/UX mit dem nativen Compiler von Apple.
89 - TOPIC lieferte bei unbekanntem Channel einen falschen Fehlercode.
90 - LIST versteht nun Wildcards und kann an andere Server geforwarded werden.
91 - wurde ein KILL fuer nicht-lokale Clients empfangen, so wurden die
92 Verwaltungs-Strukturen nicht korrekt freigegeben.
93 - empfangene NJOIN's wurden "zerhackt" an andere Server weitergegeben.
94 - neue Konfigurationsoption "OperCanUseMode" (Sektion "Global"):
95 ist sie aktiv, koennen IRC-Operatoren immer Channel-Modes setzen.
96 - Dokumentation des neuen IRC+-Protokolls begonnen: doc/Protocol.txt
97 - Protokoll- und Server-ID bei PASS-Befehlen auf neues Format umgestellt;
98 bei empfangenen PASS-Befehlen werden diese zudem nun auch ausgewertet.
99 Die unterstuetzten Flags sind in doc/Protocol.txt beschrieben.
100 - mit dem neuen Befehl CHANINFO syncronisieren Server, die das IRC+-
101 Protokoll unterstuetzen, Channel-Modes und Topics.
102 - neue Option "--disable-ircplus" fuer das configure-Script, um das
103 IRC+-Protokoll abzuschalten (per Default ist es aktiviert).
104 - Ban-Lists (setzen, erfragen und loeschen) implementiert.
105 - wird der Server mit "-n"/"--nodaemon" gestartet, so werden keine Mel-
106 dungen mehr ueber Syslog ausgegeben, sondern nur noch auf der Konsole.
107 - "Test-Suite" begonnen (in "make check" integriert): Dabei wird ein
108 speziell konfigurierter Server auf Port 6789 gestartet, mit dem dann
109 einige Tests durchgefuehrt werden (u.a. "Stress-Test" mit 50 Clients).
110 - zu lange Operator-Namen in der Konfiguration wurden falsch gekuerzt.
111 - kleine Anpassung an AIX 3.2.5: nun laeuft der ngIRCd auch dort :-)
112 - ADMIN-Befehl implementiert. Die Daten hierzu werden in der Konfig-Datei
113 im [Global]-Abschnitt mit den Variablen "AdminInfo1", "AdminInfo2" und
114 "AdminEMail" konfiguriert.
116 ngIRCd 0.4.3, 11.06.2002
118 - Bei PRIVMSG und NOTICE hat der ngIRCd nicht ueberpruft, ob das Ziel
119 ueberhaupt ein User ist. War es keiner, so fuehrte dies zu einem
120 Abbruch des Servers [es wurde assert() aufgerufen].
122 ngIRCd 0.4.2, 29.04.2002
124 - LUSERS verzaehlt sich bei eigenen Server-Links nicht mehr.
125 - QUIT wird nun auch von noch nicht registrierten Clients akzeptiert.
126 - IRC-Funktion LIST implementiert; bisher werden allerdings noch keine
127 Wildcards (bis auf "*") unterstuetzt.
129 ngIRCd 0.4.1, 08.04.2002
131 - Bei Server-Links wird nicht mehr an Hand der Anzahl der Parameter
132 eines empfangenen SERVER-Befehls, sondern "intern" erkannt, ob es
133 sich um eine ein- oder ausgehende Verbindung handelt und somit das
134 eigene PASS-SERVER-Paar gesendet werden muss oder nicht. Da sich
135 verschiedene Versionen des Original-ircd's anders verhalten, schlug
136 die Anmeldung je nach Gehenseite evtl. fehl.
137 - Bei einem NICK-Befehl eines lokalen Client konnte der Server ab-
138 stuerzen, da ein Format-String einer Log-Meldung fehlerhaft war.
140 ngIRCd 0.4.0, 01.04.2002
142 - IRC-Befehle nochmal auf weitere Source-Dateien aufgespalten.
143 - WHO implementiert (bisher ohne komplette Unterstuetzung von Masks).
144 - Der AWAY-Mode wurde nicht ueber mehrere Server-Links weitergegeben.
145 - stderr wird nun in eine Datei umgelenkt (/tmp/ngircd-<PID>.err).
146 Laeuft der Server nicht im Debug-Modus, so wird diese bei Programm-
147 ende geloescht. Sollte der Server abstuerzen, finden sich hier evtl.
148 zusaetzliche Informationen.
149 - In Nicknames wird das Zeichen "-" nun als zulaessig erkannt.
150 - die Beispiel-Konfigurationsdatei (doc/sample-ngircd.conf) wird als
151 ngircd.conf installiert, wenn noch keine "echte" Konfigurationsdatei
153 - bei WHO, WHOIS und NAMES wird nun nur noch der Status "Operator" oder
154 "voiced" geliefert -- nicht mehr beides.
155 - Server-Gruppen implementiert: es wird immer nur zu einem Server in
156 einer Gruppe eine Verbindung aufgebaut, klappt es beim ersten Server
157 nicht, so wird der naechste probiert (Variable "Group" in der Kon-
158 figurationsdatei, Sektion [Server]).
159 - IRC_PING() ist, wenn nicht im "strict RFC"-Mode, toleranter und ak-
160 zeptiert beliebig viele Parameter (z.B. BitchX sendet soetwas).
161 - die "Portab-Header" werden nicht mehr benoetigt, die System-Erkennung
162 wird nun ausschliesslich vom configure-Script durchgefuehrt. System-
163 abhaengige Definitionen finden sich nun unter src/portrab/.
164 - Clients und Channels werden nicht mehr ueber ihren Namen, sondern
165 einen Hash-Wert gesucht: sollte deutlich schneller sein.
166 - neuer Kommandozeilen-Parameter "--configtest": die Konfiguration wird
167 gelesen und dann die verwendeten Werte angezeigt.
168 - Client-Mode "s" (Server Notices) implementiert.
169 - mit dem neuen Kommandozeilen-Parameter "--config"/"-f" kann eine
170 alternative Konfigurationsdatei angegeben werden.
171 - nach dem Start kann der ngIRCd, wenn er mit root-Rechten laeuft,
172 zu einer anderen User-ID und Group-ID wechseln.
173 - URL der Homepage wird u.a. bei "--version" mit angezeigt.
175 ngIRCd 0.3.0, 02.03.2002
177 - bekommt der Server ein HUP-Signal, so startet er neu -- genau so, wie
178 er auf den IRC-Befehl RESTART reagiert.
179 - FAQ um Hinweise auf den Bugtracker erweitert.
180 - neuer Kommandozeilen-Schalter "--passive" (-p): wird er angegeben, so
181 verbindet sich der ngIRCd nicht mehr automatisch zu anderen Servern.
182 Zum Debuggen manchmal ganz praktisch :-)
183 - direkt nach dem Start schreibt der ngIRCd nun die aktiven Kommando-
184 zeilenschalter in's Logfile (Passive, Debug, Sniffer ...).
185 - das Signal-Flag SA_RESTART wird nur noch gesetzt, wenn es auf dem
186 jeweiligen System auch definiert ist.
187 - bei ausgehenden Verbindungen wird nun der Ziel-Port protokolliert.
188 - neue Befehle VERSION und KILL implementiert.
189 - make-Target "check" (und "distcheck") mit Sinn erfuellt :-)
190 (die Tests sind aber bisher nicht all zu tiefgehend ...)
191 - Durch einen Ueberlauf konnte die Idle-Time bei WHOIS negativ werden ...
192 - Anpassungen an A/UX: gehoert nun auch zu den unterstuetzten Platformen.
193 - WHOIS wird nicht mehr automatisch an den "Original-Server" weiterge-
194 leitet: war eh nicht RFC-konform und machte mit Clients Probleme.
195 - an User wird nun immer ein "komplettes" Prefix (mit Host-Mask) ver-
196 schickt, Server bekommen nach wie vor kurze: das "Original" hat bei
197 bestimmten Befehlen (PRIVMSG) ansonsten evtl. Probleme ...
198 - NAMES korrigiert und vollstaendig implementiert.
199 - SQUIT wird auf jeden Fall geforwarded, zudem besseres Logging.
200 - Ist ein Nick bei der User-Registrierung bereits belegt, nimmt der
201 Server nun korrekt weitere NICK-Befehle an und verwendet diese.
202 - PRIVMSG beachtet nun die Channel-Modes "n" und "m".
203 - AWAY implementiert. PRIVMSG, MODE, USERHOST und WHOIS angepasst.
204 - der ngIRCd unterstuetzt nun Channel-Topics (TOPIC-Befehl).
205 - ausgehende Server-Verbindungen werden nun asyncron connectiert und
206 blockieren nicht mehr den ganzen Server, wenn die Gegenseite nicht
207 erreicht werden kann (bis zum Timeout konnten Minuten vergehen!).
208 - Wert der Konfigurations-Variable "ConnectRetry" wird besser beachtet.
209 - Channel- und Nicknames werden nun ordentlich validiert.
211 ngIRCd 0.2.1, 17.02.2002
213 - NICK korrigiert: es werden nun auch alle "betroffenen" User informiert.
214 - configure-Script erweitert, u.a. bessere Anpassung an BeOS: dort wird
215 nun die "libbe" zum ngIRCd gelinkt, somit funktioniert auch syslog.
216 - Fehlerhafte bzw. noch nicht verstandene Modes werden nun ausfuehrlicher
217 an den Client geliefert.
219 ngIRCd 0.2.0, 15.02.2002
221 - Nicknames und Channel-Namen werden etwas besser auf Gueltigkeit ueber-
222 prueft; ist aber nach wie vor noch nicht ausreichend.
223 - NJOINS von Servern wurden nicht an andere Server weitergeleitet.
224 - Begonnen Channel-Modes und User-Channel-Modes zu implementieren: der
225 Server versteht an User-Modes o und v, beachtet letzteres allerdings
226 noch nirgends. Bekannte (aber nicht beachtete!) Channel-Modes sind
227 bisher a, m, n, p, q, s und t. Diese Modes werden von Usern ange-
228 nommen, von anderen Servern werden auch unbekannte Modes uebernommen.
229 - Benutzer von connectierenden Servern wurden nicht in den Channels ange-
230 kuendigt, es wurden nur die internen Strukturen angepasst.
231 - Nach dem Connect eines Users werden LUSERS-Informationen angezeigt.
233 ngIRCd 0.1.0, 29.01.2002
235 - User-Modes bei User-Registrierungen von andere Servern (NICK-Befehl)
236 wurden falsch uebernommen. Zudem wurden die Modes falsch gekuerzt.
237 - Server-Verbindungen werden nun nach dem Start erst nach einer kurzen
238 Pause aufgebaut (zur Zeit drei Sekunden).
239 - Hilfetext korrigiert: --help und --version waren vertauscht, die
240 Option --sniffer wurde gar nicht erwaehnt.
241 - FAQ.txt in doc/ begonnen.
242 - der IRC-Sniffer wird nur noch aktiviert, wenn die Option auf der
243 Kommandozeile angegeben wurde (bei entsprechend compiliertem Server).
244 - Channels implementiert, bisher jedoch noch ohne Channel-Modes, d.h.
245 es gibt keine Channel-Ops, kein Topic, kein "topic lock" etc. pp.
246 Chatten in Channels ist aber natuerlich moeglich ;-)
247 - neue Befehle fuer Channles: JOIN, PART und NJOIN.
248 - durch die Channels einige Aenderungen an PRIVMSG, WHOIS, MODE etc.
249 - neu connectierenden Servern werden nun Channels mit NJOIN angekuendigt.
250 - Signal-Hander geaendert: die Fehlermeldung "interrupted system call"
251 sollte so nicht mehr auftreten.
252 - "spaeter" neu connectierende Server werden nun im Netz angekuendigt.
253 - SERVER-Meldungen an andere Server sind nun korrekt sortiert.
254 - Clients werden nun korrekt sowohl nur ueber den Nickname als auch die
255 komplette "Host Mask" erkannt.
258 ngIRCd 0.0.3, 16.01.2002
260 - Server-Links vollstaendig implementiert: der ngIRCd kann nun auch
261 "Sub-Server" haben, also sowohl als Leaf-Node als auch Hub in einem
262 IRC-Netzwerk arbeiten.
263 - MODE und NICK melden nun die Aenderungen an andere Server, ebenso
264 die Befehle QUIT und SQUIT.
265 - WHOIS wird nun immer an den "Original-Server" weitergeleitet.
266 - Parses handhabt Leerzeichen zw. Parametern nun etwas "lockerer".
267 - Status-Codes an den Server selber werden ignorier.
268 - Log-Meldungen und Log-Level ueberarbeitet und korrigiert.
269 - Kommandozeilen-Parser: Debug- und No-Daemon-Modus, Hilfe.
270 - ngIRCd wandelt sich nun in einen Daemon (Hintergrundprozess) um.
271 - WHOIS korrigiert: Anfrage wurde u.U. an User geforwarded anstatt vom
272 Server beantwortet zu werden.
273 - neue Befehle: LUSERS, LINKS
274 - Client-Modes von Remote-Servern wurden nicht korrekt uerbernommen.
276 ngIRCd 0.0.2, 06.01.2002
278 - Struktur der Konfigurationsdatei geaendert: sie ist nun "Samba like",
279 d.h. sie besteht aus Abschnitten (siehe "doc/sample-ngircd.conf").
280 - Es koennen mehrere IRC-Server-Opertatoren konfiguriert werden.
281 - Zombies der Resolver-Prozesse werden nun ordentlich "getoetet".
282 - NICK kann nun die Gross- und Kleinschreibung eines Nicks aendern.
283 - ein Server-Passwort ist nun konfigurierbar.
284 - neue Befehle: ERROR, SERVER, NJOIN (nur als "Fake"), SQUIT.
285 - Asyncroner Resolver Hostname->IP implementiert.
286 - Server-Links teilweise implementiert: bisher kann der ngIRCd jedoch
287 nur "leafed server" sein, d.h. keine "Client-Server" haben. Einige
288 Befehle sind auch noch nicht (optimal) angepasst: PRIVMSG funktioniert
289 aber bereits, ebenso wie WHOIS (letzterer wird immer an den Server,
290 auf dem der User registriert ist, weitergegeben).
291 - "arpa/inet.h" wird nur noch includiert, wenn vorhanden.
292 - Fehler bei select() fuerhen nun zum Abbruch von ngIRCd, bisher landete
293 der Server zumeist in einer Endlosschleife.
294 - Logmeldungen und Level an vielen Stellen verbessert.
295 - lokalen Usernamen wird nun ein "~" vorangestellt, da bisher noch keine
296 Ident-Anfragen gemacht werden.
298 ngIRCd 0.0.1, 31.12.2001
300 - erste oeffentliche Version von ngIRCd als "public preview" :-)
304 $Id: ChangeLog,v 1.105 2002/10/09 17:10:15 alex Exp $