mirror of
https://github.com/monero-project/gitian.sigs.git
synced 2025-01-11 12:54:31 +00:00
Merge pull request #31 into master
This commit is contained in:
commit
4b0d2bf5d9
1 changed files with 22 additions and 22 deletions
|
@ -12,8 +12,8 @@ def verify():
|
||||||
global args, workdir
|
global args, workdir
|
||||||
if args.import_keys:
|
if args.import_keys:
|
||||||
os.chdir('gitian-pubkeys')
|
os.chdir('gitian-pubkeys')
|
||||||
print('Importing pubkeys...')
|
print('Importing gpg pubkeys...')
|
||||||
keys = [f for f in glob.glob("*.asc", recursive=True)]
|
keys = [f for f in glob.glob('*.asc', recursive=False)]
|
||||||
for key in keys:
|
for key in keys:
|
||||||
subprocess.check_call([GPG, '--import', key])
|
subprocess.check_call([GPG, '--import', key])
|
||||||
os.chdir('../')
|
os.chdir('../')
|
||||||
|
@ -38,29 +38,30 @@ def verify():
|
||||||
|
|
||||||
print('All signatures verified correctly.\n')
|
print('All signatures verified correctly.\n')
|
||||||
print('Beginning checksum comparison...\n')
|
print('Beginning checksum comparison...\n')
|
||||||
# Check that the contents between the assertion signers match. This is meant for quick verification, not for validation of their contents
|
# Check that the contents between the assertion signers match.
|
||||||
|
# This is meant for quick verification, not for validation of their contents.
|
||||||
# TODO: prevent false positives related to filenames / whitespace / formatting.
|
# TODO: prevent false positives related to filenames / whitespace / formatting.
|
||||||
builds = glob.glob(ver_pattern + '*')
|
builds = glob.glob(ver_pattern + '*')
|
||||||
for build in builds:
|
for build in builds:
|
||||||
first_file = glob.glob(build + '/*/*.assert', recursive=False)[0]
|
first_file = glob.glob(build + '/*/*.assert', recursive=False)[0]
|
||||||
f = open(first_file, "r")
|
f = open(first_file, 'r')
|
||||||
first_file_contents = f.readlines()
|
first_file_contents = f.readlines()
|
||||||
f.close()
|
f.close()
|
||||||
for assert_file in glob.glob(build + '/*/*.assert', recursive=False):
|
for assert_file in glob.glob(build + '/*/*.assert', recursive=False):
|
||||||
f = open(assert_file, "r")
|
f = open(assert_file, 'r')
|
||||||
assert_file_contents = f.readlines()
|
assert_file_contents = f.readlines()
|
||||||
f.close()
|
f.close()
|
||||||
for i in range(len(assert_file_contents)):
|
for i in range(len(assert_file_contents)):
|
||||||
# compare everything in the assertions until the base image manifests
|
# Compare each line in the assertion file until base_manifests:
|
||||||
if assert_file_contents[i] == "- base_manifests: !!omap\n":
|
if assert_file_contents[i] == '- base_manifests: !!omap\n':
|
||||||
break
|
break
|
||||||
# the OSX SDK may change from time to time
|
# The OSX SDK may change from time to time:
|
||||||
if "sdk" in assert_file_contents[i]:
|
if 'sdk' in assert_file_contents[i]:
|
||||||
continue
|
continue
|
||||||
if assert_file_contents[i] != first_file_contents[i]:
|
if assert_file_contents[i] != first_file_contents[i]:
|
||||||
print("ERROR: Found conflicting contents on line:", i)
|
sys.stderr.write('ERROR: Found conflicting contents on line:', i)
|
||||||
print(assert_file, ":\n", assert_file_contents[i])
|
sys.stderr.write(assert_file + ':\n' + assert_file_contents[i])
|
||||||
print(first_file, ":\n", first_file_contents[i])
|
sys.stderr.write(first_file + ':\n' + first_file_contents[i])
|
||||||
exit(1)
|
exit(1)
|
||||||
|
|
||||||
print('No discrepancies found in assertion files.')
|
print('No discrepancies found in assertion files.')
|
||||||
|
@ -68,15 +69,15 @@ def verify():
|
||||||
os.chdir(workdir)
|
os.chdir(workdir)
|
||||||
|
|
||||||
def main():
|
def main():
|
||||||
host_repo = "git@github.com/monero-project/gitian.sigs"
|
host_repo = 'git@github.com/monero-project/gitian.sigs'
|
||||||
global args, workdir
|
global args, workdir
|
||||||
parser = argparse.ArgumentParser(usage='%(prog)s [options]', description='Use this script to verify the signatures of existing gitian assert files and / or assert files in a specific pull request.')
|
parser = argparse.ArgumentParser(usage='%(prog)s [options]', description='Use this script to verify the signatures of existing gitian assert files and / or assert files in a specific pull request.')
|
||||||
parser.add_argument('-p', '--pull_id', dest='pull_id', help='Github Pull request id to check')
|
parser.add_argument('-p', '--pull_id', dest='pull_id', help='GitHub Pull request id to check')
|
||||||
parser.add_argument('-r', '--remote', dest='remote', default='upstream', help='git remote repository')
|
parser.add_argument('-r', '--remote', dest='remote', default='upstream', help='The git remote repository')
|
||||||
parser.add_argument('-t', '--target-branch', dest='target_branch', default='master', help='Remote repository merge into branch')
|
parser.add_argument('-t', '--target-branch', dest='target_branch', default='master', help='Remote repository merge into branch')
|
||||||
parser.add_argument('-m', '--merge', action='store_true', dest='merge', help='Merge the given pull request id')
|
parser.add_argument('-m', '--merge', action='store_true', dest='merge', help='Merge the given pull request id')
|
||||||
parser.add_argument('-k', '--refresh-keys', action='store_true', dest='refresh_keys', help='refresh all pgp public keys that are currently in the gpg keyring.')
|
parser.add_argument('-k', '--refresh-keys', action='store_true', dest='refresh_keys', help='Refresh all public keys that are currently in the gpg keyring.')
|
||||||
parser.add_argument('-i', '--import-keys', action='store_true', dest='import_keys', help='import all public keys in the gitian-pubkeys directory to the gpg keyring.')
|
parser.add_argument('-i', '--import-keys', action='store_true', dest='import_keys', help='Import all public keys in the gitian-pubkeys directory to the gpg keyring.')
|
||||||
parser.add_argument('-o', '--no-verify', action='store_true', dest='no_verify', help='Do not run any signature verification')
|
parser.add_argument('-o', '--no-verify', action='store_true', dest='no_verify', help='Do not run any signature verification')
|
||||||
parser.add_argument('-v', '--version', dest='version', help='Version number of sigs to be verified (defaults to all versions if not specified).')
|
parser.add_argument('-v', '--version', dest='version', help='Version number of sigs to be verified (defaults to all versions if not specified).')
|
||||||
|
|
||||||
|
@ -85,18 +86,17 @@ def main():
|
||||||
workdir = os.getcwd()
|
workdir = os.getcwd()
|
||||||
if args.pull_id != None:
|
if args.pull_id != None:
|
||||||
# Get branch from remote pull request and compare
|
# Get branch from remote pull request and compare
|
||||||
head_branch = args.pull_id+'_head'
|
head_branch = args.pull_id + '_head'
|
||||||
|
|
||||||
subprocess.check_call([GIT, 'fetch', args.remote])
|
subprocess.check_call([GIT, 'fetch', args.remote])
|
||||||
subprocess.check_call([GIT, 'checkout', args.remote+'/'+args.target_branch])
|
subprocess.check_call([GIT, 'checkout', args.remote + '/' + args.target_branch])
|
||||||
subprocess.check_call([GIT, 'fetch','-q', args.remote, 'pull/'+args.pull_id+'/head:'+head_branch])
|
subprocess.check_call([GIT, 'fetch', '-q', args.remote, 'pull/' + args.pull_id + '/head:' + head_branch])
|
||||||
subprocess.check_call([GIT, 'checkout', '-f', head_branch])
|
subprocess.check_call([GIT, 'checkout', '-f', head_branch])
|
||||||
if args.merge:
|
if args.merge:
|
||||||
# Hard reset the target branch to the remote's state and merge the pull request's head branch into it
|
# Hard reset the target branch to the remote's state and merge the pull request's head branch into it
|
||||||
subprocess.check_call([GIT, 'checkout', args.target_branch])
|
subprocess.check_call([GIT, 'checkout', args.target_branch])
|
||||||
subprocess.check_call([GIT, 'reset', '--hard', args.remote + '/' + args.target_branch])
|
subprocess.check_call([GIT, 'reset', '--hard', args.remote + '/' + args.target_branch])
|
||||||
print('Merging and signing pull request #' + args.pull_id + ' , if you are using a smartcard, confirm the signature now.')
|
print('Merging and signing pull request #' + args.pull_id + ' , if you are using a smartcard, confirm the signature now.')
|
||||||
subprocess.check_call([GIT, 'merge','-q', '--commit', '--no-edit', '-m', 'Merge pull request #'+args.pull_id+' into '+args.target_branch, '--no-ff', '--gpg-sign', head_branch])
|
subprocess.check_call([GIT, 'merge', '-q', '--commit', '--no-edit', '-m', 'Merge pull request #' + args.pull_id + ' into ' + args.target_branch, '--no-ff', '--gpg-sign', head_branch])
|
||||||
if not args.no_verify:
|
if not args.no_verify:
|
||||||
verify()
|
verify()
|
||||||
subprocess.check_call([GIT, 'checkout', 'master'])
|
subprocess.check_call([GIT, 'checkout', 'master'])
|
||||||
|
|
Loading…
Reference in a new issue