blob: 8b9d223f9d17782851d4fe3ee970a1a76e6ae229 [file] [log] [blame]
George Engelbrechtfe63c8c2019-08-31 22:51:29 -06001# -*- coding: utf-8 -*-
2# Copyright 2019 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"""Payload API Service."""
7
8from __future__ import print_function
9
10from chromite.api import controller
11from chromite.lib import cros_build_lib
12from chromite.api import faux
13from chromite.api import validate
14from chromite.service import payload
15
16
17_VALID_IMAGE_PAIRS = (('src_signed_image', 'tgt_signed_image'),
18 ('src_unsigned_image', 'tgt_unsigned_image'),
19 ('full_update', 'tgt_unsigned_image'),
20 ('full_update', 'tgt_signed_image'))
21
22
23# We have more fields we might validate however, they're either
24# 'oneof' or allowed to be the empty value by design. If @validate
25# gets more complex in the future we can add more here.
Michael Mortensen85d38402019-12-12 09:50:29 -070026@faux.empty_success
27@faux.empty_completed_unsuccessfully_error
George Engelbrechtfe63c8c2019-08-31 22:51:29 -060028@validate.require('bucket')
29def GeneratePayload(input_proto, output_proto, config):
30 """Generate a update payload ('do paygen').
George Engelbrechtd2348bb2019-11-25 21:18:14 -070031
George Engelbrechtfe63c8c2019-08-31 22:51:29 -060032 Args:
George Engelbrechtd2348bb2019-11-25 21:18:14 -070033 input_proto (PayloadGenerationRequest): Input proto.
34 output_proto (PayloadGenerationResult): Output proto.
35 config (api.config.ApiConfig): The API call config.
36
37 Returns:
38 A controller return code (e.g. controller.RETURN_CODE_SUCCESS).
George Engelbrechtfe63c8c2019-08-31 22:51:29 -060039 """
40
41 # Resolve the tgt image oneof.
42 tgt_name = input_proto.WhichOneof('tgt_image_oneof')
43 try:
44 tgt_image = getattr(input_proto, tgt_name)
45 except AttributeError:
46 cros_build_lib.Die('%s is not a known tgt image type' % (tgt_name,))
47
48 # Resolve the src image oneof.
49 src_name = input_proto.WhichOneof('src_image_oneof')
50
51 # If the source image is 'full_update' we lack a source entirely.
52 if src_name == 'full_update':
53 src_image = None
54 # Otherwise we have an image.
55 else:
56 try:
57 src_image = getattr(input_proto, src_name)
58 except AttributeError:
59 cros_build_lib.Die('%s is not a known src image type' % (src_name,))
60
61 # Ensure they are compatible oneofs.
62 if (src_name, tgt_name) not in _VALID_IMAGE_PAIRS:
63 cros_build_lib.Die('%s and %s are not valid image pairs' %
64 (src_image, tgt_image))
65
66 # Find the value of bucket or default to 'chromeos-releases'.
67 destination_bucket = input_proto.bucket or 'chromeos-releases'
68
Navil Perezf5482be2020-04-09 23:18:14 -060069 if input_proto.dryrun:
70 keyset = ''
71 upload = False
72 else:
73 keyset = input_proto.keyset
74 upload = True
75
George Engelbrechtfe63c8c2019-08-31 22:51:29 -060076 # There's a potential that some paygen_lib library might raise here, but since
77 # we're still involved in config we'll keep it before the validate_only.
Navil Perezf5482be2020-04-09 23:18:14 -060078 payload_config = payload.PayloadConfig(tgt_image, src_image,
79 destination_bucket, input_proto.verify,
80 keyset, upload)
George Engelbrechtfe63c8c2019-08-31 22:51:29 -060081
82 # If configured for validation only we're done here.
83 if config.validate_only:
84 return controller.RETURN_CODE_VALID_INPUT
85
86 # Do payload generation.
87 paygen_ok = payload_config.GeneratePayload()
88 _SetGeneratePayloadOutputProto(output_proto, paygen_ok)
89
90 if paygen_ok:
91 return controller.RETURN_CODE_SUCCESS
92 else:
93 return controller.RETURN_CODE_COMPLETED_UNSUCCESSFULLY
94
95
96def _SetGeneratePayloadOutputProto(output_proto, generate_payload_ok):
97 """Set the output proto with the results from the service class.
George Engelbrechtd2348bb2019-11-25 21:18:14 -070098
George Engelbrechtfe63c8c2019-08-31 22:51:29 -060099 Args:
George Engelbrechtd2348bb2019-11-25 21:18:14 -0700100 output_proto (PayloadGenerationResult_pb2): The output proto.
101 generate_payload_ok (bool): value to set output_proto.success.
George Engelbrechtfe63c8c2019-08-31 22:51:29 -0600102 """
103 output_proto.success = generate_payload_ok