X-Git-Url: https://arthur.barton.de/cgi-bin/gitweb.cgi?p=ngircd-alex.git;a=blobdiff_plain;f=ChangeLog;h=317c87d624b17b64113fc20e975b0227995a42c6;hp=25b2693ca62905d94d2e2253fdb4d03e5779a5ca;hb=f274ec06527b71420485973abf83def3bff6b73d;hpb=7efefd30f138abcaf91d1e971f330cf3cbbf37e2 diff --git a/ChangeLog b/ChangeLog index 25b2693c..317c87d6 100644 --- a/ChangeLog +++ b/ChangeLog @@ -10,12 +10,143 @@ -- ChangeLog / Aenderungen -- -ngIRCd 0.3.x, ??.??.2002 +ngIRCd CVS-HEAD + + - beim Schliessen einer Verbindung zeigt der Server nun vor dem ERROR + noch eine Statistik ueber die empfangene und gesendete Datenmenge an. + - Clients werden beim Connect mit NOTICEs ueber den Status der Resolver- + Subprozesse informiert. + - NOTICE liefert nun wirklich nie mehr einen Fehler, auch dann nicht, + wenn der sendende Client noch gar nicht registriert ist. + - NOTICEs vom Server selber (z.B. Verbindungsstatistik oder s-Mode) + haben nun ein "Text-Prefix": "*** ". + - ein "schneller Server-Reconnect" wird nur noch dann versucht, wenn die + Verbindung zuvor ordentlich (="lange genug") in Ordnung war; somit also + nicht meht, wenn der Peer-Server gleich beim Connect ein ERROR liefert. + Das vermeidet "Connect-Orgien". + - einige Datentypen aufgeraumt: z.B. sind viele INT32s nun LONGs. Das ist + auf Platformen mit 8-Byte-Integern kompatibler. + - der Server wartet bei einer eingehenden Verbindung nun laenger auf den + Resolver (4 Sekunden), wenn das Ergebnis eintrifft setzt er aber den + Login sofort fort (bisher wurde immer mind. 1 Sekunde gewartet). + + +ngIRCd 0.5.2, 04.10.2002 + + - Buffer Overflow in Read_Resolver_Result() behoben. + - Format-String-Bugs, die zum Abbruch des Servers fuehrten, behoben. + - Maximale Laenge eines IRC-Prefix wurde falsch berechnet. + +ngIRCd 0.5.1, 03.10.2002 + + - in RPL_YOURHOST_MSG wurde ein fehlerhafter Versionsstring geliefert. + - Test-Suite: start-server.sh, stop-server.sh und stress-server.sh koennen + nun "manuell" von der Kommandozeile gestartet werden, stress-server.sh + startet per Default nur noch 5 Sessions, eine andere Zahl kann auf der + Kommandozeile uebergeben werden (Syntax: "stress-server.sh "). + - In bestimmten Faellen hat der Server versucht auf einen bereits wieder + geschlossenen Socket Daten zu schreiben; das fuehrte zu einem Abbruch des + Servers durch ein assert(). Nun wird geprueft, ob der Socket noch ok ist. + - im "contrib"-Verzeichnis befindet sich nun eine RPM-Spec-Datei, aus den + .tar.gz's koennen nun mit "rpm -ta " RPM's erzeugt werden. Danke + an Sean Reifschneider ! + - Syntax von RPL_MYINFO_MSG korrigiert: liefert nun vier Parameter. + +ngIRCd 0.5.0, 20.09.2002 + + - Dokumentation aktualisiert. + - Fehler bei Validierung von "AdminInfo2" behoben. + - Test der Flags fuer "ps" in der Testsuite verbessert, ist nun zu mehr + Plattformen kompatibler. + + ngIRCd 0.5.0-pre2, 17.09.2002 + - Fix in IRC_WriteStrServersPrefix() war "badly broken" -- behoben. + + ngIRCd 0.5.0-pre1, 16.09.2002 + - Manual-Pages ngircd.8 und ngircd.conf.5 begonnen. + - Wird der Netzwerk-Sniffer aktiviert (--sniffer), so schaltet der + ngIRCd nun automatisch in den Debug-Modus. + - auf Systemen, die inet_aton() nicht kennen (wie z.B. A/UX), kann der + ngIRCd nun dennoch auch aktiv Server-Links aufbauen. + - h_errno wird auf Systemen, die das nicht kennen (wie z.B. HP-UX 10.20) + nicht mehr verwendet. Somit compiliert der ngIRCd nun auch dort :-) + - um auf dem Ziel-System nicht vorhandene Funktionen nachzubilden wird nun + die "libngportab" erzeugt; genutzt wird dies bisher fuer vsnprintf(). + Nun compiliert der ngIRCd auch unter Solaris 2.5.1. + - "persistente Channels" (Mode 'P') implementiert: diese koennen in der + Konfigurationsdatei definiert werden (Sektion "Channel", vgl. Beispiel- + Konfiguration "sample-ngircd.conf") und bleiben auch dann bestehen, + wenn kein User mehr im Channel ist. Zu Channel-Operatoren werden bisher + nur IRC-Operatoren, die den Channel betreten. Die persistenten Channels + werden durch das Flag "P" gelennzeichnet, welches normal durch Channel- + Op's gesetzt und geloescht werden kann. + - bei "--configtest" werden keine leere Abschnitte mehr ausgegeben. + - Source in weitere Module aufgespalten: lists, irc-op und resolve. + - #include's aufgeraeumt: Header includieren keine anderen mehr. + - KICK implementiert (bisher kann nur ein User aus einem Channel geckicked + werden, Listen, wir im RFC vorgesehen, werden bisher nicht unterstuetzt). + - INVITE, den Channel-Mode "i" sowie Invite-Lists ueber den MODE-Befehl + (setzen, erfragen und loeschen) implementiert. + - Source an ansi2knr fuer pre-ANSI-Compiler angepasst; ansi2knr in Source- + Tree aufgenommen und in Build-System integriert; der ngIRCd compiliert + nun z.B. unter A/UX mit dem nativen Compiler von Apple. + - TOPIC lieferte bei unbekanntem Channel einen falschen Fehlercode. + - LIST versteht nun Wildcards und kann an andere Server geforwarded werden. + - wurde ein KILL fuer nicht-lokale Clients empfangen, so wurden die + Verwaltungs-Strukturen nicht korrekt freigegeben. + - empfangene NJOIN's wurden "zerhackt" an andere Server weitergegeben. + - neue Konfigurationsoption "OperCanUseMode" (Sektion "Global"): + ist sie aktiv, koennen IRC-Operatoren immer Channel-Modes setzen. + - Dokumentation des neuen IRC+-Protokolls begonnen: doc/Protocol.txt + - Protokoll- und Server-ID bei PASS-Befehlen auf neues Format umgestellt; + bei empfangenen PASS-Befehlen werden diese zudem nun auch ausgewertet. + Die unterstuetzten Flags sind in doc/Protocol.txt beschrieben. + - mit dem neuen Befehl CHANINFO syncronisieren Server, die das IRC+- + Protokoll unterstuetzen, Channel-Modes und Topics. + - neue Option "--disable-ircplus" fuer das configure-Script, um das + IRC+-Protokoll abzuschalten (per Default ist es aktiviert). + - Ban-Lists (setzen, erfragen und loeschen) implementiert. + - wird der Server mit "-n"/"--nodaemon" gestartet, so werden keine Mel- + dungen mehr ueber Syslog ausgegeben, sondern nur noch auf der Konsole. + - "Test-Suite" begonnen (in "make check" integriert): Dabei wird ein + speziell konfigurierter Server auf Port 6789 gestartet, mit dem dann + einige Tests durchgefuehrt werden (u.a. "Stress-Test" mit 50 Clients). + - zu lange Operator-Namen in der Konfiguration wurden falsch gekuerzt. + - kleine Anpassung an AIX 3.2.5: nun laeuft der ngIRCd auch dort :-) + - ADMIN-Befehl implementiert. Die Daten hierzu werden in der Konfig-Datei + im [Global]-Abschnitt mit den Variablen "AdminInfo1", "AdminInfo2" und + "AdminEMail" konfiguriert. + +ngIRCd 0.4.3, 11.06.2002 + + - Bei PRIVMSG und NOTICE hat der ngIRCd nicht ueberpruft, ob das Ziel + ueberhaupt ein User ist. War es keiner, so fuehrte dies zu einem + Abbruch des Servers [es wurde assert() aufgerufen]. + +ngIRCd 0.4.2, 29.04.2002 + + - LUSERS verzaehlt sich bei eigenen Server-Links nicht mehr. + - QUIT wird nun auch von noch nicht registrierten Clients akzeptiert. + - IRC-Funktion LIST implementiert; bisher werden allerdings noch keine + Wildcards (bis auf "*") unterstuetzt. + +ngIRCd 0.4.1, 08.04.2002 + + - Bei Server-Links wird nicht mehr an Hand der Anzahl der Parameter + eines empfangenen SERVER-Befehls, sondern "intern" erkannt, ob es + sich um eine ein- oder ausgehende Verbindung handelt und somit das + eigene PASS-SERVER-Paar gesendet werden muss oder nicht. Da sich + verschiedene Versionen des Original-ircd's anders verhalten, schlug + die Anmeldung je nach Gehenseite evtl. fehl. + - Bei einem NICK-Befehl eines lokalen Client konnte der Server ab- + stuerzen, da ein Format-String einer Log-Meldung fehlerhaft war. + +ngIRCd 0.4.0, 01.04.2002 - IRC-Befehle nochmal auf weitere Source-Dateien aufgespalten. - - WHO implementiert (bisher ohne komplette Unerstuetzung von Masks). + - WHO implementiert (bisher ohne komplette Unterstuetzung von Masks). - Der AWAY-Mode wurde nicht ueber mehrere Server-Links weitergegeben. - - stderr wird nun in eine Datei umgelenkt (/usr/local/var/ngircd.err). + - stderr wird nun in eine Datei umgelenkt (/tmp/ngircd-.err). Laeuft der Server nicht im Debug-Modus, so wird diese bei Programm- ende geloescht. Sollte der Server abstuerzen, finden sich hier evtl. zusaetzliche Informationen. @@ -23,7 +154,6 @@ ngIRCd 0.3.x, ??.??.2002 - die Beispiel-Konfigurationsdatei (doc/sample-ngircd.conf) wird als ngircd.conf installiert, wenn noch keine "echte" Konfigurationsdatei vorhanden ist. - - bei "ngircd --help" werden nun die eincompilierten Pfade angezeigt. - bei WHO, WHOIS und NAMES wird nun nur noch der Status "Operator" oder "voiced" geliefert -- nicht mehr beides. - Server-Gruppen implementiert: es wird immer nur zu einem Server in @@ -31,19 +161,20 @@ ngIRCd 0.3.x, ??.??.2002 nicht, so wird der naechste probiert (Variable "Group" in der Kon- figurationsdatei, Sektion [Server]). - IRC_PING() ist, wenn nicht im "strict RFC"-Mode, toleranter und ak- - zeptiert beliebig viele Parameter: z.B. BitchX sendet soetwas. + zeptiert beliebig viele Parameter (z.B. BitchX sendet soetwas). - die "Portab-Header" werden nicht mehr benoetigt, die System-Erkennung wird nun ausschliesslich vom configure-Script durchgefuehrt. System- abhaengige Definitionen finden sich nun unter src/portrab/. - Clients und Channels werden nicht mehr ueber ihren Namen, sondern einen Hash-Wert gesucht: sollte deutlich schneller sein. - neuer Kommandozeilen-Parameter "--configtest": die Konfiguration wird - gelesen und die dann verwendeten Werte angezeigt. + gelesen und dann die verwendeten Werte angezeigt. - Client-Mode "s" (Server Notices) implementiert. - mit dem neuen Kommandozeilen-Parameter "--config"/"-f" kann eine alternative Konfigurationsdatei angegeben werden. - nach dem Start kann der ngIRCd, wenn er mit root-Rechten laeuft, zu einer anderen User-ID und Group-ID wechseln. + - URL der Homepage wird u.a. bei "--version" mit angezeigt. ngIRCd 0.3.0, 02.03.2002 @@ -174,4 +305,4 @@ ngIRCd 0.0.1, 31.12.2001 -- -$Id: ChangeLog,v 1.54 2002/03/29 23:41:23 alex Exp $ +$Id: ChangeLog,v 1.107 2002/10/10 15:00:09 alex Exp $