d24352bd907f7a31c1dc195f21f59e80e3ce8c39
[debian/amanda] / client-src / runtar.c
1 /*
2  * Amanda, The Advanced Maryland Automatic Network Disk Archiver
3  * Copyright (c) 1991-1998 University of Maryland at College Park
4  * All Rights Reserved.
5  *
6  * Permission to use, copy, modify, distribute, and sell this software and its
7  * documentation for any purpose is hereby granted without fee, provided that
8  * the above copyright notice appear in all copies and that both that
9  * copyright notice and this permission notice appear in supporting
10  * documentation, and that the name of U.M. not be used in advertising or
11  * publicity pertaining to distribution of the software without specific,
12  * written prior permission.  U.M. makes no representations about the
13  * suitability of this software for any purpose.  It is provided "as is"
14  * without express or implied warranty.
15  *
16  * U.M. DISCLAIMS ALL WARRANTIES WITH REGARD TO THIS SOFTWARE, INCLUDING ALL
17  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS, IN NO EVENT SHALL U.M.
18  * BE LIABLE FOR ANY SPECIAL, INDIRECT OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
19  * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION
20  * OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN
21  * CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
22  *
23  * Authors: the Amanda Development Team.  Its members are listed in a
24  * file named AUTHORS, in the root directory of this distribution.
25  */
26 /*
27  * $Id: runtar.c,v 1.17 2006/01/14 04:37:18 paddy_s Exp $
28  *
29  * runs GNUTAR program as root
30  */
31 #include "amanda.h"
32 #include "version.h"
33
34 int main P((int argc, char **argv));
35
36 int main(argc, argv)
37 int argc;
38 char **argv;
39 {
40 #ifdef GNUTAR
41     int i;
42     char *e;
43     char *dbf;
44 #endif
45
46     safe_fd(-1, 0);
47     safe_cd();
48
49     set_pname("runtar");
50
51     /* Don't die when child closes pipe */
52     signal(SIGPIPE, SIG_IGN);
53
54     dbopen();
55     dbprintf(("%s: version %s\n", argv[0], version()));
56
57 #ifndef GNUTAR
58
59     fprintf(stderr,"gnutar not available on this system.\n");
60     dbprintf(("%s: gnutar not available on this system.\n", argv[0]));
61     dbclose();
62     return 1;
63
64 #else
65
66     if(client_uid == (uid_t) -1) {
67         error("error [cannot find user %s in passwd file]\n", CLIENT_LOGIN);
68     }
69
70 #ifdef FORCE_USERID
71     if (getuid() != client_uid)
72         error("error [must be invoked by %s]\n", CLIENT_LOGIN);
73
74     if (geteuid() != 0)
75         error("error [must be setuid root]\n");
76 #endif
77
78 #if !defined (DONT_SUID_ROOT)
79     setuid(0);
80 #endif
81
82     dbprintf(("running: %s: ",GNUTAR));
83     for (i=0; argv[i]; i++)
84         dbprintf(("%s ", argv[i]));
85     dbprintf(("\n"));
86     dbf = dbfn();
87     if (dbf) {
88         dbf = stralloc(dbf);
89     }
90     dbclose();
91
92     execve(GNUTAR, argv, safe_env());
93
94     e = strerror(errno);
95     dbreopen(dbf, "more");
96     amfree(dbf);
97     dbprintf(("execve of %s failed (%s)\n", GNUTAR, e));
98     dbclose();
99
100     fprintf(stderr, "runtar: could not exec %s: %s\n", GNUTAR, e);
101     return 1;
102 #endif
103 }