From f427e05d82291a19060de3c4da086fbffe313a48 Mon Sep 17 00:00:00 2001 From: "trop[bot]" <37223003+trop[bot]@users.noreply.github.com> Date: Mon, 9 Sep 2024 17:58:57 -0500 Subject: [PATCH] fix: -Wunsafe-buffer-usage warnings in asar file IO (#43648) * fix: -Wunsafe-buffer-usage warnings in ScopedTemporaryFile::InitFromFile() Co-authored-by: Charles Kerr * fix: -Wunsafe-buffer-usage warnings in Archive::Init() Co-authored-by: Charles Kerr --------- Co-authored-by: trop[bot] <37223003+trop[bot]@users.noreply.github.com> Co-authored-by: Charles Kerr --- shell/common/asar/archive.cc | 27 +++++++++------------- shell/common/asar/scoped_temporary_file.cc | 13 ++++------- 2 files changed, 15 insertions(+), 25 deletions(-) diff --git a/shell/common/asar/archive.cc b/shell/common/asar/archive.cc index b3daddcf8c0..4fb9a70f5ce 100644 --- a/shell/common/asar/archive.cc +++ b/shell/common/asar/archive.cc @@ -201,22 +201,19 @@ bool Archive::Init() { return false; } - std::vector buf; - int len; + std::vector buf; buf.resize(8); { electron::ScopedAllowBlockingForElectron allow_blocking; - len = file_.ReadAtCurrentPos(buf.data(), buf.size()); - } - if (len != static_cast(buf.size())) { - PLOG(ERROR) << "Failed to read header size from " << path_.value(); - return false; + if (!file_.ReadAtCurrentPosAndCheck(buf)) { + PLOG(ERROR) << "Failed to read header size from " << path_.value(); + return false; + } } uint32_t size; - if (!base::PickleIterator(base::Pickle::WithData(base::as_byte_span(buf))) - .ReadUInt32(&size)) { + if (!base::PickleIterator(base::Pickle::WithData(buf)).ReadUInt32(&size)) { LOG(ERROR) << "Failed to parse header size from " << path_.value(); return false; } @@ -224,16 +221,14 @@ bool Archive::Init() { buf.resize(size); { electron::ScopedAllowBlockingForElectron allow_blocking; - len = file_.ReadAtCurrentPos(buf.data(), buf.size()); - } - if (len != static_cast(buf.size())) { - PLOG(ERROR) << "Failed to read header from " << path_.value(); - return false; + if (!file_.ReadAtCurrentPosAndCheck(buf)) { + PLOG(ERROR) << "Failed to read header from " << path_.value(); + return false; + } } std::string header; - if (!base::PickleIterator(base::Pickle::WithData(base::as_byte_span(buf))) - .ReadString(&header)) { + if (!base::PickleIterator(base::Pickle::WithData(buf)).ReadString(&header)) { LOG(ERROR) << "Failed to parse header from " << path_.value(); return false; } diff --git a/shell/common/asar/scoped_temporary_file.cc b/shell/common/asar/scoped_temporary_file.cc index 1ad0ccf55ae..e82087fef93 100644 --- a/shell/common/asar/scoped_temporary_file.cc +++ b/shell/common/asar/scoped_temporary_file.cc @@ -63,20 +63,15 @@ bool ScopedTemporaryFile::InitFromFile( return false; electron::ScopedAllowBlockingForElectron allow_blocking; - std::vector buf(size); - int len = src->Read(offset, buf.data(), buf.size()); - if (len != static_cast(size)) + std::vector buf(size); + if (!src->ReadAndCheck(offset, buf)) return false; if (integrity) - ValidateIntegrityOrDie(base::as_byte_span(buf), *integrity); + ValidateIntegrityOrDie(buf, *integrity); base::File dest(path_, base::File::FLAG_OPEN | base::File::FLAG_WRITE); - if (!dest.IsValid()) - return false; - - return dest.WriteAtCurrentPos(buf.data(), buf.size()) == - static_cast(size); + return dest.IsValid() && dest.WriteAtCurrentPosAndCheck(buf); } } // namespace asar