]> git.netwichtig.de Git - user/henk/code/inspircd.git/blobdiff - src/inspircd_io.cpp
More cleanup
[user/henk/code/inspircd.git] / src / inspircd_io.cpp
index a78666afe5e22b19a98de1e60170d5f31135d632..13dfcd1b602b28a1f4ccce4ac4ca92135a02e3f5 100644 (file)
@@ -49,11 +49,9 @@ ServerConfig::ServerConfig()
        *CustomVersion = *motd = *rules = *PrefixQuit = *DieValue = *DNSServer = '\0';
        *OperOnlyStats = *ModPath = *MyExecutable = *DisabledCommands = *PID = '\0';
        log_file = NULL;
-       nofork = false;
-       unlimitcore = false;
+       nofork = HideBans = HideSplits = unlimitcore = false;
        AllowHalfop = true;
-       HideSplits = false;
-       dns_timeout = 5;
+       dns_timeout = DieDelay = 5;
        MaxTargets = 20;
        NetBufferSize = 10240;
        SoftLimit = MAXCLIENTS;
@@ -61,7 +59,7 @@ ServerConfig::ServerConfig()
        MaxWhoResults = 100;
        debugging = 0;
        LogLevel = DEFAULT;
-       DieDelay = 5;
+       maxbans.clear();
 }
 
 void ServerConfig::ClearStack()
@@ -160,7 +158,7 @@ void ServerConfig::Read(bool bail, userrec* user)
         */
         char dbg[MAXBUF],pauseval[MAXBUF],Value[MAXBUF],timeout[MAXBUF],NB[MAXBUF],flood[MAXBUF],MW[MAXBUF],MCON[MAXBUF],MT[MAXBUF];
         char AH[MAXBUF],AP[MAXBUF],AF[MAXBUF],DNT[MAXBUF],pfreq[MAXBUF],thold[MAXBUF],sqmax[MAXBUF],rqmax[MAXBUF],SLIMT[MAXBUF];
-       char localmax[MAXBUF],globalmax[MAXBUF],HS[MAXBUF];
+       char localmax[MAXBUF],globalmax[MAXBUF],HS[MAXBUF],HB[MAXBUF],ServName[MAXBUF];
         ConnectClass c;
         std::stringstream errstr;
         include_stack.clear();
@@ -236,6 +234,7 @@ void ServerConfig::Read(bool bail, userrec* user)
        ConfValue("options","customversion",0,Config->CustomVersion,&Config->config_f);
        ConfValue("options","maxtargets",0,MT,&Config->config_f);
        ConfValue("options","hidesplits",0,HS,&Config->config_f);
+       ConfValue("options","hidebans",0,HB,&Config->config_f);
        ConfValue("options","hidewhois",0,Config->HideWhoisServer,&Config->config_f);
        ConfValue("options","tempdir",0,Config->TempDir,&Config->config_f);
 
@@ -244,6 +243,7 @@ void ServerConfig::Read(bool bail, userrec* user)
        if (!*Config->TempDir)
                strlcpy(Config->TempDir,"/tmp",1024);
        Config->HideSplits = ((*HS == 'y') || (*HS == 'Y') || (*HS == '1') || (*HS == 't') || (*HS == 'T'));
+       Config->HideBans = ((*HB == 'y') || (*HB == 'Y') || (*HB == '1') || (*HB == 't') || (*HB == 'T'));
         Config->SoftLimit = atoi(SLIMT);
        if (*MT)
                Config->MaxTargets = atoi(MT);
@@ -266,7 +266,7 @@ void ServerConfig::Read(bool bail, userrec* user)
        if (!strchr(Config->ServerName,'.'))
        {
                log(DEFAULT,"WARNING: <server:name> '%s' is not a fully-qualified domain name. Changed to '%s%c'",Config->ServerName,Config->ServerName,'.');
-               strlcat(Config->ServerName,".",MAXBUF);
+               charlcat(Config->ServerName,'.',MAXBUF);
        }
         if (!Config->dns_timeout)
                 Config->dns_timeout = 5;
@@ -409,6 +409,24 @@ void ServerConfig::Read(bool bail, userrec* user)
                 }
 
         }
+       Config->ulines.clear();
+        for (int i = 0; i < ConfValueEnum("uline",&Config->config_f); i++)
+        {       
+                ConfValue("uline","server",i,ServName,&Config->config_f);
+                {
+                       log(DEBUG,"Read ULINE '%s'",ServName);
+                        Config->ulines.push_back(ServName);
+                }
+        }
+       maxbans.clear();
+        char CM1[MAXBUF],CM2[MAXBUF];
+        for (int count = 0; count < Config->ConfValueEnum("banlist",&Config->config_f); count++)
+        {
+                Config->ConfValue("banlist","chan",count,CM1,&Config->config_f);
+               Config->ConfValue("banlist","limit",count,CM2,&Config->config_f);
+               maxbans[CM1] = atoi(CM2);
+        }
+       ReadClassesAndTypes();
         log(DEFAULT,"Reading K lines,Q lines and Z lines from config...");
         read_xline_defaults();
         log(DEFAULT,"Applying K lines, Q lines and Z lines...");
@@ -542,9 +560,8 @@ void Start (void)
 {
        printf("\033[1;32mInspire Internet Relay Chat Server, compiled %s at %s\n",__DATE__,__TIME__);
        printf("(C) ChatSpike Development team.\033[0m\n\n");
-       printf("Developers:\033[1;32m     Brain, FrostyCoolSlug\033[0m\n");
-       printf("Documentation:\033[1;32m  FrostyCoolSlug, w00t\033[0m\n");
-       printf("Testers:\033[1;32m        typobox43, piggles, Lord_Zathras, CC\033[0m\n");
+       printf("Developers:\033[1;32m     Brain, FrostyCoolSlug, w00t, Om\033[0m\n");
+       printf("Others:\033[1;32m         See /INFO Output\033[0m\n");
        printf("Name concept:\033[1;32m   Lord_Zathras\033[0m\n\n");
 }
 
@@ -580,7 +597,11 @@ int DaemonSeed (void)
        if ((childpid = fork ()) < 0)
                return (ERROR);
        else if (childpid > 0)
+       {
+               /* We wait a few seconds here, so that the shell prompt doesnt come back over the output */
+               sleep(6);
                exit (0);
+       }
        setsid ();
        umask (007);
        printf("InspIRCd Process ID: \033[1;32m%lu\033[0m\n",(unsigned long)getpid());
@@ -1170,7 +1191,7 @@ int BindSocket (int sockfd, struct sockaddr_in client, struct sockaddr_in server
        struct in_addr addy;
        inet_aton(addr,&addy);
        server.sin_family = AF_INET;
-       if (!strcmp(addr,""))
+       if (!*addr)
        {
                server.sin_addr.s_addr = htonl(INADDR_ANY);
        }