Blame tests/gpgsm/t-verify.c

Packit d7e8d0
/* t-verify.c - Regression test.
Packit d7e8d0
   Copyright (C) 2000 Werner Koch (dd9jn)
Packit d7e8d0
   Copyright (C) 2001, 2002, 2003, 2004 g10 Code GmbH
Packit d7e8d0
Packit d7e8d0
   This file is part of GPGME.
Packit d7e8d0
Packit d7e8d0
   GPGME is free software; you can redistribute it and/or modify it
Packit d7e8d0
   under the terms of the GNU Lesser General Public License as
Packit d7e8d0
   published by the Free Software Foundation; either version 2.1 of
Packit d7e8d0
   the License, or (at your option) any later version.
Packit d7e8d0
Packit d7e8d0
   GPGME is distributed in the hope that it will be useful, but
Packit d7e8d0
   WITHOUT ANY WARRANTY; without even the implied warranty of
Packit d7e8d0
   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
Packit d7e8d0
   Lesser General Public License for more details.
Packit d7e8d0
Packit d7e8d0
   You should have received a copy of the GNU Lesser General Public
Packit d7e8d0
   License along with this program; if not, write to the Free Software
Packit d7e8d0
   Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA
Packit d7e8d0
   02111-1307, USA.  */
Packit d7e8d0
Packit d7e8d0
/* We need to include config.h so that we know whether we are building
Packit d7e8d0
   with large file system (LFS) support. */
Packit d7e8d0
#ifdef HAVE_CONFIG_H
Packit d7e8d0
#include <config.h>
Packit d7e8d0
#endif
Packit d7e8d0
Packit d7e8d0
#include <stdlib.h>
Packit d7e8d0
#include <stdio.h>
Packit d7e8d0
#include <string.h>
Packit d7e8d0
Packit d7e8d0
#include <gpgme.h>
Packit d7e8d0
Packit d7e8d0
#include "t-support.h"
Packit d7e8d0
Packit d7e8d0

Packit d7e8d0
static int got_errors;
Packit d7e8d0
Packit d7e8d0
static const char test_text1[] = "Hallo Leute!\n";
Packit d7e8d0
static const char test_text1f[]= "Hallo Leute?\n";
Packit d7e8d0
static const char test_sig1[] =
Packit d7e8d0
"-----BEGIN CMS OBJECT-----\n"
Packit d7e8d0
"MIAGCSqGSIb3DQEHAqCAMIACAQExCzAJBgUrDgMCGgUAMIAGCSqGSIb3DQEHAQAA\n"
Packit d7e8d0
"MYIBOTCCATUCAQEwcDBrMQswCQYDVQQGEwJERTETMBEGA1UEBxQKRPxzc2VsZG9y\n"
Packit d7e8d0
"ZjEWMBQGA1UEChMNZzEwIENvZGUgR21iSDEZMBcGA1UECxMQQWVneXB0ZW4gUHJv\n"
Packit d7e8d0
"amVjdDEUMBIGA1UEAxMLdGVzdCBjZXJ0IDECAQAwBwYFKw4DAhqgJTAjBgkqhkiG\n"
Packit d7e8d0
"9w0BCQQxFgQU7FC/ibH3lC9GE24RJJxa8zqP7wEwCwYJKoZIhvcNAQEBBIGAA3oC\n"
Packit d7e8d0
"DUmKERmD1eoJYFw38y/qnncS/6ZPjWINDIphZeK8mzAANpvpIaRPf3sNBznb89QF\n"
Packit d7e8d0
"mRgCXIWcjlHT0DTRLBf192Ve22IyKH00L52CqFsSN3a2sajqRUlXH8RY2D+Al71e\n"
Packit d7e8d0
"MYdRclgjObCcoilA8fZ13VR4DiMJVFCxJL4qVWI=\n"
Packit d7e8d0
"-----END CMS OBJECT-----\n";
Packit d7e8d0
Packit d7e8d0
Packit d7e8d0
static void
Packit d7e8d0
check_result (gpgme_verify_result_t result, int summary, const char *fpr,
Packit d7e8d0
	      gpgme_error_t status, gpgme_validity_t validity)
Packit d7e8d0
{
Packit d7e8d0
  gpgme_signature_t sig;
Packit d7e8d0
Packit d7e8d0
  sig = result->signatures;
Packit d7e8d0
  if (!sig || sig->next)
Packit d7e8d0
    {
Packit d7e8d0
      fprintf (stderr, "%s:%i: Unexpected number of signatures\n",
Packit d7e8d0
	       __FILE__, __LINE__);
Packit d7e8d0
      got_errors = 1;
Packit d7e8d0
      if (!sig)
Packit d7e8d0
        return;
Packit d7e8d0
    }
Packit d7e8d0
  if (sig->summary != summary)
Packit d7e8d0
    {
Packit d7e8d0
      fprintf (stderr, "%s:%i: Unexpected signature summary: "
Packit d7e8d0
               "want=0x%x have=0x%x\n",
Packit d7e8d0
	       __FILE__, __LINE__, summary, sig->summary);
Packit d7e8d0
      got_errors = 1;
Packit d7e8d0
    }
Packit d7e8d0
  if (sig->fpr && strcmp (sig->fpr, fpr))
Packit d7e8d0
    {
Packit d7e8d0
      fprintf (stderr, "%s:%i: Unexpected fingerprint: %s\n",
Packit d7e8d0
	       __FILE__, __LINE__, sig->fpr);
Packit d7e8d0
      got_errors = 1;
Packit d7e8d0
    }
Packit d7e8d0
  if (gpgme_err_code (sig->status) != status)
Packit d7e8d0
    {
Packit d7e8d0
      fprintf (stderr, "%s:%i: Unexpected signature status: %s\n",
Packit d7e8d0
	       __FILE__, __LINE__, gpgme_strerror (sig->status));
Packit d7e8d0
      got_errors = 1;
Packit d7e8d0
    }
Packit d7e8d0
  if (sig->notations)
Packit d7e8d0
    {
Packit d7e8d0
      fprintf (stderr, "%s:%i: Unexpected notation data\n",
Packit d7e8d0
	       __FILE__, __LINE__);
Packit d7e8d0
      got_errors = 1;
Packit d7e8d0
    }
Packit d7e8d0
  if (sig->wrong_key_usage)
Packit d7e8d0
    {
Packit d7e8d0
      fprintf (stderr, "%s:%i: Unexpectedly wrong key usage\n",
Packit d7e8d0
	       __FILE__, __LINE__);
Packit d7e8d0
      got_errors = 1;
Packit d7e8d0
    }
Packit d7e8d0
  if (sig->validity != validity)
Packit d7e8d0
    {
Packit d7e8d0
      fprintf (stderr, "%s:%i: Unexpected validity: %i\n",
Packit d7e8d0
	       __FILE__, __LINE__, sig->validity);
Packit d7e8d0
      got_errors = 1;
Packit d7e8d0
    }
Packit d7e8d0
  if (gpgme_err_code (sig->validity_reason) != GPG_ERR_NO_ERROR)
Packit d7e8d0
    {
Packit d7e8d0
      fprintf (stderr, "%s:%i: Unexpected validity reason: %s\n",
Packit d7e8d0
	       __FILE__, __LINE__, gpgme_strerror (sig->validity_reason));
Packit d7e8d0
      got_errors = 1;
Packit d7e8d0
    }
Packit d7e8d0
}
Packit d7e8d0
Packit d7e8d0
Packit d7e8d0
static void
Packit d7e8d0
show_auditlog (gpgme_ctx_t ctx)
Packit d7e8d0
{
Packit d7e8d0
  gpgme_error_t err;
Packit d7e8d0
  gpgme_data_t data;
Packit d7e8d0
Packit d7e8d0
  err = gpgme_data_new (&data);
Packit d7e8d0
  fail_if_err (err);
Packit d7e8d0
  err = gpgme_op_getauditlog (ctx, data, 0);
Packit d7e8d0
  if (err)
Packit d7e8d0
    {
Packit d7e8d0
      fprintf (stderr, "%s:%i: Can't get audit log: %s\n",
Packit d7e8d0
	       __FILE__, __LINE__, gpgme_strerror (err));
Packit d7e8d0
      if (gpgme_err_code (err) != GPG_ERR_ASS_UNKNOWN_CMD)
Packit d7e8d0
	got_errors = 1;
Packit d7e8d0
    }
Packit d7e8d0
  print_data (data);
Packit d7e8d0
  gpgme_data_release (data);
Packit d7e8d0
}
Packit d7e8d0
Packit d7e8d0
Packit d7e8d0
Packit d7e8d0
int
Packit d7e8d0
main (void)
Packit d7e8d0
{
Packit d7e8d0
  gpgme_ctx_t ctx;
Packit d7e8d0
  gpgme_error_t err;
Packit d7e8d0
  gpgme_data_t sig, text;
Packit d7e8d0
  gpgme_verify_result_t result;
Packit d7e8d0
Packit d7e8d0
  init_gpgme (GPGME_PROTOCOL_CMS);
Packit d7e8d0
Packit d7e8d0
  err = gpgme_new (&ctx;;
Packit d7e8d0
  fail_if_err (err);
Packit d7e8d0
  gpgme_set_protocol (ctx, GPGME_PROTOCOL_CMS);
Packit d7e8d0
Packit d7e8d0
  /* Checking a valid message.  */
Packit d7e8d0
  err = gpgme_data_new_from_mem (&text, test_text1, strlen (test_text1), 0);
Packit d7e8d0
  fail_if_err (err);
Packit d7e8d0
  err = gpgme_data_new_from_mem (&sig, test_sig1, strlen (test_sig1), 0);
Packit d7e8d0
  fail_if_err (err);
Packit d7e8d0
Packit d7e8d0
  err = gpgme_op_verify (ctx, sig, text, NULL);
Packit d7e8d0
  fail_if_err (err);
Packit d7e8d0
  result = gpgme_op_verify_result (ctx);
Packit d7e8d0
  check_result (result, GPGME_SIGSUM_VALID | GPGME_SIGSUM_GREEN,
Packit d7e8d0
		"3CF405464F66ED4A7DF45BBDD1E4282E33BDB76E",
Packit d7e8d0
		GPG_ERR_NO_ERROR, GPGME_VALIDITY_FULL);
Packit d7e8d0
Packit d7e8d0
  show_auditlog (ctx);
Packit d7e8d0
Packit d7e8d0
  /* Checking a manipulated message.  */
Packit d7e8d0
  gpgme_data_release (text);
Packit d7e8d0
  err = gpgme_data_new_from_mem (&text, test_text1f, strlen (test_text1f), 0);
Packit d7e8d0
  fail_if_err (err);
Packit d7e8d0
  gpgme_data_seek (sig, 0, SEEK_SET);
Packit d7e8d0
  err = gpgme_op_verify (ctx, sig, text, NULL);
Packit d7e8d0
  fail_if_err (err);
Packit d7e8d0
  result = gpgme_op_verify_result (ctx);
Packit d7e8d0
  check_result (result, GPGME_SIGSUM_RED,
Packit d7e8d0
		"3CF405464F66ED4A7DF45BBDD1E4282E33BDB76E",
Packit d7e8d0
		GPG_ERR_BAD_SIGNATURE, GPGME_VALIDITY_UNKNOWN);
Packit d7e8d0
Packit d7e8d0
  show_auditlog (ctx);
Packit d7e8d0
Packit d7e8d0
  gpgme_data_release (text);
Packit d7e8d0
  gpgme_data_release (sig);
Packit d7e8d0
  gpgme_release (ctx);
Packit d7e8d0
  return got_errors? 1 : 0;
Packit d7e8d0
}