This repository has been archived on 2024-04-08. You can view files and clone it, but cannot push or open issues or pull requests.
deb-mbse/mbcico/callall.c

147 lines
3.7 KiB
C
Raw Normal View History

2001-08-17 05:46:24 +00:00
/*****************************************************************************
*
* File ..................: mbcico/callall.c
* Purpose ...............: Fidonet mailer
* Last modification date : 27-Nov-2000
*
*****************************************************************************
* Copyright (C) 1997-2000
*
* Michiel Broek FIDO: 2:280/2802
* Beekmansbos 10
* 1971 BV IJmuiden
* the Netherlands
*
* This file is part of MBSE BBS.
*
* This BBS is free software; you can redistribute it and/or modify it
* under the terms of the GNU General Public License as published by the
* Free Software Foundation; either version 2, or (at your option) any
* later version.
*
* MBSE BBS is distributed in the hope that it will be useful, but
* WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with MBSE BBS; see the file COPYING. If not, write to the Free
* Software Foundation, 675 Mass Ave, Cambridge, MA 02139, USA.
*****************************************************************************/
#include "../lib/libs.h"
#include "../lib/structs.h"
#include "../lib/common.h"
#include "config.h"
#include "../lib/clcomm.h"
#include "scanout.h"
#include "lutil.h"
#include "callstat.h"
#include "callall.h"
static int each(faddr*, char, int, char*);
static fa_list *alist = NULL;
fa_list *callall(void)
{
fa_list *tmp;
int rc;
if (alist) {
for (tmp = alist; tmp; tmp = alist) {
alist = tmp->next;
tidy_faddr(tmp->addr);
free(tmp);
}
alist = NULL;
}
if ((rc = scanout(each))) {
WriteError("Error scanning outbound, aborting");
return NULL;
}
return (fa_list *)alist;
}
static int each(faddr *addr, char flavor, int isflo, char *fname)
{
fa_list **tmp;
callstat *st;
if ((flavor == 'h') ||
((isflo != OUT_PKT) && (isflo != OUT_FLO) && (isflo != OUT_POL)))
return 0;
/*
* Outside Zone Mail Hour normal flavor will be hold.
*/
if (!IsZMH() && (flavor == 'o'))
return 0;
/*
* During ZMH only poll and .pkt files will be sent, except
* IMMediate mail, that goes always.
*/
if (flavor != 'i') {
if (IsZMH() && (isflo == OUT_FLO))
return 0;
}
/*
* Don't add nodes who are undiable
*/
st = getstatus(addr);
if (st->tryno >= 30)
return 0;
for (tmp = &alist; *tmp; tmp=&((*tmp)->next))
if (((*tmp)->addr->zone == addr->zone) &&
((*tmp)->addr->net == addr->net) &&
((*tmp)->addr->node == addr->node) &&
((*tmp)->addr->point == addr->point) &&
(((*tmp)->addr->domain == NULL) ||
(addr->domain == NULL) ||
(strcasecmp((*tmp)->addr->domain,addr->domain) == 0)))
break;
if (*tmp == NULL) {
*tmp=(fa_list *)malloc(sizeof(fa_list));
(*tmp)->next=NULL;
(*tmp)->addr=(faddr *)malloc(sizeof(faddr));
(*tmp)->addr->name=NULL;
(*tmp)->addr->zone=addr->zone;
(*tmp)->addr->net=addr->net;
(*tmp)->addr->node=addr->node;
(*tmp)->addr->point=addr->point;
(*tmp)->addr->domain=xstrcpy(addr->domain);
if (flavor == 'i')
(*tmp)->force = TRUE;
else
(*tmp)->force = FALSE;
if (isflo == OUT_POL)
(*tmp)->force = TRUE;
switch (flavor) {
case 'i': Syslog('+', "Immediate mail to %s", ascfnode((*tmp)->addr,0x1f));
break;
case 'c': Syslog('+', "Crash mail to %s", ascfnode((*tmp)->addr,0x1f));
break;
case 'o': Syslog('+', "Normal mail to %s",ascfnode((*tmp)->addr,0x1f));
break;
case 'p': Syslog('+', "Poll request to %s",ascfnode((*tmp)->addr,0x1f));
break;
default : Syslog('+', "Some mail (%c) to %s",flavor,ascfnode((*tmp)->addr,0x1f));
}
}
return 0;
}