3c557cfaf22140354aed52bc0b78fa6d52ac7a84
[gpgme.git] / tests / gpgsm / t-sign.c
1 /* t-sign.c - Regression test.
2    Copyright (C) 2000 Werner Koch (dd9jn)
3    Copyright (C) 2001, 2003 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 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, but
13    WITHOUT ANY WARRANTY; without even the implied warranty of
14    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
15    General Public License for more details.
16  
17    You should have received a copy of the GNU General Public License
18    along with GPGME; if not, write to the Free Software Foundation,
19    Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.  */
20
21 #include <stdlib.h>
22 #include <stdio.h>
23 #include <string.h>
24
25 #include <gpgme.h>
26
27 #define fail_if_err(err)                                        \
28   do                                                            \
29     {                                                           \
30       if (err)                                                  \
31         {                                                       \
32           fprintf (stderr, "%s:%d: gpgme_error_t %s\n",         \
33                    __FILE__, __LINE__, gpgme_strerror (err));   \
34           exit (1);                                             \
35         }                                                       \
36     }                                                           \
37   while (0)
38
39
40 static void
41 print_data (gpgme_data_t dh)
42 {
43 #define BUF_SIZE 512
44   char buf[BUF_SIZE + 1];
45   int ret;
46   
47   ret = gpgme_data_seek (dh, 0, SEEK_SET);
48   if (ret)
49     fail_if_err (GPGME_File_Error);
50   while ((ret = gpgme_data_read (dh, buf, BUF_SIZE)) > 0)
51     fwrite (buf, ret, 1, stdout);
52   if (ret < 0)
53     fail_if_err (GPGME_File_Error);
54 }
55
56
57 static void
58 check_result (gpgme_sign_result_t result, gpgme_sig_mode_t type)
59 {
60   if (result->invalid_signers)
61     {
62       fprintf (stderr, "Invalid signer found: %s\n",
63                result->invalid_signers->id);
64       exit (1);
65     }
66   if (!result->signatures || result->signatures->next)
67     {
68       fprintf (stderr, "Unexpected number of signatures created\n");
69       exit (1);
70     }
71   if (result->signatures->type != type)
72     {
73       fprintf (stderr, "Wrong type of signature created\n");
74       exit (1);
75     }
76   if (result->signatures->pubkey_algo != GPGME_PK_RSA)
77     {
78       fprintf (stderr, "Wrong pubkey algorithm reported: %i\n",
79                result->signatures->pubkey_algo);
80       exit (1);
81     }
82   if (result->signatures->hash_algo != GPGME_MD_SHA1)
83     {
84       fprintf (stderr, "Wrong hash algorithm reported: %i\n",
85                result->signatures->hash_algo);
86       exit (1);
87     }
88   if (result->signatures->class != 0)
89     {
90       fprintf (stderr, "Wrong signature class reported: %lu\n",
91                result->signatures->class);
92       exit (1);
93     }
94   if (strcmp ("3CF405464F66ED4A7DF45BBDD1E4282E33BDB76E",
95               result->signatures->fpr))
96     {
97       fprintf (stderr, "Wrong fingerprint reported: %s\n",
98                result->signatures->fpr);
99       exit (1);
100     }
101 }
102
103
104 int 
105 main (int argc, char **argv)
106 {
107   gpgme_ctx_t ctx;
108   gpgme_error_t err;
109   gpgme_data_t in, out;
110   gpgme_sign_result_t result;
111
112   err = gpgme_engine_check_version (GPGME_PROTOCOL_CMS);
113   fail_if_err (err);
114
115   err = gpgme_new (&ctx);
116   fail_if_err (err);
117
118   gpgme_set_protocol (ctx, GPGME_PROTOCOL_CMS);
119   gpgme_set_textmode (ctx, 1);
120   gpgme_set_armor (ctx, 1);
121
122   err = gpgme_data_new_from_mem (&in, "Hallo Leute!\n", 13, 0);
123   fail_if_err (err);
124
125   /* First a normal signature.  */
126   err = gpgme_data_new (&out);
127   fail_if_err (err);
128   err = gpgme_op_sign (ctx, in, out, GPGME_SIG_MODE_NORMAL);
129   fail_if_err (err);
130   result = gpgme_op_sign_result (ctx);
131   check_result (result, GPGME_SIG_MODE_NORMAL);
132   print_data (out);
133   gpgme_data_release (out);
134     
135   /* Now a detached signature.  */ 
136   gpgme_data_seek (in, 0, SEEK_SET);
137   err = gpgme_data_new (&out);
138   fail_if_err (err);
139   err = gpgme_op_sign (ctx, in, out, GPGME_SIG_MODE_DETACH);
140   fail_if_err (err);
141   result = gpgme_op_sign_result (ctx);
142   check_result (result, GPGME_SIG_MODE_DETACH);
143   print_data (out);
144   gpgme_data_release (out);
145
146   gpgme_data_release (in);
147   gpgme_release (ctx);
148   return 0;
149 }
150
151
152
153