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.

275 lines
6.0 KiB
C
Raw Normal View History

2001-08-17 05:46:24 +00:00
/*****************************************************************************
*
2001-12-23 16:44:18 +00:00
* $Id$
2001-08-17 05:46:24 +00:00
* Purpose ...............: Change BBS status
*
*****************************************************************************
2005-08-19 19:46:55 +00:00
* Copyright (C) 1997-2005
2001-08-17 05:46:24 +00:00
*
* 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
2003-08-15 20:05:34 +00:00
* Software Foundation, 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA.
2001-08-17 05:46:24 +00:00
*****************************************************************************/
2002-06-30 12:48:44 +00:00
#include "../config.h"
2004-02-21 17:22:00 +00:00
#include "../lib/mbselib.h"
2002-01-07 19:16:03 +00:00
#include "../lib/users.h"
2004-02-21 17:22:00 +00:00
#include "../lib/mbsedb.h"
2001-08-17 05:46:24 +00:00
#include "mbstat.h"
extern int do_quiet;
time_t t_start, t_end;
void Help(void)
{
2005-08-19 19:46:55 +00:00
do_quiet = FALSE;
ProgName();
mbse_colour(LIGHTCYAN, BLACK);
printf("\nUsage: mbstat [command] <options>\n\n");
mbse_colour(LIGHTBLUE, BLACK);
printf(" Commands are:\n\n");
mbse_colour(CYAN, BLACK);
printf(" c close Close the BBS for users\n");
printf(" o open Open the BBS for users\n");
printf(" s set semafore Set named semafore\n");
printf(" w wait Wait until the BBS is free\n\n");
mbse_colour(LIGHTBLUE, BLACK);
printf(" Options are:\n\n");
mbse_colour(CYAN, BLACK);
printf(" -q -quiet Quiet, no screen output\n");
mbse_colour(LIGHTGRAY, BLACK);
die(MBERR_COMMANDLINE);
2001-08-17 05:46:24 +00:00
}
void ProgName(void)
{
2005-08-19 19:46:55 +00:00
if (do_quiet)
return;
mbse_colour(WHITE, BLACK);
printf("\nMBSTAT: MBSE BBS %s Status Changer\n", VERSION);
mbse_colour(YELLOW, BLACK);
printf(" %s\n", COPYRIGHT);
mbse_colour(CYAN, BLACK);
2001-08-17 05:46:24 +00:00
}
void die(int onsig)
{
2005-08-19 19:46:55 +00:00
signal(onsig, SIG_IGN);
2001-08-17 05:46:24 +00:00
2005-08-19 19:46:55 +00:00
if (onsig)
WriteError("Terminated on signal %d", onsig);
2001-08-17 05:46:24 +00:00
2005-08-19 19:46:55 +00:00
if (!do_quiet) {
mbse_colour(LIGHTGRAY, BLACK);
printf("\n");
}
2001-08-17 05:46:24 +00:00
2005-08-19 19:46:55 +00:00
t_end = time(NULL);
Syslog(' ', "MBSTAT finished in %s", t_elapsed(t_start, t_end));
2001-08-17 05:46:24 +00:00
2005-08-19 19:46:55 +00:00
ExitClient(onsig);
2001-08-17 05:46:24 +00:00
}
int main(int argc, char **argv)
{
2005-08-19 19:46:55 +00:00
int i;
char *cmd, *semafore = NULL;
int do_open = FALSE;
int do_close = FALSE;
int do_wait = FALSE;
int do_sema = FALSE;
struct passwd *pw;
InitConfig();
mbse_TermInit(1, 80, 24);
t_start = time(NULL);
/*
* Catch or ignore signals
*/
for (i = 0; i < NSIG; i++) {
if ((i == SIGHUP) || (i == SIGINT) || (i == SIGBUS) || (i == SIGILL) || (i == SIGSEGV) || (i == SIGTERM))
signal(i, (void (*))die);
else if ((i != SIGKILL) && (i != SIGSTOP))
signal(i, SIG_IGN);
}
cmd = xstrcpy((char *)"Command line: mbstat");
for (i = 1; i < argc; i++) {
cmd = xstrcat(cmd, (char *)" ");
cmd = xstrcat(cmd, tl(argv[i]));
if (!strncmp(tl(argv[i]), "w", 1))
do_wait = TRUE;
if (!strncmp(tl(argv[i]), "o", 1))
do_open = TRUE;
if (!strncmp(tl(argv[i]), "c", 1))
do_close = TRUE;
if (!strncmp(tl(argv[i]), "s", 1)) {
do_sema = TRUE;
i++;
semafore = xstrcpy(tl(argv[i]));
cmd = xstrcat(cmd, (char *)" ");
cmd = xstrcat(cmd, tl(argv[i]));
2001-08-17 05:46:24 +00:00
}
2005-08-19 19:46:55 +00:00
if (!strncmp(tl(argv[i]), "-q", 2))
do_quiet = TRUE;
}
2001-08-17 05:46:24 +00:00
2005-08-19 19:46:55 +00:00
ProgName();
pw = getpwuid(getuid());
InitClient(pw->pw_name, (char *)"mbstat", CFG.location, CFG.logfile,
2003-09-09 19:39:51 +00:00
CFG.util_loglevel, CFG.error_log, CFG.mgrlog, CFG.debuglog);
2001-08-17 05:46:24 +00:00
2005-08-19 19:46:55 +00:00
Syslog(' ', " ");
Syslog(' ', "MBSTAT v%s", VERSION);
Syslog(' ', cmd);
free(cmd);
2001-08-17 05:46:24 +00:00
2005-08-19 19:46:55 +00:00
if (!do_quiet) {
mbse_colour(CYAN, BLACK);
printf("\n");
}
2001-08-17 05:46:24 +00:00
2005-08-19 19:46:55 +00:00
if (do_close)
do_open = FALSE;
2001-08-17 05:46:24 +00:00
2005-08-19 19:46:55 +00:00
if (do_open) {
Open();
do_close = FALSE;
do_wait = FALSE;
}
2001-08-17 05:46:24 +00:00
2005-08-19 19:46:55 +00:00
if (do_close)
Close();
2001-08-17 05:46:24 +00:00
2005-08-19 19:46:55 +00:00
if (do_wait)
Wait();
2001-08-17 05:46:24 +00:00
2005-08-19 19:46:55 +00:00
if (do_sema)
Semafore(semafore);
2001-08-17 05:46:24 +00:00
2005-08-19 19:46:55 +00:00
if (!(do_open || do_close || do_wait || do_sema))
Help();
2001-08-17 05:46:24 +00:00
2005-08-19 19:46:55 +00:00
die(MBERR_OK);
return 0;
2001-08-17 05:46:24 +00:00
}
int Semafore(char *semafore)
{
2005-08-19 19:46:55 +00:00
char buf[81];
strcpy(buf, SockR("SECR:1,%s;", semafore));
if (strncmp(buf, "100:0;", 6) == 0) {
Syslog('+', "Semafore \"%s\" is set", semafore);
if (!do_quiet)
printf("Semafore \"%s\" is set\n", semafore);
return TRUE;
} else {
Syslog('+', "Failed to set \"%s\" semafore", semafore);
printf("Failed to set \"%s\" semafore\n", semafore);
return FALSE;
}
2001-08-17 05:46:24 +00:00
}
int Close(void)
{
2005-08-19 19:46:55 +00:00
char buf[81];
strcpy(buf, SockR("SCLO:0;"));
if (strncmp(buf, "100:0;", 6) == 0) {
Syslog('+', "The BBS is closed");
if (!do_quiet)
printf("The BBS is closed\n");
return TRUE;
} else {
printf("Failed to close the BBS\n");
return FALSE;
}
2001-08-17 05:46:24 +00:00
}
int Open(void)
{
2005-08-19 19:46:55 +00:00
char buf[81];
strcpy(buf, SockR("SOPE:0;"));
if (strncmp(buf, "100:0;", 6) == 0) {
Syslog('+', "The BBS is open");
if (!do_quiet)
printf("The BBS is open\n");
return TRUE;
} else {
printf("Failed to open the BBS\n");
return FALSE;
}
2001-08-17 05:46:24 +00:00
}
int Wait(void)
{
2005-08-19 19:46:55 +00:00
int Waiting = 3600;
char buf[PATH_MAX];
if (IsSema((char *)"upsdown"))
Waiting = 30;
Syslog('+', "Waiting for the BBS to become free, timeout %d seconds", Waiting);
while (Waiting) {
strcpy(buf, SockR("SFRE:0;"));
if (strncmp(buf, "100:0;", 6) == 0) {
Syslog('+', "The BBS is free");
if (!do_quiet)
printf("The BBS is free. \n");
return TRUE;
2001-08-17 05:46:24 +00:00
}
2005-08-19 19:46:55 +00:00
if (!do_quiet) {
buf[strlen(buf) -1] = '\0';
printf("\r%s\r", buf+6);
fflush(stdout);
}
sleep(1);
Waiting--;
}
2001-08-17 05:46:24 +00:00
2005-08-19 19:46:55 +00:00
WriteError("Wait for BBS free timeout, aborting");
return FALSE;
2001-08-17 05:46:24 +00:00
}