New API gpgme_op_getauditlog.
[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 const char test_text1[] = "Hallo Leute!\n";
38 static const char test_text1f[]= "Hallo Leute?\n";
39 static const char test_sig1[] =
40 "-----BEGIN CMS OBJECT-----\n"
41 "MIAGCSqGSIb3DQEHAqCAMIACAQExCzAJBgUrDgMCGgUAMIAGCSqGSIb3DQEHAQAA\n"
42 "MYIBOTCCATUCAQEwcDBrMQswCQYDVQQGEwJERTETMBEGA1UEBxQKRPxzc2VsZG9y\n"
43 "ZjEWMBQGA1UEChMNZzEwIENvZGUgR21iSDEZMBcGA1UECxMQQWVneXB0ZW4gUHJv\n"
44 "amVjdDEUMBIGA1UEAxMLdGVzdCBjZXJ0IDECAQAwBwYFKw4DAhqgJTAjBgkqhkiG\n"
45 "9w0BCQQxFgQU7FC/ibH3lC9GE24RJJxa8zqP7wEwCwYJKoZIhvcNAQEBBIGAA3oC\n"
46 "DUmKERmD1eoJYFw38y/qnncS/6ZPjWINDIphZeK8mzAANpvpIaRPf3sNBznb89QF\n"
47 "mRgCXIWcjlHT0DTRLBf192Ve22IyKH00L52CqFsSN3a2sajqRUlXH8RY2D+Al71e\n"
48 "MYdRclgjObCcoilA8fZ13VR4DiMJVFCxJL4qVWI=\n"
49 "-----END CMS OBJECT-----\n";
50
51
52 static void
53 check_result (gpgme_verify_result_t result, int summary, char *fpr,
54               gpgme_error_t status, gpgme_validity_t validity)
55 {
56   gpgme_signature_t sig;
57
58   sig = result->signatures;
59   if (!sig || sig->next)
60     {
61       fprintf (stderr, "%s:%i: Unexpected number of signatures\n",
62                __FILE__, __LINE__);
63       exit (1);
64     }
65   if (sig->summary != summary)
66     {
67       fprintf (stderr, "%s:%i: Unexpected signature summary: "
68                "want=0x%x have=0x%x\n",
69                __FILE__, __LINE__, summary, sig->summary);
70       exit (1);
71     }
72   if (strcmp (sig->fpr, fpr))
73     {
74       fprintf (stderr, "%s:%i: Unexpected fingerprint: %s\n",
75                __FILE__, __LINE__, sig->fpr);
76       exit (1);
77     }
78   if (gpg_err_code (sig->status) != status)
79     {
80       fprintf (stderr, "%s:%i: Unexpected signature status: %s\n",
81                __FILE__, __LINE__, gpgme_strerror (sig->status));
82       exit (1);
83     }
84   if (sig->notations)
85     {
86       fprintf (stderr, "%s:%i: Unexpected notation data\n",
87                __FILE__, __LINE__);
88       exit (1);
89     }
90   if (sig->wrong_key_usage)
91     {
92       fprintf (stderr, "%s:%i: Unexpectedly wrong key usage\n",
93                __FILE__, __LINE__);
94       exit (1);
95     }
96   if (sig->validity != validity)
97     {
98       fprintf (stderr, "%s:%i: Unexpected validity: %i\n",
99                __FILE__, __LINE__, sig->validity);
100       exit (1);
101     }
102   if (gpg_err_code (sig->validity_reason) != GPG_ERR_NO_ERROR)
103     {
104       fprintf (stderr, "%s:%i: Unexpected validity reason: %s\n",
105                __FILE__, __LINE__, gpgme_strerror (sig->validity_reason));
106       exit (1);
107     }
108 }
109
110
111 static void
112 show_auditlog (gpgme_ctx_t ctx)
113 {
114   gpgme_error_t err;
115   gpgme_data_t data;
116
117   err = gpgme_data_new (&data);
118   fail_if_err (err);
119   err = gpgme_op_getauditlog (ctx, data, 0);
120   fail_if_err (err);
121   gpgme_data_release (data);
122 }
123
124
125
126 int 
127 main (int argc, char **argv)
128 {
129   gpgme_ctx_t ctx;
130   gpgme_error_t err;
131   gpgme_data_t sig, text;
132   gpgme_verify_result_t result;
133
134   init_gpgme (GPGME_PROTOCOL_CMS);
135
136   err = gpgme_new (&ctx);
137   fail_if_err (err);
138   gpgme_set_protocol (ctx, GPGME_PROTOCOL_CMS);
139   
140   /* Checking a valid message.  */
141   err = gpgme_data_new_from_mem (&text, test_text1, strlen (test_text1), 0);
142   fail_if_err (err);
143   err = gpgme_data_new_from_mem (&sig, test_sig1, strlen (test_sig1), 0);
144   fail_if_err (err);
145
146   err = gpgme_op_verify (ctx, sig, text, NULL);
147   fail_if_err (err);
148   result = gpgme_op_verify_result (ctx);
149   check_result (result, GPGME_SIGSUM_VALID | GPGME_SIGSUM_GREEN,
150                 "3CF405464F66ED4A7DF45BBDD1E4282E33BDB76E",
151                 GPG_ERR_NO_ERROR, GPGME_VALIDITY_FULL);
152
153   show_auditlog (ctx);
154
155   /* Checking a manipulated message.  */
156   gpgme_data_release (text);
157   err = gpgme_data_new_from_mem (&text, test_text1f, strlen (test_text1f), 0);
158   fail_if_err (err);
159   gpgme_data_seek (sig, 0, SEEK_SET);
160   err = gpgme_op_verify (ctx, sig, text, NULL);
161   fail_if_err (err);
162   result = gpgme_op_verify_result (ctx);
163   check_result (result, GPGME_SIGSUM_RED,
164                 "3CF405464F66ED4A7DF45BBDD1E4282E33BDB76E",
165                 GPG_ERR_BAD_SIGNATURE, GPGME_VALIDITY_UNKNOWN);
166
167   gpgme_data_release (text);
168   gpgme_data_release (sig);
169   gpgme_release (ctx);  
170   return 0;
171 }