Make getauditlog work. For now only when configured with --enable-fd-passing.
[gpgme.git] / tests / gpgsm / t-verify.c
1 /* t-verify.c - Regression test.
2    Copyright (C) 2000 Werner Koch (dd9jn)
3    Copyright (C) 2001, 2002, 2003, 2004 g10 Code GmbH
4
5    This file is part of GPGME.
6  
7    GPGME is free software; you can redistribute it and/or modify it
8    under the terms of the GNU Lesser General Public License as
9    published by the Free Software Foundation; either version 2.1 of
10    the License, or (at your option) any later version.
11    
12    GPGME is distributed in the hope that it will be useful, but
13    WITHOUT ANY WARRANTY; without even the implied warranty of
14    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
15    Lesser General Public License for more details.
16    
17    You should have received a copy of the GNU Lesser General Public
18    License along with this program; if not, write to the Free Software
19    Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA
20    02111-1307, USA.  */
21
22 /* We need to include config.h so that we know whether we are building
23    with large file system (LFS) support. */
24 #ifdef HAVE_CONFIG_H
25 #include <config.h>
26 #endif
27
28 #include <stdlib.h>
29 #include <stdio.h>
30 #include <string.h>
31
32 #include <gpgme.h>
33
34 #include "t-support.h"
35
36 \f
37 static int got_errors;
38
39 static const char test_text1[] = "Hallo Leute!\n";
40 static const char test_text1f[]= "Hallo Leute?\n";
41 static const char test_sig1[] =
42 "-----BEGIN CMS OBJECT-----\n"
43 "MIAGCSqGSIb3DQEHAqCAMIACAQExCzAJBgUrDgMCGgUAMIAGCSqGSIb3DQEHAQAA\n"
44 "MYIBOTCCATUCAQEwcDBrMQswCQYDVQQGEwJERTETMBEGA1UEBxQKRPxzc2VsZG9y\n"
45 "ZjEWMBQGA1UEChMNZzEwIENvZGUgR21iSDEZMBcGA1UECxMQQWVneXB0ZW4gUHJv\n"
46 "amVjdDEUMBIGA1UEAxMLdGVzdCBjZXJ0IDECAQAwBwYFKw4DAhqgJTAjBgkqhkiG\n"
47 "9w0BCQQxFgQU7FC/ibH3lC9GE24RJJxa8zqP7wEwCwYJKoZIhvcNAQEBBIGAA3oC\n"
48 "DUmKERmD1eoJYFw38y/qnncS/6ZPjWINDIphZeK8mzAANpvpIaRPf3sNBznb89QF\n"
49 "mRgCXIWcjlHT0DTRLBf192Ve22IyKH00L52CqFsSN3a2sajqRUlXH8RY2D+Al71e\n"
50 "MYdRclgjObCcoilA8fZ13VR4DiMJVFCxJL4qVWI=\n"
51 "-----END CMS OBJECT-----\n";
52
53
54 static void
55 check_result (gpgme_verify_result_t result, int summary, char *fpr,
56               gpgme_error_t status, gpgme_validity_t validity)
57 {
58   gpgme_signature_t sig;
59
60   sig = result->signatures;
61   if (!sig || sig->next)
62     {
63       fprintf (stderr, "%s:%i: Unexpected number of signatures\n",
64                __FILE__, __LINE__);
65       got_errors = 1;
66     }
67   if (sig->summary != summary)
68     {
69       fprintf (stderr, "%s:%i: Unexpected signature summary: "
70                "want=0x%x have=0x%x\n",
71                __FILE__, __LINE__, summary, sig->summary);
72       got_errors = 1;
73     }
74   if (strcmp (sig->fpr, fpr))
75     {
76       fprintf (stderr, "%s:%i: Unexpected fingerprint: %s\n",
77                __FILE__, __LINE__, sig->fpr);
78       got_errors = 1;
79     }
80   if (gpg_err_code (sig->status) != status)
81     {
82       fprintf (stderr, "%s:%i: Unexpected signature status: %s\n",
83                __FILE__, __LINE__, gpgme_strerror (sig->status));
84       got_errors = 1;
85     }
86   if (sig->notations)
87     {
88       fprintf (stderr, "%s:%i: Unexpected notation data\n",
89                __FILE__, __LINE__);
90       got_errors = 1;
91     }
92   if (sig->wrong_key_usage)
93     {
94       fprintf (stderr, "%s:%i: Unexpectedly wrong key usage\n",
95                __FILE__, __LINE__);
96       got_errors = 1;
97     }
98   if (sig->validity != validity)
99     {
100       fprintf (stderr, "%s:%i: Unexpected validity: %i\n",
101                __FILE__, __LINE__, sig->validity);
102       got_errors = 1;
103     }
104   if (gpg_err_code (sig->validity_reason) != GPG_ERR_NO_ERROR)
105     {
106       fprintf (stderr, "%s:%i: Unexpected validity reason: %s\n",
107                __FILE__, __LINE__, gpgme_strerror (sig->validity_reason));
108       got_errors = 1;
109     }
110 }
111
112
113 static void
114 show_auditlog (gpgme_ctx_t ctx)
115 {
116   gpgme_error_t err;
117   gpgme_data_t data;
118
119   err = gpgme_data_new (&data);
120   fail_if_err (err);
121   err = gpgme_op_getauditlog (ctx, data, 0);
122   if (err)
123     {
124       fprintf (stderr, "%s:%i: Can't get audit log: %s\n",
125                __FILE__, __LINE__, gpgme_strerror (err));
126       got_errors = 1;
127     }
128   print_data (data);
129   gpgme_data_release (data);
130 }
131
132
133
134 int 
135 main (int argc, char **argv)
136 {
137   gpgme_ctx_t ctx;
138   gpgme_error_t err;
139   gpgme_data_t sig, text;
140   gpgme_verify_result_t result;
141
142   init_gpgme (GPGME_PROTOCOL_CMS);
143
144   err = gpgme_new (&ctx);
145   fail_if_err (err);
146   gpgme_set_protocol (ctx, GPGME_PROTOCOL_CMS);
147   
148   /* Checking a valid message.  */
149   err = gpgme_data_new_from_mem (&text, test_text1, strlen (test_text1), 0);
150   fail_if_err (err);
151   err = gpgme_data_new_from_mem (&sig, test_sig1, strlen (test_sig1), 0);
152   fail_if_err (err);
153
154   err = gpgme_op_verify (ctx, sig, text, NULL);
155   fail_if_err (err);
156   result = gpgme_op_verify_result (ctx);
157   check_result (result, GPGME_SIGSUM_VALID | GPGME_SIGSUM_GREEN,
158                 "3CF405464F66ED4A7DF45BBDD1E4282E33BDB76E",
159                 GPG_ERR_NO_ERROR, GPGME_VALIDITY_FULL);
160
161   show_auditlog (ctx);
162
163   /* Checking a manipulated message.  */
164   gpgme_data_release (text);
165   err = gpgme_data_new_from_mem (&text, test_text1f, strlen (test_text1f), 0);
166   fail_if_err (err);
167   gpgme_data_seek (sig, 0, SEEK_SET);
168   err = gpgme_op_verify (ctx, sig, text, NULL);
169   fail_if_err (err);
170   result = gpgme_op_verify_result (ctx);
171   check_result (result, GPGME_SIGSUM_RED,
172                 "3CF405464F66ED4A7DF45BBDD1E4282E33BDB76E",
173                 GPG_ERR_BAD_SIGNATURE, GPGME_VALIDITY_UNKNOWN);
174
175   show_auditlog (ctx);
176
177   gpgme_data_release (text);
178   gpgme_data_release (sig);
179   gpgme_release (ctx);  
180   return got_errors? 1 : 0;
181 }