dnssec-importkey.c revision 6b0434299b05b6ca05c6836b9e8fbb7e67f05fb8
63737247d167ffa7151bc3d228ca5c0875751818Tinderbox User * Copyright (C) 2013 Internet Systems Consortium, Inc. ("ISC")
0c91911b4d1e872b87eaf6431ed47fe24d18dd43Mark Andrews * Permission to use, copy, modify, and/or distribute this software for any
0c91911b4d1e872b87eaf6431ed47fe24d18dd43Mark Andrews * purpose with or without fee is hereby granted, provided that the above
0c91911b4d1e872b87eaf6431ed47fe24d18dd43Mark Andrews * copyright notice and this permission notice appear in all copies.
0c91911b4d1e872b87eaf6431ed47fe24d18dd43Mark Andrews * THE SOFTWARE IS PROVIDED "AS IS" AND ISC DISCLAIMS ALL WARRANTIES WITH
0c91911b4d1e872b87eaf6431ed47fe24d18dd43Mark Andrews * REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY
0c91911b4d1e872b87eaf6431ed47fe24d18dd43Mark Andrews * AND FITNESS. IN NO EVENT SHALL ISC BE LIABLE FOR ANY SPECIAL, DIRECT,
0c91911b4d1e872b87eaf6431ed47fe24d18dd43Mark Andrews * INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM
0c91911b4d1e872b87eaf6431ed47fe24d18dd43Mark Andrews * LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE
0c91911b4d1e872b87eaf6431ed47fe24d18dd43Mark Andrews * OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
0c91911b4d1e872b87eaf6431ed47fe24d18dd43Mark Andrews * PERFORMANCE OF THIS SOFTWARE.
0c91911b4d1e872b87eaf6431ed47fe24d18dd43Mark Andrews#define PATH_MAX 1024 /* AIX, WIN32, and others don't define this. */
0c91911b4d1e872b87eaf6431ed47fe24d18dd43Mark Andrewsstatic isc_boolean_t setpub = ISC_FALSE, setdel = ISC_FALSE;
0c91911b4d1e872b87eaf6431ed47fe24d18dd43Mark Andrews isc_buffer_init(&buf, setname, strlen(setname));
0c91911b4d1e872b87eaf6431ed47fe24d18dd43Mark Andrews result = dns_name_fromtext(name, &buf, dns_rootname, 0, NULL);
0c91911b4d1e872b87eaf6431ed47fe24d18dd43Mark Andrews fatal("dns_db_beginload failed: %s", isc_result_totext(result));
0c91911b4d1e872b87eaf6431ed47fe24d18dd43Mark Andrews result = dns_master_loadstream(fp, name, name, rdclass, 0,
0c91911b4d1e872b87eaf6431ed47fe24d18dd43Mark Andrews fatal("can't load from input: %s", isc_result_totext(result));
0c91911b4d1e872b87eaf6431ed47fe24d18dd43Mark Andrews fatal("dns_db_endload failed: %s", isc_result_totext(result));
0c91911b4d1e872b87eaf6431ed47fe24d18dd43Mark Andrewsloadset(const char *filename, dns_rdataset_t *rdataset) {
0c91911b4d1e872b87eaf6431ed47fe24d18dd43Mark Andrews dns_name_format(name, setname, sizeof(setname));
0c91911b4d1e872b87eaf6431ed47fe24d18dd43Mark Andrews result = dns_db_create(mctx, "rbt", name, dns_dbtype_zone,
0c91911b4d1e872b87eaf6431ed47fe24d18dd43Mark Andrews result = dns_db_load3(db, filename, dns_masterformat_text,
0c91911b4d1e872b87eaf6431ed47fe24d18dd43Mark Andrews if (result != ISC_R_SUCCESS && result != DNS_R_SEENINCLUDE)
0c91911b4d1e872b87eaf6431ed47fe24d18dd43Mark Andrews result = dns_db_findnode(db, name, ISC_FALSE, &node);
0c91911b4d1e872b87eaf6431ed47fe24d18dd43Mark Andrews fatal("can't find %s node in %s", setname, filename);
0c91911b4d1e872b87eaf6431ed47fe24d18dd43Mark Andrews result = dns_db_findrdataset(db, node, NULL, dns_rdatatype_dnskey,
0c91911b4d1e872b87eaf6431ed47fe24d18dd43Mark Andrews fatal("no DNSKEY RR for %s in %s", setname, filename);
0c91911b4d1e872b87eaf6431ed47fe24d18dd43Mark Andrewsloadkey(char *filename, unsigned char *key_buf, unsigned int key_buf_size,
0c91911b4d1e872b87eaf6431ed47fe24d18dd43Mark Andrews result = dst_key_fromnamedfile(filename, NULL, DST_TYPE_PUBLIC,
0c91911b4d1e872b87eaf6431ed47fe24d18dd43Mark Andrews dns_rdata_fromregion(rdata, dst_key_class(key),
0c91911b4d1e872b87eaf6431ed47fe24d18dd43Mark Andrews result = dns_name_copy(dst_key_name(key), name, NULL);
0c91911b4d1e872b87eaf6431ed47fe24d18dd43Mark Andrews isc_buffer_init(&buf, rdata->data, rdata->length);
0c91911b4d1e872b87eaf6431ed47fe24d18dd43Mark Andrews result = dst_key_fromdns(name, rdclass, &buf, mctx, &key);
0c91911b4d1e872b87eaf6431ed47fe24d18dd43Mark Andrews fatal("dst_key_fromdns: %s", isc_result_totext(result));
6b0434299b05b6ca05c6836b9e8fbb7e67f05fb8Mark Andrews isc_buffer_init(&buf, pubname, sizeof(pubname));
0c91911b4d1e872b87eaf6431ed47fe24d18dd43Mark Andrews result = dst_key_buildfilename(key, DST_TYPE_PUBLIC, dir, &buf);
0c91911b4d1e872b87eaf6431ed47fe24d18dd43Mark Andrews fatal("Failed to build public key filename: %s",
6b0434299b05b6ca05c6836b9e8fbb7e67f05fb8Mark Andrews isc_buffer_init(&buf, priname, sizeof(priname));
6b0434299b05b6ca05c6836b9e8fbb7e67f05fb8Mark Andrews result = dst_key_buildfilename(key, DST_TYPE_PRIVATE, dir, &buf);
6b0434299b05b6ca05c6836b9e8fbb7e67f05fb8Mark Andrews fatal("Failed to build private key filename: %s",
6b0434299b05b6ca05c6836b9e8fbb7e67f05fb8Mark Andrews result = dst_key_fromfile(dst_key_name(key), dst_key_id(key),
6b0434299b05b6ca05c6836b9e8fbb7e67f05fb8Mark Andrews if (dst_key_isprivate(tmp) && !dst_key_isexternal(tmp))
6b0434299b05b6ca05c6836b9e8fbb7e67f05fb8Mark Andrews fatal("Private key already exists in %s", priname);
0c91911b4d1e872b87eaf6431ed47fe24d18dd43Mark Andrews result = dst_key_tofile(key, DST_TYPE_PUBLIC|DST_TYPE_PRIVATE,
0c91911b4d1e872b87eaf6431ed47fe24d18dd43Mark Andrews result = dst_key_buildfilename(key, DST_TYPE_PRIVATE, dir, &buf);
0c91911b4d1e872b87eaf6431ed47fe24d18dd43Mark Andrews fatal("Failed to build private key filename: %s",
6b0434299b05b6ca05c6836b9e8fbb7e67f05fb8Mark Andrews fprintf(stderr, " %s options [-K dir] keyfile\n\n", program);
6b0434299b05b6ca05c6836b9e8fbb7e67f05fb8Mark Andrews fprintf(stderr, " %s options -f file [keyname]\n\n", program);
6b0434299b05b6ca05c6836b9e8fbb7e67f05fb8Mark Andrews fprintf(stderr, " -f file: read key from zone file\n");
0c91911b4d1e872b87eaf6431ed47fe24d18dd43Mark Andrews fprintf(stderr, " -K <directory>: directory in which to store "
6b0434299b05b6ca05c6836b9e8fbb7e67f05fb8Mark Andrews "the key files\n");
6b0434299b05b6ca05c6836b9e8fbb7e67f05fb8Mark Andrews fprintf(stderr, " -L ttl: set default key TTL\n");
6b0434299b05b6ca05c6836b9e8fbb7e67f05fb8Mark Andrews fprintf(stderr, " -h: print usage and exit\n");
6b0434299b05b6ca05c6836b9e8fbb7e67f05fb8Mark Andrews fprintf(stderr, " -P date/[+-]offset/none: set/unset key "
6b0434299b05b6ca05c6836b9e8fbb7e67f05fb8Mark Andrews "publication date\n");
6b0434299b05b6ca05c6836b9e8fbb7e67f05fb8Mark Andrews fprintf(stderr, " -D date/[+-]offset/none: set/unset key "
6b0434299b05b6ca05c6836b9e8fbb7e67f05fb8Mark Andrews "deletion date\n");
6b0434299b05b6ca05c6836b9e8fbb7e67f05fb8Mark Andrews while ((ch = isc_commandline_parse(argc, argv, CMDLINE_FLAGS)) != -1) {
0c91911b4d1e872b87eaf6431ed47fe24d18dd43Mark Andrews del = strtotime(isc_commandline_argument, now, now);
6b0434299b05b6ca05c6836b9e8fbb7e67f05fb8Mark Andrews if (strcmp(isc_commandline_argument, "none") == 0)
0c91911b4d1e872b87eaf6431ed47fe24d18dd43Mark Andrews pub = strtotime(isc_commandline_argument, now, now);
0c91911b4d1e872b87eaf6431ed47fe24d18dd43Mark Andrews verbose = strtol(isc_commandline_argument, &endp, 0);
0c91911b4d1e872b87eaf6431ed47fe24d18dd43Mark Andrews /* FALLTHROUGH */
0c91911b4d1e872b87eaf6431ed47fe24d18dd43Mark Andrews if (argc < isc_commandline_index + 1 && filename == NULL)
0c91911b4d1e872b87eaf6431ed47fe24d18dd43Mark Andrews result = isc_hash_create(mctx, ectx, DNS_NAME_MAXWIRE);
6b0434299b05b6ca05c6836b9e8fbb7e67f05fb8Mark Andrews /* using filename as zone name */
0c91911b4d1e872b87eaf6431ed47fe24d18dd43Mark Andrews fatal("could not initialize name %s", namestr);