2001-05-28 17:08:52 +00:00

164 lines
2.8 KiB
C
Raw Blame History

This file contains invisible Unicode characters

This file contains invisible Unicode characters that are indistinguishable to humans but may be processed differently by a computer. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

/*
* Copyright (c) 1999-2001 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.
*
*/
#ifndef lint
static char id[] = "@(#)$Id: main.c,v 8.34.4.11 2001/05/07 22:06:37 gshapiro Exp $";
#endif /* ! lint */
#if _FFR_MILTER
#define _DEFINE 1
#include "libmilter.h"
#include <fcntl.h>
#include <sys/stat.h>
static smfiDesc_ptr smfi = NULL;
/*
** SMFI_REGISTER -- register a filter description
**
** Parameters:
** smfilter -- description of filter to register
**
** Returns:
** MI_SUCCESS/MI_FAILURE
*/
int
smfi_register(smfilter)
smfiDesc_str smfilter;
{
size_t len;
if (smfi == NULL)
{
smfi = (smfiDesc_ptr) malloc(sizeof *smfi);
if (smfi == NULL)
return MI_FAILURE;
}
(void) memcpy(smfi, &smfilter, sizeof *smfi);
if (smfilter.xxfi_name == NULL)
smfilter.xxfi_name = "Unknown";
len = strlen(smfilter.xxfi_name) + 1;
smfi->xxfi_name = (char *) malloc(len);
if (smfi->xxfi_name == NULL)
return MI_FAILURE;
(void) strlcpy(smfi->xxfi_name, smfilter.xxfi_name, len);
/* compare milter version with hard coded version */
if (smfi->xxfi_version != SMFI_VERSION)
{
/* hard failure for now! */
smi_log(SMI_LOG_ERR,
"%s: smfi_register: version mismatch application: %d != milter: %d",
smfi->xxfi_name, smfi->xxfi_version,
(int) SMFI_VERSION);
return MI_FAILURE;
}
return MI_SUCCESS;
}
/*
** SMFI_STOP -- stop milter
**
** Parameters:
** none.
**
** Returns:
** success.
*/
int
smfi_stop()
{
mi_stop_milters(MILTER_STOP);
return MI_SUCCESS;
}
static int dbg = 0;
static char *conn = NULL;
static int timeout = MI_TIMEOUT;
static int backlog= MI_SOMAXCONN;
int
smfi_setdbg(odbg)
int odbg;
{
dbg = odbg;
return MI_SUCCESS;
}
int
smfi_settimeout(otimeout)
int otimeout;
{
timeout = otimeout;
return MI_SUCCESS;
}
int
smfi_setconn(oconn)
char *oconn;
{
size_t l;
if (oconn == NULL || *oconn == '\0')
return MI_FAILURE;
l = strlen(oconn) + 1;
if ((conn = (char *) malloc(l)) == NULL)
return MI_FAILURE;
if (strlcpy(conn, oconn, l) >= l)
return MI_FAILURE;
return MI_SUCCESS;
}
int
smfi_setbacklog(obacklog)
int obacklog;
{
if (obacklog <= 0)
return MI_FAILURE;
backlog = obacklog;
return MI_SUCCESS;
}
int
smfi_main()
{
signal(SIGPIPE, SIG_IGN);
if (conn == NULL)
{
smi_log(SMI_LOG_FATAL, "%s: missing connection information",
smfi->xxfi_name);
return MI_FAILURE;
}
(void) atexit(mi_clean_signals);
if (mi_control_startup(smfi->xxfi_name) != MI_SUCCESS)
{
smi_log(SMI_LOG_FATAL,
"%s: Couldn't start signal thread",
smfi->xxfi_name);
return MI_FAILURE;
}
/* Startup the listener */
if (mi_listener(conn, dbg, smfi, timeout, backlog) != MI_SUCCESS)
return MI_FAILURE;
return MI_SUCCESS;
}
#endif /* _FFR_MILTER */