|
|
DataMuseum.dkPresents historical artifacts from the history of: DKUUG/EUUG Conference tapes |
This is an automatic "excavation" of a thematic subset of
See our Wiki for more about DKUUG/EUUG Conference tapes Excavated with: AutoArchaeologist - Free & Open Source Software. |
top - metrics - downloadIndex: T i
Length: 1946 (0x79a)
Types: TextFile
Names: »ihave.c«
└─⟦9ae75bfbd⟧ Bits:30007242 EUUGD3: Starter Kit
└─⟦cfd40dc56⟧ »EurOpenD3/news/nntp/nntp.1.5.8.tar.Z«
└─⟦2ec98eca6⟧
└─⟦this⟧ »server/ihave.c«
#ifndef lint
static char *sccsid = "@(#)$Header: ihave.c,v 1.15 90/01/16 02:29:50 sob Exp $";
#endif
#include "common.h"
#ifdef LOG
int ih_accepted;
int ih_rejected;
int ih_failed;
#endif LOG
/*
* IHAVE <messageid>
*
* Accept an article for transferral if we haven't seen it before.
*/
ihave(argc, argv)
int argc;
char *argv[];
{
char errbuf[2 * NNTP_STRLEN];
int retcode;
register char *cp;
if (argc != 2) {
printf("%d Usage: IHAVE <message-id>.\r\n", ERR_CMDSYN);
(void) fflush(stdout);
return;
}
cp = gethistent(argv[1], 1);
if (cp != NULL) {
printf("%d Got it.\r\n", ERR_GOTIT);
(void) fflush(stdout);
#ifdef LOG
ih_rejected++;
#ifdef IHAVE_DEBUG
syslog(LOG_DEBUG, "%s ihave %s rejected", hostname, argv[1]);
#endif IHAVE_DEBUG
#endif LOG
return;
}
if (!space(MINFREE)) {
/* force error reporting code into sending */
/* an out-of-space error message */
if (gethostname(errbuf, MAXHOSTNAMELEN) < 0)
(void) strcpy(errbuf, "Amnesiac");
(void) strcat(errbuf, " NNTP server out of space. Try later.");
retcode = 0; /* indicates that an error occurred */
} else
#ifdef BATCHED_INPUT
/* C news input hook */
retcode = batch_input_article(CONT_XFER, ERR_XFERFAIL, errbuf);
#else
retcode = spawn(rnews, "rnews", (char *) 0, CONT_XFER,
ERR_XFERFAIL, errbuf);
#endif
if (retcode <= 0){
cp = index(errbuf,':');
if (cp == (char *) NULL)
cp = "NULL";
while (*cp == ' ') cp++;
if (strcasecmp(cp,"inbound",7))
printf("%d %s\r\n", ERR_XFERFAIL, errbuf);
else
printf("%d %s\r\n", ERR_XFERRJCT, errbuf);
}
else if (retcode > 0)
printf("%d Thanks.\r\n",
OK_XFERED);
(void) fflush(stdout);
#ifdef LOG
if (retcode == 1)
ih_accepted++;
else
ih_failed++;
#ifdef IHAVE_DEBUG
syslog(LOG_DEBUG, "%s ihave %s accepted %s",
hostname, argv[1], retcode == 1 ? "succeeded" : "failed");
#endif IHAVE_DEBUG
#endif LOG
}