39258d20d4
refactor: take a uint8_t span in ValidateIntegrityOrDie() Doing some groundwork for fixing unsafe base::File() APIs: - Change ValidateIntegrityOrDie() to take a span<const uint8_t> arg. We'll need this to migrate asar's base::File API calls away from the ones tagged `UNSAFE_BUFFER_USAGE` because the safe counterparts use span<uint8_t> too. - Simplify ValidateIntegrityOrDie()'s implementation by using crypto::SHA256Hash() instead of reinventing the wheel. Co-authored-by: trop[bot] <37223003+trop[bot]@users.noreply.github.com> Co-authored-by: Charles Kerr <charles@charleskerr.com>
39 lines
1.1 KiB
C++
39 lines
1.1 KiB
C++
// Copyright (c) 2015 GitHub, Inc.
|
|
// Use of this source code is governed by the MIT license that can be
|
|
// found in the LICENSE file.
|
|
|
|
#ifndef ELECTRON_SHELL_COMMON_ASAR_ASAR_UTIL_H_
|
|
#define ELECTRON_SHELL_COMMON_ASAR_ASAR_UTIL_H_
|
|
|
|
#include <memory>
|
|
#include <string>
|
|
|
|
#include "base/containers/span.h"
|
|
|
|
namespace base {
|
|
class FilePath;
|
|
}
|
|
|
|
namespace asar {
|
|
|
|
class Archive;
|
|
struct IntegrityPayload;
|
|
|
|
// Gets or creates and caches a new Archive from the path.
|
|
std::shared_ptr<Archive> GetOrCreateAsarArchive(const base::FilePath& path);
|
|
|
|
// Separates the path to Archive out.
|
|
bool GetAsarArchivePath(const base::FilePath& full_path,
|
|
base::FilePath* asar_path,
|
|
base::FilePath* relative_path,
|
|
bool allow_root = false);
|
|
|
|
// Same with base::ReadFileToString but supports asar Archive.
|
|
bool ReadFileToString(const base::FilePath& path, std::string* contents);
|
|
|
|
void ValidateIntegrityOrDie(base::span<const uint8_t> input,
|
|
const IntegrityPayload& integrity);
|
|
|
|
} // namespace asar
|
|
|
|
#endif // ELECTRON_SHELL_COMMON_ASAR_ASAR_UTIL_H_
|