Skip to content

Commit

Permalink
chore: avoid deprecated funcs to calculate sha256
Browse files Browse the repository at this point in the history
Signed-off-by: Federico Aponte <[email protected]>
  • Loading branch information
federico-sysdig authored and poiana committed Jan 13, 2025
1 parent 3277d6e commit ec2c2e8
Showing 1 changed file with 10 additions and 10 deletions.
20 changes: 10 additions & 10 deletions userspace/engine/falco_utils.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -23,7 +23,7 @@ limitations under the License.

#include <re2/re2.h>
#if defined(__linux__) and !defined(MINIMAL_BUILD) and !defined(__EMSCRIPTEN__)
#include <openssl/sha.h>
#include <openssl/evp.h>
#endif
#include <cstring>
#include <fstream>
Expand Down Expand Up @@ -144,22 +144,22 @@ std::string calculate_file_sha256sum(const std::string& filename) {
return "";
}

SHA256_CTX sha256_context;
SHA256_Init(&sha256_context);
std::unique_ptr<EVP_MD_CTX, decltype(&EVP_MD_CTX_free)> ctx(EVP_MD_CTX_new(), EVP_MD_CTX_free);
EVP_DigestInit_ex(ctx.get(), EVP_sha256(), nullptr);

constexpr size_t buffer_size = 4096;
char buffer[buffer_size];
while(file.read(buffer, buffer_size)) {
SHA256_Update(&sha256_context, buffer, buffer_size);
EVP_DigestUpdate(ctx.get(), buffer, buffer_size);
}
SHA256_Update(&sha256_context, buffer, file.gcount());
EVP_DigestUpdate(ctx.get(), buffer, file.gcount());

unsigned char digest[SHA256_DIGEST_LENGTH];
SHA256_Final(digest, &sha256_context);
std::vector<uint8_t> digest(EVP_MD_size(EVP_sha256()));
EVP_DigestFinal_ex(ctx.get(), digest.data(), nullptr);

std::stringstream ss;
for(int i = 0; i < SHA256_DIGEST_LENGTH; ++i) {
ss << std::hex << std::setw(2) << std::setfill('0') << static_cast<unsigned>(digest[i]);
std::ostringstream ss;
for(auto& c : digest) {
ss << std::hex << std::setw(2) << std::setfill('0') << (int)c;
}
return ss.str();
}
Expand Down

0 comments on commit ec2c2e8

Please sign in to comment.