release.py now checks to make sure file hash is correct; release.py now asks the user to review the filepath and release title are correct

This commit is contained in:
cyian-1756 2018-06-06 12:33:53 -04:00
parent ca6ed447e6
commit 8e4f91ada2

View File

@ -3,6 +3,7 @@ import re
import os
import sys
from hashlib import sha256
from github import Github
import json
from datetime import timezone
@ -13,6 +14,7 @@ parser = argparse.ArgumentParser(description="Make a new ripme release on github
parser.add_argument("-f", "--file", help="Path to the version of ripme to release")
parser.add_argument("-t", "--token", help="Your github personal access token")
parser.add_argument("-d", "--debug", help="Run in debug mode", action="store_true")
parser.add_argument("-n", "--non-interactive", help="Do not ask for any input from the user", action="store_true")
args = parser.parse_args()
@ -23,6 +25,8 @@ def isJar(filename):
return filename.endswith("jar")
# Returns true if last entry to the "changeList" section of ripme.json is in the format of $number.$number.$number: and
# false if not
def isValidCommitMessage(message):
if debug:
print("Checking if {} matchs pattern ^\d+\.\d+\.\d+:".format(message))
@ -30,19 +34,41 @@ def isValidCommitMessage(message):
return re.match(pattern, message)
fileToUpload = args.file
commitMessage = json.loads(open("ripme.json").read()).get("changeList")[0]
ripmeJson = json.loads(open("ripme.json").read())
fileToUploadPath = args.file
InNoninteractiveMode = args.non_interactive
commitMessage = ripmeJson.get("changeList")[0]
debug = args.debug
if not os.path.isfile(fileToUpload):
print("[!] Error: {} does not exist".format(fileToUpload))
if not os.path.isfile(fileToUploadPath):
print("[!] Error: {} does not exist".format(fileToUploadPath))
sys.exit(1)
if not isJar(fileToUpload):
print("[!] Error: {} is not a jar file!".format(fileToUpload))
if not isJar(fileToUploadPath):
print("[!] Error: {} is not a jar file!".format(fileToUploadPath))
sys.exit(1)
if not isValidCommitMessage(commitMessage):
print("[!] Error: {} is not a valid commit message as it does not start with a version".format(fileToUpload))
print("[!] Error: {} is not a valid commit message as it does not start with a version".format(fileToUploadPath))
sys.exit(1)
ripmeUpdate = open(fileToUploadPath, mode='rb').read()
# The hash that we expect the update to have
expectedHash = ripmeJson.get("currentHash")
# The actual hash of the file on disk
actualHash = sha256(ripmeUpdate).hexdigest()
# Make sure that the hash of the file we're uploading matches the hash in ripme.json. These hashes not matching will
# cause ripme to refuse to install the update for all users who haven't disabled update hash checking
if expectedHash != actualHash:
print("[!] Error: expected hash of file and actual hash differ")
print("[!] Expected hash is {}".format(expectedHash))
print("[!] Actual hash is {}".format(actualHash))
# This only runs in we're in interactive mode
if not InNoninteractiveMode:
print("File path: {}\n".format(fileToUploadPath))
print("Release title: {}".format(commitMessage))
input("\nPlease review the information above and ensure it is correct and then press enter")