blob: e2a3921f62fc3e33cf135ad85e74323821e7f1c1 [file] [log] [blame]
Tianjie Xu7a78d632019-10-08 16:32:39 -07001//
2// Copyright (C) 2019 The Android Open Source Project
3//
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//
16
17#ifndef UPDATE_ENGINE_CERTIFICATE_PARSER_ANDROID_H_
18#define UPDATE_ENGINE_CERTIFICATE_PARSER_ANDROID_H_
19
20#include <memory>
21#include <string>
22#include <vector>
23
Kokoa Matsuda1783eb32024-10-16 13:49:17 +090024#include <android-base/macros.h>
Tianjie Xu7a78d632019-10-08 16:32:39 -070025
26#include "payload_consumer/certificate_parser_interface.h"
27
28namespace chromeos_update_engine {
29// This class parses the certificates from a zip file. Because the Android
30// build system stores the certs in otacerts.zip.
31class CertificateParserAndroid : public CertificateParserInterface {
32 public:
33 CertificateParserAndroid() = default;
34
35 bool ReadPublicKeysFromCertificates(
36 const std::string& path,
37 std::vector<std::unique_ptr<EVP_PKEY, decltype(&EVP_PKEY_free)>>*
38 out_public_keys) override;
39
40 private:
41 DISALLOW_COPY_AND_ASSIGN(CertificateParserAndroid);
42};
43
44} // namespace chromeos_update_engine
45
46#endif