/***************************************************************************** * * $Id$ * Purpose ...............: mbtask - calllist * ***************************************************************************** * Copyright (C) 1997-2002 * * 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 "libs.h" #include "../lib/structs.h" #include "taskstat.h" #include "taskutil.h" #include "callstat.h" #include "outstat.h" #include "mbtask.h" #include "ports.h" #include "calllist.h" /* * Global variables */ tocall calllist[MAXTASKS]; /* Array with calllist */ extern int internet; /* Internet is down */ extern int s_scanout; /* Scan outbound sema */ extern int s_do_inet; /* Internet wanted */ extern _alist_l *alist; /* Nodes to call list */ extern int pots_calls; extern int isdn_calls; extern int inet_calls; /* * Check the actual list of nodes to call. */ int check_calllist(void) { int i, found, call_work; struct _alist *tmp; /* * Check callist, remove obsolete entries. */ for (i = 0; i < MAXTASKS; i++) { if (calllist[i].addr.zone) { found = FALSE; for (tmp = alist; tmp; tmp = tmp->next) { if ((calllist[i].addr.zone == tmp->addr.zone) && (calllist[i].addr.net == tmp->addr.net) && (calllist[i].addr.node == tmp->addr.node) && (calllist[i].addr.point == tmp->addr.point) && ((tmp->flavors) & F_CALL)) { found = TRUE; } } if (!found) { tasklog('c', "Removing slot %d node %s from calllist", i, ascfnode(calllist[i].addr, 0x0f)); memset(&calllist[i], 0, sizeof(tocall)); } } } check_ports(); if (pots_calls || isdn_calls || inet_calls) { call_work = 0; for (tmp = alist; tmp; tmp = tmp->next) { if (tmp->callmode != CM_NONE) { call_work++; found = FALSE; for (i = 0; i < MAXTASKS; i++) { if ((calllist[i].addr.zone == tmp->addr.zone) && (calllist[i].addr.net == tmp->addr.net) && (calllist[i].addr.node == tmp->addr.node) && (calllist[i].addr.point == tmp->addr.point)) { found = TRUE; /* * Refresh last call status */ calllist[i].cst = tmp->cst; } } if (!found) { for (i = 0; i < MAXTASKS; i++) { if (!calllist[i].addr.zone) { tasklog('c', "Adding %s to calllist slot %d", ascfnode(tmp->addr, 0x1f), i); calllist[i].addr = tmp->addr; calllist[i].cst = tmp->cst; calllist[i].callmode = tmp->callmode; calllist[i].moflags = tmp->moflags; calllist[i].diflags = tmp->diflags; calllist[i].ipflags = tmp->ipflags; break; } } } } } tasklog('o', "%d systems to call", call_work); } else { if (s_scanout) sem_set((char *)"scanout", FALSE); } /* * Check if we need to remove the do_inet semafore */ if (!inet_calls && internet && s_do_inet) { tasklog('c', "Removing do_inet semafore"); s_do_inet = FALSE; if (IsSema((char *)"do_inet")) { RemoveSema((char *)"do_inet"); } } call_work = 0; for (i = 0; i < MAXTASKS; i++) { if (calllist[i].addr.zone) { if (!call_work) { tasklog('c', "Slot Call Pid Try Status Mode Modem ISDN TCP/IP Address"); tasklog('c', "---- ----- ----- --- ------- ------- -------- -------- -------- ----------------"); } call_work++; tasklog('c', "%4d %s %5d %3d %s %s %08x %08x %08x %s", i, calllist[i].calling?"true ":"false", calllist[i].taskpid, calllist[i].cst.tryno, callstatus(calllist[i].cst.trystat), callmode(calllist[i].callmode), calllist[i].moflags, calllist[i].diflags, calllist[i].ipflags, ascfnode(calllist[i].addr, 0x1f)); } } return call_work; }