1#!/usr/bin/env python 2# -*- coding: utf-8 -*- 3# Copyright (c) 2023 Huawei Device Co., Ltd. 4# Licensed under the Apache License, Version 2.0 (the "License"); 5# you may not use this file except in compliance with the License. 6# You may obtain a copy of the License at 7# 8# http://www.apache.org/licenses/LICENSE-2.0 9# 10# Unless required by applicable law or agreed to in writing, software 11# distributed under the License is distributed on an "AS IS" BASIS, 12# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 13# See the License for the specific language governing permissions and 14# limitations under the License. 15 16import tarfile 17import argparse 18import os 19import subprocess 20import sys 21import shutil 22 23 24def untar_file(tar_file_path, extract_path): 25 try: 26 tar_cmd = ['tar', '-zxf', tar_file_path, '-C', extract_path] 27 subprocess.run(tar_cmd, check=True) 28 except Exception as e: 29 print("tar error!") 30 return 31 32def copy_file(dir): 33 src_name = '/mime.convs.in' 34 dest_name = '/mime.convs' 35 src_file = dir + src_name 36 dest_file = dir + dest_name 37 print(f'copy from %s to %s', src_file, dest_file) 38 shutil.copy2(src_file, dest_file) 39 40def move_file(src_path, dst_path): 41 files = [ 42 "backport-CVE-2022-26691.patch", 43 "backport-CVE-2023-32324.patch", 44 "backport-CVE-2023-34241.patch", 45 "ohos-multi-file-print.patch", 46 "ohos-modify-pthread.patch", 47 "ohos-add-openssl.patch", 48 "backport-CVE-2023-4504.patch", 49 "config.h" 50 ] 51 for file in files: 52 src_file = os.path.join(src_path, file) 53 dst_file = os.path.join(dst_path, file) 54 shutil.copy(src_file, dst_file) 55 56 57def apply_patch(patch_file, target_dir): 58 try: 59 if not os.path.exists(target_dir): 60 return 61 patch_cmd = ['patch', '-p1', "--fuzz=0", "--no-backup-if-mismatch", '-i', patch_file, '-d', target_dir] 62 subprocess.run(patch_cmd, check=True) 63 except Exception as e: 64 print("apply_patch error!") 65 return 66 67 68def do_patch(target_dir): 69 patch_file = [ 70 "backport-CVE-2022-26691.patch", 71 "backport-CVE-2023-32324.patch", 72 "backport-CVE-2023-34241.patch", 73 "ohos-multi-file-print.patch", 74 "ohos-modify-pthread.patch", 75 "ohos-add-openssl.patch", 76 "backport-CVE-2023-4504.patch" 77 ] 78 79 for patch in patch_file: 80 apply_patch(patch, target_dir) 81 82 83def main(): 84 cups_path = argparse.ArgumentParser() 85 cups_path.add_argument('--gen-dir', help='generate path of log', required=True) 86 cups_path.add_argument('--source-dir', help='generate path of log', required=True) 87 args = cups_path.parse_args() 88 tar_file_path = os.path.join(args.source_dir, "cups-2.4.0-source.tar.gz") 89 target_dir = os.path.join(args.gen_dir, "cups-2.4.0") 90 convs_dir = os.path.join(target_dir, "conf") 91 92 untar_file(tar_file_path, args.gen_dir) 93 move_file(args.source_dir, target_dir) 94 do_patch(target_dir) 95 copy_file(convs_dir) 96 return 0 97 98if __name__ == '__main__': 99 sys.exit(main()) 100