summaryrefslogtreecommitdiff
path: root/src/buildtool/file_system/git_cas.cpp
diff options
context:
space:
mode:
authorPaul Cristian Sarbu <paul.cristian.sarbu@huawei.com>2025-05-09 13:16:20 +0200
committerPaul Cristian Sarbu <paul.cristian.sarbu@huawei.com>2025-06-04 14:34:44 +0200
commit8970cd4cbd4d75322d3c6132c6b440b194dcca89 (patch)
treebf19f9079a3668ec2e7fecddc9ac6eb227c52966 /src/buildtool/file_system/git_cas.cpp
parentecb6a45bf6d97000519b567d2e5269fffce780dd (diff)
downloadjustbuild-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.cpp14
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
}