-#ifndef lint
+#if (!defined(lint) && !defined(SABER))
static char rcsid_module_c[] = "$Header$";
#endif lint
-/* This is the file main.c for allmaint, the SMS client that allows
- * a user to maintaint most important parts of the SMS database.
- * It Contains: The main driver for this program.
+/* This is the file main.c for the Moira Client, which allows a nieve
+ * user to quickly and easily maintain most parts of the Moira database.
+ * It Contains: The main driver for the Moira Client.
*
* Created: 4/12/88
* By: Chris D. Peterson
* $Author$
* $Header$
*
- * Copyright 1987, 1988 by the Massachusetts Institute of Technology.
+ * Copyright 1988 by the Massachusetts Institute of Technology.
*
* For further information on copyright and distribution
* see the file mit-copyright.h
#include <signal.h>
#include <stdio.h>
#include <strings.h>
-#include <sms.h>
+#include <sys/types.h>
+#include <moira.h>
#include <menu.h>
+#include <krb_et.h>
#include "mit-copyright.h"
-#include "allmaint.h"
+#include "defs.h"
+#include "f_defs.h"
#include "globals.h"
-static void init_listmaint(), error_exit(), usage();
-void Put_message();
+char * whoami; /* used by menu.c ugh!!! */
+char * moira_server;
+int interrupt = 0;
+
+extern Menu moira_top_menu, list_menu, user_menu, dcm_menu;
+
+#ifndef DEBUG
+static void SignalHandler(), CatchInterrupt();
+#endif DEBUG
+
+static void ErrorExit(), Usage();
char *getlogin();
uid_t getuid();
struct passwd *getpwuid();
+#ifdef _AIX
+Bool use_menu = FALSE; /* whether or not we are using a menu. */
+#else
Bool use_menu = TRUE; /* whether or not we are using a menu. */
+#endif
/* Function Name: main
- * Description: The main driver for allmaint.
+ * Description: The main driver for the Moira Client.
* Arguments: argc, argv - standard command line args.
* Returns: doesn't return.
*/
int argc;
char ** argv;
{
- char buf[BUFSIZ];
+ int status;
+ Menu *menu;
+ char *motd, **arg;
if ((user = getlogin()) == NULL)
user = getpwuid((int) getuid())->pw_name;
user = (user && strlen(user)) ? Strsave(user) : "";
- init_sms_err_tbl();
- init_krb_err_tbl();
-
- switch (argc) {
- case 2:
- if (strcmp(argv[1], "-nomenu") == 0)
- use_menu = FALSE;
- else
- usage();
- /* Fall Through. */
- case 1:
- if ((program_name = rindex(argv[0], '/')) == NULL)
- program_name = argv[0];
- else
- program_name++;
- break;
- default:
- usage();
- break;
+ if ((program_name = rindex(argv[0], '/')) == NULL)
+ program_name = argv[0];
+ else
+ program_name++;
+ program_name = Strsave(program_name);
+ whoami = Strsave(program_name); /* used by menu.c, ugh !!! */
+
+ verbose = TRUE;
+ arg = argv;
+ moira_server = NULL;
+
+ while (++arg - argv < argc) {
+ if (**arg == '-') {
+ if (!strcmp(*arg, "-nomenu"))
+ use_menu = FALSE;
+ else if (!strcmp(*arg, "-db"))
+ if (arg - argv < argc - 1) {
+ ++arg;
+ moira_server = *arg;
+ } else
+ Usage(argv);
+ else
+ Usage(argv);
+ }
+ }
+
+ if ( status = mr_connect(moira_server) )
+ ErrorExit("\nConnection to Moira server failed", status);
+
+ if ( status = mr_motd(&motd) )
+ ErrorExit("\nUnable to check server status", status);
+ if (motd) {
+ fprintf(stderr, "The Moira server is currently unavailable:\n%s\n", motd);
+ mr_disconnect();
+ exit(1);
}
-
- if ( status = sms_connect() )
- error_exit("\nConnection to SMS server failed", status);
- if ( status = sms_auth(argv[0]) )
- error_exit("\nAuthorization failed -- please run kinit", status);
+ if ( status = mr_auth(program_name) ) {
+ if (status == MR_USER_AUTH) {
+ char buf[BUFSIZ];
+ com_err(program_name, status, "\nPress [RETURN] to continue");
+ gets(buf);
+ } else {
+ if (status >= ERROR_TABLE_BASE_krb &&
+ status <= ERROR_TABLE_BASE_krb + 256)
+ ErrorExit("\nAuthorization failed -- please run kinit", status);
+ else
+ ErrorExit("\nAuthorization failed.", status);
+ }
+ }
/*
* These signals should not be set until just before we fire up the menu
* system.
*/
- (void) signal(SIGHUP, signal_handler);
- (void) signal(SIGINT, signal_handler);
- (void) signal(SIGQUIT, signal_handler);
+
+#ifndef DEBUG
+ (void) signal(SIGHUP, SignalHandler);
+ (void) signal(SIGQUIT, SignalHandler);
+ if (use_menu)
+ (void) signal(SIGINT, SignalHandler);
+ else
+ (void) signal(SIGINT, CatchInterrupt);
+#endif DEBUG
+
+ initialize_gdss_error_table();
+
+ if (!strcmp(program_name, "listmaint"))
+ menu = &list_menu;
+ else if (!strcmp(program_name, "usermaint"))
+ menu = &user_menu;
+ else if (!strcmp(program_name, "dcmmaint"))
+ menu = &dcm_menu;
+ else
+ menu = &moira_top_menu;
if (use_menu) { /* Start menus that execute program */
Start_paging();
- Start_menu(&allmaint_top_menu);
+ Start_menu(menu);
Stop_paging();
}
else /* Start program without menus. */
- Start_no_menu(&allmaint_top_menu);
+ Start_no_menu(menu);
- sms_disconnect();
+ mr_disconnect();
exit(0);
}
-/* Function Name: error_exit
+/* Function Name: ErrorExit
* Description: This function does the error handling and exits.
* Arguments: buf - the error message to print.
* status - the error code.
*/
static void
-error_exit(buf,status);
+ErrorExit(buf,status)
int status;
-char * whoami, *buf;
+char * buf;
{
com_err(program_name, status, buf);
- sms_disconnect();
+ mr_disconnect();
exit(1);
}
*/
static void
-usage()
+Usage()
{
fprintf(stderr, "Usage: %s [-nomenu]\n", program_name);
exit(1);
}
-/* Function Name: signal_handler
+#ifndef DEBUG
+/* Function Name: SignalHandler
* Description: This function cleans up from a signal interrupt.
* Arguments: none.
* Returns: doesn't
*/
-static int *
-signal_handler()
+static void
+SignalHandler()
{
Put_message("Signal caught - exiting");
if (use_menu)
Cleanup_menu();
- sms_disconnect();
+ mr_disconnect();
exit(1);
}
+
+
+static void
+CatchInterrupt()
+{
+ Put_message("Interrupt! Press RETURN to continue");
+ interrupt = 1;
+}
+#endif DEBUG