electron/shell/common/asar/archive.h

118 lines
2.9 KiB
C
Raw Normal View History

// Copyright (c) 2014 GitHub, Inc.
// Use of this source code is governed by the MIT license that can be
// found in the LICENSE file.
2019-06-19 20:56:58 +00:00
#ifndef SHELL_COMMON_ASAR_ARCHIVE_H_
#define SHELL_COMMON_ASAR_ARCHIVE_H_
2016-07-04 06:08:55 +00:00
#include <memory>
#include <string>
2017-04-04 04:50:44 +00:00
#include <unordered_map>
2014-09-24 10:44:00 +00:00
#include <vector>
#include "base/files/file.h"
#include "base/files/file_path.h"
#include "base/macros.h"
#include "base/synchronization/lock.h"
#include "third_party/abseil-cpp/absl/types/optional.h"
namespace base {
class DictionaryValue;
}
namespace asar {
class ScopedTemporaryFile;
enum HashAlgorithm {
SHA256,
NONE,
};
struct IntegrityPayload {
2021-09-10 02:52:23 +00:00
IntegrityPayload();
~IntegrityPayload();
IntegrityPayload(const IntegrityPayload& other);
HashAlgorithm algorithm;
std::string hash;
uint32_t block_size;
std::vector<std::string> blocks;
};
// This class represents an asar package, and provides methods to read
// information from it. It is thread-safe after |Init| has been called.
class Archive {
public:
struct FileInfo {
2021-09-10 02:52:23 +00:00
FileInfo();
~FileInfo();
bool unpacked;
bool executable;
2016-03-08 04:40:10 +00:00
uint32_t size;
2016-03-08 14:28:53 +00:00
uint64_t offset;
absl::optional<IntegrityPayload> integrity;
};
2014-09-24 04:02:33 +00:00
struct Stats : public FileInfo {
Stats() : is_file(true), is_directory(false), is_link(false) {}
bool is_file;
bool is_directory;
bool is_link;
};
explicit Archive(const base::FilePath& path);
virtual ~Archive();
// Read and parse the header.
bool Init();
absl::optional<IntegrityPayload> HeaderIntegrity() const;
absl::optional<base::FilePath> RelativePath() const;
// Get the info of a file.
bool GetFileInfo(const base::FilePath& path, FileInfo* info) const;
2014-09-24 04:02:33 +00:00
// Fs.stat(path).
bool Stat(const base::FilePath& path, Stats* stats) const;
2014-09-24 04:02:33 +00:00
2014-09-24 10:44:00 +00:00
// Fs.readdir(path).
bool Readdir(const base::FilePath& path,
std::vector<base::FilePath>* files) const;
2014-09-24 10:44:00 +00:00
2014-09-30 06:53:41 +00:00
// Fs.realpath(path).
bool Realpath(const base::FilePath& path, base::FilePath* realpath) const;
2014-09-30 06:53:41 +00:00
// Copy the file into a temporary file, and return the new path.
// For unpacked file, this method will return its real path.
bool CopyFileOut(const base::FilePath& path, base::FilePath* out);
// Returns the file's fd.
// Using this fd will not validate the integrity of any files
// you read out of the ASAR manually. Callers are responsible
// for integrity validation after this fd is handed over.
int GetUnsafeFD() const;
base::FilePath path() const { return path_; }
private:
bool initialized_;
bool header_validated_ = false;
const base::FilePath path_;
base::File file_;
int fd_ = -1;
uint32_t header_size_ = 0;
2016-05-23 01:59:39 +00:00
std::unique_ptr<base::DictionaryValue> header_;
// Cached external temporary files.
base::Lock external_files_lock_;
2017-04-04 04:50:44 +00:00
std::unordered_map<base::FilePath::StringType,
2018-04-18 01:44:10 +00:00
std::unique_ptr<ScopedTemporaryFile>>
external_files_;
DISALLOW_COPY_AND_ASSIGN(Archive);
};
} // namespace asar
2019-06-19 20:56:58 +00:00
#endif // SHELL_COMMON_ASAR_ARCHIVE_H_