// Copyright (c) 2011 The Chromium Authors. All rights reserved. // Use of this source code is governed by a BSD-style license that can be // found in the LICENSE file. #ifndef CHROME_BROWSER_DOWNLOAD_BASE_FILE_H_ #define CHROME_BROWSER_DOWNLOAD_BASE_FILE_H_ #pragma once #include <string> #include "base/file_path.h" #include "base/memory/linked_ptr.h" #include "base/memory/scoped_ptr.h" #include "chrome/browser/power_save_blocker.h" #include "googleurl/src/gurl.h" namespace crypto { class SecureHash; } namespace net { class FileStream; } // File being downloaded and saved to disk. This is a base class // for DownloadFile and SaveFile, which keep more state information. class BaseFile { public: BaseFile(const FilePath& full_path, const GURL& source_url, const GURL& referrer_url, int64 received_bytes, const linked_ptr<net::FileStream>& file_stream); ~BaseFile(); // If calculate_hash is true, sha256 hash will be calculated. bool Initialize(bool calculate_hash); // Write a new chunk of data to the file. Returns true on success (all bytes // written to the file). bool AppendDataToFile(const char* data, size_t data_len); // Rename the download file. Returns true on success. virtual bool Rename(const FilePath& full_path); // Detach the file so it is not deleted on destruction. virtual void Detach(); // Abort the download and automatically close the file. void Cancel(); // Indicate that the download has finished. No new data will be received. void Finish(); // Informs the OS that this file came from the internet. void AnnotateWithSourceInformation(); FilePath full_path() const { return full_path_; } bool in_progress() const { return file_stream_ != NULL; } int64 bytes_so_far() const { return bytes_so_far_; } // Set |hash| with sha256 digest for the file. // Returns true if digest is successfully calculated. virtual bool GetSha256Hash(std::string* hash); virtual std::string DebugString() const; protected: bool Open(); void Close(); // Full path to the file including the file name. FilePath full_path_; private: static const size_t kSha256HashLen = 32; // Source URL for the file being downloaded. GURL source_url_; // The URL where the download was initiated. GURL referrer_url_; // OS file stream for writing linked_ptr<net::FileStream> file_stream_; // Amount of data received up so far, in bytes. int64 bytes_so_far_; // RAII handle to keep the system from sleeping while we're downloading. PowerSaveBlocker power_save_blocker_; // Indicates if sha256 hash should be calculated for the file. bool calculate_hash_; // Used to calculate sha256 hash for the file when calculate_hash_ // is set. scoped_ptr<crypto::SecureHash> secure_hash_; unsigned char sha256_hash_[kSha256HashLen]; // Indicates that this class no longer owns the associated file, and so // won't delete it on destruction. bool detached_; DISALLOW_COPY_AND_ASSIGN(BaseFile); }; #endif // CHROME_BROWSER_DOWNLOAD_BASE_FILE_H_