blob: 9eca20f10d4924509a548c4c65aa53d53c9b7e19 [file] [log] [blame]
Alice Wang76a36a22023-07-27 12:11:01 +00001// Copyright 2023, The Android Open Source Project
2//
3// Licensed under the Apache License, Version 2.0 (the "License");
4// you may not use this file except in compliance with the License.
5// You may obtain a copy of the License at
6//
7// http://www.apache.org/licenses/LICENSE-2.0
8//
9// Unless required by applicable law or agreed to in writing, software
10// distributed under the License is distributed on an "AS IS" BASIS,
11// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12// See the License for the specific language governing permissions and
13// limitations under the License.
14
15//! This module contains the main API for the request processing module.
16
Alice Wang9aeb4062023-10-30 14:19:38 +000017use crate::client_vm;
Alice Wang7b4b6132023-10-05 08:00:16 +000018use crate::rkp;
Alice Wang76a36a22023-07-27 12:11:01 +000019use alloc::vec::Vec;
Alice Wang77639bf2023-09-21 06:57:12 +000020use diced_open_dice::DiceArtifacts;
Alice Wang76a36a22023-07-27 12:11:01 +000021use service_vm_comm::{Request, Response};
22
23/// Processes a request and returns the corresponding response.
Alice Wang9eebbab2024-04-10 14:57:27 +000024/// This function serves as the entry point for the request processing module.
25pub fn process_request(request: Request, context: &RequestContext) -> Response {
Alice Wang83c974d2023-10-05 12:05:36 +000026 match request {
Alice Wang76a36a22023-07-27 12:11:01 +000027 Request::Reverse(v) => Response::Reverse(reverse(v)),
Alice Wang9eebbab2024-04-10 14:57:27 +000028 Request::GenerateEcdsaP256KeyPair => {
29 rkp::generate_ecdsa_p256_key_pair(context.dice_artifacts)
30 .map_or_else(Response::Err, Response::GenerateEcdsaP256KeyPair)
31 }
Alice Wang77639bf2023-09-21 06:57:12 +000032 Request::GenerateCertificateRequest(p) => {
Alice Wang9eebbab2024-04-10 14:57:27 +000033 rkp::generate_certificate_request(p, context.dice_artifacts)
Alice Wang77639bf2023-09-21 06:57:12 +000034 .map_or_else(Response::Err, Response::GenerateCertificateRequest)
35 }
Alice Wang9eebbab2024-04-10 14:57:27 +000036 Request::RequestClientVmAttestation(p) => client_vm::request_attestation(
37 p,
38 context.dice_artifacts,
39 context.vendor_hashtree_root_digest,
40 )
41 .map_or_else(Response::Err, Response::RequestClientVmAttestation),
Alice Wang83c974d2023-10-05 12:05:36 +000042 }
Alice Wang76a36a22023-07-27 12:11:01 +000043}
44
Alice Wang9eebbab2024-04-10 14:57:27 +000045/// The context for the request processing.
46///
47/// This struct contains the reference data used during the request processing.
48pub struct RequestContext<'a> {
49 /// The reference DICE artifacts.
50 pub dice_artifacts: &'a dyn DiceArtifacts,
51
52 /// The reference hash tree root digest of the vendor partition if exists.
53 pub vendor_hashtree_root_digest: Option<&'a [u8]>,
54}
55
Alice Wang76a36a22023-07-27 12:11:01 +000056fn reverse(payload: Vec<u8>) -> Vec<u8> {
57 payload.into_iter().rev().collect()
58}