diff options
Diffstat (limited to 'innbbsd/bbslib.c')
-rw-r--r-- | innbbsd/bbslib.c | 1102 |
1 files changed, 576 insertions, 526 deletions
diff --git a/innbbsd/bbslib.c b/innbbsd/bbslib.c index c0177e87..d8ab6401 100644 --- a/innbbsd/bbslib.c +++ b/innbbsd/bbslib.c @@ -1,712 +1,762 @@ #if defined( LINUX ) -# include "innbbsconf.h" -# include "bbslib.h" -# include <stdarg.h> +#include "innbbsconf.h" +#include "bbslib.h" +#include <stdarg.h> #else -# include <stdarg.h> -# include "innbbsconf.h" -# include "bbslib.h" +#include <stdarg.h> +#include "innbbsconf.h" +#include "bbslib.h" #endif -char INNBBSCONF[MAXPATHLEN]; -char INNDHOME[MAXPATHLEN]; -char HISTORY[MAXPATHLEN]; -char LOGFILE[MAXPATHLEN]; -char MYBBSID[MAXPATHLEN]; -char ECHOMAIL[MAXPATHLEN]; -char BBSFEEDS[MAXPATHLEN]; -char LOCALDAEMON[MAXPATHLEN]; - -int His_Maint_Min= HIS_MAINT_MIN; -int His_Maint_Hour= HIS_MAINT_HOUR; -int Expiredays = EXPIREDAYS; - -nodelist_t *NODELIST=NULL, **NODELIST_BYNODE=NULL; -newsfeeds_t *NEWSFEEDS=NULL, **NEWSFEEDS_BYBOARD=NULL; -static char *NODELIST_BUF, *NEWSFEEDS_BUF; -int NFCOUNT, NLCOUNT; -int LOCALNODELIST=0, NONENEWSFEEDS=0; +char INNBBSCONF[MAXPATHLEN]; +char INNDHOME[MAXPATHLEN]; +char HISTORY[MAXPATHLEN]; +char LOGFILE[MAXPATHLEN]; +char MYBBSID[MAXPATHLEN]; +char ECHOMAIL[MAXPATHLEN]; +char BBSFEEDS[MAXPATHLEN]; +char LOCALDAEMON[MAXPATHLEN]; + +int His_Maint_Min = HIS_MAINT_MIN; +int His_Maint_Hour = HIS_MAINT_HOUR; +int Expiredays = EXPIREDAYS; + +nodelist_t *NODELIST = NULL, **NODELIST_BYNODE = NULL; +newsfeeds_t *NEWSFEEDS = NULL, **NEWSFEEDS_BYBOARD = NULL; +static char *NODELIST_BUF, *NEWSFEEDS_BUF; +int NFCOUNT, NLCOUNT; +int LOCALNODELIST = 0, NONENEWSFEEDS = 0; #ifndef _PATH_BBSHOME -# define _PATH_BBSHOME "/u/staff/bbsroot/csie_util/bntpd/home" +#define _PATH_BBSHOME "/u/staff/bbsroot/csie_util/bntpd/home" #endif -static FILE *bbslogfp; +static FILE *bbslogfp; -static int -verboseFlag=0; +static int + verboseFlag = 0; -static char* -verboseFilename=NULL; -static char verbosename[MAXPATHLEN]; +static char * + verboseFilename = NULL; +static char verbosename[MAXPATHLEN]; verboseon(filename) -char *filename; + char *filename; { - verboseFlag = 1; - if ( filename != NULL ) { - if (strchr(filename,'/') == NULL) { - sprintf(verbosename,"%s/innd/%s",BBSHOME,filename); - filename = verbosename; - } - } - verboseFilename = filename; + verboseFlag = 1; + if (filename != NULL) { + if (strchr(filename, '/') == NULL) { + sprintf(verbosename, "%s/innd/%s", BBSHOME, filename); + filename = verbosename; + } + } + verboseFilename = filename; } verboseoff() { - verboseFlag = 0; + verboseFlag = 0; } setverboseon() { - verboseFlag = 1; + verboseFlag = 1; } isverboselog() { - return verboseFlag; + return verboseFlag; } setverboseoff() { - verboseoff(); - if (bbslogfp != NULL) { - fclose(bbslogfp); - bbslogfp = NULL; - } + verboseoff(); + if (bbslogfp != NULL) { + fclose(bbslogfp); + bbslogfp = NULL; + } } -verboselog(char *fmt, ...) +verboselog(char *fmt,...) { - va_list ap; - char datebuf[40]; - time_t now; + va_list ap; + char datebuf[40]; + time_t now; - if (verboseFlag == 0) return; + if (verboseFlag == 0) + return; - va_start(ap, fmt); + va_start(ap, fmt); - time(&now); - strftime(datebuf, sizeof(datebuf), "%b %d %X ", localtime(&now)); + time(&now); + strftime(datebuf, sizeof(datebuf), "%b %d %X ", localtime(&now)); - if (bbslogfp == NULL) { - if (verboseFilename != NULL) - bbslogfp = fopen(verboseFilename, "a"); - else - bbslogfp = fdopen(1, "a"); - } - if (bbslogfp == NULL) { - va_end(ap); - return; - } - fprintf(bbslogfp,"%s[%d] ",datebuf, getpid()); - vfprintf(bbslogfp, fmt, ap); - fflush(bbslogfp); + if (bbslogfp == NULL) { + if (verboseFilename != NULL) + bbslogfp = fopen(verboseFilename, "a"); + else + bbslogfp = fdopen(1, "a"); + } + if (bbslogfp == NULL) { va_end(ap); + return; + } + fprintf(bbslogfp, "%s[%d] ", datebuf, getpid()); + vfprintf(bbslogfp, fmt, ap); + fflush(bbslogfp); + va_end(ap); } #ifdef PalmBBS -xbbslog(char *fmt, ...) +xbbslog(char *fmt,...) #else -bbslog(char *fmt, ...) +bbslog(char *fmt,...) #endif { - va_list ap; - char datebuf[40]; - time_t now; + va_list ap; + char datebuf[40]; + time_t now; - va_start(ap, fmt); + va_start(ap, fmt); - time(&now); - strftime(datebuf, sizeof(datebuf), "%b %d %X ", localtime(&now)); + time(&now); + strftime(datebuf, sizeof(datebuf), "%b %d %X ", localtime(&now)); - if (bbslogfp == NULL) { - bbslogfp = fopen(LOGFILE, "a"); - } - if (bbslogfp == NULL) { - va_end(ap); - return; - } - fprintf(bbslogfp,"%s[%d] ",datebuf,getpid()); - vfprintf(bbslogfp, fmt, ap); - fflush(bbslogfp); + if (bbslogfp == NULL) { + bbslogfp = fopen(LOGFILE, "a"); + } + if (bbslogfp == NULL) { va_end(ap); + return; + } + fprintf(bbslogfp, "%s[%d] ", datebuf, getpid()); + vfprintf(bbslogfp, fmt, ap); + fflush(bbslogfp); + va_end(ap); } initial_bbs(outgoing) -char *outgoing; + char *outgoing; { - FILE* FN; - struct stat st; - int fd, i; - char *bbsnameptr=NULL; - -/* reopen bbslog */ - if (bbslogfp != NULL) { - fclose(bbslogfp); - bbslogfp = NULL; - } - + FILE *FN; + struct stat st; + int fd, i; + char *bbsnameptr = NULL; + + /* reopen bbslog */ + if (bbslogfp != NULL) { + fclose(bbslogfp); + bbslogfp = NULL; + } #ifdef WITH_ECHOMAIL - init_echomailfp(); - init_bbsfeedsfp(); + init_echomailfp(); + init_bbsfeedsfp(); #endif - LOCALNODELIST=0, NONENEWSFEEDS =0; - sprintf(INNDHOME,"%s/innd",BBSHOME); - sprintf(HISTORY, "%s/history",INNDHOME); - sprintf(LOGFILE, "%s/bbslog",INNDHOME); - sprintf(ECHOMAIL,"%s/echomail.log",BBSHOME); - sprintf(LOCALDAEMON,"%s/.innbbsd",INNDHOME); - sprintf(INNBBSCONF,"%s/innbbs.conf",INNDHOME); - sprintf(BBSFEEDS,"%s/bbsfeeds.log",INNDHOME); - - if (isfile(INNBBSCONF)) { - FILE *conf; - char buffer[MAXPATHLEN]; - conf = fopen(INNBBSCONF,"r"); - if (conf != NULL) { - while (fgets( buffer, sizeof buffer, conf) != NULL) { - char *ptr, *front=NULL, *value=NULL, *value2=NULL, *value3=NULL; - if ( buffer[0] == '#' || buffer[0] == '\n') continue; - for ( front = buffer; *front && isspace(*front); front++); - for ( ptr = front; *ptr && !isspace(*ptr) ; ptr++) ; - if (*ptr == '\0') continue; - *ptr++ = '\0'; - for ( ; *ptr && isspace(*ptr) ; ptr++) ; - if (*ptr == '\0') continue; - value = ptr++; - for ( ; *ptr && !isspace(*ptr) ; ptr++) ; - if (*ptr) { - *ptr++ = '\0'; - for ( ; *ptr && isspace(*ptr) ; ptr++) ; - value2 = ptr++; - for ( ; *ptr && !isspace(*ptr) ; ptr++) ; - if (*ptr) { - *ptr++ = '\0'; - for ( ; *ptr && isspace(*ptr) ; ptr++) ; - value3 = ptr++; - for ( ; *ptr && !isspace(*ptr) ; ptr++) ; - if (*ptr) { - *ptr++ = '\0'; - } - } - } - if ( strcasecmp(front,"expiredays") == 0) { - Expiredays = atoi(value); - if (Expiredays < 0) { - Expiredays = EXPIREDAYS; - } - } else if ( strcasecmp(front,"expiretime") == 0) { - ptr = strchr(value,':'); - if (ptr == NULL) { - fprintf(stderr, "Syntax error in innbbs.conf\n"); - } else { - *ptr++ = '\0'; - His_Maint_Hour = atoi(value); - His_Maint_Min = atoi(ptr); - if (His_Maint_Hour < 0) - His_Maint_Hour = HIS_MAINT_HOUR; - if (His_Maint_Min < 0) - His_Maint_Min = HIS_MAINT_MIN; + LOCALNODELIST = 0, NONENEWSFEEDS = 0; + sprintf(INNDHOME, "%s/innd", BBSHOME); + sprintf(HISTORY, "%s/history", INNDHOME); + sprintf(LOGFILE, "%s/bbslog", INNDHOME); + sprintf(ECHOMAIL, "%s/echomail.log", BBSHOME); + sprintf(LOCALDAEMON, "%s/.innbbsd", INNDHOME); + sprintf(INNBBSCONF, "%s/innbbs.conf", INNDHOME); + sprintf(BBSFEEDS, "%s/bbsfeeds.log", INNDHOME); + + if (isfile(INNBBSCONF)) { + FILE *conf; + char buffer[MAXPATHLEN]; + conf = fopen(INNBBSCONF, "r"); + if (conf != NULL) { + while (fgets(buffer, sizeof buffer, conf) != NULL) { + char *ptr, *front = NULL, *value = NULL, *value2 = NULL, + *value3 = NULL; + if (buffer[0] == '#' || buffer[0] == '\n') + continue; + for (front = buffer; *front && isspace(*front); front++); + for (ptr = front; *ptr && !isspace(*ptr); ptr++); + if (*ptr == '\0') + continue; + *ptr++ = '\0'; + for (; *ptr && isspace(*ptr); ptr++); + if (*ptr == '\0') + continue; + value = ptr++; + for (; *ptr && !isspace(*ptr); ptr++); + if (*ptr) { + *ptr++ = '\0'; + for (; *ptr && isspace(*ptr); ptr++); + value2 = ptr++; + for (; *ptr && !isspace(*ptr); ptr++); + if (*ptr) { + *ptr++ = '\0'; + for (; *ptr && isspace(*ptr); ptr++); + value3 = ptr++; + for (; *ptr && !isspace(*ptr); ptr++); + if (*ptr) { + *ptr++ = '\0'; + } + } } - } else if ( strcasecmp(front,"newsfeeds") == 0) { - if (strcmp(value,"none")==0) - NONENEWSFEEDS = 1; - } else if ( strcasecmp(front,"nodelist") == 0) { - if (strcmp(value,"local")==0) - LOCALNODELIST = 1; - } /*else if ( strcasecmp(front,"newsfeeds") == 0) { - printf("newsfeeds %s\n", value); - } else if ( strcasecmp(front,"nodelist") == 0) { - printf("nodelist %s\n", value); - } else if ( strcasecmp(front,"bbsname") == 0) { - printf("bbsname %s\n", value); - } */ - } - fclose(conf); - } - } - + if (strcasecmp(front, "expiredays") == 0) { + Expiredays = atoi(value); + if (Expiredays < 0) { + Expiredays = EXPIREDAYS; + } + } else if (strcasecmp(front, "expiretime") == 0) { + ptr = strchr(value, ':'); + if (ptr == NULL) { + fprintf(stderr, "Syntax error in innbbs.conf\n"); + } else { + *ptr++ = '\0'; + His_Maint_Hour = atoi(value); + His_Maint_Min = atoi(ptr); + if (His_Maint_Hour < 0) + His_Maint_Hour = HIS_MAINT_HOUR; + if (His_Maint_Min < 0) + His_Maint_Min = HIS_MAINT_MIN; + } + } else if (strcasecmp(front, "newsfeeds") == 0) { + if (strcmp(value, "none") == 0) + NONENEWSFEEDS = 1; + } else if (strcasecmp(front, "nodelist") == 0) { + if (strcmp(value, "local") == 0) + LOCALNODELIST = 1; + } /* else if ( strcasecmp(front,"newsfeeds") == + * 0) { printf("newsfeeds %s\n", value); } + * else if ( strcasecmp(front,"nodelist") == + * 0) { printf("nodelist %s\n", value); } + * else if ( strcasecmp(front,"bbsname") == + * 0) { printf("bbsname %s\n", value); } */ + } + fclose(conf); + } + } #ifdef WITH_ECHOMAIL - bbsnameptr = (char*) fileglue("%s/bbsname.bbs",INNDHOME); - if ((FN = fopen( bbsnameptr ,"r" ))==NULL) { - fprintf(stderr,"can't open file %s\n", bbsnameptr); - return 0; - } - while ( fscanf(FN,"%s", MYBBSID) != EOF); - fclose(FN); - if( ! isdir(fileglue("%s/out.going",BBSHOME)) ) { - mkdir( (char*)fileglue("%s/out.going",BBSHOME), 0750 ); - } - if (NONENEWSFEEDS == 0) - readnffile(INNDHOME); - if (LOCALNODELIST == 0) { - if (readnlfile(INNDHOME, outgoing) != 0) return 0; - } - + bbsnameptr = (char *)fileglue("%s/bbsname.bbs", INNDHOME); + if ((FN = fopen(bbsnameptr, "r")) == NULL) { + fprintf(stderr, "can't open file %s\n", bbsnameptr); + return 0; + } + while (fscanf(FN, "%s", MYBBSID) != EOF); + fclose(FN); + if (!isdir(fileglue("%s/out.going", BBSHOME))) { + mkdir((char *)fileglue("%s/out.going", BBSHOME), 0750); + } + if (NONENEWSFEEDS == 0) + readnffile(INNDHOME); + if (LOCALNODELIST == 0) { + if (readnlfile(INNDHOME, outgoing) != 0) + return 0; + } #endif - return 1; + return 1; } -static int -nf_byboardcmp(a,b) -newsfeeds_t **a, **b; +static int +nf_byboardcmp(a, b) + newsfeeds_t **a, **b; { -/* - if (!a || !*a || !(*a)->board) return -1; - if (!b || !*b || !(*b)->board) return 1; -*/ - return strcasecmp((*a)->board, (*b)->board); + /* + * if (!a || !*a || !(*a)->board) return -1; if (!b || !*b || + * !(*b)->board) return 1; + */ + return strcasecmp((*a)->board, (*b)->board); } -static int -nfcmp(a,b) -newsfeeds_t *a, *b; +static int +nfcmp(a, b) + newsfeeds_t *a, *b; { -/* - if (!a || !a->newsgroups) return -1; - if (!b || !b->newsgroups) return 1; -*/ - return strcasecmp(a->newsgroups, b->newsgroups); + /* + * if (!a || !a->newsgroups) return -1; if (!b || !b->newsgroups) return + * 1; + */ + return strcasecmp(a->newsgroups, b->newsgroups); } -static int -nlcmp(a,b) -nodelist_t *a, *b; +static int +nlcmp(a, b) + nodelist_t *a, *b; { -/* - if (!a || !a->host) return -1; - if (!b || !b->host) return 1; -*/ - return strcasecmp(a->host, b->host); + /* + * if (!a || !a->host) return -1; if (!b || !b->host) return 1; + */ + return strcasecmp(a->host, b->host); } -static int -nl_bynodecmp(a,b) -nodelist_t **a, **b; +static int +nl_bynodecmp(a, b) + nodelist_t **a, **b; { -/* - if (!a || !*a || !(*a)->node) return -1; - if (!b || !*b || !(*b)->node) return 1; -*/ - return strcasecmp((*a)->node, (*b)->node); + /* + * if (!a || !*a || !(*a)->node) return -1; if (!b || !*b || !(*b)->node) + * return 1; + */ + return strcasecmp((*a)->node, (*b)->node); } /* read in newsfeeds.bbs and nodelist.bbs */ readnlfile(inndhome, outgoing) -char *inndhome; -char *outgoing; + char *inndhome; + char *outgoing; { - FILE *fp; - char buff[1024]; - struct stat st; - int i, count, j; - char *ptr, *nodelistptr; - static lastcount=0; - - sprintf(buff,"%s/nodelist.bbs", inndhome); - fp = fopen(buff,"r"); + FILE *fp; + char buff[1024]; + struct stat st; + int i, count, j; + char *ptr, *nodelistptr; + static lastcount = 0; + + sprintf(buff, "%s/nodelist.bbs", inndhome); + fp = fopen(buff, "r"); if (fp == NULL) { - fprintf(stderr,"open fail %s",buff); - return -1; + fprintf(stderr, "open fail %s", buff); + return -1; } - if (fstat(fileno(fp),&st) != 0) { - fprintf(stderr,"stat fail %s", buff); - return -1; + if (fstat(fileno(fp), &st) != 0) { + fprintf(stderr, "stat fail %s", buff); + return -1; } if (NODELIST_BUF == NULL) { - NODELIST_BUF = (char*) mymalloc( st.st_size +1); + NODELIST_BUF = (char *)mymalloc(st.st_size + 1); } else { - NODELIST_BUF = (char*) myrealloc( NODELIST_BUF, st.st_size +1); + NODELIST_BUF = (char *)myrealloc(NODELIST_BUF, st.st_size + 1); } - i = 0, count =0; + i = 0, count = 0; while (fgets(buff, sizeof buff, fp) != NULL) { - if (buff[0] == '#') continue; - if (buff[0] == '\n') continue; - strcpy(NODELIST_BUF+i, buff); - i += strlen(buff); - count ++; + if (buff[0] == '#') + continue; + if (buff[0] == '\n') + continue; + strcpy(NODELIST_BUF + i, buff); + i += strlen(buff); + count++; } fclose(fp); if (NODELIST == NULL) { - NODELIST = (nodelist_t*) mymalloc(sizeof(nodelist_t) * (count+1)); - NODELIST_BYNODE = (nodelist_t**) mymalloc(sizeof(nodelist_t*) * (count+1)); + NODELIST = (nodelist_t *) mymalloc(sizeof(nodelist_t) * (count + 1)); + NODELIST_BYNODE = (nodelist_t **) mymalloc(sizeof(nodelist_t *) * (count + 1)); } else { - NODELIST = (nodelist_t*) myrealloc(NODELIST, sizeof(nodelist_t) * (count+1)); - NODELIST_BYNODE = (nodelist_t**) myrealloc(NODELIST_BYNODE, sizeof(nodelist_t*) * (count+1)); + NODELIST = (nodelist_t *) myrealloc(NODELIST, sizeof(nodelist_t) * (count + 1)); + NODELIST_BYNODE = (nodelist_t **) myrealloc(NODELIST_BYNODE, sizeof(nodelist_t *) * (count + 1)); } - for (i=lastcount; i< count; i++) { - NODELIST[i].feedfp = NULL; + for (i = lastcount; i < count; i++) { + NODELIST[i].feedfp = NULL; } lastcount = count; NLCOUNT = 0; - for (ptr = NODELIST_BUF; (nodelistptr = (char*)strchr(ptr,'\n')) != NULL; ptr = nodelistptr +1, NLCOUNT++) { - char *nptr , *bptr, *pptr, *tptr; + for (ptr = NODELIST_BUF; (nodelistptr = (char *)strchr(ptr, '\n')) != NULL; ptr = nodelistptr + 1, NLCOUNT++) { + char *nptr, *bptr, *pptr, *tptr; *nodelistptr = '\0'; NODELIST[NLCOUNT].host = ""; NODELIST[NLCOUNT].exclusion = ""; NODELIST[NLCOUNT].node = ""; NODELIST[NLCOUNT].protocol = "IHAVE(119)"; NODELIST[NLCOUNT].comments = ""; - NODELIST_BYNODE[NLCOUNT] = NODELIST+NLCOUNT; - for (nptr= ptr ;*nptr && isspace(*nptr); ) nptr++; + NODELIST_BYNODE[NLCOUNT] = NODELIST + NLCOUNT; + for (nptr = ptr; *nptr && isspace(*nptr);) + nptr++; if (*nptr == '\0') { - bbslog("nodelist.bbs %d entry read error\n", NLCOUNT); - return -1; - } - /*NODELIST[NLCOUNT].id = nptr;*/ - NODELIST[NLCOUNT].node = nptr; - for (nptr++; *nptr && !isspace(*nptr); ) nptr++; + bbslog("nodelist.bbs %d entry read error\n", NLCOUNT); + return -1; + } + /* NODELIST[NLCOUNT].id = nptr; */ + NODELIST[NLCOUNT].node = nptr; + for (nptr++; *nptr && !isspace(*nptr);) + nptr++; if (*nptr == '\0') { - bbslog("nodelist.bbs node %d entry read error\n", NLCOUNT); - return -1; - } - *nptr = '\0'; - if ((tptr = strchr(NODELIST[NLCOUNT].node,'/'))) { - *tptr = '\0'; - NODELIST[NLCOUNT].exclusion = tptr + 1; + bbslog("nodelist.bbs node %d entry read error\n", NLCOUNT); + return -1; + } + *nptr = '\0'; + if ((tptr = strchr(NODELIST[NLCOUNT].node, '/'))) { + *tptr = '\0'; + NODELIST[NLCOUNT].exclusion = tptr + 1; } else { - NODELIST[NLCOUNT].exclusion = ""; + NODELIST[NLCOUNT].exclusion = ""; } - for (nptr++ ;*nptr && isspace(*nptr); ) nptr++; - if (*nptr == '\0') continue; - if (*nptr=='+' || *nptr=='-') { - NODELIST[NLCOUNT].feedtype = *nptr; - if (NODELIST[NLCOUNT].feedfp != NULL) { - fclose(NODELIST[NLCOUNT].feedfp); - } - if ( NODELIST[NLCOUNT].feedtype == '+') - if (outgoing != NULL) { - NODELIST[NLCOUNT].feedfp = fopen((char*)fileglue("%s/out.going/%s.%s",BBSHOME, NODELIST[NLCOUNT].node, outgoing),"a"); - } - nptr++; + for (nptr++; *nptr && isspace(*nptr);) + nptr++; + if (*nptr == '\0') + continue; + if (*nptr == '+' || *nptr == '-') { + NODELIST[NLCOUNT].feedtype = *nptr; + if (NODELIST[NLCOUNT].feedfp != NULL) { + fclose(NODELIST[NLCOUNT].feedfp); + } + if (NODELIST[NLCOUNT].feedtype == '+') + if (outgoing != NULL) { + NODELIST[NLCOUNT].feedfp = fopen((char *)fileglue("%s/out.going/%s.%s", BBSHOME, NODELIST[NLCOUNT].node, outgoing), "a"); + } + nptr++; } else { - NODELIST[NLCOUNT].feedtype = ' '; + NODELIST[NLCOUNT].feedtype = ' '; } - NODELIST[NLCOUNT].host = nptr; - for (nptr++; *nptr && !isspace(*nptr); ) nptr++; + NODELIST[NLCOUNT].host = nptr; + for (nptr++; *nptr && !isspace(*nptr);) + nptr++; if (*nptr == '\0') { - continue; - } - *nptr = '\0'; - for (nptr++;*nptr && isspace(*nptr); ) nptr++; - if (*nptr == '\0') continue; - NODELIST[NLCOUNT].protocol = nptr; - for (nptr++; *nptr && !isspace(*nptr); ) nptr++; - if (*nptr == '\0') continue; - *nptr = '\0'; - for (nptr++;*nptr && strchr(" \t\r\n",*nptr); ) nptr++; - if (*nptr == '\0') continue; - NODELIST[NLCOUNT].comments = nptr; + continue; + } + *nptr = '\0'; + for (nptr++; *nptr && isspace(*nptr);) + nptr++; + if (*nptr == '\0') + continue; + NODELIST[NLCOUNT].protocol = nptr; + for (nptr++; *nptr && !isspace(*nptr);) + nptr++; + if (*nptr == '\0') + continue; + *nptr = '\0'; + for (nptr++; *nptr && strchr(" \t\r\n", *nptr);) + nptr++; + if (*nptr == '\0') + continue; + NODELIST[NLCOUNT].comments = nptr; } qsort(NODELIST, NLCOUNT, sizeof(nodelist_t), nlcmp); - qsort(NODELIST_BYNODE, NLCOUNT, sizeof(nodelist_t*), nl_bynodecmp); + qsort(NODELIST_BYNODE, NLCOUNT, sizeof(nodelist_t *), nl_bynodecmp); return 0; } readnffile(inndhome) -char *inndhome; + char *inndhome; { - FILE *fp; - char buff[1024]; - struct stat st; - int i, count; - char *ptr, *newsfeedsptr; - - sprintf(buff,"%s/newsfeeds.bbs", inndhome); - fp = fopen(buff,"r"); + FILE *fp; + char buff[1024]; + struct stat st; + int i, count; + char *ptr, *newsfeedsptr; + + sprintf(buff, "%s/newsfeeds.bbs", inndhome); + fp = fopen(buff, "r"); if (fp == NULL) { - fprintf(stderr,"open fail %s",buff); - return -1; + fprintf(stderr, "open fail %s", buff); + return -1; } - if (fstat(fileno(fp),&st) != 0) { - fprintf(stderr,"stat fail %s", buff); - return -1; + if (fstat(fileno(fp), &st) != 0) { + fprintf(stderr, "stat fail %s", buff); + return -1; } if (NEWSFEEDS_BUF == NULL) { - NEWSFEEDS_BUF = (char*) mymalloc( st.st_size +1); + NEWSFEEDS_BUF = (char *)mymalloc(st.st_size + 1); } else { - NEWSFEEDS_BUF = (char*) myrealloc( NEWSFEEDS_BUF, st.st_size +1); + NEWSFEEDS_BUF = (char *)myrealloc(NEWSFEEDS_BUF, st.st_size + 1); } - i = 0, count =0; + i = 0, count = 0; while (fgets(buff, sizeof buff, fp) != NULL) { - if (buff[0] == '#') continue; - if (buff[0] == '\n') continue; - strcpy(NEWSFEEDS_BUF+i, buff); - i += strlen(buff); - count ++; + if (buff[0] == '#') + continue; + if (buff[0] == '\n') + continue; + strcpy(NEWSFEEDS_BUF + i, buff); + i += strlen(buff); + count++; } fclose(fp); if (NEWSFEEDS == NULL) { - NEWSFEEDS = (newsfeeds_t*) mymalloc(sizeof(newsfeeds_t) * (count+1)); - NEWSFEEDS_BYBOARD = (newsfeeds_t**) mymalloc(sizeof(newsfeeds_t*) * (count+1)); + NEWSFEEDS = (newsfeeds_t *) mymalloc(sizeof(newsfeeds_t) * (count + 1)); + NEWSFEEDS_BYBOARD = (newsfeeds_t **) mymalloc(sizeof(newsfeeds_t *) * (count + 1)); } else { - NEWSFEEDS = (newsfeeds_t*) myrealloc(NEWSFEEDS, sizeof(newsfeeds_t) * (count+1)); - NEWSFEEDS_BYBOARD = (newsfeeds_t**) myrealloc(NEWSFEEDS_BYBOARD, sizeof(newsfeeds_t*) * (count+1)); + NEWSFEEDS = (newsfeeds_t *) myrealloc(NEWSFEEDS, sizeof(newsfeeds_t) * (count + 1)); + NEWSFEEDS_BYBOARD = (newsfeeds_t **) myrealloc(NEWSFEEDS_BYBOARD, sizeof(newsfeeds_t *) * (count + 1)); } - NFCOUNT = 0; - for (ptr = NEWSFEEDS_BUF; (newsfeedsptr = (char*)strchr(ptr,'\n')) != NULL; ptr = newsfeedsptr +1, NFCOUNT++) { - char *nptr , *bptr, *pptr; + NFCOUNT = 0; + for (ptr = NEWSFEEDS_BUF; (newsfeedsptr = (char *)strchr(ptr, '\n')) != NULL; ptr = newsfeedsptr + 1, NFCOUNT++) { + char *nptr, *bptr, *pptr; *newsfeedsptr = '\0'; NEWSFEEDS[NFCOUNT].newsgroups = ""; NEWSFEEDS[NFCOUNT].board = ""; NEWSFEEDS[NFCOUNT].path = NULL; - NEWSFEEDS_BYBOARD[NFCOUNT] = NEWSFEEDS+NFCOUNT; - for (nptr= ptr ;*nptr && isspace(*nptr); ) nptr++; - if (*nptr == '\0') continue; - NEWSFEEDS[NFCOUNT].newsgroups = nptr; - for (nptr++; *nptr && !isspace(*nptr); ) nptr++; - if (*nptr == '\0') continue; - *nptr = '\0'; - for (nptr++ ;*nptr && isspace(*nptr); ) nptr++; - if (*nptr == '\0') continue; - NEWSFEEDS[NFCOUNT].board = nptr; - for (nptr++; *nptr && !isspace(*nptr); ) nptr++; - if (*nptr == '\0') continue; - *nptr = '\0'; - for (nptr++;*nptr && isspace(*nptr); ) nptr++; - if (*nptr == '\0') continue; - NEWSFEEDS[NFCOUNT].path = nptr; - for (nptr++; *nptr && !strchr("\r\n",*nptr); ) nptr++; - *nptr = '\0'; + NEWSFEEDS_BYBOARD[NFCOUNT] = NEWSFEEDS + NFCOUNT; + for (nptr = ptr; *nptr && isspace(*nptr);) + nptr++; + if (*nptr == '\0') + continue; + NEWSFEEDS[NFCOUNT].newsgroups = nptr; + for (nptr++; *nptr && !isspace(*nptr);) + nptr++; + if (*nptr == '\0') + continue; + *nptr = '\0'; + for (nptr++; *nptr && isspace(*nptr);) + nptr++; + if (*nptr == '\0') + continue; + NEWSFEEDS[NFCOUNT].board = nptr; + for (nptr++; *nptr && !isspace(*nptr);) + nptr++; + if (*nptr == '\0') + continue; + *nptr = '\0'; + for (nptr++; *nptr && isspace(*nptr);) + nptr++; + if (*nptr == '\0') + continue; + NEWSFEEDS[NFCOUNT].path = nptr; + for (nptr++; *nptr && !strchr("\r\n", *nptr);) + nptr++; + *nptr = '\0'; } qsort(NEWSFEEDS, NFCOUNT, sizeof(newsfeeds_t), nfcmp); - qsort(NEWSFEEDS_BYBOARD, NFCOUNT, sizeof(newsfeeds_t*), nf_byboardcmp); + qsort(NEWSFEEDS_BYBOARD, NFCOUNT, sizeof(newsfeeds_t *), nf_byboardcmp); } -newsfeeds_t *search_board(board) -char *board; +newsfeeds_t * +search_board(board) + char *board; { - newsfeeds_t nft, *nftptr, **find; - if (NONENEWSFEEDS) return NULL; - nft.board = board; - nftptr = &nft; - find = (newsfeeds_t**)bsearch((char*)&nftptr, NEWSFEEDS_BYBOARD, NFCOUNT, sizeof(newsfeeds_t*), nf_byboardcmp); - if (find != NULL) return *find; - return NULL; + newsfeeds_t nft, *nftptr, **find; + if (NONENEWSFEEDS) + return NULL; + nft.board = board; + nftptr = &nft; + find = (newsfeeds_t **) bsearch((char *)&nftptr, NEWSFEEDS_BYBOARD, NFCOUNT, sizeof(newsfeeds_t *), nf_byboardcmp); + if (find != NULL) + return *find; + return NULL; } -nodelist_t *search_nodelist_bynode(node) -char *node; +nodelist_t * +search_nodelist_bynode(node) + char *node; { - nodelist_t nlt, *nltptr, **find; - if (LOCALNODELIST) return NULL; - nlt.node = node; - nltptr = ≮ - find = (nodelist_t**)bsearch((char*)&nltptr, NODELIST_BYNODE, NLCOUNT, sizeof(nodelist_t*), nl_bynodecmp); - if (find != NULL) return *find; - return NULL; + nodelist_t nlt, *nltptr, **find; + if (LOCALNODELIST) + return NULL; + nlt.node = node; + nltptr = ≮ + find = (nodelist_t **) bsearch((char *)&nltptr, NODELIST_BYNODE, NLCOUNT, sizeof(nodelist_t *), nl_bynodecmp); + if (find != NULL) + return *find; + return NULL; } -nodelist_t *search_nodelist(site, identuser) -char *site; -char *identuser; +nodelist_t * +search_nodelist(site, identuser) + char *site; + char *identuser; { - nodelist_t nlt, *find; - char buffer[1024]; - if (LOCALNODELIST) return NULL; - nlt.host = site; - find = (nodelist_t*)bsearch((char*)&nlt, NODELIST, NLCOUNT, sizeof(nodelist_t), nlcmp); - if (find == NULL && identuser != NULL) { - sprintf(buffer,"%s@%s", identuser, site); - nlt.host = buffer; - find = (nodelist_t*)bsearch((char*)&nlt, NODELIST, NLCOUNT, sizeof(nodelist_t), nlcmp); - } - return find; + nodelist_t nlt, *find; + char buffer[1024]; + if (LOCALNODELIST) + return NULL; + nlt.host = site; + find = (nodelist_t *) bsearch((char *)&nlt, NODELIST, NLCOUNT, sizeof(nodelist_t), nlcmp); + if (find == NULL && identuser != NULL) { + sprintf(buffer, "%s@%s", identuser, site); + nlt.host = buffer; + find = (nodelist_t *) bsearch((char *)&nlt, NODELIST, NLCOUNT, sizeof(nodelist_t), nlcmp); + } + return find; } -newsfeeds_t *search_group(newsgroup) -char *newsgroup; +newsfeeds_t * +search_group(newsgroup) + char *newsgroup; { - newsfeeds_t nft, *find; - if (NONENEWSFEEDS) return NULL; - nft.newsgroups = newsgroup; - find = (newsfeeds_t*)bsearch((char*)&nft, NEWSFEEDS, NFCOUNT, sizeof(newsfeeds_t), nfcmp); - return find; + newsfeeds_t nft, *find; + if (NONENEWSFEEDS) + return NULL; + nft.newsgroups = newsgroup; + find = (newsfeeds_t *) bsearch((char *)&nft, NEWSFEEDS, NFCOUNT, sizeof(newsfeeds_t), nfcmp); + return find; } -char *ascii_date(now) -time_t now; +char * +ascii_date(now) + time_t now; { - static char datebuf[40]; - /*time_t now; - time(&now);*/ - strftime(datebuf, sizeof(datebuf), "%d %b %Y %X GMT", gmtime(&now)); - return datebuf; + static char datebuf[40]; + /* + * time_t now; time(&now); + */ + strftime(datebuf, sizeof(datebuf), "%d %b %Y %X GMT", gmtime(&now)); + return datebuf; } -char * +char * restrdup(ptr, string) -char *ptr; -char *string; + char *ptr; + char *string; { - int len ; - if (string == NULL) { - if (ptr != NULL) *ptr = '\0'; - return ptr; - } - len = strlen(string) + 1; - if (ptr != NULL) { - ptr = (char*)myrealloc(ptr, len); - } else - ptr = (char*)mymalloc(len); - strcpy(ptr, string); - return ptr; + int len; + if (string == NULL) { + if (ptr != NULL) + *ptr = '\0'; + return ptr; + } + len = strlen(string) + 1; + if (ptr != NULL) { + ptr = (char *)myrealloc(ptr, len); + } else + ptr = (char *)mymalloc(len); + strcpy(ptr, string); + return ptr; } -void * +void * mymalloc(size) -int size; + int size; { - char *ptr = (char*)malloc(size); + char *ptr = (char *)malloc(size); if (ptr == NULL) { - fprintf(stderr, "cant allocate memory\n"); - syslog(LOG_ERR, "cant allocate memory %m"); - exit(1); + fprintf(stderr, "cant allocate memory\n"); + syslog(LOG_ERR, "cant allocate memory %m"); + exit(1); } return ptr; } -void * +void * myrealloc(optr, size) -void *optr; -int size; + void *optr; + int size; { - char *ptr = (char*)realloc(optr, size); + char *ptr = (char *)realloc(optr, size); if (ptr == NULL) { - fprintf(stderr, "cant allocate memory\n"); - syslog(LOG_ERR, "cant allocate memory %m"); - exit(1); + fprintf(stderr, "cant allocate memory\n"); + syslog(LOG_ERR, "cant allocate memory %m"); + exit(1); } return ptr; } testandmkdir(dir) -char *dir; + char *dir; { - if (!isdir(dir)) { - char path[MAXPATHLEN+12]; - sprintf(path,"mkdir -p %s",dir); - system(path); - } + if (!isdir(dir)) { + char path[MAXPATHLEN + 12]; + sprintf(path, "mkdir -p %s", dir); + system(path); + } } - -static char splitbuf[2048]; -static char joinbuf[1024]; -#define MAXTOK 50 -static char* Splitptr[MAXTOK]; -char **split(line,pat) -char *line,*pat; + +static char splitbuf[2048]; +static char joinbuf[1024]; +#define MAXTOK 50 +static char *Splitptr[MAXTOK]; +char ** +split(line, pat) + char *line, *pat; { - char *p; - int i; - - for (i=0;i<MAXTOK;++i) Splitptr[i] = NULL; - strncpy(splitbuf,line,sizeof splitbuf - 1 ); - /*printf("%d %d\n",strlen(line),strlen(splitbuf));*/ - splitbuf[sizeof splitbuf - 1] = '\0'; - for (i=0,p=splitbuf;*p && i< MAXTOK -1 ;){ - for (Splitptr[i++]=p;*p && !strchr(pat,*p);p++); - if (*p=='\0') break; - for (*p++='\0'; *p && strchr(pat,*p);p++); - } - return Splitptr; + char *p; + int i; + + for (i = 0; i < MAXTOK; ++i) + Splitptr[i] = NULL; + strncpy(splitbuf, line, sizeof splitbuf - 1); + /* printf("%d %d\n",strlen(line),strlen(splitbuf)); */ + splitbuf[sizeof splitbuf - 1] = '\0'; + for (i = 0, p = splitbuf; *p && i < MAXTOK - 1;) { + for (Splitptr[i++] = p; *p && !strchr(pat, *p); p++); + if (*p == '\0') + break; + for (*p++ = '\0'; *p && strchr(pat, *p); p++); + } + return Splitptr; } -char **BNGsplit(line) -char *line; +char ** +BNGsplit(line) + char *line; { - char **ptr = split(line,","); - newsfeeds_t *nf1, *nf2; - char *n11, *n12, *n21, *n22; - int i,j; - for (i=0; ptr[i] != NULL; i++) { - nf1 = (newsfeeds_t*)search_group(ptr[i]); - for (j=i+1; ptr[j] != NULL; j++) { - if (strcmp(ptr[i],ptr[j])==0) { - *ptr[j] = '\0'; - continue; - } - nf2 = (newsfeeds_t*)search_group(ptr[j]); - if (nf1 && nf2) { - if (strcmp(nf1->board,nf2->board)==0) { - *ptr[j] = '\0'; - continue; - } - for (n11 = nf1->board, n12 = (char*)strchr(n11,','); - n11 && *n11 ; n12 = (char*) strchr(n11,',')) { - if (n12) *n12 = '\0'; - for (n21 = nf2->board, n22 = (char*)strchr(n21,','); - n21 && *n21 ; n22 = (char*) strchr(n21,',')) { - if (n22) *n22 = '\0'; - if (strcmp(n11,n21)==0) { - *n21 = '\t'; - } - if (n22) { - *n22 = ','; - n21 = n22 + 1; - } else - break; - } - if (n12) { - *n12 = ','; - n11 = n12 +1; - } else - break; - } - } - } - } - return ptr; + char **ptr = split(line, ","); + newsfeeds_t *nf1, *nf2; + char *n11, *n12, *n21, *n22; + int i, j; + for (i = 0; ptr[i] != NULL; i++) { + nf1 = (newsfeeds_t *) search_group(ptr[i]); + for (j = i + 1; ptr[j] != NULL; j++) { + if (strcmp(ptr[i], ptr[j]) == 0) { + *ptr[j] = '\0'; + continue; + } + nf2 = (newsfeeds_t *) search_group(ptr[j]); + if (nf1 && nf2) { + if (strcmp(nf1->board, nf2->board) == 0) { + *ptr[j] = '\0'; + continue; + } + for (n11 = nf1->board, n12 = (char *)strchr(n11, ','); + n11 && *n11; n12 = (char *)strchr(n11, ',')) { + if (n12) + *n12 = '\0'; + for (n21 = nf2->board, n22 = (char *)strchr(n21, ','); + n21 && *n21; n22 = (char *)strchr(n21, ',')) { + if (n22) + *n22 = '\0'; + if (strcmp(n11, n21) == 0) { + *n21 = '\t'; + } + if (n22) { + *n22 = ','; + n21 = n22 + 1; + } else + break; + } + if (n12) { + *n12 = ','; + n11 = n12 + 1; + } else + break; + } + } + } + } + return ptr; } -char **ssplit(line,pat) -char *line,*pat; +char ** +ssplit(line, pat) + char *line, *pat; { - char *p; - int i; - for (i=0;i<MAXTOK;++i) Splitptr[i] = NULL; - strncpy(splitbuf,line,1024); - for (i=0,p=splitbuf;*p && i< MAXTOK;){ - for (Splitptr[i++]=p;*p && !strchr(pat,*p);p++); - if (*p=='\0') break; - *p=0;p++; -/* for (*p='\0'; strchr(pat,*p);p++);*/ - } - return Splitptr; + char *p; + int i; + for (i = 0; i < MAXTOK; ++i) + Splitptr[i] = NULL; + strncpy(splitbuf, line, 1024); + for (i = 0, p = splitbuf; *p && i < MAXTOK;) { + for (Splitptr[i++] = p; *p && !strchr(pat, *p); p++); + if (*p == '\0') + break; + *p = 0; + p++; + /* for (*p='\0'; strchr(pat,*p);p++); */ + } + return Splitptr; } -char *join(lineptr,pat,num) -char **lineptr,*pat; -int num; +char * +join(lineptr, pat, num) + char **lineptr, *pat; + int num; { - int i; + int i; + joinbuf[0] = '\0'; + if (lineptr[0] != NULL) + strncpy(joinbuf, lineptr[0], 1024); + else { joinbuf[0] = '\0'; - if (lineptr[0] != NULL) - strncpy(joinbuf,lineptr[0],1024); - else { - joinbuf[0]='\0'; - return joinbuf; - } - for (i=1;i<num;i++) { - strcat(joinbuf,pat); - if (lineptr[i] != NULL) - strcat(joinbuf,lineptr[i]); - else - break; - } return joinbuf; + } + for (i = 1; i < num; i++) { + strcat(joinbuf, pat); + if (lineptr[i] != NULL) + strcat(joinbuf, lineptr[i]); + else + break; + } + return joinbuf; } #ifdef BBSLIB main() { - initial_bbs("feed"); - printf("%s\n",ascii_date()); + initial_bbs("feed"); + printf("%s\n", ascii_date()); } #endif - |