s3:lib/afs move afs.c to common lib dir
[samba.git] / source3 / utils / net_afs.c
1 /*
2    Samba Unix/Linux SMB client library
3    net afs commands
4    Copyright (C) 2003  Volker Lendecke  (vl@samba.org)
5
6    This program is free software; you can redistribute it and/or modify
7    it under the terms of the GNU General Public License as published by
8    the Free Software Foundation; either version 3 of the License, or
9    (at your option) any later version.
10
11    This program is distributed in the hope that it will be useful,
12    but WITHOUT ANY WARRANTY; without even the implied warranty of
13    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
14    GNU General Public License for more details.
15
16    You should have received a copy of the GNU General Public License
17    along with this program.  If not, see <http://www.gnu.org/licenses/>.
18 */
19
20 #include "includes.h"
21 #include "utils/net.h"
22 #include "utils/net_afs.h"
23 #include "secrets.h"
24 #include "system/filesys.h"
25 #include "lib/afs/afs_funcs.h"
26
27 int net_afs_usage(struct net_context *c, int argc, const char **argv)
28 {
29         d_printf(_("  net afs key filename\n"
30                  "\tImports a OpenAFS KeyFile into our secrets.tdb\n\n"));
31         d_printf(_("  net afs impersonate <user> <cell>\n"
32                  "\tCreates a token for user@cell\n\n"));
33         return -1;
34 }
35
36 int net_afs_key(struct net_context *c, int argc, const char **argv)
37 {
38         int fd;
39         struct afs_keyfile keyfile;
40
41         if (argc != 2) {
42                 d_printf("%s net afs key <keyfile> cell\n", _("Usage:"));
43                 return -1;
44         }
45
46         if (!secrets_init()) {
47                 d_fprintf(stderr, _("Could not open secrets.tdb\n"));
48                 return -1;
49         }
50
51         if ((fd = open(argv[0], O_RDONLY, 0)) < 0) {
52                 d_fprintf(stderr, _("Could not open %s\n"), argv[0]);
53                 return -1;
54         }
55
56         if (read(fd, &keyfile, sizeof(keyfile)) != sizeof(keyfile)) {
57                 d_fprintf(stderr, _("Could not read keyfile\n"));
58                 close(fd);
59                 return -1;
60         }
61         close(fd);
62
63         if (!secrets_store_afs_keyfile(argv[1], &keyfile)) {
64                 d_fprintf(stderr, _("Could not write keyfile to secrets.tdb\n"));
65                 return -1;
66         }
67
68         return 0;
69 }
70
71 int net_afs_impersonate(struct net_context *c, int argc,
72                                const char **argv)
73 {
74         char *token;
75
76         if (argc != 2) {
77                 d_fprintf(stderr, "%s net afs impersonate <user> <cell>\n",
78                           _("Usage:"));
79                 exit(1);
80         }
81
82         token = afs_createtoken_str(argv[0], argv[1]);
83
84         if (token == NULL) {
85                 fprintf(stderr, _("Could not create token\n"));
86                 exit(1);
87         }
88
89         if (!afs_settoken_str(token)) {
90                 fprintf(stderr, _("Could not set token into kernel\n"));
91                 exit(1);
92         }
93
94         printf(_("Success: %s@%s\n"), argv[0], argv[1]);
95         return 0;
96 }
97
98 int net_afs(struct net_context *c, int argc, const char **argv)
99 {
100         struct functable func[] = {
101                 {
102                         "key",
103                         net_afs_key,
104                         NET_TRANSPORT_LOCAL,
105                         N_("Import an OpenAFS keyfile"),
106                         N_("net afs key <filename>\n"
107                            "    Import kefile from <filename>.")
108                 },
109                 {
110                         "impersonate",
111                         net_afs_impersonate,
112                         NET_TRANSPORT_LOCAL,
113                         N_("Get a user token"),
114                         N_("net afs impersonate <user> <cell>\n"
115                            "    Create token for user@cell")
116                 },
117                 {NULL, NULL, 0, NULL, NULL}
118         };
119         return net_run_function(c, argc, argv, "net afs", func);
120 }
121