• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
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