2 * Copyright (C) 2010-2012 Free Software Foundation, Inc.
4 * Author: Nikos Mavrogiannopoulos
6 * This file is part of GnuTLS.
8 * GnuTLS is free software: you can redistribute it and/or modify it
9 * under the terms of the GNU General Public License as published by
10 * the Free Software Foundation, either version 3 of the License, or
11 * (at your option) any later version.
13 * GnuTLS is distributed in the hope that it will be useful, but
14 * WITHOUT ANY WARRANTY; without even the implied warranty of
15 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
16 * General Public License for more details.
18 * You should have received a copy of the GNU General Public License
19 * along with this program. If not, see
20 * <http://www.gnu.org/licenses/>.
25 #include <gnutls/gnutls.h>
26 #include <gnutls/x509.h>
27 #include <gnutls/openpgp.h>
28 #include <gnutls/pkcs12.h>
29 #include <gnutls/pkcs11.h>
30 #include <gnutls/abstract.h>
39 #include <sys/types.h>
44 /* Gnulib portability files. */
45 #include <read-file.h>
47 #include <version-etc.h>
49 #include "p11tool-args.h"
51 #include "certtool-common.h"
53 static void cmd_parser (int argc
, char **argv
);
59 tls_log_func (int level
, const char *str
)
61 fprintf (stderr
, "|<%d>| %s", level
, str
);
66 main (int argc
, char **argv
)
68 set_program_name (argv
[0]);
69 cmd_parser (argc
, argv
);
75 cmd_parser (int argc
, char **argv
)
79 unsigned int pkcs11_type
= -1, key_type
= GNUTLS_PK_UNKNOWN
;
80 const char* url
= NULL
;
81 unsigned int detailed_url
= 0, optct
;
82 unsigned int login
= 0, bits
= 0;
83 const char* label
= NULL
, *sec_param
= NULL
;
85 optct
= optionProcess( &p11toolOptions
, argc
, argv
);
89 if (url
== NULL
&& argc
> 0)
95 debug
= OPT_VALUE_DEBUG
;
97 gnutls_global_set_log_function (tls_log_func
);
98 gnutls_global_set_log_level (debug
);
100 printf ("Setting log level to %d\n", debug
);
102 if ((ret
= gnutls_global_init ()) < 0)
103 error (EXIT_FAILURE
, 0, "global_init: %s", gnutls_strerror (ret
));
105 if (HAVE_OPT(PROVIDER
))
107 ret
= gnutls_pkcs11_init (GNUTLS_PKCS11_FLAG_MANUAL
, NULL
);
109 fprintf (stderr
, "pkcs11_init: %s", gnutls_strerror (ret
));
112 ret
= gnutls_pkcs11_add_provider (OPT_ARG(PROVIDER
), NULL
);
114 error (EXIT_FAILURE
, 0, "pkcs11_add_provider: %s",
115 gnutls_strerror (ret
));
120 ret
= gnutls_pkcs11_init (GNUTLS_PKCS11_FLAG_AUTO
, NULL
);
122 fprintf (stderr
, "pkcs11_init: %s", gnutls_strerror (ret
));
125 if (HAVE_OPT(OUTFILE
))
127 outfile
= safe_open_rw (OPT_ARG(OUTFILE
), 0);
129 error (EXIT_FAILURE
, errno
, "%s", OPT_ARG(OUTFILE
));
134 memset (&cinfo
, 0, sizeof (cinfo
));
136 if (HAVE_OPT(SECRET_KEY
))
137 cinfo
.secret_key
= OPT_ARG(SECRET_KEY
);
139 if (HAVE_OPT(LOAD_PRIVKEY
))
140 cinfo
.privkey
= OPT_ARG(LOAD_PRIVKEY
);
145 if (ENABLED_OPT(INDER
) || ENABLED_OPT(INRAW
))
146 cinfo
.incert_format
= GNUTLS_X509_FMT_DER
;
148 cinfo
.incert_format
= GNUTLS_X509_FMT_PEM
;
150 if (HAVE_OPT(LOAD_CERTIFICATE
))
151 cinfo
.cert
= OPT_ARG(LOAD_CERTIFICATE
);
153 if (HAVE_OPT(LOAD_PUBKEY
))
154 cinfo
.pubkey
= OPT_ARG(LOAD_PUBKEY
);
156 if (ENABLED_OPT(DETAILED_URL
))
159 if (ENABLED_OPT(LOGIN
))
164 label
= OPT_ARG(LABEL
);
169 bits
= OPT_VALUE_BITS
;
172 if (HAVE_OPT(SEC_PARAM
))
174 sec_param
= OPT_ARG(SEC_PARAM
);
179 if (HAVE_OPT(PRIVATE
)) fprintf(stderr
, "Private: %s\n", ENABLED_OPT(PRIVATE
)?"yes":"no");
180 fprintf(stderr
, "Trusted: %s\n", ENABLED_OPT(TRUSTED
)?"yes":"no");
181 fprintf(stderr
, "Login: %s\n", ENABLED_OPT(LOGIN
)?"yes":"no");
182 fprintf(stderr
, "Detailed URLs: %s\n", ENABLED_OPT(DETAILED_URL
)?"yes":"no");
183 fprintf(stderr
, "\n");
188 if (HAVE_OPT(LIST_TOKENS
))
189 pkcs11_token_list (outfile
, detailed_url
, &cinfo
);
190 else if (HAVE_OPT(LIST_MECHANISMS
))
191 pkcs11_mechanism_list (outfile
, url
, login
,
193 else if (HAVE_OPT(LIST_ALL
))
195 pkcs11_type
= PKCS11_TYPE_ALL
;
196 pkcs11_list (outfile
, url
, pkcs11_type
,
197 login
, detailed_url
, &cinfo
);
199 else if (HAVE_OPT(LIST_ALL_CERTS
))
201 pkcs11_type
= PKCS11_TYPE_CRT_ALL
;
202 pkcs11_list (outfile
, url
, pkcs11_type
,
203 login
, detailed_url
, &cinfo
);
205 else if (HAVE_OPT(LIST_CERTS
))
207 pkcs11_type
= PKCS11_TYPE_PK
;
208 pkcs11_list (outfile
, url
, pkcs11_type
,
209 login
, detailed_url
, &cinfo
);
211 else if (HAVE_OPT(LIST_ALL_PRIVKEYS
))
213 pkcs11_type
= PKCS11_TYPE_PRIVKEY
;
214 pkcs11_list (outfile
, url
, pkcs11_type
,
215 login
, detailed_url
, &cinfo
);
217 else if (HAVE_OPT(LIST_ALL_TRUSTED
))
219 pkcs11_type
= PKCS11_TYPE_TRUSTED
;
220 pkcs11_list (outfile
, url
, pkcs11_type
,
221 login
, detailed_url
, &cinfo
);
223 else if (HAVE_OPT(EXPORT
))
225 pkcs11_export (outfile
, url
, login
, &cinfo
);
227 else if (HAVE_OPT(WRITE
))
231 if (HAVE_OPT(PRIVATE
))
232 priv
= ENABLED_OPT(PRIVATE
);
234 pkcs11_write (outfile
, url
, label
,
235 ENABLED_OPT(TRUSTED
), priv
, login
, &cinfo
);
237 else if (HAVE_OPT(INITIALIZE
))
238 pkcs11_init (outfile
, url
, label
, &cinfo
);
239 else if (HAVE_OPT(DELETE
))
240 pkcs11_delete (outfile
, url
, 0, login
, &cinfo
);
241 else if (HAVE_OPT(GENERATE_ECC
))
243 key_type
= GNUTLS_PK_EC
;
244 pkcs11_generate (outfile
, url
, key_type
, get_bits(key_type
, bits
, sec_param
, 0),
245 label
, ENABLED_OPT(PRIVATE
), detailed_url
, login
,
248 else if (HAVE_OPT(GENERATE_RSA
))
250 key_type
= GNUTLS_PK_RSA
;
251 pkcs11_generate (outfile
, url
, key_type
, get_bits(key_type
, bits
, sec_param
, 0),
252 label
, ENABLED_OPT(PRIVATE
), detailed_url
, login
,
255 else if (HAVE_OPT(GENERATE_DSA
))
257 key_type
= GNUTLS_PK_DSA
;
258 pkcs11_generate (outfile
, url
, key_type
, get_bits(key_type
, bits
, sec_param
, 0),
259 label
, ENABLED_OPT(PRIVATE
), detailed_url
, login
,
270 gnutls_pkcs11_deinit ();
272 gnutls_global_deinit ();