diff options
Diffstat (limited to 'qmail-newmrh.c')
| -rw-r--r-- | qmail-newmrh.c | 70 |
1 files changed, 70 insertions, 0 deletions
diff --git a/qmail-newmrh.c b/qmail-newmrh.c new file mode 100644 index 0000000..25a4a10 --- /dev/null +++ b/qmail-newmrh.c | |||
| @@ -0,0 +1,70 @@ | |||
| 1 | #include "strerr.h" | ||
| 2 | #include "stralloc.h" | ||
| 3 | #include "substdio.h" | ||
| 4 | #include "getln.h" | ||
| 5 | #include "exit.h" | ||
| 6 | #include "readwrite.h" | ||
| 7 | #include "open.h" | ||
| 8 | #include "auto_qmail.h" | ||
| 9 | #include "cdbmss.h" | ||
| 10 | |||
| 11 | #define FATAL "qmail-newmrh: fatal: " | ||
| 12 | |||
| 13 | void die_read() | ||
| 14 | { | ||
| 15 | strerr_die2sys(111,FATAL,"unable to read control/morercpthosts: "); | ||
| 16 | } | ||
| 17 | void die_write() | ||
| 18 | { | ||
| 19 | strerr_die2sys(111,FATAL,"unable to write to control/morercpthosts.tmp: "); | ||
| 20 | } | ||
| 21 | |||
| 22 | char inbuf[1024]; | ||
| 23 | substdio ssin; | ||
| 24 | |||
| 25 | int fd; | ||
| 26 | int fdtemp; | ||
| 27 | |||
| 28 | struct cdbmss cdbmss; | ||
| 29 | stralloc line = {0}; | ||
| 30 | int match; | ||
| 31 | |||
| 32 | void main() | ||
| 33 | { | ||
| 34 | umask(033); | ||
| 35 | if (chdir(auto_qmail) == -1) | ||
| 36 | strerr_die4sys(111,FATAL,"unable to chdir to ",auto_qmail,": "); | ||
| 37 | |||
| 38 | fd = open_read("control/morercpthosts"); | ||
| 39 | if (fd == -1) die_read(); | ||
| 40 | |||
| 41 | substdio_fdbuf(&ssin,read,fd,inbuf,sizeof inbuf); | ||
| 42 | |||
| 43 | fdtemp = open_trunc("control/morercpthosts.tmp"); | ||
| 44 | if (fdtemp == -1) die_write(); | ||
| 45 | |||
| 46 | if (cdbmss_start(&cdbmss,fdtemp) == -1) die_write(); | ||
| 47 | |||
| 48 | for (;;) { | ||
| 49 | if (getln(&ssin,&line,&match,'\n') != 0) die_read(); | ||
| 50 | case_lowerb(line.s,line.len); | ||
| 51 | while (line.len) { | ||
| 52 | if (line.s[line.len - 1] == ' ') { --line.len; continue; } | ||
| 53 | if (line.s[line.len - 1] == '\n') { --line.len; continue; } | ||
| 54 | if (line.s[line.len - 1] == '\t') { --line.len; continue; } | ||
| 55 | if (line.s[0] != '#') | ||
| 56 | if (cdbmss_add(&cdbmss,line.s,line.len,"",0) == -1) | ||
| 57 | die_write(); | ||
| 58 | break; | ||
| 59 | } | ||
| 60 | if (!match) break; | ||
| 61 | } | ||
| 62 | |||
| 63 | if (cdbmss_finish(&cdbmss) == -1) die_write(); | ||
| 64 | if (fsync(fdtemp) == -1) die_write(); | ||
| 65 | if (close(fdtemp) == -1) die_write(); /* NFS stupidity */ | ||
| 66 | if (rename("control/morercpthosts.tmp","control/morercpthosts.cdb") == -1) | ||
| 67 | strerr_die2sys(111,FATAL,"unable to move control/morercpthosts.tmp to control/morercpthosts.cdb"); | ||
| 68 | |||
| 69 | _exit(0); | ||
| 70 | } | ||
