Add support for gpg --fetch-keys.
[gpgme.git] / tests / gpg / pgp-keylist.c
1 /* pgp-keylist.c  - Helper to show a key listing.
2    Copyright (C) 2008, 2009 g10 Code GmbH
3
4    This file is part of GPGME.
5  
6    GPGME is free software; you can redistribute it and/or modify it
7    under the terms of the GNU Lesser General Public License as
8    published by the Free Software Foundation; either version 2.1 of
9    the License, or (at your option) any later version.
10    
11    GPGME is distributed in the hope that it will be useful, but
12    WITHOUT ANY WARRANTY; without even the implied warranty of
13    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
14    Lesser General Public License for more details.
15    
16    You should have received a copy of the GNU Lesser General Public
17    License along with this program; if not, see <http://www.gnu.org/licenses/>.
18 */
19
20 /* We need to include config.h so that we know whether we are building
21    with large file system (LFS) support. */
22 #ifdef HAVE_CONFIG_H
23 #include <config.h>
24 #endif
25
26 #include <stdlib.h>
27 #include <stdio.h>
28 #include <string.h>
29
30 #include <gpgme.h>
31
32 #define PGM "pgp-keylist"
33
34 #include "t-support.h"
35
36
37 static int verbose;
38
39
40 static int
41 show_usage (int ex)
42 {
43   fputs ("usage: " PGM " [options] [USERID]\n\n"
44          "Options:\n"
45          "  --verbose        run in verbose mode\n"
46          "  --local          use GPGME_KEYLIST_MODE_LOCAL\n"
47          "  --extern         use GPGME_KEYLIST_MODE_EXTERN\n"
48          "  --sigs           use GPGME_KEYLIST_MODE_SIGS\n"
49          "  --sig-notations  use GPGME_KEYLIST_MODE_SIG_NOTATIONS\n"
50          "  --ephemeral      use GPGME_KEYLIST_MODE_EPHEMERAL\n"
51          "  --validate       use GPGME_KEYLIST_MODE_VALIDATE\n"
52          "  --import         import all keys\n"
53          , stderr);
54   exit (ex);
55 }
56
57 int 
58 main (int argc, char **argv)
59 {
60   int last_argc = -1;
61   gpgme_error_t err;
62   gpgme_ctx_t ctx;
63   gpgme_keylist_mode_t mode = 0;
64   gpgme_key_t key;
65   gpgme_keylist_result_t result;
66   int import = 0;
67   gpgme_key_t keyarray[100];
68   int keyidx = 0;
69
70   if (argc)
71     { argc--; argv++; }
72
73   while (argc && last_argc != argc )
74     {
75       last_argc = argc;
76       if (!strcmp (*argv, "--"))
77         {
78           argc--; argv++;
79           break;
80         }
81       else if (!strcmp (*argv, "--help"))
82         show_usage (0);
83       else if (!strcmp (*argv, "--verbose"))
84         {
85           verbose = 1;
86           argc--; argv++;
87         }
88       else if (!strcmp (*argv, "--local"))
89         {
90           mode |= GPGME_KEYLIST_MODE_LOCAL;
91           argc--; argv++;
92         }
93       else if (!strcmp (*argv, "--extern"))
94         {
95           mode |= GPGME_KEYLIST_MODE_EXTERN;
96           argc--; argv++;
97         }
98       else if (!strcmp (*argv, "--sigs"))
99         {
100           mode |= GPGME_KEYLIST_MODE_SIGS;
101           argc--; argv++;
102         }
103       else if (!strcmp (*argv, "--sig-notations"))
104         {
105           mode |= GPGME_KEYLIST_MODE_SIG_NOTATIONS;
106           argc--; argv++;
107         }
108       else if (!strcmp (*argv, "--ephemeral"))
109         {
110           mode |= GPGME_KEYLIST_MODE_EPHEMERAL;
111           argc--; argv++;
112         }
113       else if (!strcmp (*argv, "--validate"))
114         {
115           mode |= GPGME_KEYLIST_MODE_VALIDATE;
116           argc--; argv++;
117         }
118       else if (!strcmp (*argv, "--import"))
119         {
120           import = 1;
121           argc--; argv++;
122         }
123       else if (!strncmp (*argv, "--", 2))
124         show_usage (1);
125       
126     }          
127  
128   if (argc > 1)
129     show_usage (1);
130
131   init_gpgme (GPGME_PROTOCOL_OpenPGP);
132
133   err = gpgme_new (&ctx);
134   fail_if_err (err);
135   gpgme_set_protocol (ctx, GPGME_PROTOCOL_OpenPGP);
136
137   gpgme_set_keylist_mode (ctx, mode);
138
139   err = gpgme_op_keylist_start (ctx, argc? argv[0]:NULL, 0);
140   fail_if_err (err);
141     
142   while (!(err = gpgme_op_keylist_next (ctx, &key)))
143     {
144       gpgme_user_id_t uid;
145       int nuids;
146       
147
148       printf ("keyid   : %s\n", key->subkeys?nonnull (key->subkeys->keyid):"?");
149       printf ("fpr     : %s\n", key->subkeys?nonnull (key->subkeys->fpr):"?");
150       printf ("caps    : %s%s%s%s\n",
151               key->can_encrypt? "e":"",
152               key->can_sign? "s":"",
153               key->can_certify? "c":"",
154               key->can_authenticate? "a":"");
155       printf ("flags   :%s%s%s%s%s%s\n",
156               key->secret? " secret":"",
157               key->revoked? " revoked":"",
158               key->expired? " expired":"",
159               key->disabled? " disabled":"",
160               key->invalid? " invalid":"",
161               key->is_qualified? " qualifid":"");
162       for (nuids=0, uid=key->uids; uid; uid = uid->next, nuids++)
163         {
164           printf ("userid %d: %s\n", nuids, nonnull(uid->uid));
165           printf ("valid  %d: %s\n", nuids, 
166                   uid->validity == GPGME_VALIDITY_UNKNOWN? "unknown":
167                   uid->validity == GPGME_VALIDITY_UNDEFINED? "undefined":
168                   uid->validity == GPGME_VALIDITY_NEVER? "never":
169                   uid->validity == GPGME_VALIDITY_MARGINAL? "marginal":
170                   uid->validity == GPGME_VALIDITY_FULL? "full":
171                   uid->validity == GPGME_VALIDITY_ULTIMATE? "ultimate": "[?]");
172         }
173
174       putchar ('\n');
175
176       if (import)
177         {
178           if (keyidx < DIM (keyarray)-1)
179             keyarray[keyidx++] = key;
180           else
181             {
182               fprintf (stderr, PGM": too many keys in import mode"
183                        "- skipping this key\n");
184               gpgme_key_unref (key);
185             }
186         }
187       else
188         gpgme_key_unref (key);
189     }
190   if (gpg_err_code (err) != GPG_ERR_EOF)
191     fail_if_err (err);
192   err = gpgme_op_keylist_end (ctx);
193   fail_if_err (err);
194   keyarray[keyidx] = NULL;
195
196   result = gpgme_op_keylist_result (ctx);
197   if (result->truncated)
198     {
199       fprintf (stderr, PGM ": key listing unexpectedly truncated\n");
200       exit (1);
201     }
202
203   if (import)
204     {
205       gpgme_import_result_t impres;
206
207       err = gpgme_op_import_keys (ctx, keyarray);
208       fail_if_err (err);
209       impres = gpgme_op_import_result (ctx);
210       if (!impres)
211         {
212           fprintf (stderr, PGM ": no import result returned\n");
213           exit (1);
214         }
215       print_import_result (impres);
216     }
217
218   for (keyidx=0; keyarray[keyidx]; keyidx++)
219     gpgme_key_unref (keyarray[keyidx]);
220
221   gpgme_release (ctx);
222   return 0;
223 }