Blame tests/gpgsm/t-keylist.c

Packit Service 672cf4
/* t-keylist.c  - regression test
Packit Service 6c01f9
   Copyright (C) 2000 Werner Koch (dd9jn)
Packit Service 6c01f9
   Copyright (C) 2001, 2003, 2004 g10 Code GmbH
Packit Service 6c01f9
Packit Service 6c01f9
   This file is part of GPGME.
Packit Service 6c01f9
Packit Service 6c01f9
   GPGME is free software; you can redistribute it and/or modify it
Packit Service 6c01f9
   under the terms of the GNU Lesser General Public License as
Packit Service 6c01f9
   published by the Free Software Foundation; either version 2.1 of
Packit Service 6c01f9
   the License, or (at your option) any later version.
Packit Service 6c01f9
Packit Service 6c01f9
   GPGME is distributed in the hope that it will be useful, but
Packit Service 6c01f9
   WITHOUT ANY WARRANTY; without even the implied warranty of
Packit Service 6c01f9
   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
Packit Service 6c01f9
   Lesser General Public License for more details.
Packit Service 6c01f9
Packit Service 6c01f9
   You should have received a copy of the GNU Lesser General Public
Packit Service 6c01f9
   License along with this program; if not, write to the Free Software
Packit Service 6c01f9
   Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA
Packit Service 6c01f9
   02111-1307, USA.  */
Packit Service 672cf4
Packit Service 672cf4
/* We need to include config.h so that we know whether we are building
Packit Service 672cf4
   with large file system (LFS) support. */
Packit Service 672cf4
#ifdef HAVE_CONFIG_H
Packit Service 672cf4
#include <config.h>
Packit Service 672cf4
#endif
Packit Service 672cf4
Packit Service 672cf4
#include <stdlib.h>
Packit Service 672cf4
#include <stdio.h>
Packit Service 672cf4
#include <string.h>
Packit Service 672cf4
Packit Service 672cf4
#include <gpgme.h>
Packit Service 672cf4
Packit Service 672cf4
#include "t-support.h"
Packit Service 672cf4
Packit Service 672cf4

Packit Service 672cf4
struct
Packit Service 672cf4
{
Packit Service 672cf4
  const char *fpr;
Packit Service 672cf4
  int secret;
Packit Service 672cf4
  long timestamp;
Packit Service 672cf4
  long expires;
Packit Service 672cf4
  const char *issuer_serial;
Packit Service 672cf4
  const char *issuer_name;
Packit Service 672cf4
  const char *chain_id;
Packit Service 672cf4
  const char *uid;
Packit Service 672cf4
  const char *email;
Packit Service 672cf4
  gpgme_validity_t validity;
Packit Service 672cf4
  unsigned int key_length;
Packit Service 672cf4
}
Packit Service 672cf4
keys[] =
Packit Service 672cf4
  {
Packit Service 672cf4
    { "3CF405464F66ED4A7DF45BBDD1E4282E33BDB76E", 1, 1007372198, 1038908198, "00",
Packit Service 672cf4
      "CN=test cert 1,OU=Aegypten Project,O=g10 Code GmbH,L=D\xc3\xbcsseldorf,C=DE",
Packit Service 672cf4
      "3CF405464F66ED4A7DF45BBDD1E4282E33BDB76E",
Packit Service 672cf4
      "CN=test cert 1,OU=Aegypten Project,O=g10 Code GmbH,L=D\xc3\xbcsseldorf,C=DE",
Packit Service 672cf4
      NULL, GPGME_VALIDITY_ULTIMATE, 1024
Packit Service 672cf4
    },
Packit Service 672cf4
    { "DFA56FB5FC41E3A8921F77AD1622EEFD9152A5AD", 0, 909684190, 1009821790, "01",
Packit Service 672cf4
      "1.2.840.113549.1.9.1=#63657274696679407063612E64666E2E6465,"
Packit Service 672cf4
      "CN=DFN Top Level Certification Authority,OU=DFN-PCA,"
Packit Service 672cf4
      "O=Deutsches Forschungsnetz,C=DE",
Packit Service 672cf4
      "DFA56FB5FC41E3A8921F77AD1622EEFD9152A5AD",
Packit Service 672cf4
      "1.2.840.113549.1.9.1=#63657274696679407063612E64666E2E6465,"
Packit Service 672cf4
      "CN=DFN Top Level Certification Authority,OU=DFN-PCA,"
Packit Service 672cf4
      "O=Deutsches Forschungsnetz,C=DE",
Packit Service 672cf4
      "<certify@pca.dfn.de>", GPGME_VALIDITY_NEVER, 2048
Packit Service 672cf4
    },
Packit Service 672cf4
    { "2C8F3C356AB761CB3674835B792CDA52937F9285", 0, 973183644, 1009735200, "15",
Packit Service 672cf4
      "1.2.840.113549.1.9.1=#63657274696679407063612E64666E2E6465,"
Packit Service 672cf4
      "CN=DFN Top Level Certification Authority,OU=DFN-PCA,"
Packit Service 672cf4
      "O=Deutsches Forschungsnetz,C=DE",
Packit Service 672cf4
      "DFA56FB5FC41E3A8921F77AD1622EEFD9152A5AD",
Packit Service 672cf4
      "1.2.840.113549.1.9.1=#63657274696679407063612E64666E2E6465,"
Packit Service 672cf4
      "CN=DFN Server Certification Authority,OU=DFN-PCA,"
Packit Service 672cf4
      "O=Deutsches Forschungsnetz,C=DE",
Packit Service 672cf4
      "<certify@pca.dfn.de>", GPGME_VALIDITY_UNKNOWN, 2048
Packit Service 672cf4
    },
Packit Service 672cf4
    { NULL }
Packit Service 672cf4
  };
Packit Service 672cf4
Packit Service 672cf4
Packit Service 672cf4
int
Packit Service 672cf4
main (void)
Packit Service 672cf4
{
Packit Service 672cf4
  gpgme_error_t err;
Packit Service 672cf4
  gpgme_ctx_t ctx;
Packit Service 672cf4
  gpgme_key_t key;
Packit Service 672cf4
  gpgme_keylist_result_t result;
Packit Service 672cf4
  int i = 0;
Packit Service 672cf4
Packit Service 672cf4
  init_gpgme (GPGME_PROTOCOL_CMS);
Packit Service 672cf4
Packit Service 672cf4
  err = gpgme_new (&ctx;;
Packit Service 672cf4
  fail_if_err (err);
Packit Service 672cf4
  gpgme_set_protocol (ctx, GPGME_PROTOCOL_CMS);
Packit Service 672cf4
Packit Service 672cf4
  err = gpgme_op_keylist_start (ctx, NULL, 0);
Packit Service 672cf4
  fail_if_err (err);
Packit Service 672cf4
Packit Service 672cf4
  while (!(err = gpgme_op_keylist_next (ctx, &key)))
Packit Service 672cf4
    {
Packit Service 672cf4
      if (!keys[i].fpr)
Packit Service 672cf4
	{
Packit Service 672cf4
	  fprintf (stderr, "More keys returned than expected\n");
Packit Service 672cf4
	  exit (1);
Packit Service 672cf4
	}
Packit Service 672cf4
Packit Service 672cf4
      if (strcmp (key->subkeys->fpr, keys[i].fpr))
Packit Service 672cf4
	{
Packit Service 672cf4
	  fprintf (stderr, "Warning: Skipping unknown key %s\n",
Packit Service 672cf4
		   key->subkeys->fpr);
Packit Service 672cf4
	  gpgme_key_unref (key);
Packit Service 672cf4
	  continue;
Packit Service 672cf4
	}
Packit Service 672cf4
      else
Packit Service 672cf4
	printf ("Checking key %s\n", key->subkeys->fpr);
Packit Service 672cf4
Packit Service 672cf4
      /* Global key flags.  */
Packit Service 672cf4
      if (key->revoked)
Packit Service 672cf4
	{
Packit Service 672cf4
	  fprintf (stderr, "Key unexpectedly revoked\n");
Packit Service 672cf4
	  exit (1);
Packit Service 672cf4
	}
Packit Service 672cf4
      if (key->expired)
Packit Service 672cf4
	{
Packit Service 672cf4
	  fprintf (stderr, "Key unexpectedly expired\n");
Packit Service 672cf4
	  exit (1);
Packit Service 672cf4
	}
Packit Service 672cf4
      if (key->disabled)
Packit Service 672cf4
	{
Packit Service 672cf4
	  fprintf (stderr, "Key unexpectedly disabled\n");
Packit Service 672cf4
	  exit (1);
Packit Service 672cf4
	}
Packit Service 672cf4
      if (key->invalid)
Packit Service 672cf4
	{
Packit Service 672cf4
	  fprintf (stderr, "Key unexpectedly invalid\n");
Packit Service 672cf4
	  exit (1);
Packit Service 672cf4
	}
Packit Service 672cf4
      if (key->can_encrypt != keys[i].secret)
Packit Service 672cf4
	{
Packit Service 672cf4
	  fprintf (stderr, "Key unexpectedly%s usable for encryption\n",
Packit Service 672cf4
		   key->can_encrypt ? "" : " not");
Packit Service 672cf4
	  exit (1);
Packit Service 672cf4
	}
Packit Service 672cf4
      if (key->can_sign != keys[i].secret)
Packit Service 672cf4
	{
Packit Service 672cf4
	  fprintf (stderr, "Key unexpectedly%s usable for signing\n",
Packit Service 672cf4
		   key->can_sign ? "" : " not");
Packit Service 672cf4
	  exit (1);
Packit Service 672cf4
	}
Packit Service 672cf4
      if (!key->can_certify)
Packit Service 672cf4
	{
Packit Service 672cf4
	  fprintf (stderr, "Key unexpectedly unusable for certifications\n");
Packit Service 672cf4
	  exit (1);
Packit Service 672cf4
	}
Packit Service 672cf4
      if (key->secret != keys[i].secret)
Packit Service 672cf4
	{
Packit Service 672cf4
	  fprintf (stderr, "Key unexpectedly%s secret\n",
Packit Service 672cf4
		   key->secret ? "" : " not");
Packit Service 672cf4
	  exit (1);
Packit Service 672cf4
	}
Packit Service 672cf4
      if (key->protocol != GPGME_PROTOCOL_CMS)
Packit Service 672cf4
	{
Packit Service 672cf4
	  fprintf (stderr, "Key has unexpected protocol: %s\n",
Packit Service 672cf4
		   gpgme_get_protocol_name (key->protocol));
Packit Service 672cf4
	  exit (1);
Packit Service 672cf4
	}
Packit Service 672cf4
      if (!key->issuer_serial)
Packit Service 672cf4
	{
Packit Service 672cf4
	  fprintf (stderr, "Key unexpectedly misses issuer serial\n");
Packit Service 672cf4
	  exit (1);
Packit Service 672cf4
	}
Packit Service 672cf4
      if (strcmp (key->issuer_serial, keys[i].issuer_serial))
Packit Service 672cf4
	{
Packit Service 672cf4
	  fprintf (stderr, "Key has unexpected issuer serial: %s\n",
Packit Service 672cf4
		   key->issuer_serial);
Packit Service 672cf4
	  exit (1);
Packit Service 672cf4
	}
Packit Service 672cf4
      if (!key->issuer_name)
Packit Service 672cf4
	{
Packit Service 672cf4
	  fprintf (stderr, "Key unexpectedly misses issuer name\n");
Packit Service 672cf4
	  exit (1);
Packit Service 672cf4
	}
Packit Service 672cf4
      if (strcmp (key->issuer_name, keys[i].issuer_name))
Packit Service 672cf4
	{
Packit Service 672cf4
	  fprintf (stderr, "Key has unexpected issuer name: %s\n",
Packit Service 672cf4
		   key->issuer_name);
Packit Service 672cf4
	  exit (1);
Packit Service 672cf4
	}
Packit Service 672cf4
      if (key->chain_id && !keys[i].chain_id)
Packit Service 672cf4
	{
Packit Service 672cf4
	  fprintf (stderr, "Key unexpectedly carries chain ID: %s\n",
Packit Service 672cf4
		   key->chain_id);
Packit Service 672cf4
	  exit (1);
Packit Service 672cf4
	}
Packit Service 672cf4
      if (!key->chain_id && keys[i].chain_id)
Packit Service 672cf4
	{
Packit Service 672cf4
	  fprintf (stderr, "Key unexpectedly carries no chain ID\n");
Packit Service 672cf4
	  exit (1);
Packit Service 672cf4
	}
Packit Service 672cf4
      if (key->chain_id && strcmp (key->chain_id, keys[i].chain_id))
Packit Service 672cf4
	{
Packit Service 672cf4
	  fprintf (stderr, "Key carries unexpected chain ID: %s\n",
Packit Service 672cf4
		   key->chain_id);
Packit Service 672cf4
	  exit (1);
Packit Service 672cf4
	}
Packit Service 672cf4
      if (key->owner_trust != GPGME_VALIDITY_UNKNOWN)
Packit Service 672cf4
	{
Packit Service 672cf4
	  fprintf (stderr, "Key has unexpected owner trust: %i\n",
Packit Service 672cf4
		   key->owner_trust);
Packit Service 672cf4
	  exit (1);
Packit Service 672cf4
	}
Packit Service 672cf4
      if (!key->subkeys || key->subkeys->next)
Packit Service 672cf4
	{
Packit Service 672cf4
	  fprintf (stderr, "Key has unexpected number of subkeys\n");
Packit Service 672cf4
	  exit (1);
Packit Service 672cf4
	}
Packit Service 672cf4
Packit Service 672cf4
      /* Primary key.  */
Packit Service 672cf4
      if (key->subkeys->revoked)
Packit Service 672cf4
	{
Packit Service 672cf4
	  fprintf (stderr, "Primary key unexpectedly revoked\n");
Packit Service 672cf4
	  exit (1);
Packit Service 672cf4
	}
Packit Service 672cf4
      if (key->subkeys->expired)
Packit Service 672cf4
	{
Packit Service 672cf4
	  fprintf (stderr, "Primary key unexpectedly expired\n");
Packit Service 672cf4
	  exit (1);
Packit Service 672cf4
	}
Packit Service 672cf4
      if (key->subkeys->disabled)
Packit Service 672cf4
	{
Packit Service 672cf4
	  fprintf (stderr, "Primary key unexpectedly disabled\n");
Packit Service 672cf4
	  exit (1);
Packit Service 672cf4
	}
Packit Service 672cf4
      if (key->subkeys->invalid)
Packit Service 672cf4
	{
Packit Service 672cf4
	  fprintf (stderr, "Primary key unexpectedly invalid\n");
Packit Service 672cf4
	  exit (1);
Packit Service 672cf4
	}
Packit Service 672cf4
      if (key->subkeys->can_encrypt != keys[i].secret)
Packit Service 672cf4
	{
Packit Service 672cf4
	  fprintf (stderr, "Key unexpectedly%s usable for encryption\n",
Packit Service 672cf4
		   key->subkeys->can_encrypt ? "" : " not");
Packit Service 672cf4
	  exit (1);
Packit Service 672cf4
	}
Packit Service 672cf4
      if (key->subkeys->can_sign != keys[i].secret)
Packit Service 672cf4
	{
Packit Service 672cf4
	  fprintf (stderr, "Key unexpectedly%s usable for signing\n",
Packit Service 672cf4
		   key->subkeys->can_sign ? "" : " not");
Packit Service 672cf4
	  exit (1);
Packit Service 672cf4
	}
Packit Service 672cf4
      if (!key->subkeys->can_certify)
Packit Service 672cf4
	{
Packit Service 672cf4
	  fprintf (stderr, "Primary key unexpectedly unusable for certifications\n");
Packit Service 672cf4
	  exit (1);
Packit Service 672cf4
	}
Packit Service 672cf4
      if (key->subkeys->secret != keys[i].secret)
Packit Service 672cf4
	{
Packit Service 672cf4
	  fprintf (stderr, "Primary Key unexpectedly%s secret\n",
Packit Service 672cf4
		   key->secret ? "" : " not");
Packit Service 672cf4
	  exit (1);
Packit Service 672cf4
	}
Packit Service 672cf4
      if (key->subkeys->pubkey_algo != GPGME_PK_RSA)
Packit Service 672cf4
	{
Packit Service 672cf4
	  fprintf (stderr, "Primary key has unexpected public key algo: %s\n",
Packit Service 672cf4
		   gpgme_pubkey_algo_name (key->subkeys->pubkey_algo));
Packit Service 672cf4
	  exit (1);
Packit Service 672cf4
	}
Packit Service 672cf4
      if (key->subkeys->length != keys[i].key_length)
Packit Service 672cf4
	{
Packit Service 672cf4
	  fprintf (stderr, "Primary key has unexpected length: %i\n",
Packit Service 672cf4
		   key->subkeys->length);
Packit Service 672cf4
	  exit (1);
Packit Service 672cf4
	}
Packit Service 672cf4
      if (strcmp (key->subkeys->keyid, &keys[i].fpr[40 - 16]))
Packit Service 672cf4
	{
Packit Service 672cf4
	  fprintf (stderr, "Primary key has unexpected key ID: %s\n",
Packit Service 672cf4
		   key->subkeys->keyid);
Packit Service 672cf4
	  exit (1);
Packit Service 672cf4
	}
Packit Service 672cf4
      if (strcmp (key->subkeys->fpr, keys[i].fpr))
Packit Service 672cf4
	{
Packit Service 672cf4
	  fprintf (stderr, "Primary key has unexpected fingerprint: %s\n",
Packit Service 672cf4
		   key->subkeys->fpr);
Packit Service 672cf4
	  exit (1);
Packit Service 672cf4
	}
Packit Service 672cf4
      if (key->subkeys->timestamp != keys[i].timestamp)
Packit Service 672cf4
	{
Packit Service 672cf4
	  fprintf (stderr, "Primary key unexpected timestamp: %lu\n",
Packit Service 672cf4
		   key->subkeys->timestamp);
Packit Service 672cf4
	  exit (1);
Packit Service 672cf4
	}
Packit Service 672cf4
      if (key->subkeys->expires != keys[i].expires)
Packit Service 672cf4
	{
Packit Service 672cf4
	  fprintf (stderr, "Primary key unexpectedly expires: %lu\n",
Packit Service 672cf4
		   key->subkeys->expires);
Packit Service 672cf4
	  exit (1);
Packit Service 672cf4
	}
Packit Service 672cf4
Packit Service 672cf4
      /* Be tolerant against a missing email (ie, older gpgsm versions).  */
Packit Service 672cf4
      if (!key->uids || (key->uids->next && !keys[i].email))
Packit Service 672cf4
	{
Packit Service 672cf4
	  fprintf (stderr, "Key has unexpected number of user IDs\n");
Packit Service 672cf4
	  exit (1);
Packit Service 672cf4
	}
Packit Service 672cf4
      if (key->uids->revoked)
Packit Service 672cf4
	{
Packit Service 672cf4
	  fprintf (stderr, "User ID unexpectedly revoked\n");
Packit Service 672cf4
	  exit (1);
Packit Service 672cf4
	}
Packit Service 672cf4
      if (key->uids->invalid)
Packit Service 672cf4
	{
Packit Service 672cf4
	  fprintf (stderr, "User ID unexpectedly invalid\n");
Packit Service 672cf4
	  exit (1);
Packit Service 672cf4
	}
Packit Service 672cf4
      if (key->uids->validity != keys[i].validity)
Packit Service 672cf4
	{
Packit Service 672cf4
	  fprintf (stderr, "User ID unexpectedly validity: %i\n",
Packit Service 672cf4
		   key->uids->validity);
Packit Service 672cf4
	  exit (1);
Packit Service 672cf4
	}
Packit Service 672cf4
      if (key->uids->signatures)
Packit Service 672cf4
	{
Packit Service 672cf4
	  fprintf (stderr, "User ID unexpectedly signed\n");
Packit Service 672cf4
	  exit (1);
Packit Service 672cf4
	}
Packit Service 672cf4
      if (!key->uids->name || key->uids->name[0])
Packit Service 672cf4
	{
Packit Service 672cf4
	  fprintf (stderr, "Unexpected name in user ID: %s\n",
Packit Service 672cf4
		   key->uids->name);
Packit Service 672cf4
	  exit (1);
Packit Service 672cf4
	}
Packit Service 672cf4
      if (!key->uids->comment || key->uids->comment[0])
Packit Service 672cf4
	{
Packit Service 672cf4
	  fprintf (stderr, "Unexpected comment in user ID: %s\n",
Packit Service 672cf4
		   key->uids->comment);
Packit Service 672cf4
	  exit (1);
Packit Service 672cf4
	}
Packit Service 672cf4
      if (!key->uids->email || key->uids->email[0])
Packit Service 672cf4
	{
Packit Service 672cf4
	  fprintf (stderr, "Unexpected email in user ID: %s\n",
Packit Service 672cf4
		   key->uids->email);
Packit Service 672cf4
	  exit (1);
Packit Service 672cf4
	}
Packit Service 672cf4
      if (!key->uids->uid || strcmp (key->uids->uid, keys[i].uid))
Packit Service 672cf4
	{
Packit Service 672cf4
	  fprintf (stderr, "Unexpected uid in user ID: %s\n",
Packit Service 672cf4
		   key->uids->uid);
Packit Service 672cf4
	  exit (1);
Packit Service 672cf4
	}
Packit Service 672cf4
      if (key->uids->next && strcmp (key->uids->next->uid, keys[i].email))
Packit Service 672cf4
	{
Packit Service 672cf4
	  fprintf (stderr, "Unexpected email in user ID: %s\n",
Packit Service 672cf4
		   key->uids->next->uid);
Packit Service 672cf4
	  exit (1);
Packit Service 672cf4
	}
Packit Service 672cf4
      if (key->uids->next && strcmp (key->uids->next->uid, keys[i].email))
Packit Service 672cf4
	{
Packit Service 672cf4
	  fprintf (stderr, "Unexpected email in user ID: %s\n",
Packit Service 672cf4
		   key->uids->next->uid);
Packit Service 672cf4
	  exit (1);
Packit Service 672cf4
	}
Packit Service 672cf4
Packit Service 672cf4
Packit Service 672cf4
Packit Service 672cf4
      gpgme_key_unref (key);
Packit Service 672cf4
      i++;
Packit Service 672cf4
    }
Packit Service 672cf4
  if (gpgme_err_code (err) != GPG_ERR_EOF)
Packit Service 672cf4
    fail_if_err (err);
Packit Service 672cf4
  err = gpgme_op_keylist_end (ctx);
Packit Service 672cf4
  fail_if_err (err);
Packit Service 672cf4
Packit Service 672cf4
  result = gpgme_op_keylist_result (ctx);
Packit Service 672cf4
  if (result->truncated)
Packit Service 672cf4
    {
Packit Service 672cf4
      fprintf (stderr, "Key listing unexpectedly truncated\n");
Packit Service 672cf4
      exit (1);
Packit Service 672cf4
    }
Packit Service 672cf4
Packit Service 672cf4
  if (keys[i].fpr)
Packit Service 672cf4
    {
Packit Service 672cf4
      fprintf (stderr, "Less keys returned than expected\n");
Packit Service 672cf4
      exit (1);
Packit Service 672cf4
    }
Packit Service 672cf4
Packit Service 672cf4
  gpgme_release (ctx);
Packit Service 672cf4
  return 0;
Packit Service 672cf4
}