+ fp = NULL;
+
+ buf = g_strdup_printf("%d", cert->port);
+ chain_file = get_certificate_chain_path(cert->host, buf, cert->fingerprint);
+ g_free(buf);
+ if (is_file_exist(chain_file)) {
+ unsigned char md[128];
+ size_t n;
+ char *fingerprint;
+
+ fp = g_fopen(chain_file, "r");
+ if ((r = gnutls_import_X509_list_fp(fp, GNUTLS_X509_FMT_PEM, &chain, &max_certs)) < 0) {
+ debug_print("chain import failed: %s\n", gnutls_strerror(r));
+ fclose(fp);
+ g_free(chain_file);
+ return (guint)-1;
+ }
+ g_free(chain_file);
+ fclose(fp);
+ fp = NULL;
+
+ gnutls_x509_crt_get_fingerprint(chain[0], GNUTLS_DIG_MD5, md, &n);
+ fingerprint = readable_fingerprint(md, n);
+ if (!fingerprint || strcmp(fingerprint, cert->fingerprint)) {
+ debug_print("Saved chain fingerprint does not match current : %s / %s",
+ cert->fingerprint, fingerprint);
+
+ return (guint)-1;
+ }
+ g_free(fingerprint);
+
+ r = gnutls_x509_crt_list_verify (chain,
+ max_certs,
+ ca_list, max_ca,
+ NULL, 0,
+ GNUTLS_VERIFY_ALLOW_X509_V1_CA_CRT,
+ &status);
+ if (r < 0)
+ debug_print("chain check failed: %s\n", gnutls_strerror(r));
+
+ for (i = 0; i < max_certs; i++)
+ gnutls_x509_crt_deinit(chain[i]);
+ free(chain);