* gpg/t-verify.c (validity_string): New.
[gpgme.git] / tests / gpg / t-verify.c
1 /* t-verify.c  - regression test
2  *      Copyright (C) 2000 Werner Koch (dd9jn)
3  *      Copyright (C) 2001, 2002 g10 Code GmbH
4  *
5  * This file is part of GPGME.
6  *
7  * GPGME is free software; you can redistribute it and/or modify
8  * it under the terms of the GNU General Public License as published by
9  * the Free Software Foundation; either version 2 of the License, or
10  * (at your option) any later version.
11  *
12  * GPGME is distributed in the hope that it will be useful,
13  * but WITHOUT ANY WARRANTY; without even the implied warranty of
14  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
15  * GNU General Public License for more details.
16  *
17  * You should have received a copy of the GNU General Public License
18  * along with this program; if not, write to the Free Software
19  * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA
20  */
21
22 #include <stdio.h>
23 #include <stdlib.h>
24 #include <string.h>
25 #include <assert.h>
26
27 #include <gpgme.h>
28
29 static const char test_text1[] = "Just GNU it!\n";
30 static const char test_text1f[]= "Just GNU it?\n";
31 static const char test_sig1[] =
32 #if 0
33 "-----BEGIN PGP SIGNATURE-----\n"
34 "\n"
35 "iEYEABECAAYFAjoKgjIACgkQLXJ8x2hpdzQMSwCeO/xUrhysZ7zJKPf/FyXA//u1\n"
36 "ZgIAn0204PBR7yxSdQx6CFxugstNqmRv\n"
37 "=yku6\n"
38 "-----END PGP SIGNATURE-----\n"
39 #elif 0
40 "-----BEGIN PGP SIGNATURE-----\n"
41 "Version: GnuPG v1.0.4-2 (GNU/Linux)\n"
42 "Comment: For info see http://www.gnupg.org\n"
43 "\n"
44 "iJcEABECAFcFAjoS8/E1FIAAAAAACAAkZm9vYmFyLjF0aGlzIGlzIGEgbm90YXRp\n"
45 "b24gZGF0YSB3aXRoIDIgbGluZXMaGmh0dHA6Ly93d3cuZ3Uub3JnL3BvbGljeS8A\n"
46 "CgkQLXJ8x2hpdzQLyQCbBW/fgU8ZeWSlWPM1F8umHX17bAAAoIfSNDSp5zM85XcG\n"
47 "iwxMrf+u8v4r\n"
48 "=88Zo\n"
49 "-----END PGP SIGNATURE-----\n"
50 #elif 1
51 "-----BEGIN PGP SIGNATURE-----\n"
52 "\n"
53 "iN0EABECAJ0FAjoS+i9FFIAAAAAAAwA5YmFyw7bDpMO8w58gZGFzIHdhcmVuIFVt\n"
54 "bGF1dGUgdW5kIGpldHp0IGVpbiBwcm96ZW50JS1aZWljaGVuNRSAAAAAAAgAJGZv\n"
55 "b2Jhci4xdGhpcyBpcyBhIG5vdGF0aW9uIGRhdGEgd2l0aCAyIGxpbmVzGhpodHRw\n"
56 "Oi8vd3d3Lmd1Lm9yZy9wb2xpY3kvAAoJEC1yfMdoaXc0JBIAoIiLlUsvpMDOyGEc\n"
57 "dADGKXF/Hcb+AKCJWPphZCphduxSvrzH0hgzHdeQaA==\n"
58 "=nts1\n"
59 "-----END PGP SIGNATURE-----\n"
60 #endif
61 ;
62 static const char test_sig2[] =
63 "-----BEGIN PGP MESSAGE-----\n"
64 "\n"
65 "owGbwMvMwCSoW1RzPCOz3IRxjXQSR0lqcYleSUWJTZOvjVdpcYmCu1+oQmaJIleH\n"
66 "GwuDIBMDGysTSIqBi1MApi+nlGGuwDeHao53HBr+FoVGP3xX+kvuu9fCMJvl6IOf\n"
67 "y1kvP4y+8D5a11ang0udywsA\n"
68 "=Crq6\n"
69 "-----END PGP MESSAGE-----\n";
70
71
72 #define fail_if_err(a) do { if(a) {                                       \
73                                fprintf (stderr, "%s:%d: GpgmeError %s\n", \
74                                 __FILE__, __LINE__, gpgme_strerror(a));   \
75                                 exit (1); }                               \
76                              } while(0)
77
78
79 static const char *
80 status_string (GpgmeSigStat status)
81 {
82     const char *s = "?";
83
84     switch ( status ) {
85       case GPGME_SIG_STAT_NONE:
86         s = "None";
87         break;
88       case GPGME_SIG_STAT_NOSIG:
89         s = "No Signature";
90         break;
91       case GPGME_SIG_STAT_GOOD:
92         s = "Good";
93         break;
94       case GPGME_SIG_STAT_GOOD_EXP:
95         s = "Good but expired";
96         break;
97       case GPGME_SIG_STAT_GOOD_EXPKEY:
98         s = "Good but key exipired";
99         break;
100       case GPGME_SIG_STAT_BAD:
101         s = "Bad";
102         break;
103       case GPGME_SIG_STAT_NOKEY:
104         s = "No Key";
105         break;
106       case GPGME_SIG_STAT_ERROR:
107         s = "Error";
108         break;
109       case GPGME_SIG_STAT_DIFF:
110         s = "More than one signature";
111         break;
112     }
113     return s;
114 }
115
116 static const char *
117 validity_string (GpgmeValidity val)
118 {
119   const char *s = "?";
120
121   switch (val)
122     {
123     case GPGME_VALIDITY_UNKNOWN: s = "unknown"; break;
124     case GPGME_VALIDITY_NEVER:   s = "not trusted"; break;
125     case GPGME_VALIDITY_MARGINAL:s = "marginal trusted"; break;
126     case GPGME_VALIDITY_FULL:   s = "fully trusted"; break;
127     case GPGME_VALIDITY_UNDEFINED:
128     case GPGME_VALIDITY_ULTIMATE:
129       break;
130     }
131   return s;
132 }
133
134
135 static void
136 print_sig_stat ( GpgmeCtx ctx, GpgmeSigStat status )
137 {
138     const char *s;
139     time_t created;
140     int idx;
141     GpgmeKey key;
142
143     printf ("Verification Status: %s\n", status_string (status));
144     
145     for(idx=0; (s=gpgme_get_sig_status (ctx, idx, &status, &created)); idx++ ) {
146         printf ("sig %d: created: %lu expires: %lu status: %s\n",
147                 idx, (unsigned long)created, 
148                 gpgme_get_sig_ulong_attr (ctx, idx, GPGME_ATTR_EXPIRE, 0),
149                 status_string(status) );
150         printf ("sig %d: fpr/keyid: `%s' validity: %s\n",
151                 idx, s,
152                 validity_string (gpgme_get_sig_ulong_attr
153                                  (ctx, idx, GPGME_ATTR_VALIDITY, 0)) );
154         if ( !gpgme_get_sig_key (ctx, idx, &key) ) {
155             char *p = gpgme_key_get_as_xml ( key );
156             printf ("sig %d: key object:\n%s\n", idx, p );
157             free (p);
158             gpgme_key_release (key);
159         }
160     }
161 }
162
163 int 
164 main (int argc, char **argv )
165 {
166     GpgmeCtx ctx;
167     GpgmeError err;
168     GpgmeData sig, text;
169     GpgmeSigStat status;
170     char *nota;
171     int n = 0;
172     int i, j;
173
174     err = gpgme_new (&ctx);
175     fail_if_err (err);
176
177   do {
178     err = gpgme_data_new_from_mem ( &text,
179                                     test_text1, strlen (test_text1), 0 );
180     fail_if_err (err);
181   #if 1
182     err = gpgme_data_new_from_mem ( &sig,
183                                     test_sig1, strlen (test_sig1), 0 );
184   #else
185     err = gpgme_data_new_from_file ( &sig, "xx1", 1 );
186   #endif
187     fail_if_err (err);
188
189     puts ("checking a valid message:\n");
190     err = gpgme_op_verify (ctx, sig, text, &status );
191     fail_if_err (err);
192     print_sig_stat ( ctx, status );
193     if (status != GPGME_SIG_STAT_GOOD)
194       {
195         fprintf (stderr, "%s:%d: Wrong sig stat\n", __FILE__, __LINE__);
196         exit (1);
197       }
198
199     if ( (nota=gpgme_get_notation (ctx)) )
200         printf ("---Begin Notation---\n%s---End Notation---\n", nota );
201
202     puts ("checking a manipulated message:\n");
203     gpgme_data_release (text);
204     err = gpgme_data_new_from_mem ( &text,
205                                     test_text1f, strlen (test_text1f), 0 );
206     fail_if_err (err);
207     gpgme_data_rewind ( sig );
208     err = gpgme_op_verify (ctx, sig, text, &status );
209     fail_if_err (err);
210
211     print_sig_stat (ctx, status);
212     if (status != GPGME_SIG_STAT_BAD)
213       {
214         fprintf (stderr, "%s:%d: Wrong sig stat\n", __FILE__, __LINE__);
215         exit (1);
216       }
217     if ( (nota=gpgme_get_notation (ctx)) )
218         printf ("---Begin Notation---\n%s---End Notation---\n", nota );
219
220     puts ("checking a normal signature:");
221     gpgme_data_release (sig);
222     gpgme_data_release (text);
223     err = gpgme_data_new_from_mem (&sig,  test_sig2, strlen (test_sig2), 0);
224     fail_if_err (err);
225     err = gpgme_data_new (&text);
226     fail_if_err (err);
227     err = gpgme_op_verify (ctx, sig, text, &status);
228     fail_if_err (err);
229
230     nota = gpgme_data_release_and_get_mem (text, &i);
231     for (j = 0; j < i; j++)
232       putchar (nota[j]);
233     if (strncmp (nota, test_text1, strlen (test_text1)))
234       {
235         fprintf (stderr, "%s:%d: Wrong plaintext\n", __FILE__, __LINE__);
236         exit (1);
237       }
238    
239     print_sig_stat (ctx, status);
240     if (status != GPGME_SIG_STAT_GOOD)
241       {
242         fprintf (stderr, "%s:%d: Wrong sig stat\n", __FILE__, __LINE__);
243         exit (1);
244       }
245
246     if ((nota = gpgme_get_notation (ctx)))
247       printf ("---Begin Notation---\n%s---End Notation---\n", nota);
248
249     gpgme_data_release (sig);
250  
251 } while ( argc > 1 && !strcmp( argv[1], "--loop" ) && ++n < 20 );
252       gpgme_release (ctx);
253     
254     return 0;
255 }