summaryrefslogtreecommitdiff
path: root/usr/src/cmd/cmd-crypto/kmfcfg/export.c
diff options
context:
space:
mode:
Diffstat (limited to 'usr/src/cmd/cmd-crypto/kmfcfg/export.c')
-rw-r--r--usr/src/cmd/cmd-crypto/kmfcfg/export.c167
1 files changed, 167 insertions, 0 deletions
diff --git a/usr/src/cmd/cmd-crypto/kmfcfg/export.c b/usr/src/cmd/cmd-crypto/kmfcfg/export.c
new file mode 100644
index 0000000000..c1ddab153c
--- /dev/null
+++ b/usr/src/cmd/cmd-crypto/kmfcfg/export.c
@@ -0,0 +1,167 @@
+/*
+ * CDDL HEADER START
+ *
+ * The contents of this file are subject to the terms of the
+ * Common Development and Distribution License (the "License").
+ * You may not use this file except in compliance with the License.
+ *
+ * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
+ * or http://www.opensolaris.org/os/licensing.
+ * See the License for the specific language governing permissions
+ * and limitations under the License.
+ *
+ * When distributing Covered Code, include this CDDL HEADER in each
+ * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
+ * If applicable, add the following below this CDDL HEADER, with the
+ * fields enclosed by brackets "[]" replaced with your own identifying
+ * information: Portions Copyright [yyyy] [name of copyright owner]
+ *
+ * CDDL HEADER END
+ *
+ *
+ * Copyright 2006 Sun Microsystems, Inc. All rights reserved.
+ * Use is subject to license terms.
+ */
+
+#pragma ident "%Z%%M% %I% %E% SMI"
+
+#include <stdio.h>
+#include <strings.h>
+#include <ctype.h>
+#include <libgen.h>
+#include <libintl.h>
+#include <locale.h>
+#include <errno.h>
+#include <kmfapiP.h>
+
+#include "util.h"
+
+int
+kc_export(int argc, char *argv[])
+{
+ int rv = KC_OK;
+ char *filename = NULL;
+ char *outfile = NULL;
+ char *policyname = NULL;
+ POLICY_LIST *plclist = NULL, *pnode;
+ int opt, found = 0;
+ extern int optind_av;
+ extern char *optarg_av;
+
+ while ((opt = getopt_av(argc, argv,
+ "d:(dbfile)p:(policy)o:(outfile)")) != EOF) {
+ switch (opt) {
+ case 'd':
+ filename = get_string(optarg_av, &rv);
+ if (filename == NULL) {
+ (void) fprintf(stderr,
+ gettext("Error dbfile input.\n"));
+ }
+ break;
+ case 'p':
+ policyname = get_string(optarg_av, &rv);
+ if (policyname == NULL) {
+ (void) fprintf(stderr,
+ gettext("Error policy name.\n"));
+ }
+ break;
+ case 'o':
+ outfile = get_string(optarg_av, &rv);
+ if (outfile == NULL) {
+ (void) fprintf(stderr,
+ gettext("Error outfile input.\n"));
+ }
+ break;
+ default:
+ (void) fprintf(stderr,
+ gettext("Error input option.\n"));
+ rv = KC_ERR_USAGE;
+ break;
+ }
+
+ if (rv != KC_OK)
+ goto out;
+ }
+
+ /* No additional args allowed. */
+ argc -= optind_av;
+ if (argc) {
+ (void) fprintf(stderr,
+ gettext("Error input option\n"));
+ rv = KC_ERR_USAGE;
+ goto out;
+ }
+
+ if (filename == NULL) {
+ filename = strdup(KMF_DEFAULT_POLICY_FILE);
+ if (filename == NULL) {
+ rv = KC_ERR_MEMORY;
+ goto out;
+ }
+ }
+
+ if (policyname == NULL) {
+ (void) fprintf(stderr,
+ gettext("You must specify a policy name\n"));
+ rv = KC_ERR_USAGE;
+ goto out;
+ }
+
+ if (outfile == NULL) {
+ (void) fprintf(stderr,
+ gettext("You must specify a output DB file\n"));
+ rv = KC_ERR_USAGE;
+ goto out;
+ }
+
+ if (strcmp(outfile, KMF_DEFAULT_POLICY_FILE) == 0 &&
+ strcmp(policyname, KMF_DEFAULT_POLICY_NAME) == 0) {
+ (void) fprintf(stderr,
+ gettext("Can not export the default policy record to "
+ "the system default policy database\n"));
+ rv = KC_ERR_USAGE;
+ goto out;
+ }
+
+ rv = load_policies(filename, &plclist);
+ if (rv != KMF_OK)
+ goto out;
+
+ pnode = plclist;
+ while (pnode != NULL && !found) {
+ if (strcmp(policyname, pnode->plc.name) == 0) {
+ KMF_RETURN ret;
+
+ found++;
+ ret = KMF_VerifyPolicy(&pnode->plc);
+ if (ret != KMF_OK) {
+ print_sanity_error(ret);
+ rv = KC_ERR_VERIFY_POLICY;
+ break;
+ }
+ rv = KMF_AddPolicyToDB(&pnode->plc, outfile, B_FALSE);
+ }
+ pnode = pnode->next;
+ }
+
+ if (!found) {
+ (void) fprintf(stderr,
+ gettext("Could not find policy \"%s\" in %s\n"),
+ policyname, filename);
+ rv = KC_ERR_FIND_POLICY;
+ }
+
+out:
+ if (filename != NULL)
+ free(filename);
+
+ if (policyname != NULL)
+ free(policyname);
+
+ if (outfile != NULL)
+ free(outfile);
+
+ free_policy_list(plclist);
+
+ return (rv);
+}