summaryrefslogtreecommitdiffstats
path: root/util
diff options
context:
space:
mode:
authorscw <scw@63ad8ddf-47c3-0310-b6dd-a9e9d9715204>2005-09-11 20:44:44 +0800
committerscw <scw@63ad8ddf-47c3-0310-b6dd-a9e9d9715204>2005-09-11 20:44:44 +0800
commitf1f932a3e642b746188294c0880006f8dcab8d35 (patch)
tree51ba7a6de96d178c53f189d77e386fc33c464266 /util
parent915be02b2a9538045ac94c4cac2fdfd49fd2a1e6 (diff)
downloadpttbbs-f1f932a3e642b746188294c0880006f8dcab8d35.tar
pttbbs-f1f932a3e642b746188294c0880006f8dcab8d35.tar.gz
pttbbs-f1f932a3e642b746188294c0880006f8dcab8d35.tar.bz2
pttbbs-f1f932a3e642b746188294c0880006f8dcab8d35.tar.lz
pttbbs-f1f932a3e642b746188294c0880006f8dcab8d35.tar.xz
pttbbs-f1f932a3e642b746188294c0880006f8dcab8d35.tar.zst
pttbbs-f1f932a3e642b746188294c0880006f8dcab8d35.zip
* fix toplazyBM and toplazyBBM mailing and logging wrong id bug
* indent toplazyBBM.c git-svn-id: http://opensvn.csie.org/pttbbs/trunk/pttbbs@3156 63ad8ddf-47c3-0310-b6dd-a9e9d9715204
Diffstat (limited to 'util')
-rw-r--r--util/toplazyBBM.c270
-rw-r--r--util/toplazyBM.c8
2 files changed, 139 insertions, 139 deletions
diff --git a/util/toplazyBBM.c b/util/toplazyBBM.c
index 7d11d7a5..e4df67f0 100644
--- a/util/toplazyBBM.c
+++ b/util/toplazyBBM.c
@@ -10,36 +10,36 @@ extern int numboards;
boardheader_t allbrd[MAX_BOARD];
typedef struct lostbm {
- char *bmname;
- char *title;
- char *ctitle;
- int lostdays;
+ char bmname[IDLEN + 1];
+ char *title;
+ char *ctitle;
+ int lostdays;
} lostbm;
lostbm lostbms[MAX_BOARD];
typedef struct BMarray{
- char *bmname;
- int flag;
+ char bmname[IDLEN + 1];
+ int flag;
} BMArray;
BMArray bms[3];
int bmlostdays_cmp(const void *va, const void *vb)
{
- lostbm *a=(lostbm *)va, *b=(lostbm *)vb;
- if (a->lostdays > b->lostdays) return -1;
- else if (a->lostdays == b->lostdays) return 0;
- else return 1;
+ lostbm *a=(lostbm *)va, *b=(lostbm *)vb;
+ if (a->lostdays > b->lostdays) return -1;
+ else if (a->lostdays == b->lostdays) return 0;
+ else return 1;
}
int LINK(char* src, char* dst){
- char cmd[200];
- if(symlink(src,dst) == -1)
- {
+ char cmd[200];
+ if(symlink(src,dst) == -1)
+ {
sprintf(cmd, "/bin/cp -R %s %s", src, dst);
return system(cmd);
- }
- return 0;
+ }
+ return 0;
}
int main(int argc, char *argv[])
@@ -51,146 +51,146 @@ int main(int argc, char *argv[])
resolve_boards();
if(passwd_init())
- exit(1);
-
- memcpy(allbrd,bcache,numboards*sizeof(boardheader_t));
-
- /* write out the target file */
- printf("Starting Checking\n");
- inf = fopen(OUTFILE, "w+");
- if(inf == NULL){
- printf("open file error : %s\n", OUTFILE);
- exit(1);
- }
- firef = fopen(FIREFILE, "w+");
- if(firef == NULL){
- printf("open file error : %s\n", FIREFILE);
- exit(1);
- }
-
- fprintf(inf, "警告: 板主若於兩個月未上站,將予於免職\n");
- fprintf(inf,
- "看板名稱 "
- " 板主 幾天沒來啦\n"
- "---------------------------------------------------"
- "-------------------\n");
-
- fprintf(firef, "免職板主\n");
- fprintf(firef,
- "看板名稱 "
- " 板主 幾天沒來啦\n"
- "---------------------------------------------------"
- "-------------------\n");
-
-
- j = 0 ;
- for (i = 0; i < numboards; i++) {
- char *p, bmbuf[IDLEN * 3 + 3];
- int index = 0, flag = 0, k, n;
- userec_t xuser;
- p=strtok(allbrd[i].BM,"/ ");
-
- if(p)
- do
+ exit(1);
+
+ memcpy(allbrd,bcache,numboards*sizeof(boardheader_t));
+
+ /* write out the target file */
+ printf("Starting Checking\n");
+ inf = fopen(OUTFILE, "w+");
+ if(inf == NULL){
+ printf("open file error : %s\n", OUTFILE);
+ exit(1);
+ }
+ firef = fopen(FIREFILE, "w+");
+ if(firef == NULL){
+ printf("open file error : %s\n", FIREFILE);
+ exit(1);
+ }
+
+ fprintf(inf, "警告: 板主若於兩個月未上站,將予於免職\n");
+ fprintf(inf,
+ "看板名稱 "
+ " 板主 幾天沒來啦\n"
+ "---------------------------------------------------"
+ "-------------------\n");
+
+ fprintf(firef, "免職板主\n");
+ fprintf(firef,
+ "看板名稱 "
+ " 板主 幾天沒來啦\n"
+ "---------------------------------------------------"
+ "-------------------\n");
+
+
+ j = 0 ;
+ for (i = 0; i < numboards; i++) {
+ char *p, bmbuf[IDLEN * 3 + 3];
+ int index = 0, flag = 0, k, n;
+ userec_t xuser;
+ p=strtok(allbrd[i].BM,"/ ");
+
+ if(p)
+ do
+ {
+ if(allbrd[i].brdname[0] == '\0' || (allbrd[i].brdattr & BRD_GROUPBOARD) ==0 ) continue;
+ if (*p == '[' ){p[strlen(p)-1]='\0'; p++;}
+ bmid=getuser(p, &xuser);
+ strlcpy(bms[index].bmname, p, sizeof(bms[index].bmname));
+ bms[index].flag = 0;
+ if (((((int)time(NULL)-(int)xuser.lastlogin)/(60*60*24))>=7)
+ //&& isalpha(allbrd[i].brdname[0])
+ //&& isalpha(allbrd[i].BM[0])
+ && !(xuser.userlevel & PERM_SYSOPHIDE)
+ && !(xuser.userlevel & PERM_SYSOP))
{
- if(allbrd[i].brdname[0] == '\0' || (allbrd[i].brdattr & BRD_GROUPBOARD) ==0 ) continue;
- if (*p == '[' ){p[strlen(p)-1]='\0'; p++;}
- bmid=getuser(p, &xuser);
- bms[index].bmname = p;
- bms[index].flag = 0;
- if (((((int)time(NULL)-(int)xuser.lastlogin)/(60*60*24))>=7)
- //&& isalpha(allbrd[i].brdname[0])
- //&& isalpha(allbrd[i].BM[0])
- && !(xuser.userlevel & PERM_SYSOPHIDE)
- && !(xuser.userlevel & PERM_SYSOP))
- {
- lostbms[j].bmname = p;
- lostbms[j].title = allbrd[i].brdname;
- lostbms[j].ctitle = allbrd[i].title;
- lostbms[j].lostdays =
- ((int)time(NULL)-(int)xuser.lastlogin)/(60*60*24);
-
- printf("%s\n", lostbms[j].title);
- //超過六十天 免職
- if(lostbms[j].lostdays > 30){
- xuser.userlevel &= ~PERM_BM;
- bms[index].flag = 1;
- flag = 1;
- }
- j++;
- }
- index++;
- } while((p=strtok(NULL,"/ "))!=NULL);
-
- //從板主名單拿掉名字
-
- if(flag == 1){
- bmbuf[0] = '\0';
- for(k = 0 , n = 0; k < index; k++){
- if(!bms[k].flag){
- if( n++ != 0) strcat(bmbuf, "/");
- strcat(bmbuf, bms[k].bmname);
- }
- }
- strcpy(allbrd[i].BM, bmbuf);
+ strlcpy(lostbms[j].bmname, p, sizeof(bms[index].bmname));
+ lostbms[j].title = allbrd[i].brdname;
+ lostbms[j].ctitle = allbrd[i].title;
+ lostbms[j].lostdays =
+ ((int)time(NULL)-(int)xuser.lastlogin)/(60*60*24);
+
+ printf("%s\n", lostbms[j].title);
+ //超過六十天 免職
+ if(lostbms[j].lostdays > 30){
+ xuser.userlevel &= ~PERM_BM;
+ bms[index].flag = 1;
+ flag = 1;
+ }
+ j++;
}
-
- }
+ index++;
+ } while((p=strtok(NULL,"/ "))!=NULL);
+
+ //從板主名單拿掉名字
+
+ if(flag == 1){
+ bmbuf[0] = '\0';
+ for(k = 0 , n = 0; k < index; k++){
+ if(!bms[k].flag){
+ if( n++ != 0) strcat(bmbuf, "/");
+ strcat(bmbuf, bms[k].bmname);
+ }
+ }
+ strcpy(allbrd[i].BM, bmbuf);
+ }
+
+ }
qsort(lostbms, j, sizeof(lostbm), bmlostdays_cmp);
-
+
printf("Starting to mail\n");
//write to the etc/toplazyBBM
for ( i=0; i<j; i++)
{
if( lostbms[i].lostdays > 30){
- fprintf(firef, "%-*.*s%-*.*s%-*.*s%3d天沒上站\n", IDLEN, IDLEN, lostbms[i].title,
- BTLEN-10, BTLEN-10, lostbms[i].ctitle, IDLEN,IDLEN,
- lostbms[i].bmname,lostbms[i].lostdays);
+ fprintf(firef, "%-*.*s%-*.*s%-*.*s%3d天沒上站\n", IDLEN, IDLEN, lostbms[i].title,
+ BTLEN-10, BTLEN-10, lostbms[i].ctitle, IDLEN,IDLEN,
+ lostbms[i].bmname,lostbms[i].lostdays);
}else{
- fprintf(inf, "%-*.*s%-*.*s%-*.*s%3d天沒上站\n", IDLEN, IDLEN, lostbms[i].title,
- BTLEN-10, BTLEN-10, lostbms[i].ctitle, IDLEN,IDLEN,
- lostbms[i].bmname,lostbms[i].lostdays);
+ fprintf(inf, "%-*.*s%-*.*s%-*.*s%3d天沒上站\n", IDLEN, IDLEN, lostbms[i].title,
+ BTLEN-10, BTLEN-10, lostbms[i].ctitle, IDLEN,IDLEN,
+ lostbms[i].bmname,lostbms[i].lostdays);
}
}
fclose(inf);
fclose(firef);
printf("Total %d boards.\n", j);
-
+
//mail to the users
for( i=0; i<j; i++)
{
- fileheader_t mymail;
- char genbuf[200];
- int lostdays;
-
- lostdays = lostbms[i].lostdays;
+ fileheader_t mymail;
+ char genbuf[200];
+ int lostdays;
+
+ lostdays = lostbms[i].lostdays;
if( (lostdays != 14) || (lostdays != 21) ) // 14 21 天不發信
- continue;
-
- sprintf(genbuf, BBSHOME "/home/%c/%s", lostbms[i].bmname[0], lostbms[i].bmname);
- stampfile(genbuf, &mymail);
-
- strcpy(mymail.owner, "[PTT警察局]");
-
- if(lostdays <= 30){
- sprintf(mymail.title,
- "\033[32m [小組長免職警告通知] \033[m %s BM %s", lostbms[i].title, lostbms[i].bmname);
- }else{
- sprintf(mymail.title,
- "\033[32m [小組長免職通知] \033[m %s BM %s", lostbms[i].title, lostbms[i].bmname);
- }
- unlink(genbuf);
- if(lostdays <= 30){
- LINK(OUTFILE, genbuf);
- }else{
- LINK(FIREFILE, genbuf);
- }
-
- sprintf(genbuf, BBSHOME "/home/%c/%s/.DIR", lostbms[i].bmname[0], lostbms[i].bmname);
- append_record(genbuf, &mymail, sizeof(mymail));
+ continue;
+
+ sprintf(genbuf, BBSHOME "/home/%c/%s", lostbms[i].bmname[0], lostbms[i].bmname);
+ stampfile(genbuf, &mymail);
+
+ strcpy(mymail.owner, "[PTT警察局]");
+
+ if(lostdays <= 30){
+ sprintf(mymail.title,
+ "\033[32m [小組長免職警告通知] \033[m %s BM %s", lostbms[i].title, lostbms[i].bmname);
+ }else{
+ sprintf(mymail.title,
+ "\033[32m [小組長免職通知] \033[m %s BM %s", lostbms[i].title, lostbms[i].bmname);
+ }
+ unlink(genbuf);
+ if(lostdays <= 30){
+ LINK(OUTFILE, genbuf);
+ }else{
+ LINK(FIREFILE, genbuf);
+ }
+
+ sprintf(genbuf, BBSHOME "/home/%c/%s/.DIR", lostbms[i].bmname[0], lostbms[i].bmname);
+ append_record(genbuf, &mymail, sizeof(mymail));
}
-
+
return 0;
}
diff --git a/util/toplazyBM.c b/util/toplazyBM.c
index 23e65c4e..3807c250 100644
--- a/util/toplazyBM.c
+++ b/util/toplazyBM.c
@@ -8,7 +8,7 @@ extern int numboards;
boardheader_t allbrd[MAX_BOARD];
typedef struct lostbm {
- char *bmname;
+ char bmname[IDLEN + 1];
char *title;
char *ctitle;
int lostdays;
@@ -16,7 +16,7 @@ typedef struct lostbm {
lostbm lostbms[MAX_BOARD];
typedef struct BMarray{
- char *bmname;
+ char bmname[IDLEN + 1];
int flag;
} BMArray;
BMArray bms[5];
@@ -103,7 +103,7 @@ int main(int argc, char *argv[])
continue;
}
bmid=getuser(p, &xuser);
- bms[index].bmname = p;
+ strlcpy(bms[index].bmname, p, sizeof(bms[index].bmname));
bms[index].flag = 0;
diff = now - xuser.lastlogin;
@@ -113,7 +113,7 @@ int main(int argc, char *argv[])
if (diff >= 45 * 86400
&& !(xuser.userlevel & PERM_SYSOPHIDE)
&& !(xuser.userlevel & PERM_SYSOP)) {
- lostbms[j].bmname = p;
+ strlcpy(lostbms[j].bmname, p, sizeof(bms[index].bmname));
lostbms[j].title = allbrd[i].brdname;
lostbms[j].ctitle = allbrd[i].title;
lostbms[j].lostdays = diff / 86400;