]> jfr.im git - solanum.git/blobdiff - src/s_serv.c
Remove s_assert definition from ircd_defs.h and add it to its own header.
[solanum.git] / src / s_serv.c
index 02632bbf6e6787c248959f547fb9618102962881..1efc7eb05f2620a9ab293548249e237f3be33c9c 100644 (file)
@@ -54,6 +54,8 @@
 #include "msg.h"
 #include "reject.h"
 #include "sslproc.h"
+#include "capability.h"
+#include "s_assert.h"
 
 #ifndef INADDR_NONE
 #define INADDR_NONE ((unsigned int) 0xffffffff)
@@ -70,28 +72,63 @@ static char buf[BUFSIZE];
  * because all servers that we talk to already do TS, and the kludged
  * extra argument to "PASS" takes care of checking that.  -orabidoo
  */
-struct Capability captab[] = {
-/*  name     cap     */
-       { "QS",         CAP_QS },
-       { "EX",         CAP_EX },
-       { "CHW",        CAP_CHW},
-       { "IE",         CAP_IE},
-       { "KLN",        CAP_KLN},
-       { "KNOCK",      CAP_KNOCK},
-       { "ZIP",        CAP_ZIP},
-       { "TB",         CAP_TB},
-       { "UNKLN",      CAP_UNKLN},
-       { "CLUSTER",    CAP_CLUSTER},
-       { "ENCAP",      CAP_ENCAP },
-       { "SERVICES",   CAP_SERVICE },
-       { "RSFNC",      CAP_RSFNC },
-       { "SAVE",       CAP_SAVE },
-       { "EUID",       CAP_EUID },
-       { "EOPMOD",     CAP_EOPMOD },
-       { "BAN",        CAP_BAN },
-       { "MLOCK",      CAP_MLOCK },
-       {0, 0}
-};
+struct CapabilityIndex *serv_capindex = NULL;
+
+unsigned int CAP_CAP;
+unsigned int CAP_QS;
+unsigned int CAP_EX;
+unsigned int CAP_CHW;
+unsigned int CAP_IE;
+unsigned int CAP_KLN;
+unsigned int CAP_ZIP;
+unsigned int CAP_KNOCK;
+unsigned int CAP_TB;
+unsigned int CAP_UNKLN;
+unsigned int CAP_CLUSTER;
+unsigned int CAP_ENCAP;
+unsigned int CAP_TS6;
+unsigned int CAP_SERVICE;
+unsigned int CAP_RSFNC;
+unsigned int CAP_SAVE;
+unsigned int CAP_EUID;
+unsigned int CAP_EOPMOD;
+unsigned int CAP_BAN;
+unsigned int CAP_MLOCK;
+
+/*
+ * initialize our builtin capability table. --nenolod
+ */
+void
+init_builtin_capabs(void)
+{
+       serv_capindex = capability_index_create("server capabilities");
+
+       /* These two are not set via CAPAB/GCAP keywords. */
+       CAP_CAP = capability_put_anonymous(serv_capindex);
+       CAP_TS6 = capability_put_anonymous(serv_capindex);
+
+       CAP_QS = capability_put(serv_capindex, "QS");
+       CAP_EX = capability_put(serv_capindex, "EX");
+       CAP_CHW = capability_put(serv_capindex, "CHW");
+       CAP_IE = capability_put(serv_capindex, "IE");
+       CAP_KLN = capability_put(serv_capindex, "KLN");
+       CAP_KNOCK = capability_put(serv_capindex, "KNOCK");
+       CAP_ZIP = capability_put(serv_capindex, "ZIP");
+       CAP_TB = capability_put(serv_capindex, "TB");
+       CAP_UNKLN = capability_put(serv_capindex, "UNKLN");
+       CAP_CLUSTER = capability_put(serv_capindex, "CLUSTER");
+       CAP_ENCAP = capability_put(serv_capindex, "ENCAP");
+       CAP_SERVICE = capability_put(serv_capindex, "SERVICES");
+       CAP_RSFNC = capability_put(serv_capindex, "RSFNC");
+       CAP_SAVE = capability_put(serv_capindex, "SAVE");
+       CAP_EUID = capability_put(serv_capindex, "EUID");
+       CAP_EOPMOD = capability_put(serv_capindex, "EOPMOD");
+       CAP_BAN = capability_put(serv_capindex, "BAN");
+       CAP_MLOCK = capability_put(serv_capindex, "MLOCK");
+
+       capability_require(serv_capindex, "QS");
+       capability_require(serv_capindex, "ENCAP");
+}
 
 static CNCB serv_connect_callback;
 static CNCB serv_connect_ssl_callback;
@@ -131,7 +168,7 @@ hunt_server(struct Client *client_p, struct Client *source_p,
        if(parc <= server || EmptyString(parv[server]) ||
           match(parv[server], me.name) || (strcmp(parv[server], me.id) == 0))
                return (HUNTED_ISME);
-       
+
        new = LOCAL_COPY(parv[server]);
 
        /*
@@ -290,6 +327,7 @@ check_server(const char *name, struct Client *client_p)
        struct server_conf *tmp_p;
        rb_dlink_node *ptr;
        int error = -1;
+       const char *encr;
 
        s_assert(NULL != client_p);
        if(client_p == NULL)
@@ -324,8 +362,9 @@ check_server(const char *name, struct Client *client_p)
                        {
                                if(ServerConfEncrypted(tmp_p))
                                {
-                                       if(!strcmp(tmp_p->passwd, rb_crypt(client_p->localClient->passwd,
-                                                                       tmp_p->passwd)))
+                                       encr = rb_crypt(client_p->localClient->passwd,
+                                                                       tmp_p->passwd);
+                                       if(encr != NULL && !strcmp(tmp_p->passwd, encr))
                                        {
                                                server_p = tmp_p;
                                                break;
@@ -380,28 +419,9 @@ check_server(const char *name, struct Client *client_p)
  *
  */
 void
-send_capabilities(struct Client *client_p, int cap_can_send)
+send_capabilities(struct Client *client_p, unsigned int cap_can_send)
 {
-       struct Capability *cap;
-       char msgbuf[BUFSIZE];
-       char *t;
-       int tl;
-
-       t = msgbuf;
-
-       for (cap = captab; cap->name; ++cap)
-       {
-               if(cap->cap & cap_can_send)
-               {
-                       tl = rb_sprintf(t, "%s ", cap->name);
-                       t += tl;
-               }
-       }
-
-       t--;
-       *t = '\0';
-
-       sendto_one(client_p, "CAPAB :%s", msgbuf);
+       sendto_one(client_p, "CAPAB :%s", capability_index_list(serv_capindex, cap_can_send));
 }
 
 static void
@@ -490,7 +510,7 @@ burst_modes_TS6(struct Client *client_p, struct Channel *chptr,
        {
                banptr = ptr->data;
 
-               tlen = strlen(banptr->banstr) + 1;
+               tlen = strlen(banptr->banstr) + (banptr->forward ? strlen(banptr->forward) + 1 : 0) + 1;
 
                /* uh oh */
                if(cur_len + tlen > BUFSIZE - 3)
@@ -509,7 +529,10 @@ burst_modes_TS6(struct Client *client_p, struct Channel *chptr,
                        t = buf + mlen;
                }
 
-               rb_sprintf(t, "%s ", banptr->banstr);
+               if (banptr->forward)
+                       rb_sprintf(t, "%s$%s ", banptr->banstr, banptr->forward);
+               else
+                       rb_sprintf(t, "%s ", banptr->banstr);
                t += tlen;
                cur_len += tlen;
        }
@@ -693,7 +716,8 @@ const char *
 show_capabilities(struct Client *target_p)
 {
        static char msgbuf[BUFSIZE];
-       struct Capability *cap;
+
+       *msgbuf = '\0';
 
        if(has_id(target_p))
                rb_strlcpy(msgbuf, " TS6", sizeof(msgbuf));
@@ -704,11 +728,8 @@ show_capabilities(struct Client *target_p)
        if(!IsServer(target_p) || !target_p->serv->caps)        /* short circuit if no caps */
                return msgbuf + 1;
 
-       for (cap = captab; cap->cap; ++cap)
-       {
-               if(cap->cap & target_p->serv->caps)
-                       rb_snprintf_append(msgbuf, sizeof(msgbuf), " %s", cap->name);
-       }
+       rb_strlcat(msgbuf, " ", sizeof(msgbuf));
+       rb_strlcat(msgbuf, capability_index_list(serv_capindex, target_p->serv->caps), sizeof(msgbuf));
 
        return msgbuf + 1;
 }
@@ -804,9 +825,6 @@ server_estab(struct Client *client_p)
 
        SetServer(client_p);
 
-       /* Update the capability combination usage counts */
-       set_chcap_usage_counts(client_p);
-
        rb_dlinkAdd(client_p, &client_p->lnode, &me.serv->servers);
        rb_dlinkMoveNode(&client_p->localClient->tnode, &unknown_list, &serv_list);
        rb_dlinkAddTailAlloc(client_p, &global_serv_list);
@@ -870,8 +888,7 @@ server_estab(struct Client *client_p)
                                   me.id, client_p->name, client_p->id,
                                   IsHidden(client_p) ? "(H) " : "", client_p->info);
 
-                       if(IsCapable(target_p, CAP_ENCAP) &&
-                          !EmptyString(client_p->serv->fullcaps))
+                       if(!EmptyString(client_p->serv->fullcaps))
                                sendto_one(target_p, ":%s ENCAP * GCAP :%s",
                                        client_p->id, client_p->serv->fullcaps);
                }
@@ -881,8 +898,7 @@ server_estab(struct Client *client_p)
                                   me.name, client_p->name,
                                   IsHidden(client_p) ? "(H) " : "", client_p->info);
 
-                       if(IsCapable(target_p, CAP_ENCAP) &&
-                          !EmptyString(client_p->serv->fullcaps))
+                       if(!EmptyString(client_p->serv->fullcaps))
                                sendto_one(target_p, ":%s ENCAP * GCAP :%s",
                                        client_p->name, client_p->serv->fullcaps);
                }
@@ -926,8 +942,7 @@ server_estab(struct Client *client_p)
                                   target_p->name, target_p->hopcount + 1,
                                   IsHidden(target_p) ? "(H) " : "", target_p->info);
 
-               if(IsCapable(client_p, CAP_ENCAP) && 
-                  !EmptyString(target_p->serv->fullcaps))
+               if(!EmptyString(target_p->serv->fullcaps))
                        sendto_one(client_p, ":%s ENCAP * GCAP :%s",
                                        get_id(target_p, client_p),
                                        target_p->serv->fullcaps);