1 // 2 // Copyright (C) 2009 The Android Open Source Project 3 // 4 // Licensed under the Apache License, Version 2.0 (the "License"); 5 // you may not use this file except in compliance with the License. 6 // You may obtain a copy of the License at 7 // 8 // http://www.apache.org/licenses/LICENSE-2.0 9 // 10 // Unless required by applicable law or agreed to in writing, software 11 // distributed under the License is distributed on an "AS IS" BASIS, 12 // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 13 // See the License for the specific language governing permissions and 14 // limitations under the License. 15 // 16 17 #ifndef UPDATE_ENGINE_PAYLOAD_CONSUMER_FILE_WRITER_H_ 18 #define UPDATE_ENGINE_PAYLOAD_CONSUMER_FILE_WRITER_H_ 19 20 #include <fcntl.h> 21 #include <sys/stat.h> 22 #include <sys/types.h> 23 #include <unistd.h> 24 25 #include <base/logging.h> 26 27 #include "update_engine/common/error_code.h" 28 #include "update_engine/common/utils.h" 29 30 // FileWriter is a class that is used to (synchronously, for now) write to 31 // a file. This file is a thin wrapper around open/write/close system calls, 32 // but provides and interface that can be customized by subclasses that wish 33 // to filter the data. 34 35 namespace chromeos_update_engine { 36 37 class FileWriter { 38 public: FileWriter()39 FileWriter() {} ~FileWriter()40 virtual ~FileWriter() {} 41 42 // Wrapper around write. Returns true if all requested bytes 43 // were written, or false on any error, regardless of progress. 44 virtual bool Write(const void* bytes, size_t count) = 0; 45 46 // Same as the Write method above but returns a detailed |error| code 47 // in addition if the returned value is false. By default this method 48 // returns kActionExitDownloadWriteError as the error code, but subclasses 49 // can override if they wish to return more specific error codes. Write(const void * bytes,size_t count,ErrorCode * error)50 virtual bool Write(const void* bytes, size_t count, ErrorCode* error) { 51 *error = ErrorCode::kDownloadWriteError; 52 return Write(bytes, count); 53 } 54 55 // Wrapper around close. Returns 0 on success or -errno on error. 56 virtual int Close() = 0; 57 58 private: 59 DISALLOW_COPY_AND_ASSIGN(FileWriter); 60 }; 61 62 // Direct file writer is probably the simplest FileWriter implementation. 63 // It calls the system calls directly. 64 65 class DirectFileWriter : public FileWriter { 66 public: 67 DirectFileWriter() = default; 68 69 // FileWriter overrides. 70 bool Write(const void* bytes, size_t count) override; 71 int Close() override; 72 73 // Wrapper around open. Returns 0 on success or -errno on error. 74 int Open(const char* path, int flags, mode_t mode); 75 fd()76 int fd() const { return fd_; } 77 78 private: 79 int fd_{-1}; 80 81 DISALLOW_COPY_AND_ASSIGN(DirectFileWriter); 82 }; 83 84 class ScopedFileWriterCloser { 85 public: ScopedFileWriterCloser(FileWriter * writer)86 explicit ScopedFileWriterCloser(FileWriter* writer) : writer_(writer) {} ~ScopedFileWriterCloser()87 ~ScopedFileWriterCloser() { 88 int err = writer_->Close(); 89 if (err) 90 LOG(ERROR) << "FileWriter::Close failed: " 91 << utils::ErrnoNumberAsString(-err); 92 } 93 94 private: 95 FileWriter* writer_; 96 97 DISALLOW_COPY_AND_ASSIGN(ScopedFileWriterCloser); 98 }; 99 100 } // namespace chromeos_update_engine 101 102 #endif // UPDATE_ENGINE_PAYLOAD_CONSUMER_FILE_WRITER_H_ 103