]> andersk Git - moira.git/blob - clients/moira/main.c
28f75b506545dbb06136607a763c1fe4fa51a6ed
[moira.git] / clients / moira / main.c
1 #if (!defined(lint) && !defined(SABER))
2   static char rcsid_module_c[] = "$Header$";
3 #endif lint
4
5 /*      This is the file main.c for the SMS Client, which allows a nieve
6  *      user to quickly and easily maintain most parts of the SMS database.
7  *      It Contains: The main driver for the SMS Client.
8  *      
9  *      Created:        4/12/88
10  *      By:             Chris D. Peterson
11  *
12  *      $Source$
13  *      $Author$
14  *      $Header$
15  *      
16  *      Copyright 1988 by the Massachusetts Institute of Technology.
17  *
18  *      For further information on copyright and distribution 
19  *      see the file mit-copyright.h
20  */
21
22 #include <pwd.h>
23 #include <signal.h>
24 #include <stdio.h>
25 #include <strings.h>
26 #include <sys/types.h>
27 #include <sms.h>
28 #include <menu.h>
29
30 #include "mit-copyright.h"
31 #include "defs.h"
32 #include "f_defs.h"
33 #include "globals.h"
34
35 char * whoami;                  /* used by menu.c ugh!!! */
36
37 extern Menu sms_top_menu, list_menu, user_menu, dcm_menu;
38
39 #ifndef DEBUG
40 static void SignalHandler();
41 #endif DEBUG
42
43 static void ErrorExit(), Usage();
44 char *getlogin();
45 uid_t getuid();
46 struct passwd *getpwuid();
47
48 Bool use_menu = TRUE;           /* whether or not we are using a menu. */
49
50 /*      Function Name: main
51  *      Description: The main driver for the SMS Client.
52  *      Arguments: argc, argv - standard command line args.
53  *      Returns: doesn't return.
54  */
55
56 void
57 main(argc, argv)
58     int argc;
59     char ** argv;
60 {
61     int status;
62     Menu *menu;
63
64     if ((user = getlogin()) == NULL) 
65         user = getpwuid((int) getuid())->pw_name;
66     user = (user && strlen(user)) ? Strsave(user) : "";
67
68     if ((program_name = rindex(argv[0], '/')) == NULL)
69       program_name = argv[0];
70     else
71       program_name++;
72     program_name = Strsave(program_name);
73     whoami = Strsave(program_name); /* used by menu.c,  ugh !!! */
74
75     verbose = TRUE;
76
77     switch (argc) {
78     case 2:
79       if (strcmp(argv[1], "-nomenu") == 0)
80         use_menu = FALSE;
81       else 
82         Usage();
83       break;
84     case 1:
85       break;
86     default:
87       Usage();
88       break;
89     }
90
91     if ( status = sms_connect(SMS_SERVER) ) 
92         ErrorExit("\nConnection to SMS server failed", status);
93
94     if ( status = sms_auth(program_name) ) 
95         ErrorExit("\nAuthorization failed -- please run kinit", status);
96
97 /*
98  * These signals should not be set until just before we fire up the menu
99  * system. 
100  */
101
102 #ifndef DEBUG
103     (void) signal(SIGHUP, SignalHandler);
104     (void) signal(SIGINT, SignalHandler); 
105     (void) signal(SIGQUIT, SignalHandler);
106 #endif DEBUG
107
108     if (!strcmp(program_name, "listmaint"))
109       menu = &list_menu;
110     else if (!strcmp(program_name, "usermaint"))
111       menu = &user_menu;
112     else if (!strcmp(program_name, "dcmmaint"))
113       menu = &dcm_menu;
114     else
115       menu = &sms_top_menu;
116
117     if (use_menu) {             /* Start menus that execute program */
118         Start_paging();
119         Start_menu(menu);
120         Stop_paging();
121     }
122     else                        /* Start program without menus. */
123         Start_no_menu(menu);
124
125     sms_disconnect();
126     exit(0);
127 }
128
129 /*      Function Name: ErrorExit
130  *      Description: This function does the error handling and exits.
131  *      Arguments: buf - the error message to print.
132  *                 status - the error code.
133  *      Returns: doesn't return.
134  */
135
136 static void
137 ErrorExit(buf,status)
138 int status;
139 char * buf;    
140 {
141     com_err(program_name, status, buf);
142     sms_disconnect();
143     exit(1);
144 }
145
146 /*      Function Name: usage
147  *      Description: Prints usage info and then exits.
148  *      Arguments: none
149  *      Returns: doesn't return.
150  */
151
152 static void
153 Usage()
154 {
155     fprintf(stderr, "Usage: %s [-nomenu]\n", program_name);
156     exit(1);
157 }
158
159 #ifndef DEBUG
160 /*      Function Name: SignalHandler
161  *      Description: This function cleans up from a signal interrupt.
162  *      Arguments: none.
163  *      Returns: doesn't
164  */
165
166 static void
167 SignalHandler()
168 {
169     Put_message("Signal caught - exiting");
170     if (use_menu)
171       Cleanup_menu();
172     sms_disconnect();
173     exit(1);
174 }
175 #endif DEBUG
This page took 0.036335 seconds and 3 git commands to generate.