* along with this program; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307,
* USA.
- * $Id: ircd_parser.y,v 1.56.2.1 2005/10/06 00:37:31 entrope Exp $
+ * $Id: ircd_parser.y,v 1.56.2.6 2006/06/30 19:54:35 entrope Exp $
*/
%{
#include "hash.h"
#include "ircd.h"
#include "ircd_alloc.h"
-#include "ircd_auth.h"
#include "ircd_chattr.h"
#include "ircd_log.h"
#include "ircd_reply.h"
#include "opercmds.h"
#include "parse.h"
#include "res.h"
+#include "s_auth.h"
#include "s_bsd.h"
#include "s_conf.h"
#include "s_debug.h"
extern struct ServerConf* serverConfList;
extern struct s_map* GlobalServiceMapList;
extern struct qline* GlobalQuarantineList;
+ extern struct sline* GlobalSList;
int yylex(void);
/* Now all the globals we need :/... */
struct DenyConf *dconf;
struct ServerConf *sconf;
struct s_map *smap;
+ struct sline *spoof;
struct Privs privs;
struct Privs privs_dirty;
%token TIMEOUT
%token FAST
%token AUTOCONNECT
+%token PROGRAM
+%token SPOOFHOST
/* and now a lot of privileges... */
%token TPRIV_CHAN_LIMIT TPRIV_MODE_LCHAN TPRIV_DEOP_LCHAN TPRIV_WALK_LCHAN
%token TPRIV_LOCAL_KILL TPRIV_REHASH TPRIV_RESTART TPRIV_DIE
%token TPRIV_SEE_CHAN TPRIV_SHOW_INVIS TPRIV_SHOW_ALL_INVIS TPRIV_PROPAGATE
%token TPRIV_UNLIMIT_QUERY TPRIV_DISPLAY TPRIV_SEE_OPERS TPRIV_WIDE_GLINE
%token TPRIV_FORCE_OPMODE TPRIV_FORCE_LOCAL_OPMODE TPRIV_APASS_OPMODE
+%token TPRIV_LIST_CHAN
/* and some types... */
%type <num> sizespec
%type <num> timespec timefactor factoredtimes factoredtime
block: adminblock | generalblock | classblock | connectblock |
uworldblock | operblock | portblock | jupeblock | clientblock |
killblock | cruleblock | motdblock | featuresblock | quarantineblock |
- pseudoblock | iauthblock | error ';';
+ pseudoblock | iauthblock | spoofblock | error ';';
/* The timespec, sizespec and expr was ripped straight from
* ircd-hybrid-7. */
MyFree($3);
};
-adminblock: ADMIN '{' adminitems '}' ';'
+adminblock: ADMIN
+{
+ MyFree(localConf.location1);
+ MyFree(localConf.location2);
+ MyFree(localConf.contact);
+ localConf.location1 = localConf.location2 = localConf.contact = NULL;
+}
+'{' adminitems '}' ';'
{
if (localConf.location1 == NULL)
DupString(localConf.location1, "");
TPRIV_DISPLAY { $$ = PRIV_DISPLAY; } |
TPRIV_SEE_OPERS { $$ = PRIV_SEE_OPERS; } |
TPRIV_WIDE_GLINE { $$ = PRIV_WIDE_GLINE; } |
+ TPRIV_LIST_CHAN { $$ = PRIV_LIST_CHAN; } |
LOCAL { $$ = PRIV_PROPAGATE; invert = 1; } |
TPRIV_FORCE_OPMODE { $$ = PRIV_FORCE_OPMODE; } |
TPRIV_FORCE_LOCAL_OPMODE { $$ = PRIV_FORCE_LOCAL_OPMODE; } |
{
c_class = find_class($3);
if (!c_class)
- parse_error("No such connection class '%s' for Class block", $3);
+ parse_error("No such connection class '%s' for Client block", $3);
MyFree($3);
};
clientpass: PASS '=' QSTRING ';'
{
stringlist[0] = $1;
stringno = 1;
-} '=' stringlist ';';
-
-stringlist: QSTRING
-{
- stringlist[1] = $1;
- stringno = 2;
-} posextrastrings
-{
+} '=' stringlist ';' {
unsigned int ii;
feature_set(NULL, (const char * const *)stringlist, stringno);
for (ii = 0; ii < stringno; ++ii)
MyFree(stringlist[ii]);
};
-posextrastrings: /* empty */ | extrastrings;
-extrastrings: extrastrings extrastring | extrastring;
+
+stringlist: stringlist extrastring | extrastring;
extrastring: QSTRING
{
if (stringno < MAX_STRINGS)
smap->flags |= SMAP_FAST;
};
-iauthblock: IAUTH '{'
+iauthblock: IAUTH '{' iauthitems '}' ';'
{
- tconn = 60;
- tping = 60;
-} iauthitems '}' ';'
-{
- if (!host)
- parse_error("Missing host in iauth block");
- else if (!port)
- parse_error("Missing port in iauth block");
- else
- iauth_connect(host, port, pass, tconn, tping);
- MyFree(pass);
- MyFree(host);
- pass = host = NULL;
- port = tconn = tping = 0;
+ auth_spawn(stringno, stringlist);
+ while (stringno > 0)
+ MyFree(stringlist[--stringno]);
};
iauthitems: iauthitem iauthitems | iauthitem;
-iauthitem: iauthpass | iauthhost | iauthport | iauthconnfreq | iauthtimeout;
-iauthpass: PASS '=' QSTRING ';'
+iauthitem: iauthprogram;
+iauthprogram: PROGRAM '='
{
- MyFree(pass);
- pass = $3;
-};
-iauthhost: HOST '=' QSTRING ';'
+ while (stringno > 0)
+ MyFree(stringlist[--stringno]);
+} stringlist ';';
+
+spoofblock: SPOOFHOST QSTRING '{'
{
- MyFree(host);
- host = $3;
+ spoof = MyCalloc(1, sizeof(struct sline));
+ spoof->spoofhost = $2;
+ spoof->passwd = NULL;
+ spoof->realhost = NULL;
+ spoof->username = NULL;
+}
+spoofitems '}' ';'
+{
+ struct irc_in_addr ip;
+ char bits;
+
+ if (spoof->username == NULL && spoof->realhost) {
+ parse_error("Username missing in spoofhost.");
+ } else if (spoof->realhost == NULL && spoof->username) {
+ parse_error("Realhost missing in spoofhost.");
+ }
+
+ if (spoof->realhost) {
+ if (!string_has_wildcards(spoof->realhost)) {
+ if (ipmask_parse(spoof->realhost, &ip, &bits) != 0) {
+ spoof->address = ip;
+ spoof->bits = bits;
+ spoof->flags = SLINE_FLAGS_IP;
+ } else {
+ Debug((DEBUG_DEBUG, "S-Line: \"%s\" appears not to be a valid IP address, might be wildcarded.", spoof->realhost));
+ spoof->flags = SLINE_FLAGS_HOSTNAME;
+ }
+ } else
+ spoof->flags = SLINE_FLAGS_HOSTNAME;
+ } else
+ spoof->flags = 0;
+
+
+ spoof->next = GlobalSList;
+ GlobalSList = spoof;
+
+ spoof = NULL;
};
-iauthport: PORT '=' NUMBER ';'
+
+spoofitems: spoofitem spoofitems | spoofitem;
+spoofitem: spoofpassword | spoofrealhost | spoofrealident;
+spoofpassword: PASS '=' QSTRING ';'
{
- port = $3;
+ MyFree(spoof->passwd);
+ spoof->passwd = $3;
};
-iauthconnfreq: CONNECTFREQ '=' timespec ';'
+spoofrealhost: HOST '=' QSTRING ';'
{
- tconn = $3;
+ MyFree(spoof->realhost);
+ spoof->realhost = $3;
};
-iauthtimeout: TIMEOUT '=' timespec ';'
+spoofrealident: USERNAME '=' QSTRING ';'
{
- tping = $3;
+ MyFree(spoof->username);
+ spoof->username = $3;
};