Annotation of 43BSDReno/kerberosIV/kstash/kstash.c, revision 1.1

1.1     ! root        1: /*
        !             2:  * $Source: /usr/src/kerberosIV/kstash/RCS/kstash.c,v $
        !             3:  * $Author: kfall $
        !             4:  *
        !             5:  * Copyright 1985, 1986, 1987, 1988 by the Massachusetts Institute
        !             6:  * of Technology 
        !             7:  *
        !             8:  * For copying and distribution information, please see the file
        !             9:  * <mit-copyright.h>.
        !            10:  *
        !            11:  * Description.
        !            12:  */
        !            13: 
        !            14: #ifndef        lint
        !            15: static char rcsid_kstash_c[] =
        !            16: "$Header: /usr/src/kerberosIV/kstash/RCS/kstash.c,v 4.1 90/06/25 21:33:13 kfall Exp $";
        !            17: #endif lint
        !            18: 
        !            19: #include <mit-copyright.h>
        !            20: 
        !            21: #include <stdio.h>
        !            22: #include <sys/types.h>
        !            23: #include <sys/socket.h>
        !            24: #include <netinet/in.h>
        !            25: #include <netdb.h>
        !            26: #include <signal.h>
        !            27: #include <sgtty.h>
        !            28: #include <sys/ioctl.h>
        !            29: #include <sys/time.h>
        !            30: #include <sys/file.h>
        !            31: 
        !            32: #include <des.h>
        !            33: #include <krb.h>
        !            34: #include <klog.h>
        !            35: #include <prot.h>
        !            36: #include <krb_db.h>
        !            37: #include <kdc.h>
        !            38: 
        !            39: extern int errno;
        !            40: 
        !            41: /* change this later, but krblib_dbm needs it for now */
        !            42: char   *progname;
        !            43: 
        !            44: static C_Block master_key;
        !            45: static Key_schedule master_key_schedule;
        !            46: static Principal s_name_data;  /* for services requested */
        !            47: static unsigned char master_key_version;
        !            48: int     debug;
        !            49: static int more;
        !            50: static int kfile;
        !            51: static void clear_secrets();
        !            52: 
        !            53: main(argc, argv)
        !            54:     int     argc;
        !            55:     char  **argv;
        !            56: {
        !            57:     long    n;
        !            58:     if (n = kerb_init()) {
        !            59:        fprintf(stderr, "Kerberos db and cache init failed = %d\n", n);
        !            60:        exit(1);
        !            61:     }
        !            62: 
        !            63:     if (kdb_get_master_key (TRUE, master_key, master_key_schedule) != 0) {
        !            64:       fprintf (stderr, "%s: Couldn't read master key.\n", argv[0]);
        !            65:       fflush (stderr);
        !            66:       clear_secrets();
        !            67:       exit (-1);
        !            68:     }
        !            69: 
        !            70:     if (kdb_verify_master_key (master_key, master_key_schedule, stderr) < 0) {
        !            71:       clear_secrets();
        !            72:       exit (-1);
        !            73:     }
        !            74: 
        !            75:     kfile = open(MKEYFILE, O_TRUNC | O_RDWR | O_CREAT, 0600);
        !            76:     if (kfile < 0) {
        !            77:        clear_secrets();
        !            78:        fprintf(stderr, "\n\07\07%s: Unable to open master key file\n",
        !            79:                argv[0]);
        !            80:        exit(1);
        !            81:     }
        !            82:     if (write(kfile, (char *) master_key, 8) < 0) {
        !            83:        clear_secrets();
        !            84:        fprintf(stderr, "\n%s: Write I/O error on master key file\n",
        !            85:                argv[0]);
        !            86:        exit(1);
        !            87:     }
        !            88:     (void) close(kfile);
        !            89:     clear_secrets();
        !            90: }
        !            91: 
        !            92: static void 
        !            93: clear_secrets()
        !            94: {
        !            95:     bzero(master_key_schedule, sizeof(master_key_schedule));
        !            96:     bzero(master_key, sizeof(master_key));
        !            97: }

unix.superglobalmegacorp.com

This archive runs on limited infrastructure. Preserving old code on modern bandwidth. Automated agents are requested to crawl responsibly.