summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--util/expire.c173
1 files changed, 107 insertions, 66 deletions
diff --git a/util/expire.c b/util/expire.c
index 4335ca16..ed02d013 100644
--- a/util/expire.c
+++ b/util/expire.c
@@ -10,22 +10,20 @@
#define DEF_MINP 300
#define EXPIRE_CONF BBSHOME "/etc/expire.conf"
-extern boardheader_t *bcache;
-char bpath[256];
-
-struct life
-{
- char bname[16]; /* board ID */
- int days; /* expired days */
- int maxp; /* max post */
- int minp; /* min post */
-};
-typedef struct life life;
+#ifdef SAFE_ARTICLE_DELETE
+char safe_delete_only = 0;
+#endif
+extern boardheader_t *bcache;
+char bpath[256];
+typedef struct {
+ char bname[IDLEN + 1]; /* board ID */
+ int days; /* expired days */
+ int maxp; /* max post */
+ int minp; /* min post */
+} life_t;
-void
- expire(brd)
-life *brd;
+void expire(life_t *brd)
{
fileheader_t head;
struct stat state;
@@ -83,8 +81,16 @@ life *brd;
{
done = 1;
ftime = atoi(head.filename + 2);
- if (head.owner[0] == '-')
+ if (head.owner[0] == '-'
+#ifdef SAFE_ARTICLE_DELETE
+ || strncmp(head.filename, ".delete", 7) == 0
+#endif
+ )
keep = 0;
+#ifdef SAFE_ARTICLE_DELETE
+ else if( safe_delete_only )
+ keep = 1;
+#endif
else if (head.filemode & FILE_MARKED || total <= brd->minp)
keep = 1;
else if (ftime < duetime || total > brd->maxp)
@@ -126,16 +132,31 @@ life *brd;
close(fd);
}
+int count;
+life_t db, table[MAX_BOARD], *key;
+
+void toexpire(char *brdname)
+{
+ if( brdname[0] > ' ' && brdname[0] != '.' ){
+ key = NULL;
+
+ if( count )
+ key = (life_t *)bsearch(brdname, table, count,
+ sizeof(life_t), (QCAST)strcasecmp);
+ if( key == NULL )
+ key = &db;
+
+ strcpy(key->bname, brdname);
+ expire(key);
+ }
+}
-int main(argc, argv)
-char *argv[];
+int main(int argc, char **argv)
{
- FILE *fin;
- int number, count;
- life db, table[MAX_BOARD], *key;
- struct dirent *de;
- DIR *dirp;
- int i;
+ FILE *fin;
+ int number, i, ch;
+ struct dirent *de;
+ DIR *dirp;
char *ptr, *bname, buf[256];
char dirs[] = {'0', '1', '2', '3', '4', '5', '6', '7', '8', '9',
'q', 'w', 'e', 'r', 't', 'y', 'u', 'i', 'o', 'p',
@@ -145,30 +166,59 @@ char *argv[];
'A', 'S', 'D', 'F', 'G', 'H', 'J', 'K', 'L',
'Z', 'X', 'C', 'V', 'B', 'N', 'M', NULL};
- attach_SHM();
- resolve_boards();
- db.days = ((argc > 1) && (number = atoi(argv[1])) > 0) ? number : DEF_DAYS;
- db.maxp = ((argc > 2) && (number = atoi(argv[2])) > 0) ? number : DEF_MAXP;
- db.minp = ((argc > 3) && (number = atoi(argv[3])) > 0) ? number : DEF_MINP;
+ /* default value */
+ db.days = DEF_DAYS;
+ db.maxp = DEF_MAXP;
+ db.minp = DEF_MINP;
+
+ while( (ch = getopt(argc, argv, "d:M:m:h"
+#ifdef SAFE_ARTICLE_DELETE
+"D"
+#endif
+ )) != -1 )
+ switch( ch ){
+#ifdef SAFE_ARTICLE_DELETE
+ case 'D':
+ safe_delete_only = 1;
+ break;
+#endif
+ case 'd':
+ db.days = atoi(optarg);
+ break;
+ case 'M':
+ db.maxp = atoi(optarg);
+ break;
+ case 'm':
+ db.minp = atoi(optarg);
+ break;
+ case 'h':
+ default:
+ fprintf(stderr,
+ "usage: expire [-m minp] [-M MAXP] [-d days] [board name...]\n"
+ "deletion policy:\n"
+ " do nothing if #articles < minp (default:%d)\n"
+ " delete NOT MARKED articles which were post before days \n"
+ " (default:%d) or #articles > MAXP (default:%d)\n",
+ DEF_MINP, DEF_DAYS, DEF_MAXP);
+ return 0;
+ }
+ argc -= optind;
+ argv += optind;
/* --------------- */
/* load expire.ctl */
/* --------------- */
count = 0;
- if((fin = fopen(EXPIRE_CONF, "r")))
- {
- while (fgets(buf, 256, fin))
- {
+ if( (fin = fopen(EXPIRE_CONF, "r")) ){
+ while( fgets(buf, 256, fin) != NULL ){
if (buf[0] == '#')
continue;
bname = (char *) strtok(buf, " \t\r\n");
- if (bname && *bname)
- {
+ if( bname && *bname ){
ptr = (char *) strtok(NULL, " \t\r\n");
- if (ptr && (number = atoi(ptr)) > 0)
- {
+ if( ptr && (number = atoi(ptr)) > 0 ){
key = &(table[count++]);
strcpy(key->bname, bname);
key->days = number;
@@ -176,13 +226,11 @@ char *argv[];
key->minp = db.minp;
ptr = (char *) strtok(NULL, " \t\r\n");
- if (ptr && (number = atoi(ptr)) > 0)
- {
+ if( ptr && (number = atoi(ptr)) > 0 ){
key->maxp = number;
-
+
ptr = (char *) strtok(NULL, " \t\r\n");
- if (ptr && (number = atoi(ptr)) > 0)
- {
+ if( ptr && (number = atoi(ptr)) > 0 ){
key->minp = number;
}
}
@@ -192,35 +240,28 @@ char *argv[];
fclose(fin);
}
- if (count > 1)
- {
- qsort(table, count, sizeof(life), (QCAST)strcasecmp);
- }
-
-/* ---------------- */
-/* visit all boards */
-/* ---------------- */
+ if( count > 1)
+ qsort(table, count, sizeof(life_t), (QCAST)strcasecmp);
- for( i = 0 ; dirs[i] != NULL ; ++i ){
- sprintf(bpath, BBSHOME "/boards/%c", dirs[i]);
- if (!(dirp = opendir(bpath))){
- printf(":Err: unable to open %s\n", bpath);
- continue;
+ attach_SHM();
+ if( argc > 0 ){
+ for( i = 0 ; i < argc ; ++i ){
+ sprintf(bpath, BBSHOME "/boards/%c", argv[i][0]);
+ toexpire(argv[i]);
}
- while((de = readdir(dirp))){
- ptr = de->d_name;
- if (ptr[0] > ' ' && ptr[0] != '.'){
- if (count)
- key = (life *) bsearch(ptr, table, count, sizeof(life), (QCAST)strcasecmp);
- else
- key = NULL;
- if (!key)
- key = &db;
- strcpy(key->bname, ptr);
- expire(key);
+ }
+ else{ // visit all boards
+ for( i = 0 ; dirs[i] != NULL ; ++i ){
+ sprintf(bpath, BBSHOME "/boards/%c", dirs[i]);
+ if (!(dirp = opendir(bpath))){
+ printf(":Err: unable to open %s\n", bpath);
+ continue;
}
+ while( (de = readdir(dirp)) != NULL )
+ toexpire(de->d_name);
+
+ closedir(dirp);
}
- closedir(dirp);
}
return 0;
}