blob: 1d3d0cd27dca3867d083d1e8ef7ecee59edb29cb [file] [log] [blame]
The Android Open Source Projectc24a8e62009-03-03 19:28:42 -08001/*
2 * Copyright (C) 2007 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 RECOVERY_INSTALL_H_
18#define RECOVERY_INSTALL_H_
19
Tao Bao641fa972018-04-25 18:59:40 -070020#include <stddef.h>
21
Yabin Cuifd99a312016-06-09 14:09:39 -070022#include <string>
Tao Bao641fa972018-04-25 18:59:40 -070023
Yabin Cuifd99a312016-06-09 14:09:39 -070024#include <ziparchive/zip_archive.h>
The Android Open Source Projectc24a8e62009-03-03 19:28:42 -080025
Hridya Valsarajueb6f13a2018-09-12 10:25:01 -070026enum InstallResult {
27 INSTALL_SUCCESS,
28 INSTALL_ERROR,
29 INSTALL_CORRUPT,
30 INSTALL_NONE,
31 INSTALL_SKIPPED,
32 INSTALL_RETRY,
33 INSTALL_KEY_INTERRUPTED
34};
Tao Baoac9d94d2016-11-03 11:37:15 -070035
Tao Bao29ee69b2017-05-01 12:23:17 -070036// Installs the given update package. If INSTALL_SUCCESS is returned and *wipe_cache is true on
37// exit, caller should wipe the cache partition.
Tao Bao641fa972018-04-25 18:59:40 -070038int install_package(const std::string& package, bool* wipe_cache, bool needs_mount,
39 int retry_count);
The Android Open Source Projectc24a8e62009-03-03 19:28:42 -080040
Yabin Cuifd99a312016-06-09 14:09:39 -070041// Verify the package by ota keys. Return true if the package is verified successfully,
42// otherwise return false.
43bool verify_package(const unsigned char* package_data, size_t package_size);
44
45// Read meta data file of the package, write its content in the string pointed by meta_data.
46// Return true if succeed, otherwise return false.
Tao Bao29ee69b2017-05-01 12:23:17 -070047bool read_metadata_from_package(ZipArchiveHandle zip, std::string* metadata);
Doug Zongker28ce47c2011-10-28 10:33:05 -070048
Tao Bao29ee69b2017-05-01 12:23:17 -070049// Verifies the compatibility info in a Treble-compatible package. Returns true directly if the
Tao Bao1d866052017-04-10 16:55:57 -070050// entry doesn't exist.
51bool verify_package_compatibility(ZipArchiveHandle package_zip);
52
The Android Open Source Projectc24a8e62009-03-03 19:28:42 -080053#endif // RECOVERY_INSTALL_H_