From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: from lists.gentoo.org (pigeon.gentoo.org [208.92.234.80]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by finch.gentoo.org (Postfix) with ESMTPS id 1143D139088 for ; Sat, 24 Dec 2016 09:41:22 +0000 (UTC) Received: from pigeon.gentoo.org (localhost [127.0.0.1]) by pigeon.gentoo.org (Postfix) with SMTP id 7533F2241A3; Sat, 24 Dec 2016 09:41:20 +0000 (UTC) Received: from smtp.gentoo.org (smtp.gentoo.org [140.211.166.183]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by pigeon.gentoo.org (Postfix) with ESMTPS id 4290CE0C1E for ; Sat, 24 Dec 2016 09:41:20 +0000 (UTC) Received: from oystercatcher.gentoo.org (unknown [IPv6:2a01:4f8:202:4333:225:90ff:fed9:fc84]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by smtp.gentoo.org (Postfix) with ESMTPS id CFADA341134 for ; Sat, 24 Dec 2016 09:41:18 +0000 (UTC) Received: from localhost.localdomain (localhost [127.0.0.1]) by oystercatcher.gentoo.org (Postfix) with ESMTP id 424E89D8 for ; Sat, 24 Dec 2016 09:41:17 +0000 (UTC) From: "Brian Dolbec" To: gentoo-commits@lists.gentoo.org Content-Transfer-Encoding: 8bit Content-type: text/plain; charset=UTF-8 Reply-To: gentoo-dev@lists.gentoo.org, "Brian Dolbec" Message-ID: <1482572365.89d64ec041b3f4ce51d339e252073bf38bb77206.dolsen@gentoo> Subject: [gentoo-commits] proj/gentoo-keys:gsoc-2016 commit in: gkeys/gkeys/ X-VCS-Repository: proj/gentoo-keys X-VCS-Files: gkeys/gkeys/action_map.py gkeys/gkeys/actions.py gkeys/gkeys/lib.py X-VCS-Directories: gkeys/gkeys/ X-VCS-Committer: dolsen X-VCS-Committer-Name: Brian Dolbec X-VCS-Revision: 89d64ec041b3f4ce51d339e252073bf38bb77206 X-VCS-Branch: gsoc-2016 Date: Sat, 24 Dec 2016 09:41:17 +0000 (UTC) Precedence: bulk List-Post: List-Help: List-Unsubscribe: List-Subscribe: List-Id: Gentoo Linux mail X-BeenThere: gentoo-commits@lists.gentoo.org X-Archives-Salt: e30ca9c8-caf8-434b-ad25-d7e5bc39ead2 X-Archives-Hash: 6372fc0bb536a43546dcdc10e44f2cdc commit: 89d64ec041b3f4ce51d339e252073bf38bb77206 Author: aeroniero33 gmail com> AuthorDate: Tue Jun 21 01:40:28 2016 +0000 Commit: Brian Dolbec gentoo org> CommitDate: Sat Dec 24 09:39:25 2016 +0000 URL: https://gitweb.gentoo.org/proj/gentoo-keys.git/commit/?id=89d64ec0 Created the send-key function use _set_category() for consistency gkeys/gkeys/action_map.py | 11 ++++++++++- gkeys/gkeys/actions.py | 27 +++++++++++++++++++++++++++ gkeys/gkeys/lib.py | 16 ++++++++++++++++ 3 files changed, 53 insertions(+), 1 deletion(-) diff --git a/gkeys/gkeys/action_map.py b/gkeys/gkeys/action_map.py index e4ea412..f372a5c 100644 --- a/gkeys/gkeys/action_map.py +++ b/gkeys/gkeys/action_map.py @@ -18,7 +18,7 @@ Seed_Actions = ['----seeds----', 'add-seed', 'fetch-seed', 'list-seed', 'list-seedfiles', 'move-seed', 'remove-seed'] Key_Actions = ['----keys-----', 'check-key', 'installed', - 'install-key', 'list-key', 'refresh-key', 'remove-key', + 'install-key', 'list-key', 'send-key', 'refresh-key', 'remove-key', 'search-key', 'spec-check'] General_Actions = ['---general---', 'list-cats', 'sign','verify'] @@ -174,6 +174,15 @@ Gpg info.: pub 4096R/825533CBF6CD6C97 2014-10-03 [expires: 2017-09-17] Gkey task results: Done.''', }), + ('send-key', { + 'func': 'sendkey', + 'options': ['category', 'nick', 'name', 'fingerprint', 'keyid', 'keys', + 'keydir', 'keyring'], + 'desc': '''Uploads the selected gpg key''', + 'long_desc': '''Uploads the selected gpg key''', + 'example': '''gkeys send-key -C gentoo -n gkeys''', + }), + ('move-key', { 'func': 'movekey', 'options': ['category', 'nick', 'name', 'fingerprint', 'keys', diff --git a/gkeys/gkeys/actions.py b/gkeys/gkeys/actions.py index aaa3f02..12b8efa 100644 --- a/gkeys/gkeys/actions.py +++ b/gkeys/gkeys/actions.py @@ -194,6 +194,33 @@ class Actions(ActionBase): return (False, messages) + def sendkey(self, args): + '''Send selected key(s) to the server''' + if not args.category: + return (False, ["Please specify seeds type."]) + self.logger.debug(_unicode("ACTIONS: sendkey; args: %s") + % _unicode(args)) + seeds = self.seedhandler.load_category(args.category, refresh=True) + self._set_category(args.category) + results = {} + kwargs = self.seedhandler.build_gkeydict(args) + keyresults = seeds.list(**kwargs) + if keyresults: + self.output('', '\n sending keys...') + else: + return (False, ["Key(s) not found"]) + for gkey in sorted(keyresults): + self.logger.info(_unicode("Sending key %s, %s") + % (gkey.nick, gkey.pub_keyid)) + self.output('', _unicode(" %s: %s") + % (gkey.name, ', '.join(gkey.pub_keyid))) + self.logger.debug(_unicode("ACTIONS: sendkey; gkey = %s") + % _unicode(gkey)) + results[gkey.keydir] = self.gpg.send_keys(gkey) + return (True, ['Completed']) + + + def listkey(self, args): '''Pretty-print the selected gpg key''' # get confirmation diff --git a/gkeys/gkeys/lib.py b/gkeys/gkeys/lib.py index 5ad1aab..a8529f4 100644 --- a/gkeys/gkeys/lib.py +++ b/gkeys/gkeys/lib.py @@ -273,6 +273,22 @@ class GkeysGPG(GPG): self.logger.info('GPG return code: ' + str(result.returncode)) return result + def send_keys(self, gkey): + '''Send gkey to keyserver + @param gkey: the gkey to be sent to the server + @return: GKEY_CHECK instance + ''' + self.config.defaults['gpg_defaults'].append('--no-permission-warning') + self.set_keyserver() + self.set_keydir(gkey.keydir, 'send-keys', reset=True) + self.set_keyring('pubring.gpg', 'send-keys', reset=False) + self.set_keyseedfile(refresh=True) + self.logger.debug("LIB: send-keys, gkey: %s" % str(gkey)) + self.logger.debug("** Calling runGPG with Running 'gpg %s --send-keys' for: %s" + % (' '.join(self.config.get_key('tasks', 'send-keys')), str(gkey))) + result = self.runGPG(task='send-keys', inputfile='') + self.logger.info('GPG return code: ' + str(result.returncode)) + return result def check_keys(self, keydir, keyid, result=None): '''Check specified or all keys based on the seed type