Alex Klein | 19c4cc4 | 2019-02-27 14:47:57 -0700 | [diff] [blame] | 1 | # Copyright 2019 The Chromium OS Authors. All rights reserved. |
| 2 | # Use of this source code is governed by a BSD-style license that can be |
| 3 | # found in the LICENSE file. |
| 4 | |
| 5 | """SDK chroot operations.""" |
| 6 | |
Alex Klein | 19c4cc4 | 2019-02-27 14:47:57 -0700 | [diff] [blame] | 7 | import os |
| 8 | |
Alex Klein | 231d2da | 2019-07-22 16:44:45 -0600 | [diff] [blame] | 9 | from chromite.api import controller |
Alex Klein | 076841b | 2019-08-29 15:19:39 -0600 | [diff] [blame] | 10 | from chromite.api import faux |
Alex Klein | 231d2da | 2019-07-22 16:44:45 -0600 | [diff] [blame] | 11 | from chromite.api import validate |
Alex Klein | 71a9a1d | 2019-10-28 15:45:10 -0600 | [diff] [blame] | 12 | from chromite.api.controller import controller_util |
Alex Klein | 19c4cc4 | 2019-02-27 14:47:57 -0700 | [diff] [blame] | 13 | from chromite.lib import cros_build_lib |
| 14 | from chromite.service import sdk |
| 15 | |
| 16 | |
Alex Klein | 076841b | 2019-08-29 15:19:39 -0600 | [diff] [blame] | 17 | def _ChrootVersionResponse(_input_proto, output_proto, _config): |
| 18 | """Add a fake chroot version to a successful response.""" |
| 19 | output_proto.version.version = 168 |
| 20 | |
| 21 | |
| 22 | @faux.success(_ChrootVersionResponse) |
| 23 | @faux.empty_error |
Alex Klein | 231d2da | 2019-07-22 16:44:45 -0600 | [diff] [blame] | 24 | def Create(input_proto, output_proto, config): |
Alex Klein | 19c4cc4 | 2019-02-27 14:47:57 -0700 | [diff] [blame] | 25 | """Chroot creation, includes support for replacing an existing chroot. |
| 26 | |
| 27 | Args: |
| 28 | input_proto (CreateRequest): The input proto. |
| 29 | output_proto (CreateResponse): The output proto. |
Alex Klein | 231d2da | 2019-07-22 16:44:45 -0600 | [diff] [blame] | 30 | config (api_config.ApiConfig): The API call config. |
Alex Klein | 19c4cc4 | 2019-02-27 14:47:57 -0700 | [diff] [blame] | 31 | """ |
| 32 | replace = not input_proto.flags.no_replace |
| 33 | bootstrap = input_proto.flags.bootstrap |
| 34 | use_image = not input_proto.flags.no_use_image |
| 35 | |
Alex Klein | 00aa807 | 2019-04-15 16:36:00 -0600 | [diff] [blame] | 36 | chroot_path = input_proto.chroot.path |
| 37 | cache_dir = input_proto.chroot.cache_dir |
Alex Klein | 19c4cc4 | 2019-02-27 14:47:57 -0700 | [diff] [blame] | 38 | |
| 39 | if chroot_path and not os.path.isabs(chroot_path): |
| 40 | cros_build_lib.Die('The chroot path must be absolute.') |
| 41 | |
Alex Klein | 231d2da | 2019-07-22 16:44:45 -0600 | [diff] [blame] | 42 | if config.validate_only: |
| 43 | return controller.RETURN_CODE_VALID_INPUT |
| 44 | |
Chris McDonald | 5dcdb89 | 2020-02-07 15:10:46 -0700 | [diff] [blame] | 45 | args = sdk.CreateArguments( |
| 46 | replace=replace, |
| 47 | bootstrap=bootstrap, |
| 48 | use_image=use_image, |
| 49 | cache_dir=cache_dir, |
| 50 | chroot_path=chroot_path) |
Alex Klein | 19c4cc4 | 2019-02-27 14:47:57 -0700 | [diff] [blame] | 51 | |
| 52 | version = sdk.Create(args) |
| 53 | |
| 54 | if version: |
| 55 | output_proto.version.version = version |
| 56 | else: |
| 57 | # This should be very rare, if ever used, but worth noting. |
| 58 | cros_build_lib.Die('No chroot version could be found. There was likely an' |
| 59 | 'error creating the chroot that was not detected.') |
Alex Klein | aa5c417 | 2019-02-27 17:12:20 -0700 | [diff] [blame] | 60 | |
| 61 | |
Alex Klein | 076841b | 2019-08-29 15:19:39 -0600 | [diff] [blame] | 62 | @faux.success(_ChrootVersionResponse) |
| 63 | @faux.empty_error |
Alex Klein | 45b7343 | 2020-09-23 13:51:20 -0600 | [diff] [blame] | 64 | @validate.require_each('toolchain_targets', ['name']) |
Alex Klein | 231d2da | 2019-07-22 16:44:45 -0600 | [diff] [blame] | 65 | @validate.validation_complete |
| 66 | def Update(input_proto, output_proto, _config): |
Alex Klein | aa5c417 | 2019-02-27 17:12:20 -0700 | [diff] [blame] | 67 | """Update the chroot. |
| 68 | |
| 69 | Args: |
| 70 | input_proto (UpdateRequest): The input proto. |
| 71 | output_proto (UpdateResponse): The output proto. |
Alex Klein | 231d2da | 2019-07-22 16:44:45 -0600 | [diff] [blame] | 72 | _config (api_config.ApiConfig): The API call config. |
Alex Klein | aa5c417 | 2019-02-27 17:12:20 -0700 | [diff] [blame] | 73 | """ |
| 74 | build_source = input_proto.flags.build_source |
| 75 | targets = [target.name for target in input_proto.toolchain_targets] |
Chris McDonald | 68faa2a | 2020-01-13 12:23:05 -0700 | [diff] [blame] | 76 | toolchain_changed = input_proto.flags.toolchain_changed |
Alex Klein | aa5c417 | 2019-02-27 17:12:20 -0700 | [diff] [blame] | 77 | |
Chris McDonald | 68faa2a | 2020-01-13 12:23:05 -0700 | [diff] [blame] | 78 | args = sdk.UpdateArguments( |
| 79 | build_source=build_source, |
| 80 | toolchain_targets=targets, |
| 81 | toolchain_changed=toolchain_changed) |
| 82 | |
Alex Klein | aa5c417 | 2019-02-27 17:12:20 -0700 | [diff] [blame] | 83 | version = sdk.Update(args) |
| 84 | |
| 85 | if version: |
| 86 | output_proto.version.version = version |
| 87 | else: |
| 88 | # This should be very rare, if ever used, but worth noting. |
| 89 | cros_build_lib.Die('No chroot version could be found. There was likely an' |
| 90 | 'error creating the chroot that was not detected.') |
Alex Klein | 730cf55 | 2019-10-16 11:28:22 -0600 | [diff] [blame] | 91 | |
| 92 | |
| 93 | @faux.all_empty |
| 94 | @validate.validation_complete |
| 95 | def Delete(input_proto, _output_proto, _config): |
| 96 | """Delete a chroot.""" |
Alex Klein | 71a9a1d | 2019-10-28 15:45:10 -0600 | [diff] [blame] | 97 | chroot = controller_util.ParseChroot(input_proto.chroot) |
Michael Mortensen | 42a700e | 2020-07-01 12:50:45 -0600 | [diff] [blame] | 98 | sdk.Delete(chroot, force=True) |
Chris McDonald | 53ad544 | 2020-01-17 14:11:55 -0700 | [diff] [blame] | 99 | |
| 100 | |
| 101 | @faux.all_empty |
| 102 | @validate.validation_complete |
| 103 | def Unmount(input_proto, _output_proto, _config): |
| 104 | """Unmount a chroot""" |
| 105 | chroot = controller_util.ParseChroot(input_proto.chroot) |
| 106 | sdk.Unmount(chroot) |
Chris McDonald | f48ea20 | 2020-01-29 13:19:23 -0700 | [diff] [blame] | 107 | |
| 108 | |
| 109 | @faux.all_empty |
Michael Mortensen | 52a98ac | 2020-07-28 16:00:18 -0600 | [diff] [blame] | 110 | @validate.require('path.path') |
| 111 | @validate.validation_complete |
| 112 | def UnmountPath(input_proto, _output_proto, _config): |
| 113 | """Unmount a path""" |
Alex Klein | b44a6af | 2020-08-05 15:57:12 -0600 | [diff] [blame] | 114 | sdk.UnmountPath(input_proto.path.path) |
Michael Mortensen | 52a98ac | 2020-07-28 16:00:18 -0600 | [diff] [blame] | 115 | |
| 116 | |
| 117 | @faux.all_empty |
Chris McDonald | f48ea20 | 2020-01-29 13:19:23 -0700 | [diff] [blame] | 118 | @validate.validation_complete |
| 119 | def Clean(input_proto, _output_proto, _config): |
| 120 | """Clean unneeded files from a chroot.""" |
| 121 | chroot = controller_util.ParseChroot(input_proto.chroot) |
Alex Klein | 76c4438 | 2022-01-18 17:27:28 -0700 | [diff] [blame^] | 122 | sdk.Clean( |
| 123 | chroot, |
| 124 | images=True, |
| 125 | sysroots=True, |
| 126 | tmp=True, |
| 127 | cache=True, |
| 128 | logs=True, |
| 129 | workdirs=True) |
Chris McDonald | 9d48680 | 2020-01-29 15:57:22 -0700 | [diff] [blame] | 130 | |
| 131 | |
| 132 | @faux.all_empty |
| 133 | @validate.validation_complete |
| 134 | def CreateSnapshot(input_proto, output_proto, _config): |
| 135 | """Create a chroot snapshot and return a corresponding opaque snapshot key.""" |
| 136 | chroot = controller_util.ParseChroot(input_proto.chroot) |
| 137 | token = sdk.CreateSnapshot(chroot, replace_if_needed=True) |
| 138 | output_proto.snapshot_token.value = token |
| 139 | |
| 140 | |
| 141 | @faux.all_empty |
| 142 | @validate.validation_complete |
| 143 | def RestoreSnapshot(input_proto, _output_proto, _config): |
| 144 | """Restore a chroot snapshot from a snapshot key.""" |
| 145 | chroot = controller_util.ParseChroot(input_proto.chroot) |
| 146 | token = input_proto.snapshot_token.value |
| 147 | sdk.RestoreSnapshot(token, chroot) |