diff options
author | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-15 05:54:39 +0000 |
---|---|---|
committer | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-15 05:54:39 +0000 |
commit | 267c6f2ac71f92999e969232431ba04678e7437e (patch) | |
tree | 358c9467650e1d0a1d7227a21dac2e3d08b622b2 /bin/update/create_full_mar.py | |
parent | Initial commit. (diff) | |
download | libreoffice-267c6f2ac71f92999e969232431ba04678e7437e.tar.xz libreoffice-267c6f2ac71f92999e969232431ba04678e7437e.zip |
Adding upstream version 4:24.2.0.upstream/4%24.2.0
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'bin/update/create_full_mar.py')
-rwxr-xr-x | bin/update/create_full_mar.py | 80 |
1 files changed, 80 insertions, 0 deletions
diff --git a/bin/update/create_full_mar.py b/bin/update/create_full_mar.py new file mode 100755 index 0000000000..b4f53c48f1 --- /dev/null +++ b/bin/update/create_full_mar.py @@ -0,0 +1,80 @@ +#!/usr/bin/env python3 + +import sys +import glob +import os +import re +import subprocess +import json +import argparse + +from tools import uncompress_file_to_dir, get_file_info, make_complete_mar_name +from signing import sign_mar_file +from path import UpdaterPath, convert_to_unix, convert_to_native + + +def main(): + parser = argparse.ArgumentParser() + parser.add_argument('product_name') + parser.add_argument('workdir') + parser.add_argument('filename_prefix') + parser.add_argument('certificate_path') + parser.add_argument('certificate_name') + parser.add_argument('base_url') + parser.add_argument('version') + args = parser.parse_args() + + certificate_path = args.certificate_path + certificate_name = args.certificate_name + base_url = args.base_url + filename_prefix = args.filename_prefix + workdir = args.workdir + product_name = args.product_name + version = args.version + + update_path = UpdaterPath(workdir) + update_path.ensure_dir_exist() + + target_dir = update_path.get_update_dir() + temp_dir = update_path.get_current_build_dir() + + tar_file_glob = os.path.join(update_path.get_workdir(), "installation", product_name, "archive", "install", "*", f'{product_name}_*_archive*') + tar_files = glob.glob(tar_file_glob) + if len(tar_files) != 1: + raise Exception(f'`{tar_file_glob}` does not match exactly one file') + tar_file = tar_files[0] + + uncompress_dir = uncompress_file_to_dir(tar_file, temp_dir) + + metadatafile = os.path.join( + update_path.get_workdir(), 'installation', product_name, 'archive', 'install', 'metadata') + ifsfile = os.path.join(update_path.get_mar_dir(), 'ifs') + with open(metadatafile) as meta, open(ifsfile, 'w') as ifs: + for l in meta: + m = re.fullmatch('(skip|cond) (.*)', l.rstrip()) + if m and m.group(2).startswith(f'{product_name}/'): + path = m.group(2)[len(f'{product_name}/'):] + if m.group(1) == 'skip': + os.remove(os.path.join(uncompress_dir, path)) + else: + ifs.write(f'"{path}" "{path}"\n') + + mar_file = make_complete_mar_name(target_dir, filename_prefix) + path = os.path.join( + workdir, 'UnpackedTarball/onlineupdate/tools/update-packaging/make_full_update.sh') + os.putenv('MOZ_PRODUCT_VERSION', version) + os.putenv('MAR_CHANNEL_ID', 'LOOnlineUpdater') + subprocess.call([ + path, convert_to_native(mar_file), convert_to_native(uncompress_dir), + convert_to_native(ifsfile)]) + + sign_mar_file(target_dir, certificate_path, certificate_name, mar_file, filename_prefix) + + file_info = {'complete': get_file_info(mar_file, base_url)} + + with open(os.path.join(target_dir, 'complete_info.json'), "w") as complete_info_file: + json.dump(file_info, complete_info_file, indent=4) + + +if __name__ == '__main__': + main() |