]> arthur.barton.de Git - ngircd-alex.git/blobdiff - src/ngircd/lists.c
New configuration option "Mask" for [Operator] sections to limit OPER command.
[ngircd-alex.git] / src / ngircd / lists.c
index 0f08bc61463590e532becf1a48eec335e10579af..fce351a9ea52fcdaadca8096c9f73b5d344c4b15 100644 (file)
@@ -1,6 +1,6 @@
 /*
  * ngIRCd -- The Next Generation IRC Daemon
- * Copyright (c)2001,2002 by Alexander Barton (alex@barton.de)
+ * Copyright (c)2001-2005 Alexander Barton (alex@barton.de)
  *
  * This program is free software; you can redistribute it and/or modify
  * it under the terms of the GNU General Public License as published by
@@ -14,7 +14,7 @@
 
 #include "portab.h"
 
-static char UNUSED id[] = "$Id: lists.c,v 1.14 2004/04/09 21:41:52 alex Exp $";
+static char UNUSED id[] = "$Id: lists.c,v 1.16 2005/01/26 13:23:24 alex Exp $";
 
 #include "imp.h"
 #include <assert.h>
@@ -101,6 +101,16 @@ Lists_CheckInvited( CLIENT *Client, CHANNEL *Chan )
 } /* Lists_CheckInvited */
 
 
+GLOBAL BOOLEAN
+Lists_IsInviteEntry( CHAR *Mask, CHANNEL *Chan )
+{
+       assert( Mask != NULL );
+       assert( Chan != NULL );
+       
+       return Already_Registered( My_Invites, Mask, Chan );
+} /* Lists_IsInviteEntry */
+
+
 GLOBAL BOOLEAN
 Lists_AddInvited( CHAR *Mask, CHANNEL *Chan, BOOLEAN OnlyOnce )
 {
@@ -176,6 +186,40 @@ Lists_ShowInvites( CLIENT *Client, CHANNEL *Channel )
 } /* Lists_ShowInvites */
 
 
+GLOBAL BOOLEAN
+Lists_SendInvites( CLIENT *Client )
+{
+       C2C *c2c;
+       
+       assert( Client != NULL );
+       
+       c2c = My_Invites;
+       while( c2c )
+       {
+               if( ! IRC_WriteStrClient( Client, "MODE %s +I %s", Channel_Name( c2c->channel ), c2c->mask )) return DISCONNECTED;
+               c2c = c2c->next;
+       }
+       return CONNECTED;
+} /* Lists_SendInvites */
+
+
+GLOBAL BOOLEAN
+Lists_SendBans( CLIENT *Client )
+{
+       C2C *c2c;
+       
+       assert( Client != NULL );
+       
+       c2c = My_Bans;
+       while( c2c )
+       {
+               if( ! IRC_WriteStrClient( Client, "MODE %s +b %s", Channel_Name( c2c->channel ), c2c->mask )) return DISCONNECTED;
+               c2c = c2c->next;
+       }
+       return CONNECTED;
+} /* Lists_SendBans */
+
+
 GLOBAL BOOLEAN
 Lists_CheckBanned( CLIENT *Client, CHANNEL *Chan )
 {
@@ -183,6 +227,16 @@ Lists_CheckBanned( CLIENT *Client, CHANNEL *Chan )
 } /* Lists_CheckBanned */
 
 
+GLOBAL BOOLEAN
+Lists_IsBanEntry( CHAR *Mask, CHANNEL *Chan )
+{
+       assert( Mask != NULL );
+       assert( Chan != NULL );
+       
+       return Already_Registered( My_Bans, Mask, Chan );
+} /* Lists_IsBanEntry */
+
+
 GLOBAL BOOLEAN
 Lists_AddBanned( CHAR *Mask, CHANNEL *Chan )
 {
@@ -306,9 +360,10 @@ Lists_DeleteChannel( CHANNEL *Chan )
 GLOBAL CHAR *
 Lists_MakeMask( CHAR *Pattern )
 {
-       /* Hier wird aus einem "beliebigen" Pattern eine gueltige IRC-Mask erzeugt.
-        * Diese ist aber nur bis zum naechsten Aufruf von Lists_MakeMask() gueltig,
-        * da ein einziger globaler Puffer verwendet wird. ->Umkopieren!*/
+       /* This function generats a valid IRC mask of "any" string. This
+        * mask is only valid until the next call to Lists_MakeMask(),
+        * because a single global buffer is used. You have to copy the
+        * generated mask to some sane location yourself! */
 
        STATIC CHAR TheMask[MASK_LEN];
        CHAR *excl, *at;
@@ -322,7 +377,7 @@ Lists_MakeMask( CHAR *Pattern )
 
        if(( ! at ) && ( ! excl ))
        {
-               /* weder ! noch @ vorhanden: als Nick annehmen */
+               /* Neither "!" nor "@" found: use string as nick name */
                strlcpy( TheMask, Pattern, sizeof( TheMask ) - 5 );
                strlcat( TheMask, "!*@*", sizeof( TheMask ));
                return TheMask;
@@ -330,7 +385,7 @@ Lists_MakeMask( CHAR *Pattern )
 
        if(( ! at ) && ( excl ))
        {
-               /* Domain fehlt */
+               /* Domain part is missing */
                strlcpy( TheMask, Pattern, sizeof( TheMask ) - 3 );
                strlcat( TheMask, "@*", sizeof( TheMask ));
                return TheMask;
@@ -338,15 +393,15 @@ Lists_MakeMask( CHAR *Pattern )
 
        if(( at ) && ( ! excl ))
        {
-               /* User fehlt */
+               /* User name is missing */
                *at = '\0'; at++;
-               strlcpy( TheMask, Pattern, sizeof( TheMask ) - strlen( at ) - 4 );
+               strlcpy( TheMask, Pattern, sizeof( TheMask ) - 5 );
                strlcat( TheMask, "!*@", sizeof( TheMask ));
                strlcat( TheMask, at, sizeof( TheMask ));
                return TheMask;
        }
 
-       /* alle Teile vorhanden */
+       /* All parts (nick, user and domain name) are given */
        strlcpy( TheMask, Pattern, sizeof( TheMask ));
        return TheMask;
 } /* Lists_MakeMask */