xref: /aosp_15_r20/system/apex/apexd/apex_sha.cpp (revision 33f3758387333dbd2962d7edbd98681940d895da)
1*33f37583SAndroid Build Coastguard Worker /*
2*33f37583SAndroid Build Coastguard Worker  * Copyright (C) 2024 The Android Open Source Project
3*33f37583SAndroid Build Coastguard Worker  *
4*33f37583SAndroid Build Coastguard Worker  * Licensed under the Apache License, Version 2.0 (the "License");
5*33f37583SAndroid Build Coastguard Worker  * you may not use this file except in compliance with the License.
6*33f37583SAndroid Build Coastguard Worker  * You may obtain a copy of the License at
7*33f37583SAndroid Build Coastguard Worker  *
8*33f37583SAndroid Build Coastguard Worker  *      http://www.apache.org/licenses/LICENSE-2.0
9*33f37583SAndroid Build Coastguard Worker  *
10*33f37583SAndroid Build Coastguard Worker  * Unless required by applicable law or agreed to in writing, software
11*33f37583SAndroid Build Coastguard Worker  * distributed under the License is distributed on an "AS IS" BASIS,
12*33f37583SAndroid Build Coastguard Worker  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13*33f37583SAndroid Build Coastguard Worker  * See the License for the specific language governing permissions and
14*33f37583SAndroid Build Coastguard Worker  * limitations under the License.
15*33f37583SAndroid Build Coastguard Worker  */
16*33f37583SAndroid Build Coastguard Worker 
17*33f37583SAndroid Build Coastguard Worker #include "apex_sha.h"
18*33f37583SAndroid Build Coastguard Worker 
19*33f37583SAndroid Build Coastguard Worker #include <android-base/logging.h>
20*33f37583SAndroid Build Coastguard Worker #include <openssl/sha.h>
21*33f37583SAndroid Build Coastguard Worker 
22*33f37583SAndroid Build Coastguard Worker #include <fstream>
23*33f37583SAndroid Build Coastguard Worker #include <sstream>
24*33f37583SAndroid Build Coastguard Worker 
25*33f37583SAndroid Build Coastguard Worker static constexpr const int kBufSize = 1024;
26*33f37583SAndroid Build Coastguard Worker 
27*33f37583SAndroid Build Coastguard Worker using android::base::Error;
28*33f37583SAndroid Build Coastguard Worker using android::base::Result;
29*33f37583SAndroid Build Coastguard Worker 
30*33f37583SAndroid Build Coastguard Worker namespace android {
31*33f37583SAndroid Build Coastguard Worker namespace apex {
32*33f37583SAndroid Build Coastguard Worker 
CalculateSha512(const std::string & path)33*33f37583SAndroid Build Coastguard Worker Result<std::string> CalculateSha512(const std::string& path) {
34*33f37583SAndroid Build Coastguard Worker   LOG(DEBUG) << "Calculating SHA512 of " << path;
35*33f37583SAndroid Build Coastguard Worker   SHA512_CTX ctx;
36*33f37583SAndroid Build Coastguard Worker   SHA512_Init(&ctx);
37*33f37583SAndroid Build Coastguard Worker   std::ifstream apex(path, std::ios::binary);
38*33f37583SAndroid Build Coastguard Worker   if (apex.bad()) {
39*33f37583SAndroid Build Coastguard Worker     return Error() << "Failed to open " << path;
40*33f37583SAndroid Build Coastguard Worker   }
41*33f37583SAndroid Build Coastguard Worker   char buf[kBufSize];
42*33f37583SAndroid Build Coastguard Worker   while (!apex.eof()) {
43*33f37583SAndroid Build Coastguard Worker     apex.read(buf, kBufSize);
44*33f37583SAndroid Build Coastguard Worker     if (apex.bad()) {
45*33f37583SAndroid Build Coastguard Worker       return Error() << "Failed to read " << path;
46*33f37583SAndroid Build Coastguard Worker     }
47*33f37583SAndroid Build Coastguard Worker     int bytes_read = apex.gcount();
48*33f37583SAndroid Build Coastguard Worker     SHA512_Update(&ctx, buf, bytes_read);
49*33f37583SAndroid Build Coastguard Worker   }
50*33f37583SAndroid Build Coastguard Worker   uint8_t hash[SHA512_DIGEST_LENGTH];
51*33f37583SAndroid Build Coastguard Worker   SHA512_Final(hash, &ctx);
52*33f37583SAndroid Build Coastguard Worker   std::stringstream ss;
53*33f37583SAndroid Build Coastguard Worker   ss << std::hex;
54*33f37583SAndroid Build Coastguard Worker   for (int i = 0; i < SHA512_DIGEST_LENGTH; i++) {
55*33f37583SAndroid Build Coastguard Worker     ss << std::setw(2) << std::setfill('0') << static_cast<int>(hash[i]);
56*33f37583SAndroid Build Coastguard Worker   }
57*33f37583SAndroid Build Coastguard Worker   return ss.str();
58*33f37583SAndroid Build Coastguard Worker }
59*33f37583SAndroid Build Coastguard Worker 
CalculateSha256(const std::string & path)60*33f37583SAndroid Build Coastguard Worker Result<std::string> CalculateSha256(const std::string& path) {
61*33f37583SAndroid Build Coastguard Worker   LOG(DEBUG) << "Calculating SHA256 of " << path;
62*33f37583SAndroid Build Coastguard Worker   SHA256_CTX ctx;
63*33f37583SAndroid Build Coastguard Worker   SHA256_Init(&ctx);
64*33f37583SAndroid Build Coastguard Worker   std::ifstream apex(path, std::ios::binary);
65*33f37583SAndroid Build Coastguard Worker   if (apex.bad()) {
66*33f37583SAndroid Build Coastguard Worker     return Error() << "Failed to open " << path;
67*33f37583SAndroid Build Coastguard Worker   }
68*33f37583SAndroid Build Coastguard Worker   char buf[kBufSize];
69*33f37583SAndroid Build Coastguard Worker   while (!apex.eof()) {
70*33f37583SAndroid Build Coastguard Worker     apex.read(buf, kBufSize);
71*33f37583SAndroid Build Coastguard Worker     if (apex.bad()) {
72*33f37583SAndroid Build Coastguard Worker       return Error() << "Failed to read " << path;
73*33f37583SAndroid Build Coastguard Worker     }
74*33f37583SAndroid Build Coastguard Worker     int bytes_read = apex.gcount();
75*33f37583SAndroid Build Coastguard Worker     SHA256_Update(&ctx, buf, bytes_read);
76*33f37583SAndroid Build Coastguard Worker   }
77*33f37583SAndroid Build Coastguard Worker   uint8_t hash[SHA256_DIGEST_LENGTH];
78*33f37583SAndroid Build Coastguard Worker   SHA256_Final(hash, &ctx);
79*33f37583SAndroid Build Coastguard Worker   std::stringstream ss;
80*33f37583SAndroid Build Coastguard Worker   ss << std::hex;
81*33f37583SAndroid Build Coastguard Worker   for (int i = 0; i < SHA256_DIGEST_LENGTH; i++) {
82*33f37583SAndroid Build Coastguard Worker     ss << std::setw(2) << std::setfill('0') << static_cast<int>(hash[i]);
83*33f37583SAndroid Build Coastguard Worker   }
84*33f37583SAndroid Build Coastguard Worker   return ss.str();
85*33f37583SAndroid Build Coastguard Worker }
86*33f37583SAndroid Build Coastguard Worker 
87*33f37583SAndroid Build Coastguard Worker }  // namespace apex
88*33f37583SAndroid Build Coastguard Worker }  // namespace android
89