/* This example code is placed in the public domain. */ #include #include #include #include #include #define URL "pkcs11:URL" int main (int argc, char** argv) { gnutls_pkcs11_obj_t *obj_list; gnutls_x509_crt_t xcrt; unsigned int obj_list_size = 0; gnutls_datum_t cinfo; int ret; unsigned int i; obj_list_size = 0; ret = gnutls_pkcs11_obj_list_import_url (NULL, &obj_list_size, URL, GNUTLS_PKCS11_OBJ_ATTR_CRT_WITH_PRIVKEY, 0); if (ret < 0 && ret != GNUTLS_E_SHORT_MEMORY_BUFFER) return -1; /* no error checking from now on */ obj_list = malloc (sizeof (*obj_list) * obj_list_size); gnutls_pkcs11_obj_list_import_url (obj_list, &obj_list_size, URL, GNUTLS_PKCS11_OBJ_ATTR_CRT_WITH_PRIVKEY, 0); /* now all certificates are in obj_list */ for (i = 0; i < obj_list_size; i++) { gnutls_x509_crt_init (&xcrt); gnutls_x509_crt_import_pkcs11 (xcrt, obj_list[i]); gnutls_x509_crt_print (xcrt, GNUTLS_CRT_PRINT_FULL, &cinfo); fprintf (stdout, "cert[%d]:\n %s\n\n", i, cinfo.data); gnutls_free (cinfo.data); gnutls_x509_crt_deinit (xcrt); } return 0; }