blob: 55b24084aded3895f524753a340cd63860cd386e [file] [log] [blame]
Tudor Brindus3e03eba2018-07-18 11:27:13 -07001# -*- coding: utf-8 -*-
2# Copyright 2018 The Chromium OS Authors. All rights reserved.
3# Use of this source code is governed by a BSD-style license that can be
4# found in the LICENSE file.
5
6"""Script to generate a Chromium OS update for use by the update engine.
7
8If a source .bin is specified, the update is assumed to be a delta update.
9"""
10
11from __future__ import print_function
12
Tudor Brindus3e03eba2018-07-18 11:27:13 -070013from chromite.lib import commandline
Tudor Brindus3e03eba2018-07-18 11:27:13 -070014from chromite.lib import cros_logging as logging
Tudor Brindus3e03eba2018-07-18 11:27:13 -070015
Amin Hassanibdda5e42018-10-10 22:56:11 -070016from chromite.lib.paygen import partition_lib
Amin Hassani6bc73a12018-11-29 21:07:12 -080017from chromite.lib.paygen import paygen_payload_lib
Tudor Brindus3e03eba2018-07-18 11:27:13 -070018
19
20def ParseArguments(argv):
21 """Returns a namespace for the CLI arguments."""
22 parser = commandline.ArgumentParser(description=__doc__)
Amin Hassania809eda2019-03-07 15:28:01 -080023 parser.add_argument('--image',
24 help='The path (to local disk or Google Storage Bucket)'
25 ' of the target image to build the payload for.')
26 parser.add_argument('--src_image',
27 help='The path (to local disk or Google Storage Bucket)'
28 ' of the source image. If specified, this makes a delta'
29 ' update payload.')
Tudor Brindus3e03eba2018-07-18 11:27:13 -070030 parser.add_argument('--output', type='path', help='Output file.')
Tudor Brindus3e03eba2018-07-18 11:27:13 -070031 parser.add_argument('--private_key', type='path',
32 help='Path to private key in .pem format.')
Amin Hassani6bc73a12018-11-29 21:07:12 -080033 parser.add_argument('--check', action='store_true',
34 help='If passed, verifies the integrity of the payload')
Tudor Brindus3e03eba2018-07-18 11:27:13 -070035 parser.add_argument('--out_metadata_hash_file', type='path',
36 help='Path to output metadata hash file.')
Tudor Brindus3e03eba2018-07-18 11:27:13 -070037 parser.add_argument('--extract', action='store_true',
38 help='If set, extract old/new kernel/rootfs to '
39 '[old|new]_[kern|root].dat. Useful for debugging.')
Amin Hassani6bc73a12018-11-29 21:07:12 -080040 parser.add_argument('--work_dir', type='path',
41 help='Path to a temporary directory in the chroot.')
Amin Hassaniff618842019-06-02 21:43:14 -070042 parser.add_argument('--payload', type='path',
43 help='Path to the input payload file. Only used when '
44 'trying to generate the payload properties file using '
45 'the given payload. If --output is not passed, the '
46 'payload properties file path will be generated by '
47 'appending .json to the payload filename itself.')
Tudor Brindus3e03eba2018-07-18 11:27:13 -070048
49 # Specifying any of the following will cause it to not be cleaned up on exit.
50 parser.add_argument('--kern_path', type='path',
51 help='File path for extracting the kernel partition.')
52 parser.add_argument('--root_path', type='path',
53 help='File path for extracting the rootfs partition.')
54 parser.add_argument('--root_pretruncate_path', type='path',
55 help='File path for extracting the rootfs partition, '
56 'pre-truncation.')
57 parser.add_argument('--src_kern_path', type='path',
58 help='File path for extracting the source kernel '
59 'partition.')
60 parser.add_argument('--src_root_path', type='path',
61 help='File path for extracting the source root '
62 'partition.')
63
64 opts = parser.parse_args(argv)
65 opts.Freeze()
66
Tudor Brindus3e03eba2018-07-18 11:27:13 -070067 return opts
68
69
70def main(argv):
71 opts = ParseArguments(argv)
72
Amin Hassani6bc73a12018-11-29 21:07:12 -080073 if opts.kern_path:
74 partition_lib.ExtractKernel(opts.image, opts.kern_path)
75 if opts.root_path:
76 partition_lib.ExtractRoot(opts.image, opts.root_path)
77 if opts.root_pretruncate_path:
78 partition_lib.ExtractRoot(opts.image, opts.root_pretruncate_path,
79 truncate=False)
80
81 if opts.src_image:
82 if opts.src_kern_path:
83 partition_lib.ExtractKernel(opts.src_image, opts.src_kern_path)
84 if opts.src_root_path:
85 partition_lib.ExtractRoot(opts.src_image, opts.src_root_path)
86
87 if opts.extract:
88 # If we just wanted extraction, we did it, just return.
89 logging.info('Done extracting kernel/root.')
90 return
91
Amin Hassaniff618842019-06-02 21:43:14 -070092 if opts.payload:
93 # We only want the payload's metadata. Create it and exit.
94 logging.info('Generating payload properties file.')
95 paygen_payload_lib.GenerateUpdatePayloadPropertiesFile(opts.payload,
96 opts.output)
97 return
98
Amin Hassani6bc73a12018-11-29 21:07:12 -080099 return paygen_payload_lib.GenerateUpdatePayload(
100 opts.image, opts.output, src_image=opts.src_image, work_dir=opts.work_dir,
101 private_key=opts.private_key, check=opts.check,
102 out_metadata_hash_file=opts.out_metadata_hash_file)