e61952413e2844e80634387cf59cbc5afa67c9d4
[gpgme.git] / lang / python / examples / howto / import-keys-hkp.py
1 #!/usr/bin/env python3
2 # -*- coding: utf-8 -*-
3
4 from __future__ import absolute_import, division, unicode_literals
5
6 import gpg
7 import hkp4py
8 import sys
9
10 # Copyright (C) 2018 Ben McGinnes <ben@gnupg.org>
11 #
12 # This program is free software; you can redistribute it and/or modify it under
13 # the terms of the GNU General Public License as published by the Free Software
14 # Foundation; either version 2 of the License, or (at your option) any later
15 # version.
16 #
17 # This program is free software; you can redistribute it and/or modify it under
18 # the terms of the GNU Lesser General Public License as published by the Free
19 # Software Foundation; either version 2.1 of the License, or (at your option)
20 # any later version.
21 #
22 # This program is distributed in the hope that it will be useful, but WITHOUT
23 # ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
24 # FOR A PARTICULAR PURPOSE.  See the GNU General Public License and the GNU
25 # Lesser General Public License for more details.
26 #
27 # You should have received a copy of the GNU General Public License and the GNU
28 # Lesser General Public along with this program; if not, see
29 # <https://www.gnu.org/licenses/>.
30
31 print("""
32 This script imports one or more public keys from the SKS keyservers.
33 """)
34
35 c = gpg.Context()
36 server = hkp4py.KeyServer("hkps://hkps.pool.sks-keyservers.net")
37 results = []
38
39 if len(sys.argv) > 2:
40     pattern = " ".join(sys.argv[1:])
41 elif len(sys.argv) == 2:
42     pattern = sys.argv[1]
43 else:
44     pattern = input("Enter the pattern to search for keys or user IDs: ")
45
46 try:
47     keys = server.search(pattern)
48     if keys is not None:
49         print("Found {0} key(s).".format(len(keys)))
50     else:
51         pass
52 except Exception as e:
53     keys = []
54     for logrus in pattern.split():
55         if logrus.startswith("0x") is True:
56             key = server.search(logrus)
57         else:
58             key = server.search("0x{0}".format(logrus))
59         keys.append(key[0])
60     print("Found {0} key(s).".format(len(keys)))
61
62 if keys is not None:
63     for key in keys:
64         import_result = c.key_import(key.key_blob)
65         results.append(import_result)
66
67 for result in results:
68     if result is not None and hasattr(result, "considered") is False:
69         print(result)
70     elif result is not None and hasattr(result, "considered") is True:
71         num_keys = len(result.imports)
72         new_revs = result.new_revocations
73         new_sigs = result.new_signatures
74         new_subs = result.new_sub_keys
75         new_uids = result.new_user_ids
76         new_scrt = result.secret_imported
77         nochange = result.unchanged
78         print("""
79 The total number of keys considered for import was:  {0}
80
81    Number of keys revoked:  {1}
82  Number of new signatures:  {2}
83     Number of new subkeys:  {3}
84    Number of new user IDs:  {4}
85 Number of new secret keys:  {5}
86  Number of unchanged keys:  {6}
87
88 The key IDs for all considered keys were:
89 """.format(num_keys, new_revs, new_sigs, new_subs, new_uids, new_scrt,
90            nochange))
91         for i in range(num_keys):
92             print(result.imports[i].fpr)
93         print("")
94     else:
95         pass