17
17
"""Command which looks for unsigned commits by the current user, and signs them.
20
from bzrlib.lazy_import import lazy_import
21
lazy_import(globals(), """
20
from __future__ import absolute_import
26
revision as _mod_revision,
26
from bzrlib.bzrdir import BzrDir
28
from bzrlib.commands import Command
29
from bzrlib.option import Option
28
from .commands import Command
29
from .option import Option
30
from .i18n import gettext, ngettext
31
from .sixish import text_type
32
34
class cmd_sign_my_commits(Command):
46
help='Don\'t actually sign anything, just print'
47
' the revisions that would be signed.'),
48
help='Don\'t actually sign anything, just print'
49
' the revisions that would be signed.'),
49
51
takes_args = ['location?', 'committer?']
51
53
def run(self, location=None, committer=None, dry_run=False):
52
54
if location is None:
53
bzrdir = BzrDir.open_containing('.')[0]
55
bzrdir = controldir.ControlDir.open_containing('.')[0]
55
57
# Passed in locations should be exact
56
bzrdir = BzrDir.open(location)
58
bzrdir = controldir.ControlDir.open(location)
57
59
branch = bzrdir.open_branch()
58
60
repo = branch.repository
59
branch_config = branch.get_config()
61
branch_config = branch.get_config_stack()
61
63
if committer is None:
62
committer = branch_config.username()
64
committer = branch_config.get('email')
63
65
gpg_strategy = gpg.GPGStrategy(branch_config)
68
with repo.lock_write():
69
graph = repo.get_graph()
68
70
repo.start_write_group()
70
for rev_id in repo.get_ancestry(branch.last_revision())[1:]:
72
for rev_id, parents in graph.iter_ancestry(
73
[branch.last_revision()]):
74
if _mod_revision.is_null(rev_id):
71
79
if repo.has_signature_for_revision_id(rev_id):
73
81
rev = repo.get_revision(rev_id)
86
94
repo.commit_write_group()
89
print 'Signed %d revisions' % (count,)
96
ngettext('Signed %d revision.\n', 'Signed %d revisions.\n', count) %
100
class cmd_verify_signatures(Command):
101
__doc__ = """Verify all commit signatures.
103
Verifies that all commits in the branch are signed by known GnuPG keys.
107
Option('acceptable-keys',
108
help='Comma separated list of GPG key patterns which are'
109
' acceptable for verification.',
115
takes_args = ['location?']
117
def run(self, acceptable_keys=None, revision=None, verbose=None,
119
bzrdir = controldir.ControlDir.open_containing(location)[0]
120
branch = bzrdir.open_branch()
121
repo = branch.repository
122
branch_config = branch.get_config_stack()
123
gpg_strategy = gpg.GPGStrategy(branch_config)
125
gpg_strategy.set_acceptable_keys(acceptable_keys)
128
self.outf.write(string + "\n")
130
def write_verbose(string):
131
self.outf.write(" " + string + "\n")
133
self.add_cleanup(repo.lock_read().unlock)
134
# get our list of revisions
136
if revision is not None:
137
if len(revision) == 1:
138
revno, rev_id = revision[0].in_history(branch)
139
revisions.append(rev_id)
140
elif len(revision) == 2:
141
from_revno, from_revid = revision[0].in_history(branch)
142
to_revno, to_revid = revision[1].in_history(branch)
144
to_revno = branch.revno()
145
if from_revno is None or to_revno is None:
146
raise errors.BzrCommandError(gettext(
147
'Cannot verify a range of non-revision-history revisions'))
148
for revno in range(from_revno, to_revno + 1):
149
revisions.append(branch.get_rev_id(revno))
151
# all revisions by default including merges
152
graph = repo.get_graph()
154
for rev_id, parents in graph.iter_ancestry(
155
[branch.last_revision()]):
156
if _mod_revision.is_null(rev_id):
161
revisions.append(rev_id)
162
count, result, all_verifiable = gpg.bulk_verify_signatures(
163
repo, revisions, gpg_strategy)
165
write(gettext("All commits signed with verifiable keys"))
167
for message in gpg.verbose_valid_message(result):
168
write_verbose(message)
171
write(gpg.valid_commits_message(count))
173
for message in gpg.verbose_valid_message(result):
174
write_verbose(message)
175
write(gpg.expired_commit_message(count))
177
for message in gpg.verbose_expired_key_message(result, repo):
178
write_verbose(message)
179
write(gpg.unknown_key_message(count))
181
for message in gpg.verbose_missing_key_message(result):
182
write_verbose(message)
183
write(gpg.commit_not_valid_message(count))
185
for message in gpg.verbose_not_valid_message(result, repo):
186
write_verbose(message)
187
write(gpg.commit_not_signed_message(count))
189
for message in gpg.verbose_not_signed_message(result, repo):
190
write_verbose(message)