1fb299fa2Sopenharmony_ci/* 2fb299fa2Sopenharmony_ci * Copyright (c) 2022 Huawei Device Co., Ltd. 3fb299fa2Sopenharmony_ci * Licensed under the Apache License, Version 2.0 (the "License"); 4fb299fa2Sopenharmony_ci * you may not use this file except in compliance with the License. 5fb299fa2Sopenharmony_ci * You may obtain a copy of the License at 6fb299fa2Sopenharmony_ci * 7fb299fa2Sopenharmony_ci * http://www.apache.org/licenses/LICENSE-2.0 8fb299fa2Sopenharmony_ci * 9fb299fa2Sopenharmony_ci * Unless required by applicable law or agreed to in writing, software 10fb299fa2Sopenharmony_ci * distributed under the License is distributed on an "AS IS" BASIS, 11fb299fa2Sopenharmony_ci * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 12fb299fa2Sopenharmony_ci * See the License for the specific language governing permissions and 13fb299fa2Sopenharmony_ci * limitations under the License. 14fb299fa2Sopenharmony_ci */ 15fb299fa2Sopenharmony_ci 16fb299fa2Sopenharmony_ci#ifndef PKG_VERIFY_UTIL_H 17fb299fa2Sopenharmony_ci#define PKG_VERIFY_UTIL_H 18fb299fa2Sopenharmony_ci 19fb299fa2Sopenharmony_ci#include <vector> 20fb299fa2Sopenharmony_ci#include "pkcs7_signed_data.h" 21fb299fa2Sopenharmony_ci#include "pkg_stream.h" 22fb299fa2Sopenharmony_ci 23fb299fa2Sopenharmony_cinamespace Hpackage { 24fb299fa2Sopenharmony_ciclass PkgVerifyUtil { 25fb299fa2Sopenharmony_cipublic: 26fb299fa2Sopenharmony_ci PkgVerifyUtil() {} 27fb299fa2Sopenharmony_ci 28fb299fa2Sopenharmony_ci ~PkgVerifyUtil() {} 29fb299fa2Sopenharmony_ci 30fb299fa2Sopenharmony_ci int32_t VerifyPackageSign(const Hpackage::PkgStreamPtr PkgStream) const; 31fb299fa2Sopenharmony_ci int32_t VerifySign(std::vector<uint8_t> &signData, std::vector<uint8_t> &digest) const; 32fb299fa2Sopenharmony_ci int32_t VerifySourceDigest(std::vector<uint8_t> &signature, std::vector<uint8_t> &sourceDigest, 33fb299fa2Sopenharmony_ci const std::string &keyPath) const; 34fb299fa2Sopenharmony_ci int32_t VerifyAccPackageSign(const PkgStreamPtr pkgStream, const std::string &keyPath) const; 35fb299fa2Sopenharmony_ci int32_t GetSignature(const PkgStreamPtr pkgStream, size_t &signatureSize, 36fb299fa2Sopenharmony_ci std::vector<uint8_t> &signature, uint16_t &commentTotalLenAll) const; 37fb299fa2Sopenharmony_ci#ifndef UPDATER_UT 38fb299fa2Sopenharmony_ciprivate: 39fb299fa2Sopenharmony_ci#else 40fb299fa2Sopenharmony_cipublic: 41fb299fa2Sopenharmony_ci#endif 42fb299fa2Sopenharmony_ci 43fb299fa2Sopenharmony_ci int32_t ParsePackage(const PkgStreamPtr pkgStream, size_t &signatureStart, 44fb299fa2Sopenharmony_ci size_t &signatureSize, uint16_t &commentTotalLenAll) const; 45fb299fa2Sopenharmony_ci 46fb299fa2Sopenharmony_ci int32_t Pkcs7verify(std::vector<uint8_t> &signature, std::vector<uint8_t> &hash) const; 47fb299fa2Sopenharmony_ci 48fb299fa2Sopenharmony_ci int32_t HashCheck(const PkgStreamPtr srcData, const size_t dataLen, 49fb299fa2Sopenharmony_ci const std::vector<uint8_t> &hash) const; 50fb299fa2Sopenharmony_ci}; 51fb299fa2Sopenharmony_ci} // namespace Hpackage 52fb299fa2Sopenharmony_ci#endif 53