contrib: Clean up previous_releases.py

* Replace curl single char options with their verbose counterpart
* Stricter check for tarballHash
This commit is contained in:
MarcoFalke 2020-07-21 10:56:12 +02:00
parent ea595d39f7
commit facdf530c7
No known key found for this signature in database
GPG key ID: CE2B75697E69A548

View file

@ -4,7 +4,9 @@
# Distributed under the MIT software license, see the accompanying # Distributed under the MIT software license, see the accompanying
# file COPYING or http://www.opensource.org/licenses/mit-license.php. # file COPYING or http://www.opensource.org/licenses/mit-license.php.
# #
# Build previous releases. # Download or build previous releases.
# Needs curl and tar to download a release, or the build dependencies when
# building a release.
import argparse import argparse
import contextlib import contextlib
@ -52,14 +54,14 @@ def download_binary(tag, args) -> int:
print('Fetching: {sha256SumsUrl}'.format(sha256SumsUrl=sha256SumsUrl)) print('Fetching: {sha256SumsUrl}'.format(sha256SumsUrl=sha256SumsUrl))
header, status = subprocess.Popen( header, status = subprocess.Popen(
['curl', '-I', tarballUrl], stdout=subprocess.PIPE).communicate() ['curl', '--head', tarballUrl], stdout=subprocess.PIPE).communicate()
if re.search("404 Not Found", header.decode("utf-8")): if re.search("404 Not Found", header.decode("utf-8")):
print("Binary tag was not found") print("Binary tag was not found")
return 1 return 1
curlCmds = [ curlCmds = [
['curl', '-O', tarballUrl], ['curl', '--remote-name', tarballUrl],
['curl', "-o", sha256Sums, sha256SumsUrl], ['curl', '--output', sha256Sums, sha256SumsUrl],
] ]
for cmd in curlCmds: for cmd in curlCmds:
@ -69,23 +71,17 @@ def download_binary(tag, args) -> int:
hasher = hashlib.sha256() hasher = hashlib.sha256()
with open(tarball, "rb") as afile: with open(tarball, "rb") as afile:
buf = afile.read() hasher.update(afile.read())
hasher.update(buf)
afile.close()
tarballHash = hasher.hexdigest() tarballHash = hasher.hexdigest()
file = open(sha256Sums, 'r', encoding="utf-8") tarballHash = '{} {}\n'.format(tarballHash, tarball)
lst = list(file.readlines()) with open(sha256Sums, 'r', encoding="utf-8") as afile:
file.close() shasums = afile.readlines()
lastline = lst[len(lst)-1]
for line in lst: if tarballHash not in shasums:
if re.search(tarballHash, line):
print("Checksum matched")
break
elif lastline == line:
print("Checksum did not match") print("Checksum did not match")
Path(tarball).unlink() Path(tarball).unlink()
return 1 return 1
print("Checksum matched")
# Bitcoin Core Release Signing Keys v0.11.0+ # Bitcoin Core Release Signing Keys v0.11.0+
signingKey = "01EA5486DE18A882D4C2684590C8019E36C2E964" signingKey = "01EA5486DE18A882D4C2684590C8019E36C2E964"
@ -182,7 +178,6 @@ def check_host(args) -> int:
def main(args) -> int: def main(args) -> int:
if not Path(args.target_dir).is_dir():
Path(args.target_dir).mkdir(exist_ok=True, parents=True) Path(args.target_dir).mkdir(exist_ok=True, parents=True)
print("Releases directory: {}".format(args.target_dir)) print("Releases directory: {}".format(args.target_dir))
ret = check_host(args) ret = check_host(args)