Annotation of sbbs/sbbs3/logon.cpp, revision 1.1

1.1     ! root        1: /* logon.cpp */
        !             2: 
        !             3: /* Synchronet user logon routines */
        !             4: 
        !             5: /* $Id: logon.cpp,v 1.10 2000/12/11 23:21:12 rswindell Exp $ */
        !             6: 
        !             7: /****************************************************************************
        !             8:  * @format.tab-size 4          (Plain Text/Source Code File Header)                    *
        !             9:  * @format.use-tabs true       (see http://www.synchro.net/ptsc_hdr.html)              *
        !            10:  *                                                                                                                                                     *
        !            11:  * Copyright 2000 Rob Swindell - http://www.synchro.net/copyright.html         *
        !            12:  *                                                                                                                                                     *
        !            13:  * This program is free software; you can redistribute it and/or                       *
        !            14:  * modify it under the terms of the GNU General Public License                         *
        !            15:  * as published by the Free Software Foundation; either version 2                      *
        !            16:  * of the License, or (at your option) any later version.                                      *
        !            17:  * See the GNU General Public License for more details: gpl.txt or                     *
        !            18:  * http://www.fsf.org/copyleft/gpl.html                                                                                *
        !            19:  *                                                                                                                                                     *
        !            20:  * Anonymous FTP access to the most recent released source is available at     *
        !            21:  * ftp://vert.synchro.net, ftp://cvs.synchro.net and ftp://ftp.synchro.net     *
        !            22:  *                                                                                                                                                     *
        !            23:  * Anonymous CVS access to the development source and modification history     *
        !            24:  * is available at cvs.synchro.net:/cvsroot/sbbs, example:                                     *
        !            25:  * cvs -d :pserver:[email protected]:/cvsroot/sbbs login                       *
        !            26:  *     (just hit return, no password is necessary)                                                     *
        !            27:  * cvs -d :pserver:[email protected]:/cvsroot/sbbs checkout src                *
        !            28:  *                                                                                                                                                     *
        !            29:  * For Synchronet coding style and modification guidelines, see                                *
        !            30:  * http://www.synchro.net/source.html                                                                          *
        !            31:  *                                                                                                                                                     *
        !            32:  * You are encouraged to submit any modifications (preferably in Unix diff     *
        !            33:  * format) via e-mail to [email protected]                                                                      *
        !            34:  *                                                                                                                                                     *
        !            35:  * Note: If this box doesn't appear square, then you need to fix your tabs.    *
        !            36:  ****************************************************************************/
        !            37: 
        !            38: #include "sbbs.h"
        !            39: #include "cmdshell.h"
        !            40: 
        !            41: extern "C" void client_on(SOCKET sock, client_t* client);
        !            42: 
        !            43: /****************************************************************************/
        !            44: /* Called once upon each user logging on the board                                                     */
        !            45: /* Returns 1 if user passed logon, 0 if user failed.                                           */
        !            46: /****************************************************************************/
        !            47: bool sbbs_t::logon()
        !            48: {
        !            49:        char    str[256],c;
        !            50:        char    tmp[512];
        !            51:        int     file;
        !            52:        uint    i,j,mailw;
        !            53:        ulong   totallogons;
        !            54:        node_t  node;
        !            55:        struct  tm* tm_p;
        !            56:        struct  tm      tm;
        !            57: 
        !            58:        now=time(NULL);
        !            59:        tm_p=localtime(&now);
        !            60:        if(tm_p==NULL)
        !            61:                return(false);
        !            62:        tm=*tm_p;
        !            63: 
        !            64:        if(!useron.number)
        !            65:                return(false);
        !            66: 
        !            67:        client.user=useron.alias;
        !            68:        client_on(client_socket,&client);
        !            69: 
        !            70:        if(useron.rest&FLAG('Q'))
        !            71:                qwklogon=1;
        !            72:        if(SYSOP && ((online==ON_REMOTE && !(cfg.sys_misc&SM_R_SYSOP))
        !            73:                || (online==ON_LOCAL && !(cfg.sys_misc&SM_L_SYSOP))))
        !            74:                return(false);
        !            75:        if(cur_rate<cfg.node_minbps && !(useron.exempt&FLAG('M'))) {
        !            76:                bprintf(text[MinimumModemSpeed],cfg.node_minbps);
        !            77:                sprintf(str,"%stooslow.msg",cfg.text_dir);
        !            78:                if(fexist(str))
        !            79:                        printfile(str,0);
        !            80:                sprintf(str,"(%04u)  %-25s  Modem speed: %u<%u"
        !            81:                        ,useron.number,useron.alias,cur_rate,cfg.node_minbps);
        !            82:                logline("+!",str);
        !            83:                return(false); }
        !            84: 
        !            85:        if(useron.rest&FLAG('G')) {     /* Guest account */
        !            86:                useron.misc=(cfg.new_misc&(~ASK_NSCAN));
        !            87:                useron.rows=0;
        !            88:                useron.misc&=~(ANSI|RIP|WIP|NO_EXASCII|COLOR);
        !            89:                useron.misc|=autoterm;
        !            90:                if(!(useron.misc&ANSI) && yesno(text[AnsiTerminalQ]))
        !            91:                        useron.misc|=ANSI;
        !            92:                if(useron.misc&(RIP|WIP)
        !            93:                        || (useron.misc&ANSI && yesno(text[ColorTerminalQ])))
        !            94:                        useron.misc|=COLOR;
        !            95:                if(!yesno(text[ExAsciiTerminalQ]))
        !            96:                        useron.misc|=NO_EXASCII;
        !            97:                for(i=0;i<cfg.total_xedits;i++)
        !            98:                        if(!stricmp(cfg.xedit[i]->code,cfg.new_xedit)
        !            99:                                && chk_ar(cfg.xedit[i]->ar,&useron))
        !           100:                                break;
        !           101:                if(i<cfg.total_xedits)
        !           102:                        useron.xedit=i+1;
        !           103:                else
        !           104:                        useron.xedit=0;
        !           105:                useron.prot=cfg.new_prot;
        !           106:                useron.shell=cfg.new_shell; }
        !           107: 
        !           108:        if(cfg.node_dollars_per_call) {
        !           109:                adjustuserrec(&cfg,useron.number,U_CDT,10
        !           110:                        ,cfg.cdt_per_dollar*cfg.node_dollars_per_call);
        !           111:                bprintf(text[CreditedAccount]
        !           112:                        ,cfg.cdt_per_dollar*cfg.node_dollars_per_call);
        !           113:                sprintf(str,"%s #%u was billed $%d T: %u seconds"
        !           114:                        ,useron.alias,useron.number
        !           115:                        ,cfg.node_dollars_per_call,(uint)now-answertime);
        !           116:                logline("$+",str);
        !           117:                hangup();
        !           118:                return(false); }
        !           119: 
        !           120:        //lclini(node_scrnlen-1);
        !           121: 
        !           122:        if(!chk_ar(cfg.node_ar,&useron)) {
        !           123:                bputs(text[NoNodeAccess]);
        !           124:                sprintf(str,"(%04u)  %-25s  Insufficient node access"
        !           125:                        ,useron.number,useron.alias);
        !           126:                logline("+!",str);
        !           127:                return(false); }
        !           128: 
        !           129:        getnodedat(cfg.node_num,&thisnode,1);
        !           130:        if(thisnode.misc&NODE_LOCK) {
        !           131:                putnodedat(cfg.node_num,&thisnode);     /* must unlock! */
        !           132:                if(!SYSOP && !(useron.exempt&FLAG('N'))) {
        !           133:                        bputs(text[NodeLocked]);
        !           134:                        sprintf(str,"(%04u)  %-25s  Locked node logon attempt"
        !           135:                                ,useron.number,useron.alias);
        !           136:                        logline("+!",str);
        !           137:                        return(false); }
        !           138:                if(yesno(text[RemoveNodeLockQ])) {
        !           139:                        getnodedat(cfg.node_num,&thisnode,1);
        !           140:                        logline("S-","Removed Node Lock");
        !           141:                        thisnode.misc&=~NODE_LOCK; }
        !           142:                else
        !           143:                        getnodedat(cfg.node_num,&thisnode,1); }
        !           144: 
        !           145:        if((useron.exempt&FLAG('Q') && useron.misc&QUIET))
        !           146:                thisnode.status=NODE_QUIET;
        !           147:        else
        !           148:                thisnode.status=NODE_INUSE;
        !           149:        action=thisnode.action=NODE_LOGN;
        !           150:        thisnode.connection=0xffff;
        !           151:        thisnode.misc&=~(NODE_ANON|NODE_INTR|NODE_MSGW|NODE_POFF|NODE_AOFF);
        !           152:        if(useron.chat&CHAT_NOACT)
        !           153:                thisnode.misc|=NODE_AOFF;
        !           154:        if(useron.chat&CHAT_NOPAGE)
        !           155:                thisnode.misc|=NODE_POFF;
        !           156:        thisnode.useron=useron.number;
        !           157:        putnodedat(cfg.node_num,&thisnode);
        !           158: 
        !           159:        getusrsubs();
        !           160:        getusrdirs();
        !           161: 
        !           162:        if(useron.misc&CURSUB && !(useron.rest&FLAG('G'))) {
        !           163:                for(i=0;i<usrgrps;i++) {
        !           164:                        for(j=0;j<usrsubs[i];j++) {
        !           165:                                if(!strcmp(cfg.sub[usrsub[i][j]]->code,useron.cursub))
        !           166:                                        break; }
        !           167:                        if(j<usrsubs[i]) {
        !           168:                                curgrp=i;
        !           169:                                cursub[i]=j;
        !           170:                                break; } }
        !           171:                for(i=0;i<usrlibs;i++) {
        !           172:                        for(j=0;j<usrdirs[i];j++)
        !           173:                                if(!strcmp(cfg.dir[usrdir[i][j]]->code,useron.curdir))
        !           174:                                        break;
        !           175:                        if(j<usrdirs[i]) {
        !           176:                                curlib=i;
        !           177:                                curdir[i]=j;
        !           178:                                break; } } }
        !           179: 
        !           180: 
        !           181:        if(useron.misc&AUTOTERM) {
        !           182:                useron.misc&=~(ANSI|RIP|WIP);
        !           183:                useron.misc|=autoterm; }
        !           184: 
        !           185:        if(!chk_ar(cfg.shell[useron.shell]->ar,&useron)) {
        !           186:                useron.shell=cfg.new_shell;
        !           187:                if(!chk_ar(cfg.shell[useron.shell]->ar,&useron)) {
        !           188:                        for(i=0;i<cfg.total_shells;i++)
        !           189:                                if(chk_ar(cfg.shell[i]->ar,&useron))
        !           190:                                        break;
        !           191:                        if(i==cfg.total_shells)
        !           192:                                useron.shell=0; } }
        !           193: 
        !           194:        logon_ml=useron.level;
        !           195:        logontime=time(NULL);
        !           196:        starttime=logontime;
        !           197:        last_ns_time=ns_time=useron.ns_time;
        !           198:        // ns_time-=(useron.tlast*60); /* file newscan time == last logon time */
        !           199:        delfiles(cfg.temp_dir,ALLFILES);
        !           200:        sprintf(str,"%smsgs/n%3.3u.msg",cfg.data_dir,cfg.node_num);
        !           201:        remove(str);            /* remove any pending node messages */
        !           202:        sprintf(str,"%smsgs/n%3.3u.ixb",cfg.data_dir,cfg.node_num);
        !           203:        remove(str);                    /* remove any pending node message indices */
        !           204: 
        !           205:        if(!SYSOP && online==ON_REMOTE) {
        !           206:                rioctl(IOCM|ABORT);     /* users can't abort anything */
        !           207:                rioctl(IOCS|ABORT); }
        !           208: 
        !           209:        CLS;
        !           210:        if(useron.rows)
        !           211:                rows=useron.rows;
        !           212:        else if(online==ON_LOCAL)
        !           213:                rows=cfg.node_scrnlen-1;
        !           214:        unixtodstr(&cfg,logontime,str);
        !           215:        if(!strncmp(str,useron.birth,5) && !(useron.rest&FLAG('Q'))) {
        !           216:                bputs(text[HappyBirthday]);
        !           217:                pause();
        !           218:                CLS;
        !           219:                user_event(EVENT_BIRTHDAY); }
        !           220:        unixtodstr(&cfg,useron.laston,tmp);
        !           221:        if(strcmp(str,tmp)) {                   /* str still equals logon time */
        !           222:                useron.ltoday=1;
        !           223:                useron.ttoday=useron.etoday=useron.ptoday=useron.textra=0;
        !           224:                useron.freecdt=cfg.level_freecdtperday[useron.level]; }
        !           225:        else
        !           226:                useron.ltoday++;
        !           227: 
        !           228:        gettimeleft();
        !           229:        sprintf(str,"%sfile/%04u.dwn",cfg.data_dir,useron.number);
        !           230:        batch_add_list(str);
        !           231:        if(!qwklogon) {          /* QWK Nodes don't go through this */
        !           232: 
        !           233:                if(cfg.sys_pwdays
        !           234:                        && (ulong)logontime>(useron.pwmod+((ulong)cfg.sys_pwdays*24UL*60UL*60UL))) {
        !           235:                        bprintf(text[TimeToChangePw],cfg.sys_pwdays);
        !           236: 
        !           237:                        c=0;
        !           238:                        while(c<LEN_PASS) {                             /* Create random password */
        !           239:                                str[c]=sbbs_random(43)+'0';
        !           240:                                if(isalnum(str[c]))
        !           241:                                        c++; }
        !           242:                        str[c]=0;
        !           243:                        bprintf(text[YourPasswordIs],str);
        !           244: 
        !           245:                        if(cfg.sys_misc&SM_PWEDIT && yesno(text[NewPasswordQ]))
        !           246:                                while(online) {
        !           247:                                        bputs(text[NewPassword]);
        !           248:                                        getstr(str,LEN_PASS,K_UPPER|K_LINE);
        !           249:                                        truncsp(str);
        !           250:                                        if(chkpass(str,&useron,true))
        !           251:                                                break;
        !           252:                                        CRLF; }
        !           253: 
        !           254:                        while(online) {
        !           255:                                if(cfg.sys_misc&SM_PWEDIT) {
        !           256:                                        CRLF;
        !           257:                                        bputs(text[VerifyPassword]); }
        !           258:                                else
        !           259:                                        bputs(text[NewUserPasswordVerify]);
        !           260:                                console|=CON_R_ECHOX;
        !           261:                                if(!(cfg.sys_misc&SM_ECHO_PW))
        !           262:                                        console|=CON_L_ECHOX;
        !           263:                                getstr(tmp,LEN_PASS,K_UPPER);
        !           264:                                console&=~(CON_R_ECHOX|CON_L_ECHOX);
        !           265:                                if(strcmp(str,tmp)) {
        !           266:                                        bputs(text[Wrong]);
        !           267:                                        continue; }
        !           268:                                break; }
        !           269:                        strcpy(useron.pass,str);
        !           270:                        useron.pwmod=time(NULL);
        !           271:                        putuserrec(&cfg,useron.number,U_PWMOD,8,ultoa(useron.pwmod,str,16));
        !           272:                        bputs(text[PasswordChanged]);
        !           273:                        pause(); }
        !           274:                if(useron.ltoday>cfg.level_callsperday[useron.level]
        !           275:                        && !(useron.exempt&FLAG('L'))) {
        !           276:                        bputs(text[NoMoreLogons]);
        !           277:                        sprintf(str,"(%04u)  %-25s  Out of logons"
        !           278:                                ,useron.number,useron.alias);
        !           279:                        logline("+!",str);
        !           280:                        hangup();
        !           281:                        return(false); }
        !           282:                if(useron.rest&FLAG('L') && useron.ltoday>1) {
        !           283:                        bputs(text[R_Logons]);
        !           284:                        sprintf(str,"(%04u)  %-25s  Out of logons"
        !           285:                                ,useron.number,useron.alias);
        !           286:                        logline("+!",str);
        !           287:                        hangup();
        !           288:                        return(false); }
        !           289:                if(!(useron.rest&FLAG('G'))) {
        !           290:                        if(!useron.name[0] && ((cfg.uq&UQ_ALIASES && cfg.uq&UQ_REALNAME)
        !           291:                                || cfg.uq&UQ_COMPANY))
        !           292:                                while(online) {
        !           293:                                        if(cfg.uq&UQ_ALIASES && cfg.uq&UQ_REALNAME)
        !           294:                                                bputs(text[EnterYourRealName]);
        !           295:                                        else
        !           296:                                                bputs(text[EnterYourCompany]);
        !           297:                                        getstr(useron.name,LEN_NAME,K_UPRLWR|(cfg.uq&UQ_NOEXASC));
        !           298:                                        if(cfg.uq&UQ_ALIASES && cfg.uq&UQ_REALNAME) {
        !           299:                                                if(trashcan(useron.name,"name") || !useron.name[0]
        !           300:                                                        || !strchr(useron.name,SP)
        !           301:                                                        || strchr(useron.name,0xff)
        !           302:                                                        || (cfg.uq&UQ_DUPREAL
        !           303:                                                                && userdatdupe(useron.number,U_NAME,LEN_NAME
        !           304:                                                                ,useron.name,0)))
        !           305:                                                        bputs(text[YouCantUseThatName]);
        !           306:                                                else
        !           307:                                                        break; }
        !           308:                                        else
        !           309:                                                break; }
        !           310:                        if(cfg.uq&UQ_HANDLE && !useron.handle[0]) {
        !           311:                                sprintf(useron.handle,"%.*s",LEN_HANDLE,useron.alias);
        !           312:                                while(online) {
        !           313:                                        bputs(text[EnterYourHandle]);
        !           314:                                        if(!getstr(useron.handle,LEN_HANDLE
        !           315:                                                ,K_LINE|K_EDIT|K_AUTODEL|(cfg.uq&UQ_NOEXASC))
        !           316:                                                || strchr(useron.handle,0xff)
        !           317:                                                || (cfg.uq&UQ_DUPHAND
        !           318:                                                        && userdatdupe(useron.number,U_HANDLE,LEN_HANDLE
        !           319:                                                        ,useron.handle,0))
        !           320:                                                || trashcan(useron.handle,"name"))
        !           321:                                                bputs(text[YouCantUseThatName]);
        !           322:                                        else
        !           323:                                                break; } }
        !           324:                        if(cfg.uq&UQ_LOCATION && !useron.location[0])
        !           325:                                while(online) {
        !           326:                                        bputs(text[EnterYourCityState]);
        !           327:                                        if(getstr(useron.location,LEN_LOCATION,K_UPRLWR|(cfg.uq&UQ_NOEXASC)))
        !           328:                                                break; }
        !           329:                        if(cfg.uq&UQ_ADDRESS && !useron.address[0])
        !           330:                                while(online) {
        !           331:                                        bputs(text[EnterYourAddress]);
        !           332:                                        if(getstr(useron.address,LEN_ADDRESS,K_UPRLWR|(cfg.uq&UQ_NOEXASC)))
        !           333:                                                break; }
        !           334:                        if(cfg.uq&UQ_ADDRESS && !useron.zipcode[0])
        !           335:                                while(online) {
        !           336:                                        bputs(text[EnterYourZipCode]);
        !           337:                                        if(getstr(useron.zipcode,LEN_ZIPCODE,K_UPPER|(cfg.uq&UQ_NOEXASC)))
        !           338:                                                break; }
        !           339:                        if(cfg.uq&UQ_PHONE && !useron.phone[0]) {
        !           340:                                i=yesno(text[CallingFromNorthAmericaQ]);
        !           341:                                while(online) {
        !           342:                                        bputs(text[EnterYourPhoneNumber]);
        !           343:                                        if(i) {
        !           344:                                                if(gettmplt(useron.phone,cfg.sys_phonefmt
        !           345:                                                        ,K_LINE|(cfg.uq&UQ_NOEXASC))<strlen(cfg.sys_phonefmt))
        !           346:                                                         continue; }
        !           347:                                        else {
        !           348:                                                if(getstr(useron.phone,LEN_PHONE
        !           349:                                                        ,K_UPPER|(cfg.uq&UQ_NOEXASC))<5)
        !           350:                                                        continue; }
        !           351:                                        if(!trashcan(useron.phone,"phone"))
        !           352:                                                break; } }
        !           353:                        if(!(sys_status&SS_RLOGIN) 
        !           354:                                && /* cfg.uq&UQ_EMAIL && */ !useron.netmail[0]) {
        !           355:                                while(online) {
        !           356:                                        bputs(text[EnterNetMailAddress]);
        !           357:                                        if(getstr(useron.netmail,LEN_NETMAIL,K_EDIT|K_AUTODEL|K_LINE))
        !           358:                                                break;
        !           359:                                }
        !           360:                                if(useron.netmail[0] && !noyes(text[ForwardMailQ]))
        !           361:                                        useron.misc|=NETMAIL;
        !           362:                                else 
        !           363:                                        useron.misc&=~NETMAIL;
        !           364:                        }
        !           365:                        if(cfg.new_sif[0]) {
        !           366:                                sprintf(str,"%suser/%4.4u.dat",cfg.data_dir,useron.number);
        !           367:                                if(flength(str)<1L)
        !           368:                                        create_sif_dat(cfg.new_sif,str); } 
        !           369:                }
        !           370:        }       
        !           371:        if(!online) {
        !           372:                sprintf(str,"(%04u)  %-25s  Unsuccessful logon"
        !           373:                        ,useron.number,useron.alias);
        !           374:                logline("+!",str);
        !           375:                return(false); }
        !           376:        strcpy(useron.modem,connection);
        !           377:        useron.logons++;
        !           378:        putuserdat(&cfg,&useron);
        !           379:        getmsgptrs();
        !           380:        sys_status|=SS_USERON;          /* moved from further down */
        !           381: 
        !           382:        if(useron.rest&FLAG('Q')) {
        !           383:                sprintf(str,"(%04u)  %-25s  QWK Network Connection"
        !           384:                        ,useron.number,useron.alias);
        !           385:                logline("++",str);
        !           386:                return(true); }
        !           387: 
        !           388:        /********************/
        !           389:        /* SUCCESSFUL LOGON */
        !           390:        /********************/
        !           391:        totallogons=logonstats();
        !           392:        sprintf(str,"(%04u)  %-25s  Logon %lu - %u"
        !           393:                ,useron.number,useron.alias,totallogons,useron.ltoday);
        !           394:        logline("++",str);
        !           395: 
        !           396:        if(!qwklogon && cfg.logon_mod[0])
        !           397:                exec_bin(cfg.logon_mod,&main_csi);
        !           398: 
        !           399:        if(thisnode.status!=NODE_QUIET && (!REALSYSOP || cfg.sys_misc&SM_SYSSTAT)) {
        !           400:                sprintf(str,"%slogon.lst",cfg.data_dir);
        !           401:                if((file=nopen(str,O_WRONLY|O_CREAT|O_APPEND))==-1) {
        !           402:                        errormsg(WHERE,ERR_OPEN,str,O_RDWR|O_CREAT|O_APPEND);
        !           403:                        return(false); }
        !           404:                sprintf(str,text[LastFewCallersFmt],cfg.node_num
        !           405:                        ,totallogons,useron.alias
        !           406:                        ,cfg.sys_misc&SM_LISTLOC ? useron.location : useron.note
        !           407:                        ,tm.tm_hour,tm.tm_min
        !           408:                        ,connection,useron.ltoday);
        !           409:                write(file,str,strlen(str));
        !           410:                close(file); }
        !           411: 
        !           412:        if(cfg.sys_logon[0])                            /* execute system logon event */
        !           413:                external(cmdstr(cfg.sys_logon,nulstr,nulstr,NULL),EX_OUTR|EX_OUTL); /* EX_CC */
        !           414: 
        !           415:        if(qwklogon)
        !           416:                return(true);
        !           417: 
        !           418:        sys_status|=SS_PAUSEON; /* always force pause on during this section */
        !           419:        mailw=getmail(&cfg,useron.number,0);
        !           420:        bprintf(text[SiSysName],cfg.sys_name);
        !           421:        //bprintf(text[SiNodeNumberName],cfg.node_num,cfg.node_name);
        !           422:        bprintf(text[LiUserNumberName],useron.number,useron.alias);
        !           423:        bprintf(text[LiLogonsToday],useron.ltoday
        !           424:                ,cfg.level_callsperday[useron.level]);
        !           425:        bprintf(text[LiTimeonToday],useron.ttoday
        !           426:                ,cfg.level_timeperday[useron.level]+useron.min);
        !           427:        bprintf(text[LiMailWaiting],mailw);
        !           428:        strcpy(str,text[LiSysopIs]);
        !           429:        if(cfg.startup->options&BBS_OPT_SYSOP_AVAILABLE 
        !           430:                || (cfg.sys_chat_ar[0] && chk_ar(cfg.sys_chat_ar,&useron)))
        !           431:                strcat(str,text[LiSysopAvailable]);
        !           432:        else
        !           433:                strcat(str,text[LiSysopNotAvailable]);
        !           434:        bprintf("%s\r\n\r\n",str);
        !           435:        if(sys_status&SS_EVENT)
        !           436:                bputs(text[ReducedTime]);
        !           437:        getnodedat(cfg.node_num,&thisnode,1);
        !           438:        thisnode.misc&=~(NODE_AOFF|NODE_POFF);
        !           439:        if(useron.chat&CHAT_NOACT)
        !           440:                thisnode.misc|=NODE_AOFF;
        !           441:        if(useron.chat&CHAT_NOPAGE)
        !           442:                thisnode.misc|=NODE_POFF;
        !           443:        putnodedat(cfg.node_num,&thisnode);
        !           444:        getsmsg(useron.number);                 /* Moved from further down */
        !           445:        SYNC;
        !           446:        c=0;
        !           447:        for(i=1;i<=cfg.sys_nodes;i++)
        !           448:                if(i!=cfg.node_num) {
        !           449:                        getnodedat(i,&node,0);
        !           450:                        if(node.status==NODE_INUSE
        !           451:                                || ((node.status==NODE_QUIET || node.errors) && SYSOP)) {
        !           452:                                if(!c)
        !           453:                                        bputs(text[NodeLstHdr]);
        !           454:                                printnodedat(i,&node);
        !           455:                                c=1; }
        !           456:                        if(node.status==NODE_INUSE && i!=cfg.node_num && node.useron==useron.number
        !           457:                                && !SYSOP && !(useron.exempt&FLAG('G'))) {
        !           458:                                strcpy(tmp,"On two nodes at the same time");
        !           459:                                sprintf(str,"(%04u)  %-25s  %s"
        !           460:                                        ,useron.number,useron.alias,tmp);
        !           461:                                logline("+!",str);
        !           462:                                errorlog(tmp);
        !           463:                                bputs(text[UserOnTwoNodes]);
        !           464:                                hangup();
        !           465:                                return(false); }
        !           466:                        if(thisnode.status!=NODE_QUIET
        !           467:                                && (node.status==NODE_INUSE || node.status==NODE_QUIET)
        !           468:                                && !(node.misc&NODE_AOFF) && node.useron!=useron.number) {
        !           469:                                sprintf(str,text[NodeLoggedOnAtNbps]
        !           470:                                        ,cfg.node_num
        !           471:                                        ,thisnode.misc&NODE_ANON ? text[UNKNOWN_USER] : useron.alias
        !           472:                                        ,connection);
        !           473:                                putnmsg(i,str); } }
        !           474: 
        !           475:        if(cfg.sys_exp_warn && useron.expire && useron.expire>now /* Warn user of coming */
        !           476:                && (useron.expire-now)/(1440L*60L)<=cfg.sys_exp_warn) /* expiration */
        !           477:                bprintf(text[AccountWillExpireInNDays],(useron.expire-now)/(1440L*60L));
        !           478: 
        !           479:        if(criterrs && SYSOP)
        !           480:                bprintf(text[CriticalErrors],criterrs);
        !           481:        if((i=getuserxfers(0,useron.number,0))!=0) {
        !           482:                bprintf(text[UserXferForYou],i,i>1 ? "s" : nulstr); }
        !           483:        if((i=getuserxfers(useron.number,0,0))!=0) {
        !           484:                bprintf(text[UnreceivedUserXfer],i,i>1 ? "s" : nulstr); }
        !           485:        SYNC;
        !           486:        sys_status&=~SS_PAUSEON;        /* Turn off the pause override flag */
        !           487:        if(online==ON_REMOTE)
        !           488:                rioctl(IOSM|ABORT);             /* Turn abort ability on */
        !           489:        if(mailw) {
        !           490:                if(yesno(text[ReadYourMailNowQ]))
        !           491:                        readmail(useron.number,MAIL_YOUR); }
        !           492:        if(useron.misc&ASK_NSCAN && yesno(text[NScanAllGrpsQ]))
        !           493:                scanallsubs(SCAN_NEW);
        !           494:        if(useron.misc&ASK_SSCAN && yesno(text[SScanAllGrpsQ]))
        !           495:                scanallsubs(SCAN_TOYOU);
        !           496:        return(true);
        !           497: }
        !           498: 
        !           499: /****************************************************************************/
        !           500: /* Checks the system dsts.dab to see if it is a new day, if it is, all the  */
        !           501: /* nodes' and the system's csts.dab are added to, and the dsts.dab's daily  */
        !           502: /* stats are cleared. Also increments the logon values in dsts.dab if       */
        !           503: /* applicable.                                                              */
        !           504: /****************************************************************************/
        !           505: ulong sbbs_t::logonstats()
        !           506: {
        !           507:     char str[256];
        !           508:     int dsts,csts;
        !           509:     uint i;
        !           510:     time_t update_t;
        !           511:     stats_t stats;
        !           512:     node_t node;
        !           513:        struct tm * tm, update_tm;
        !           514: 
        !           515:        sprintf(str,"%sdsts.dab",cfg.ctrl_dir);
        !           516:        if((dsts=nopen(str,O_RDWR))==-1) {
        !           517:                errormsg(WHERE,ERR_OPEN,str,O_RDWR);
        !           518:                return(0L); }
        !           519:        read(dsts,&update_t,4);         /* Last updated         */
        !           520:        read(dsts,&stats.logons,4);     /* Total number of logons on system */
        !           521:        close(dsts);
        !           522:        if(update_t>now+(24L*60L*60L)) /* More than a day in the future? */
        !           523:                errormsg(WHERE,ERR_CHK,"Daily stats time stamp",update_t);
        !           524:        tm = gmtime(&update_t);
        !           525:        if(tm==NULL)
        !           526:                return(0);
        !           527:        update_tm=*tm;
        !           528:        tm = gmtime(&now);
        !           529:        if(tm==NULL)
        !           530:                return(0);
        !           531:        if((tm->tm_mday>update_tm.tm_mday && tm->tm_mon==update_tm.tm_mon)
        !           532:                || tm->tm_mon>update_tm.tm_mon || tm->tm_year>update_tm.tm_year) {
        !           533: 
        !           534:                sprintf(str,"New Day - Prev: %s ",timestr(&update_t));
        !           535:                logentry("!=",str);
        !           536: 
        !           537:                sys_status|=SS_DAILY;       /* New Day !!! */
        !           538:                sprintf(str,"%slogon.lst",cfg.data_dir);    /* Truncate logon list */
        !           539:                if((dsts=nopen(str,O_TRUNC|O_CREAT|O_WRONLY))==-1) {
        !           540:                        errormsg(WHERE,ERR_OPEN,str,O_TRUNC|O_CREAT|O_WRONLY);
        !           541:                        return(0L); }
        !           542:                close(dsts);
        !           543:                for(i=0;i<=cfg.sys_nodes;i++) {
        !           544:                        if(i) {     /* updating a node */
        !           545:                                getnodedat(i,&node,1);
        !           546:                                node.misc|=NODE_EVENT;
        !           547:                                putnodedat(i,&node); }
        !           548:                        sprintf(str,"%sdsts.dab",i ? cfg.node_path[i-1] : cfg.ctrl_dir);
        !           549:                        if((dsts=nopen(str,O_RDWR))==-1) /* node doesn't have stats yet */
        !           550:                                continue;
        !           551:                        sprintf(str,"%scsts.dab",i ? cfg.node_path[i-1] : cfg.ctrl_dir);
        !           552:                        if((csts=nopen(str,O_WRONLY|O_APPEND|O_CREAT))==-1) {
        !           553:                                close(dsts);
        !           554:                                errormsg(WHERE,ERR_OPEN,str,O_WRONLY|O_APPEND|O_CREAT);
        !           555:                                continue; }
        !           556:                        lseek(dsts,8L,SEEK_SET);        /* Skip time and logons */
        !           557:                        write(csts,&now,4);
        !           558:                        read(dsts,&stats.ltoday,4);
        !           559:                        write(csts,&stats.ltoday,4);
        !           560:                        lseek(dsts,4L,SEEK_CUR);        /* Skip total time on */
        !           561:                        read(dsts,&stats.ttoday,4);
        !           562:                        write(csts,&stats.ttoday,4);
        !           563:                        read(dsts,&stats.uls,4);
        !           564:                        write(csts,&stats.uls,4);
        !           565:                        read(dsts,&stats.ulb,4);
        !           566:                        write(csts,&stats.ulb,4);
        !           567:                        read(dsts,&stats.dls,4);
        !           568:                        write(csts,&stats.dls,4);
        !           569:                        read(dsts,&stats.dlb,4);
        !           570:                        write(csts,&stats.dlb,4);
        !           571:                        read(dsts,&stats.ptoday,4);
        !           572:                        write(csts,&stats.ptoday,4);
        !           573:                        read(dsts,&stats.etoday,4);
        !           574:                        write(csts,&stats.etoday,4);
        !           575:                        read(dsts,&stats.ftoday,4);
        !           576:                        write(csts,&stats.ftoday,4);
        !           577:                        close(csts);
        !           578:                        lseek(dsts,0L,SEEK_SET);        /* Go back to beginning */
        !           579:                        write(dsts,&now,4);             /* Update time stamp  */
        !           580:                        lseek(dsts,4L,SEEK_CUR);        /* Skip total logons */
        !           581:                        stats.ltoday=0;
        !           582:                        write(dsts,&stats.ltoday,4);  /* Logons today to 0 */
        !           583:                        lseek(dsts,4L,SEEK_CUR);     /* Skip total time on */
        !           584:                        stats.ttoday=0;              /* Set all other today variables to 0 */
        !           585:                        write(dsts,&stats.ttoday,4);        /* Time on today to 0 */
        !           586:                        write(dsts,&stats.ttoday,4);        /* Uploads today to 0 */
        !           587:                        write(dsts,&stats.ttoday,4);        /* U/L Bytes today    */
        !           588:                        write(dsts,&stats.ttoday,4);        /* Download today     */
        !           589:                        write(dsts,&stats.ttoday,4);        /* Download bytes     */
        !           590:                        write(dsts,&stats.ttoday,4);        /* Posts today        */
        !           591:                        write(dsts,&stats.ttoday,4);        /* Emails today       */
        !           592:                        write(dsts,&stats.ttoday,4);        /* Feedback today     */
        !           593:                        write(dsts,&stats.ttoday,2);        /* New users Today    */
        !           594:                        close(dsts); } }
        !           595: 
        !           596:        if(thisnode.status==NODE_QUIET)       /* Quiet users aren't counted */
        !           597:                return(0);
        !           598: 
        !           599:        if(REALSYSOP && !(cfg.sys_misc&SM_SYSSTAT))
        !           600:                return(0);
        !           601: 
        !           602:        for(i=0;i<2;i++) {
        !           603:                sprintf(str,"%sdsts.dab",i ? cfg.ctrl_dir : cfg.node_dir);
        !           604:                if((dsts=nopen(str,O_RDWR))==-1) {
        !           605:                        errormsg(WHERE,ERR_OPEN,str,O_RDWR);
        !           606:                        return(0L); }
        !           607:                lseek(dsts,4L,SEEK_SET);        /* Skip time stamp */
        !           608:                read(dsts,&stats.logons,4);
        !           609:                read(dsts,&stats.ltoday,4);
        !           610:                stats.logons++;
        !           611:                stats.ltoday++;
        !           612:                lseek(dsts,4L,SEEK_SET);        /* Rewind back and overwrite */
        !           613:                write(dsts,&stats.logons,4);
        !           614:                write(dsts,&stats.ltoday,4);
        !           615:                close(dsts); }
        !           616:        return(stats.logons);
        !           617: }
        !           618: 
        !           619: 

unix.superglobalmegacorp.com

This archive runs on limited infrastructure. Preserving old code on modern bandwidth. Automated agents are requested to crawl responsibly.