import sys
import argparse
import os
import hashlib
sys.path.append(os.path.dirname(os.path.dirname(os.path.dirname(os.path.abspath(__file__)))))
import file_utils
from scripts.util import build_utils
__MAX_BUF = 1024 * 1024
def _gen_signature(input_file):
if not os.path.isfile(input_file):
raise Exception()
hash_value = ''
sha256obj = hashlib.sha256()
try:
with open(input_file, 'rb') as file_obj:
while True:
buf = file_obj.read(__MAX_BUF)
if not buf:
break
sha256obj.update(buf)
hash_value = sha256obj.hexdigest()
except OSError as err:
sys.stdout.write("read file failed. {}".format(err))
return hash_value
def _write_signature_file(signature_file, hash_value):
if os.path.exists(signature_file):
os.remove(signature_file)
file_utils.write_file(signature_file, hash_value)
def _update_signature(signature_file, new_hash_value):
if os.path.exists(signature_file):
data = file_utils.read_file(signature_file)
if data is None:
raise Exception(
"read signatrue file '{}' failed.".format(signature_file))
old_value = data[0]
if old_value is None or old_value == '':
raise Exception(
"signatrue file '{}' content error.".format(signature_file))
if old_value == new_hash_value:
return
_write_signature_file(signature_file, new_hash_value)
def main():
parser = argparse.ArgumentParser()
parser.add_argument('--input-dir', required=True)
parser.add_argument('--output-zipfile', required=True)
parser.add_argument('--signature-file', required=True)
args = parser.parse_args()
if os.path.exists(args.output_zipfile):
os.remove(args.output_zipfile)
build_utils.zip_dir(args.output_zipfile, args.input_dir)
if not os.path.exists(args.output_zipfile):
raise Exception("generate zipfile '{}' failed.".format(
args.output_zipfile))
hash_value = _gen_signature(args.output_zipfile)
_update_signature(args.signature_file, hash_value)
return 0
if __name__ == '__main__':
sys.exit(main())