b6f8bd8de66b7d7e9f07719a7118b07c50946bc4
[openafs.git] / src / sys / pagsh.c
1 /*
2  * Copyright 2000, International Business Machines Corporation and others.
3  * All Rights Reserved.
4  * 
5  * This software has been released under the terms of the IBM Public
6  * License.  For details, see the LICENSE file in the top-level source
7  * directory or online at http://www.openafs.org/dl/license10.html
8  */
9
10 #include <afsconfig.h>
11 #include <afs/param.h>
12
13 RCSID
14     ("$Header$");
15
16 #ifdef  AFS_AIX32_ENV
17 #include <signal.h>
18 #ifdef AFS_AIX51_ENV
19 #include <sys/cred.h>
20 #endif
21 #endif
22 #include <stdio.h>
23 #include <stdlib.h>
24 #include <limits.h>
25 #ifndef AFS_NT40_ENV
26 #include <unistd.h>
27 #endif
28 #ifdef HAVE_STRING_H
29 #include <string.h>
30 #endif
31 #include <pwd.h>
32 #ifdef AFS_KERBEROS_ENV
33 #include <sys/types.h>
34 #include <sys/stat.h>
35 #endif
36
37 #include "AFS_component_version_number.c"
38
39 extern afs_int32 setpag();
40
41 int
42 main(int argc, char *argv[])
43 {
44     struct passwd *pwe;
45     int uid, gid;
46     char *shell = "/bin/sh";
47
48 #ifdef  AFS_AIX32_ENV
49     /*
50      * The following signal action for AIX is necessary so that in case of a 
51      * crash (i.e. core is generated) we can include the user's data section 
52      * in the core dump. Unfortunately, by default, only a partial core is
53      * generated which, in many cases, isn't too useful.
54      */
55     struct sigaction nsa;
56
57     sigemptyset(&nsa.sa_mask);
58     nsa.sa_handler = SIG_DFL;
59     nsa.sa_flags = SA_FULLDUMP;
60     sigaction(SIGSEGV, &nsa, NULL);
61 #endif
62     gid = getgid();
63     uid = getuid();
64     pwe = getpwuid(uid);
65     if (pwe == 0) {
66         fprintf(stderr, "Intruder alert.\n");
67     } else {
68 /*              shell = pwe->pw_shell; */
69     }
70     if (setpag() == -1) {
71         perror("setpag");
72     }
73 #ifdef AFS_KERBEROS_ENV
74     ktc_newpag();
75 #endif
76     (void)setuid(uid);
77     (void)setgid(gid);
78     argv[0] = shell;
79     execvp(shell, argv);
80     perror(shell);
81     fprintf(stderr, "No shell\n");
82     exit(1);
83 }
84
85
86 #ifdef AFS_KERBEROS_ENV
87 /* stolen from auth/ktc.c */
88
89 static afs_uint32
90 curpag(void)
91 {
92 #if defined(AFS_AIX51_ENV)
93     afs_int32 pag;
94
95     if (get_pag(PAG_AFS, &pag) < 0 || pag == 0)
96         pag = -1;
97     return pag;
98 #else
99     afs_uint32 groups[NGROUPS_MAX];
100     afs_uint32 g0, g1;
101     afs_uint32 h, l, ret;
102
103     if (getgroups(sizeof groups / sizeof groups[0], groups) < 2)
104         return 0;
105
106     g0 = groups[0] & 0xffff;
107     g1 = groups[1] & 0xffff;
108     g0 -= 0x3f00;
109     g1 -= 0x3f00;
110     if ((g0 < 0xc000) && (g1 < 0xc000)) {
111         l = ((g0 & 0x3fff) << 14) | (g1 & 0x3fff);
112         h = (g0 >> 14);
113         h = (g1 >> 14) + h + h + h;
114         ret = ((h << 28) | l);
115         /* Additional testing */
116         if (((ret >> 24) & 0xff) == 'A')
117             return ret;
118         else
119             return -1;
120     }
121     return -1;
122 #endif
123 }
124
125 int
126 ktc_newpag(void)
127 {
128     extern char **environ;
129
130     afs_uint32 pag;
131     struct stat sbuf;
132     char fname[256], *prefix = "/ticket/";
133     int numenv;
134     char **newenv, **senv, **denv;
135
136     if (stat("/ticket", &sbuf) == -1) {
137         prefix = "/tmp/tkt";
138     }
139
140     pag = curpag() & 0xffffffff;
141     if (pag == -1) {
142         sprintf(fname, "%s%d", prefix, getuid());
143     } else {
144         sprintf(fname, "%sp%ld", prefix, pag);
145     }
146 /*    ktc_set_tkt_string(fname); */
147
148     for (senv = environ, numenv = 0; *senv; senv++)
149         numenv++;
150     newenv = (char **)malloc((numenv + 2) * sizeof(char *));
151
152     for (senv = environ, denv = newenv; *senv; *senv++) {
153         if (strncmp(*senv, "KRBTKFILE=", 10) != 0)
154             *denv++ = *senv;
155     }
156
157     *denv = malloc(10 + strlen(fname) + 1);
158     strcpy(*denv, "KRBTKFILE=");
159     strcat(*denv, fname);
160     *++denv = 0;
161     environ = newenv;
162 }
163
164 #endif