diff options
author | Paul Cristian Sarbu <paul.cristian.sarbu@huawei.com> | 2025-05-09 13:16:20 +0200 |
---|---|---|
committer | Paul Cristian Sarbu <paul.cristian.sarbu@huawei.com> | 2025-06-04 14:34:44 +0200 |
commit | 8970cd4cbd4d75322d3c6132c6b440b194dcca89 (patch) | |
tree | bf19f9079a3668ec2e7fecddc9ac6eb227c52966 /src/buildtool/file_system/git_cas.cpp | |
parent | ecb6a45bf6d97000519b567d2e5269fffce780dd (diff) | |
download | justbuild-8970cd4cbd4d75322d3c6132c6b440b194dcca89.tar.gz |
git_cas read object: allow validation of individual blobs
This allows individual blobs read to be checked, e.g., for upwards
symlinks, also when not part of a tree, which performs such a
validation for its entries during its parsing into a GitTree.
Diffstat (limited to 'src/buildtool/file_system/git_cas.cpp')
-rw-r--r-- | src/buildtool/file_system/git_cas.cpp | 14 |
1 files changed, 14 insertions, 0 deletions
diff --git a/src/buildtool/file_system/git_cas.cpp b/src/buildtool/file_system/git_cas.cpp index 1af1dde2..b49a75dd 100644 --- a/src/buildtool/file_system/git_cas.cpp +++ b/src/buildtool/file_system/git_cas.cpp @@ -136,6 +136,7 @@ auto GitCAS::CreateEmpty() noexcept -> GitCASPtr { auto GitCAS::ReadObject(std::string const& id, bool is_hex_id, + bool as_valid_symlink, LogLevel log_failure) const noexcept -> std::optional<std::string> { #ifdef BOOTSTRAP_BUILD_TOOL @@ -161,8 +162,21 @@ auto GitCAS::ReadObject(std::string const& id, std::string data(static_cast<char const*>(git_odb_object_data(obj)), git_odb_object_size(obj)); + auto obj_type = GitTypeToObjectType(git_odb_object_type(obj)); git_odb_object_free(obj); + if (as_valid_symlink) { + if (not obj_type) { + return std::nullopt; + } + if (not IsTreeObject(*obj_type) and not PathIsNonUpwards(data)) { + Logger::Log(log_failure, + "invalid git object {}: upwards symlink", + is_hex_id ? id : ToHexString(id)); + return std::nullopt; + } + } + return data; #endif } |