diff options
-rw-r--r-- | util/Makefile | 7 | ||||
-rw-r--r-- | util/shmctl.c | 75 |
2 files changed, 80 insertions, 2 deletions
diff --git a/util/Makefile b/util/Makefile index 6f204648..2b7aa690 100644 --- a/util/Makefile +++ b/util/Makefile @@ -1,4 +1,4 @@ -# $Id: Makefile,v 1.4 2002/03/09 17:44:30 in2 Exp $ +# $Id: Makefile,v 1.5 2002/03/23 13:19:40 in2 Exp $ BBSHOME?=$(HOME) OSTYPE=linux @@ -30,7 +30,7 @@ CPROGS= bbsmail BM_money post account birth deluserfile expire mandex\ poststat showboard antispam countalldice webgrep bbsrf\ initbbs outmail xchatd userlist tunepasswd buildir reaper shmsweep\ merge_passwd merge_board inndBM buildAnnounce rmuid \ - toplazyBM jungo toplazyBBM + toplazyBM jungo toplazyBBM shmctl PROGS= $(CPROGS) BM_money.sh backpasswd.sh mailog.sh opendice.sh\ openticket.sh stock.sh topsong.sh weather.sh stock.perl weather.perl\ @@ -152,6 +152,9 @@ merge_board : merge_board.c bbsctl: bbsctl.c $(CC) $(CFLAGS) -o $@ $@.c +shmctl: shmctl.c + $(CC) $(CFLAGS) -o $@ $@.c $(OBJS) + install: $(PROGS) install -d $(BBSHOME)/bin/ install -c -m 755 $(PROGS) $(BBSHOME)/bin/ diff --git a/util/shmctl.c b/util/shmctl.c new file mode 100644 index 00000000..77b9c99b --- /dev/null +++ b/util/shmctl.c @@ -0,0 +1,75 @@ +#include <stdio.h> +#include <stdlib.h> +#include <unistd.h> +#include <ctype.h> +#include <signal.h> +#include <sys/types.h> +#include <sys/stat.h> +#include "config.h" +#include "pttstruct.h" +#include "util.h" + +extern struct utmpfile_t *utmpshm; + +int fixutmp(int argc, char **argv) +{ + int i; + char buf[1024], *clean; + struct stat st; + if( utmpshm->busystate ){ + puts("utmpshm is busy"); + return 0; + } + utmpshm->busystate = 1; + for( i = 0 ; i < USHM_SIZE ; ++i ) + if( utmpshm->uinfo[i].pid ){ + clean = NULL; + if( !isalpha(utmpshm->uinfo[i].userid[0]) ) + clean = "userid error"; + else{ + sprintf(buf, "/proc/%d", utmpshm->uinfo[i].pid); + if( stat(buf, &st) < 0 ) + clean = "process not exist"; + } + + if( clean ){ + printf("clean %06d(%s), userid: %s\n", + i, clean, utmpshm->uinfo[i].userid); + memset(&utmpshm->uinfo[i], 0, sizeof(userinfo_t)); + } + } + utmpshm->busystate = 0; + return 0; +} + +struct { + int (*func)(int, char **); + char *cmd, *descript; +} cmd[] = + { {fixutmp, "fixutmp", "clear dead userlist entry"}, + {NULL, NULL, NULL} }; + +int main(int argc, char **argv) +{ + int i = 0; + + if( argc >= 2 ){ + resolve_utmp(); + resolve_boards(); + //resolve_garbage(); + resolve_fcache(); + for( i = 0 ; cmd[i].func != NULL ; ++i ) + if( strcmp(cmd[i].cmd, argv[1]) == 0 ){ + cmd[i].func(argc - 2, &argv[2]); + break; + } + } + if( argc == 1 || cmd[i].func == NULL ){ + /* usage */ + printf("usage: bbsctl [command] [options]\n"); + printf("commands:\n"); + for( i = 0 ; cmd[i].func != NULL ; ++i ) + printf("\t%-15s%s\n", cmd[i].cmd, cmd[i].descript); + } + return 0; +} |