/* * 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" /* * This file implements the token list operation for this tool. * It loads the PKCS#11 modules, gets the list of slots with * tokens in them, displays the list, and cleans up. */ #include <stdio.h> #include <string.h> #include <cryptoutil.h> #include <security/cryptoki.h> #include "common.h" /* * Lists all slots with tokens in them. */ int pk_tokens(int argc, char *argv[]) { CK_SLOT_ID_PTR slots = NULL; CK_ULONG slot_count = 0; CK_TOKEN_INFO token_info; const char *fmt = NULL; CK_RV rv = CKR_OK; int i; /* Get rid of subcommand word "tokens". */ argc--; argv++; /* No additional args allowed. */ if (argc != 0) return (PK_ERR_USAGE); /* Done parsing command line options. */ /* Get the list of slots with tokens in them. */ if ((rv = get_token_slots(&slots, &slot_count)) != CKR_OK) { cryptoerror(LOG_STDERR, gettext("Unable to get token slot list (%s)."), pkcs11_strerror(rv)); return (PK_ERR_PK11); } /* Make sure we have something to display. */ if (slot_count == 0) { cryptoerror(LOG_STDERR, gettext("No slots with tokens found.")); return (0); } /* Display the list. */ fmt = "%-30.30s %-15.15s %-15.15s %-10.10s\n"; /* No I18N/L10N. */ (void) fprintf(stdout, fmt, gettext("Token Label"), gettext("Manuf ID"), gettext("Serial No"), gettext("PIN State")); for (i = 0; i < slot_count; i++) { if ((rv = C_GetTokenInfo(slots[i], &token_info)) != CKR_OK) { cryptoerror(LOG_STDERR, gettext("Unable to get slot %d token info (%s)."), i, pkcs11_strerror(rv)); continue; } (void) fprintf(stdout, fmt, token_info.label, token_info.manufacturerID, token_info.serialNumber, (token_info.flags & CKF_USER_PIN_TO_BE_CHANGED) ? gettext("default") : gettext("user set")); } /* Clean up. */ free(slots); (void) C_Finalize(NULL); return (0); }