diff options
author | peter <peter@FreeBSD.org> | 2008-08-28 02:25:51 +0000 |
---|---|---|
committer | peter <peter@FreeBSD.org> | 2008-08-28 02:25:51 +0000 |
commit | ea50d71feb02a78d4d5fa746a26ca7ddc6e8cb19 (patch) | |
tree | daf40952cf309641cc6c7d987989fd2abce2d758 /contrib/sendmail/mailstats | |
parent | a2b986fa722f9860a6c56bb5cc724b7e2937d1b7 (diff) | |
download | FreeBSD-src-ea50d71feb02a78d4d5fa746a26ca7ddc6e8cb19.zip FreeBSD-src-ea50d71feb02a78d4d5fa746a26ca7ddc6e8cb19.tar.gz |
Stage 1 of sendmail dist tree flattening. contrib/sendmail/contrib
prevents doing this in one pass.
Diffstat (limited to 'contrib/sendmail/mailstats')
-rw-r--r-- | contrib/sendmail/mailstats/Makefile | 17 | ||||
-rw-r--r-- | contrib/sendmail/mailstats/Makefile.m4 | 24 | ||||
-rw-r--r-- | contrib/sendmail/mailstats/mailstats.8 | 118 | ||||
-rw-r--r-- | contrib/sendmail/mailstats/mailstats.c | 368 |
4 files changed, 0 insertions, 527 deletions
diff --git a/contrib/sendmail/mailstats/Makefile b/contrib/sendmail/mailstats/Makefile deleted file mode 100644 index 6dbcb62..0000000 --- a/contrib/sendmail/mailstats/Makefile +++ /dev/null @@ -1,17 +0,0 @@ -# $Id: Makefile,v 8.5 1999/09/23 22:36:36 ca Exp $ - -SHELL= /bin/sh -BUILD= ./Build -OPTIONS= $(CONFIG) $(FLAGS) - -all: FRC - $(SHELL) $(BUILD) $(OPTIONS) $@ -clean: FRC - $(SHELL) $(BUILD) $(OPTIONS) $@ -install: FRC - $(SHELL) $(BUILD) $(OPTIONS) $@ - -fresh: FRC - $(SHELL) $(BUILD) $(OPTIONS) -c - -FRC: diff --git a/contrib/sendmail/mailstats/Makefile.m4 b/contrib/sendmail/mailstats/Makefile.m4 deleted file mode 100644 index 1d45412..0000000 --- a/contrib/sendmail/mailstats/Makefile.m4 +++ /dev/null @@ -1,24 +0,0 @@ -dnl $Id: Makefile.m4,v 8.36 2006/06/28 21:08:02 ca Exp $ -include(confBUILDTOOLSDIR`/M4/switch.m4') - -define(`confREQUIRE_LIBSM', `true') -define(`confREQUIRE_SM_OS_H', `true') -# sendmail dir -SMSRCDIR= ifdef(`confSMSRCDIR', `confSMSRCDIR', `${SRCDIR}/sendmail') -PREPENDDEF(`confENVDEF', `confMAPDEF') -PREPENDDEF(`confINCDIRS', `-I${SMSRCDIR} ') - -bldPRODUCT_START(`executable', `mailstats') -define(`bldINSTALL_DIR', `S') -define(`bldSOURCES', `mailstats.c ') -bldPUSH_SMLIB(`sm') -bldPUSH_SMLIB(`smutil') -APPENDDEF(`confENVDEF', `-DNOT_SENDMAIL') -bldPRODUCT_END - -bldPRODUCT_START(`manpage', `mailstats') -define(`bldSOURCES', `mailstats.8') -bldPRODUCT_END - -bldFINISH - diff --git a/contrib/sendmail/mailstats/mailstats.8 b/contrib/sendmail/mailstats/mailstats.8 deleted file mode 100644 index d6c25de..0000000 --- a/contrib/sendmail/mailstats/mailstats.8 +++ /dev/null @@ -1,118 +0,0 @@ -.\" Copyright (c) 1998-2002 Sendmail, Inc. and its suppliers. -.\" All rights reserved. -.\" -.\" By using this file, you agree to the terms and conditions set -.\" forth in the LICENSE file which can be found at the top level of -.\" the sendmail distribution. -.\" -.\" -.\" $Id: mailstats.8,v 8.31 2002/06/27 22:47:29 gshapiro Exp $ -.\" -.TH MAILSTATS 8 "$Date: 2002/06/27 22:47:29 $" -.SH NAME -mailstats -\- display mail statistics -.SH SYNOPSIS -.B mailstats -.RB [ \-c "] [" \-o "] [" \-p "] [" \-P ] -.RB [ \-C -.IR cffile ] -.RB [ \-f -.IR stfile ] -.SH DESCRIPTION -The -.B mailstats -utility displays the current mail statistics. -.PP -First, the time at which statistics started being kept is displayed, -in the format specified by -ctime(3). -Then, -the statistics for each mailer are displayed on a single line, -each with the following white space separated fields: -.sp -.RS -.PD 0.2v -.TP 1.2i -.B M -The mailer number. -.TP -.B msgsfr -Number of messages from the mailer. -.TP -.B bytes_from -Kbytes from the mailer. -.TP -.B msgsto -Number of messages to the mailer. -.TP -.B bytes_to -Kbytes to the mailer. -.TP -.B msgsrej -Number of messages rejected. -.TP -.B msgsdis -Number of messages discarded. -.TP -.B msgsqur -Number of messages quarantined. -.TP -.B Mailer -The name of the mailer. -.PD -.RE -.PP -After this display, a line totaling the values for all of the mailers -is displayed (preceded with a ``T''), -separated from the previous information by a line containing only equals -(``='') -characters. -Another line preceded with a ``C'' lists the number of TCP connections. -.PP -The options are as follows: -.TP -.B \-C -Read the specified file instead of the default -.B sendmail -configuration file. -.TP -.B \-c -Try to use submit.cf instead of the default -.B sendmail -configuration file. -.TP -.B \-f -Read the specified statistics file instead of the statistics file -specified in the -.B sendmail -configuration file. -.TP -.B \-P -Output information in program-readable mode without clearing statistics. -.TP -.B \-p -Output information in program-readable mode and clear statistics. -.TP -.B \-o -Don't display the name of the mailer in the output. -.PP -The -.B mailstats -utility exits 0 on success, and >0 if an error occurs. -.SH FILES -.PD 0.2v -.TP 2.5i -/etc/mail/sendmail.cf -The default -.B sendmail -configuration file. -.TP -/etc/mail/statistics -The default -.B sendmail -statistics file. -.PD -.SH SEE ALSO -mailq(1), -sendmail(8) diff --git a/contrib/sendmail/mailstats/mailstats.c b/contrib/sendmail/mailstats/mailstats.c deleted file mode 100644 index f8b57b3..0000000 --- a/contrib/sendmail/mailstats/mailstats.c +++ /dev/null @@ -1,368 +0,0 @@ -/* - * Copyright (c) 1998-2002 Sendmail, Inc. and its suppliers. - * All rights reserved. - * Copyright (c) 1983 Eric P. Allman. All rights reserved. - * Copyright (c) 1988, 1993 - * The Regents of the University of California. All rights reserved. - * - * By using this file, you agree to the terms and conditions set - * forth in the LICENSE file which can be found at the top level of - * the sendmail distribution. - * - * - */ - -#include <sm/gen.h> - -SM_IDSTR(copyright, -"@(#) Copyright (c) 1998-2002 Sendmail, Inc. and its suppliers.\n\ - All rights reserved.\n\ - Copyright (c) 1988, 1993\n\ - The Regents of the University of California. All rights reserved.\n") - -SM_IDSTR(id, "@(#)$Id: mailstats.c,v 8.100 2002/06/27 23:24:06 gshapiro Exp $") - -#include <unistd.h> -#include <stddef.h> -#include <stdlib.h> -#include <ctype.h> -#include <string.h> -#include <time.h> -#ifdef EX_OK -# undef EX_OK /* unistd.h may have another use for this */ -#endif /* EX_OK */ -#include <sysexits.h> - -#include <sm/errstring.h> -#include <sm/limits.h> -#include <sendmail/sendmail.h> -#include <sendmail/mailstats.h> -#include <sendmail/pathnames.h> - - -#define MNAMELEN 20 /* max length of mailer name */ - -int -main(argc, argv) - int argc; - char **argv; -{ - register int i; - int mno; - int save_errno; - int ch, fd; - char *sfile; - char *cfile; - SM_FILE_T *cfp; - bool mnames; - bool progmode; - bool trunc; - long frmsgs = 0, frbytes = 0, tomsgs = 0, tobytes = 0, rejmsgs = 0; - long dismsgs = 0; - long quarmsgs = 0; - time_t now; - char mtable[MAXMAILERS][MNAMELEN + 1]; - char sfilebuf[MAXPATHLEN]; - char buf[MAXLINE]; - struct statistics stats; - extern char *ctime(); - extern char *optarg; - extern int optind; - - cfile = getcfname(0, 0, SM_GET_SENDMAIL_CF, NULL); - sfile = NULL; - mnames = true; - progmode = false; - trunc = false; - while ((ch = getopt(argc, argv, "cC:f:opP")) != -1) - { - switch (ch) - { - case 'c': - cfile = getcfname(0, 0, SM_GET_SUBMIT_CF, NULL); - break; - - case 'C': - cfile = optarg; - break; - - case 'f': - sfile = optarg; - break; - - case 'o': - mnames = false; - break; - - case 'p': - trunc = true; - /* FALLTHROUGH */ - - case 'P': - progmode = true; - break; - - case '?': - default: - usage: - (void) sm_io_fputs(smioerr, SM_TIME_DEFAULT, - "usage: mailstats [-C cffile] [-c] [-P] [-f stfile] [-o] [-p]\n"); - exit(EX_USAGE); - } - } - argc -= optind; - argv += optind; - - if (argc != 0) - goto usage; - - if ((cfp = sm_io_open(SmFtStdio, SM_TIME_DEFAULT, cfile, SM_IO_RDONLY, - NULL)) == NULL) - { - save_errno = errno; - (void) sm_io_fprintf(smioerr, SM_TIME_DEFAULT, "mailstats: "); - errno = save_errno; - sm_perror(cfile); - exit(EX_NOINPUT); - } - - mno = 0; - (void) sm_strlcpy(mtable[mno++], "prog", MNAMELEN + 1); - (void) sm_strlcpy(mtable[mno++], "*file*", MNAMELEN + 1); - (void) sm_strlcpy(mtable[mno++], "*include*", MNAMELEN + 1); - - while (sm_io_fgets(cfp, SM_TIME_DEFAULT, buf, sizeof(buf)) != NULL) - { - register char *b; - char *s; - register char *m; - - b = strchr(buf, '#'); - if (b == NULL) - b = strchr(buf, '\n'); - if (b == NULL) - b = &buf[strlen(buf)]; - while (isascii(*--b) && isspace(*b)) - continue; - *++b = '\0'; - - b = buf; - switch (*b++) - { - case 'M': /* mailer definition */ - break; - - case 'O': /* option -- see if .st file */ - if (sm_strncasecmp(b, " StatusFile", 11) == 0 && - !(isascii(b[11]) && isalnum(b[11]))) - { - /* new form -- find value */ - b = strchr(b, '='); - if (b == NULL) - continue; - while (isascii(*++b) && isspace(*b)) - continue; - } - else if (*b++ != 'S') - { - /* something else boring */ - continue; - } - - /* this is the S or StatusFile option -- save it */ - if (sm_strlcpy(sfilebuf, b, sizeof sfilebuf) >= - sizeof sfilebuf) - { - (void) sm_io_fprintf(smioerr, SM_TIME_DEFAULT, - "StatusFile filename too long: %.30s...\n", - b); - exit(EX_CONFIG); - } - if (sfile == NULL) - sfile = sfilebuf; - - default: - continue; - } - - if (mno >= MAXMAILERS) - { - (void) sm_io_fprintf(smioerr, SM_TIME_DEFAULT, - "Too many mailers defined, %d max.\n", - MAXMAILERS); - exit(EX_SOFTWARE); - } - m = mtable[mno]; - s = m + MNAMELEN; /* is [MNAMELEN + 1] */ - while (*b != ',' && !(isascii(*b) && isspace(*b)) && - *b != '\0' && m < s) - *m++ = *b++; - *m = '\0'; - for (i = 0; i < mno; i++) - { - if (strcmp(mtable[i], mtable[mno]) == 0) - break; - } - if (i == mno) - mno++; - } - (void) sm_io_close(cfp, SM_TIME_DEFAULT); - for (; mno < MAXMAILERS; mno++) - mtable[mno][0] = '\0'; - - if (sfile == NULL) - { - (void) sm_io_fprintf(smioerr, SM_TIME_DEFAULT, - "mailstats: no statistics file located\n"); - exit(EX_OSFILE); - } - - fd = open(sfile, O_RDONLY, 0600); - if ((fd < 0) || (i = read(fd, &stats, sizeof stats)) < 0) - { - save_errno = errno; - (void) sm_io_fputs(smioerr, SM_TIME_DEFAULT, "mailstats: "); - errno = save_errno; - sm_perror(sfile); - exit(EX_NOINPUT); - } - if (i == 0) - { - (void) sleep(1); - if ((i = read(fd, &stats, sizeof stats)) < 0) - { - save_errno = errno; - (void) sm_io_fputs(smioerr, SM_TIME_DEFAULT, - "mailstats: "); - errno = save_errno; - sm_perror(sfile); - exit(EX_NOINPUT); - } - else if (i == 0) - { - memset((ARBPTR_T) &stats, '\0', sizeof stats); - (void) time(&stats.stat_itime); - } - } - if (i != 0) - { - if (stats.stat_magic != STAT_MAGIC) - { - (void) sm_io_fprintf(smioerr, SM_TIME_DEFAULT, - "mailstats: incorrect magic number in %s\n", - sfile); - exit(EX_OSERR); - } - else if (stats.stat_version != STAT_VERSION) - { - (void) sm_io_fprintf(smioerr, SM_TIME_DEFAULT, - "mailstats version (%d) incompatible with %s version (%d)\n", - STAT_VERSION, sfile, - stats.stat_version); - - exit(EX_OSERR); - } - else if (i != sizeof stats || stats.stat_size != sizeof(stats)) - { - (void) sm_io_fputs(smioerr, SM_TIME_DEFAULT, - "mailstats: file size changed.\n"); - exit(EX_OSERR); - } - } - - if (progmode) - { - (void) time(&now); - (void) sm_io_fprintf(smioout, SM_TIME_DEFAULT, "%ld %ld\n", - (long) stats.stat_itime, (long) now); - } - else - { - (void) sm_io_fprintf(smioout, SM_TIME_DEFAULT, - "Statistics from %s", - ctime(&stats.stat_itime)); - (void) sm_io_fprintf(smioout, SM_TIME_DEFAULT, - " M msgsfr bytes_from msgsto bytes_to msgsrej msgsdis"); - (void) sm_io_fprintf(smioout, SM_TIME_DEFAULT, " msgsqur"); - (void) sm_io_fprintf(smioout, SM_TIME_DEFAULT, "%s\n", - mnames ? " Mailer" : ""); - } - for (i = 0; i < MAXMAILERS; i++) - { - if (stats.stat_nf[i] || stats.stat_nt[i] || - stats.stat_nq[i] || - stats.stat_nr[i] || stats.stat_nd[i]) - { - char *format; - - if (progmode) - format = "%2d %8ld %10ld %8ld %10ld %6ld %6ld"; - else - format = "%2d %8ld %10ldK %8ld %10ldK %6ld %6ld"; - (void) sm_io_fprintf(smioout, SM_TIME_DEFAULT, - format, i, - stats.stat_nf[i], - stats.stat_bf[i], - stats.stat_nt[i], - stats.stat_bt[i], - stats.stat_nr[i], - stats.stat_nd[i]); - (void) sm_io_fprintf(smioout, SM_TIME_DEFAULT, - " %6ld", stats.stat_nq[i]); - if (mnames) - (void) sm_io_fprintf(smioout, SM_TIME_DEFAULT, - " %s", - mtable[i]); - (void) sm_io_fprintf(smioout, SM_TIME_DEFAULT, "\n"); - frmsgs += stats.stat_nf[i]; - frbytes += stats.stat_bf[i]; - tomsgs += stats.stat_nt[i]; - tobytes += stats.stat_bt[i]; - rejmsgs += stats.stat_nr[i]; - dismsgs += stats.stat_nd[i]; - quarmsgs += stats.stat_nq[i]; - } - } - if (progmode) - { - (void) sm_io_fprintf(smioout, SM_TIME_DEFAULT, - " T %8ld %10ld %8ld %10ld %6ld %6ld", - frmsgs, frbytes, tomsgs, tobytes, rejmsgs, - dismsgs); - (void) sm_io_fprintf(smioout, SM_TIME_DEFAULT, - " %6ld", quarmsgs); - (void) sm_io_fprintf(smioout, SM_TIME_DEFAULT, "\n"); - (void) sm_io_fprintf(smioout, SM_TIME_DEFAULT, - " C %8ld %8ld %6ld\n", - stats.stat_cf, stats.stat_ct, - stats.stat_cr); - (void) close(fd); - if (trunc) - { - fd = open(sfile, O_RDWR | O_TRUNC, 0600); - if (fd >= 0) - (void) close(fd); - } - } - else - { - (void) sm_io_fprintf(smioout, SM_TIME_DEFAULT, - "============================================================="); - (void) sm_io_fprintf(smioout, SM_TIME_DEFAULT, "========"); - (void) sm_io_fprintf(smioout, SM_TIME_DEFAULT, "\n"); - (void) sm_io_fprintf(smioout, SM_TIME_DEFAULT, - " T %8ld %10ldK %8ld %10ldK %6ld %6ld", - frmsgs, frbytes, tomsgs, tobytes, rejmsgs, - dismsgs); - (void) sm_io_fprintf(smioout, SM_TIME_DEFAULT, - " %6ld", quarmsgs); - (void) sm_io_fprintf(smioout, SM_TIME_DEFAULT, "\n"); - (void) sm_io_fprintf(smioout, SM_TIME_DEFAULT, - " C %8ld %10s %8ld %10s %6ld\n", - stats.stat_cf, "", stats.stat_ct, "", - stats.stat_cr); - } - exit(EX_OK); - /* NOTREACHED */ - return EX_OK; -} |