7711facfe58561dd91d6ece0f5f41150c3956c83dinak/*
7711facfe58561dd91d6ece0f5f41150c3956c83dinak * CDDL HEADER START
7711facfe58561dd91d6ece0f5f41150c3956c83dinak *
7711facfe58561dd91d6ece0f5f41150c3956c83dinak * The contents of this file are subject to the terms of the
99ebb4ca412cb0a19d77a3899a87c055b9c30fa8wyllys * Common Development and Distribution License (the "License").
99ebb4ca412cb0a19d77a3899a87c055b9c30fa8wyllys * You may not use this file except in compliance with the License.
7711facfe58561dd91d6ece0f5f41150c3956c83dinak *
7711facfe58561dd91d6ece0f5f41150c3956c83dinak * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
7711facfe58561dd91d6ece0f5f41150c3956c83dinak * or http://www.opensolaris.org/os/licensing.
7711facfe58561dd91d6ece0f5f41150c3956c83dinak * See the License for the specific language governing permissions
7711facfe58561dd91d6ece0f5f41150c3956c83dinak * and limitations under the License.
7711facfe58561dd91d6ece0f5f41150c3956c83dinak *
7711facfe58561dd91d6ece0f5f41150c3956c83dinak * When distributing Covered Code, include this CDDL HEADER in each
7711facfe58561dd91d6ece0f5f41150c3956c83dinak * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
7711facfe58561dd91d6ece0f5f41150c3956c83dinak * If applicable, add the following below this CDDL HEADER, with the
7711facfe58561dd91d6ece0f5f41150c3956c83dinak * fields enclosed by brackets "[]" replaced with your own identifying
7711facfe58561dd91d6ece0f5f41150c3956c83dinak * information: Portions Copyright [yyyy] [name of copyright owner]
7711facfe58561dd91d6ece0f5f41150c3956c83dinak *
7711facfe58561dd91d6ece0f5f41150c3956c83dinak * CDDL HEADER END
7711facfe58561dd91d6ece0f5f41150c3956c83dinak */
7711facfe58561dd91d6ece0f5f41150c3956c83dinak/*
99ebb4ca412cb0a19d77a3899a87c055b9c30fa8wyllys * Copyright 2006 Sun Microsystems, Inc. All rights reserved.
7711facfe58561dd91d6ece0f5f41150c3956c83dinak * Use is subject to license terms.
7711facfe58561dd91d6ece0f5f41150c3956c83dinak */
7711facfe58561dd91d6ece0f5f41150c3956c83dinak
7711facfe58561dd91d6ece0f5f41150c3956c83dinak#pragma ident "%Z%%M% %I% %E% SMI"
7711facfe58561dd91d6ece0f5f41150c3956c83dinak
7711facfe58561dd91d6ece0f5f41150c3956c83dinak/*
7711facfe58561dd91d6ece0f5f41150c3956c83dinak * This file implements the token list operation for this tool.
7711facfe58561dd91d6ece0f5f41150c3956c83dinak * It loads the PKCS#11 modules, gets the list of slots with
7711facfe58561dd91d6ece0f5f41150c3956c83dinak * tokens in them, displays the list, and cleans up.
7711facfe58561dd91d6ece0f5f41150c3956c83dinak */
7711facfe58561dd91d6ece0f5f41150c3956c83dinak
7711facfe58561dd91d6ece0f5f41150c3956c83dinak#include <stdio.h>
7711facfe58561dd91d6ece0f5f41150c3956c83dinak#include <string.h>
7711facfe58561dd91d6ece0f5f41150c3956c83dinak#include <cryptoutil.h>
7711facfe58561dd91d6ece0f5f41150c3956c83dinak#include <security/cryptoki.h>
7711facfe58561dd91d6ece0f5f41150c3956c83dinak#include "common.h"
7711facfe58561dd91d6ece0f5f41150c3956c83dinak
7711facfe58561dd91d6ece0f5f41150c3956c83dinak/*
7711facfe58561dd91d6ece0f5f41150c3956c83dinak * Lists all slots with tokens in them.
7711facfe58561dd91d6ece0f5f41150c3956c83dinak */
7711facfe58561dd91d6ece0f5f41150c3956c83dinakint
7711facfe58561dd91d6ece0f5f41150c3956c83dinakpk_tokens(int argc, char *argv[])
7711facfe58561dd91d6ece0f5f41150c3956c83dinak{
7711facfe58561dd91d6ece0f5f41150c3956c83dinak CK_SLOT_ID_PTR slots = NULL;
7711facfe58561dd91d6ece0f5f41150c3956c83dinak CK_ULONG slot_count = 0;
7711facfe58561dd91d6ece0f5f41150c3956c83dinak CK_TOKEN_INFO token_info;
7711facfe58561dd91d6ece0f5f41150c3956c83dinak const char *fmt = NULL;
7711facfe58561dd91d6ece0f5f41150c3956c83dinak CK_RV rv = CKR_OK;
7711facfe58561dd91d6ece0f5f41150c3956c83dinak int i;
7711facfe58561dd91d6ece0f5f41150c3956c83dinak
7711facfe58561dd91d6ece0f5f41150c3956c83dinak
7711facfe58561dd91d6ece0f5f41150c3956c83dinak /* Get rid of subcommand word "tokens". */
7711facfe58561dd91d6ece0f5f41150c3956c83dinak argc--;
7711facfe58561dd91d6ece0f5f41150c3956c83dinak argv++;
7711facfe58561dd91d6ece0f5f41150c3956c83dinak
7711facfe58561dd91d6ece0f5f41150c3956c83dinak /* No additional args allowed. */
7711facfe58561dd91d6ece0f5f41150c3956c83dinak if (argc != 0)
7711facfe58561dd91d6ece0f5f41150c3956c83dinak return (PK_ERR_USAGE);
7711facfe58561dd91d6ece0f5f41150c3956c83dinak /* Done parsing command line options. */
7711facfe58561dd91d6ece0f5f41150c3956c83dinak
7711facfe58561dd91d6ece0f5f41150c3956c83dinak /* Get the list of slots with tokens in them. */
7711facfe58561dd91d6ece0f5f41150c3956c83dinak if ((rv = get_token_slots(&slots, &slot_count)) != CKR_OK) {
7711facfe58561dd91d6ece0f5f41150c3956c83dinak cryptoerror(LOG_STDERR,
7711facfe58561dd91d6ece0f5f41150c3956c83dinak gettext("Unable to get token slot list (%s)."),
7711facfe58561dd91d6ece0f5f41150c3956c83dinak pkcs11_strerror(rv));
7711facfe58561dd91d6ece0f5f41150c3956c83dinak return (PK_ERR_PK11);
7711facfe58561dd91d6ece0f5f41150c3956c83dinak }
7711facfe58561dd91d6ece0f5f41150c3956c83dinak
7711facfe58561dd91d6ece0f5f41150c3956c83dinak /* Make sure we have something to display. */
7711facfe58561dd91d6ece0f5f41150c3956c83dinak if (slot_count == 0) {
7711facfe58561dd91d6ece0f5f41150c3956c83dinak cryptoerror(LOG_STDERR, gettext("No slots with tokens found."));
7711facfe58561dd91d6ece0f5f41150c3956c83dinak return (0);
7711facfe58561dd91d6ece0f5f41150c3956c83dinak }
7711facfe58561dd91d6ece0f5f41150c3956c83dinak
7711facfe58561dd91d6ece0f5f41150c3956c83dinak /* Display the list. */
7711facfe58561dd91d6ece0f5f41150c3956c83dinak fmt = "%-30.30s %-15.15s %-15.15s %-10.10s\n"; /* No I18N/L10N. */
7711facfe58561dd91d6ece0f5f41150c3956c83dinak (void) fprintf(stdout, fmt, gettext("Token Label"), gettext("Manuf ID"),
7711facfe58561dd91d6ece0f5f41150c3956c83dinak gettext("Serial No"), gettext("PIN State"));
7711facfe58561dd91d6ece0f5f41150c3956c83dinak for (i = 0; i < slot_count; i++) {
7711facfe58561dd91d6ece0f5f41150c3956c83dinak if ((rv = C_GetTokenInfo(slots[i], &token_info)) != CKR_OK) {
7711facfe58561dd91d6ece0f5f41150c3956c83dinak cryptoerror(LOG_STDERR,
7711facfe58561dd91d6ece0f5f41150c3956c83dinak gettext("Unable to get slot %d token info (%s)."),
7711facfe58561dd91d6ece0f5f41150c3956c83dinak i, pkcs11_strerror(rv));
7711facfe58561dd91d6ece0f5f41150c3956c83dinak continue;
7711facfe58561dd91d6ece0f5f41150c3956c83dinak }
7711facfe58561dd91d6ece0f5f41150c3956c83dinak
7711facfe58561dd91d6ece0f5f41150c3956c83dinak (void) fprintf(stdout, fmt, token_info.label,
7711facfe58561dd91d6ece0f5f41150c3956c83dinak token_info.manufacturerID, token_info.serialNumber,
7711facfe58561dd91d6ece0f5f41150c3956c83dinak (token_info.flags & CKF_USER_PIN_TO_BE_CHANGED) ?
7711facfe58561dd91d6ece0f5f41150c3956c83dinak gettext("default") : gettext("user set"));
7711facfe58561dd91d6ece0f5f41150c3956c83dinak }
7711facfe58561dd91d6ece0f5f41150c3956c83dinak
7711facfe58561dd91d6ece0f5f41150c3956c83dinak /* Clean up. */
7711facfe58561dd91d6ece0f5f41150c3956c83dinak free(slots);
99ebb4ca412cb0a19d77a3899a87c055b9c30fa8wyllys (void) C_Finalize(NULL);
7711facfe58561dd91d6ece0f5f41150c3956c83dinak return (0);
7711facfe58561dd91d6ece0f5f41150c3956c83dinak}