6faf0265c9
To increase the security of wiping A/B devices, let uncrypt write wipe package in misc partition. Then recovery verifies the wipe package before wiping the device. Bug: 29159185 Change-Id: I186691bab1928d3dc036bc5542abd64a81bc2168
41 lines
1.6 KiB
C++
41 lines
1.6 KiB
C++
/*
|
|
* Copyright (C) 2007 The Android Open Source Project
|
|
*
|
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
* you may not use this file except in compliance with the License.
|
|
* You may obtain a copy of the License at
|
|
*
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
*
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
* See the License for the specific language governing permissions and
|
|
* limitations under the License.
|
|
*/
|
|
|
|
#ifndef RECOVERY_INSTALL_H_
|
|
#define RECOVERY_INSTALL_H_
|
|
|
|
#include <string>
|
|
|
|
#include "common.h"
|
|
#include "minzip/Zip.h"
|
|
|
|
enum { INSTALL_SUCCESS, INSTALL_ERROR, INSTALL_CORRUPT, INSTALL_NONE, INSTALL_SKIPPED,
|
|
INSTALL_RETRY };
|
|
// Install the package specified by root_path. If INSTALL_SUCCESS is
|
|
// returned and *wipe_cache is true on exit, caller should wipe the
|
|
// cache partition.
|
|
int install_package(const char* root_path, bool* wipe_cache, const char* install_file,
|
|
bool needs_mount, int retry_count);
|
|
|
|
// Verify the package by ota keys. Return true if the package is verified successfully,
|
|
// otherwise return false.
|
|
bool verify_package(const unsigned char* package_data, size_t package_size);
|
|
|
|
// Read meta data file of the package, write its content in the string pointed by meta_data.
|
|
// Return true if succeed, otherwise return false.
|
|
bool read_metadata_from_package(ZipArchive* zip, std::string* meta_data);
|
|
|
|
#endif // RECOVERY_INSTALL_H_
|