2 * Copyright 2000, International Business Machines Corporation and others.
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
10 #include <afsconfig.h>
11 #include <afs/param.h>
16 #include <sys/types.h>
17 #include <netinet/in.h>
24 #include <afs/cellconfig.h>
25 #include <afs/afsutil.h>
32 #include "AFS_component_version_number.c"
35 main(int argc, char **argv)
37 struct ktc_token token;
38 struct ktc_principal sname;
39 register afs_int32 code;
40 struct afsconf_dir *dir;
43 char cellName[MAXKTCNAMELEN];
48 * The following signal action for AIX is necessary so that in case of a
49 * crash (i.e. core is generated) we can include the user's data section
50 * in the core dump. Unfortunately, by default, only a partial core is
51 * generated which, in many cases, isn't too useful.
55 sigemptyset(&nsa.sa_mask);
56 nsa.sa_handler = SIG_DFL;
57 nsa.sa_flags = SA_FULLDUMP;
58 sigaction(SIGSEGV, &nsa, NULL);
61 printf("kseal: usage is 'kseal <username> <server key>\n");
65 /* lookup configuration info */
66 dir = afsconf_Open(AFSDIR_CLIENT_ETC_DIRPATH);
68 printf("kseal: can't open config dir (%s)\n",
69 AFSDIR_CLIENT_ETC_DIRPATH);
72 code = afsconf_GetLocalCell(dir, cellName, sizeof(cellName));
74 printf("kseal: failed to get local cell name, code %d\n", code);
78 /* setup key for sealing */
79 string_to_key(argv[2], skey);
82 memcpy(session, &now, 4); /* but this is only a test pgm */
83 memcpy(session + 4, &now, 4);
85 tkt_MakeTicket(token.ticket, &token.ticketLen, skey, argv[1], "",
86 cellName, now - 300, now + 25 * 3600, session,
87 /* host */ 0, "afs", "");
89 printf("kseal: could not seal ticket, code %d!\n", code);
93 /* now send the ticket to the ticket cache */
94 strcpy(sname.name, "afs");
95 strcpy(sname.instance, "");
96 strcpy(sname.cell, cellName);
98 token.endTime = 0x7fffffff;
99 memcpy(&token.sessionKey, session, 8);
101 code = ktc_SetToken(&sname, &token, NULL, 0);
103 printf("kseal: could not install newly-sealed ticket, code %d\n",