Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. |
| 2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
| 4 #ifndef CONTENT_BROWSER_DOWNLOAD_MHTML_GENERATION_MANAGER_H_ | 4 #ifndef CONTENT_BROWSER_DOWNLOAD_MHTML_GENERATION_MANAGER_H_ |
| 5 #define CONTENT_BROWSER_DOWNLOAD_MHTML_GENERATION_MANAGER_H_ | 5 #define CONTENT_BROWSER_DOWNLOAD_MHTML_GENERATION_MANAGER_H_ |
| 6 | 6 |
| 7 #include <stdint.h> | 7 #include <stdint.h> |
| 8 | 8 |
| 9 #include <map> | 9 #include <map> |
| 10 #include <memory> | 10 #include <memory> |
| 11 #include <set> | 11 #include <set> |
| 12 #include <string> | 12 #include <string> |
| 13 | 13 |
| 14 #include "base/files/file.h" | 14 #include "base/files/file.h" |
| 15 #include "base/macros.h" | 15 #include "base/macros.h" |
| 16 #include "base/memory/singleton.h" | 16 #include "base/memory/singleton.h" |
| 17 #include "base/process/process.h" | 17 #include "base/process/process.h" |
| 18 #include "base/supports_user_data.h" | |
| 18 #include "content/common/download/mhtml_save_status.h" | 19 #include "content/common/download/mhtml_save_status.h" |
| 20 #include "content/public/browser/web_contents.h" | |
| 19 #include "content/public/common/mhtml_generation_params.h" | 21 #include "content/public/common/mhtml_generation_params.h" |
| 20 #include "ipc/ipc_platform_file.h" | 22 #include "ipc/ipc_platform_file.h" |
| 21 | 23 |
| 22 namespace base { | 24 namespace base { |
| 23 class FilePath; | 25 class FilePath; |
| 24 } | 26 } |
| 25 | 27 |
| 26 namespace content { | 28 namespace content { |
| 27 | 29 |
| 28 class RenderFrameHostImpl; | 30 class RenderFrameHostImpl; |
| 29 class WebContents; | 31 class WebContents; |
| 30 | 32 |
| 31 // The class and all of its members live on the UI thread. Only static methods | 33 // The class and all of its members live on the UI thread. Only static methods |
| 32 // are executed on other threads. | 34 // are executed on other threads. |
| 33 // | 35 // |
| 34 // MHTMLGenerationManager is a singleton. Each call to SaveMHTML method creates | 36 // MHTMLGenerationManager is a singleton. Each call to SaveMHTML method creates |
| 35 // a new instance of MHTMLGenerationManager::Job that tracks generation of a | 37 // a new instance of MHTMLGenerationManager::Job that tracks generation of a |
| 36 // single MHTML file. | 38 // single MHTML file. |
| 37 class MHTMLGenerationManager { | 39 class CONTENT_EXPORT MHTMLGenerationManager { |
| 38 public: | 40 public: |
| 39 static MHTMLGenerationManager* GetInstance(); | 41 static MHTMLGenerationManager* GetInstance(); |
| 40 | 42 |
| 41 // GenerateMHTMLCallback is called to report completion and status of MHTML | 43 // GenerateMHTMLCallback is called to report completion and status of MHTML |
| 42 // generation. On success |file_size| indicates the size of the | 44 // generation. On success |file_size| indicates the size of the |
| 43 // generated file. On failure |file_size| is -1. | 45 // generated file. On failure |file_size| is -1. |
| 44 typedef base::Callback<void(int64_t file_size)> GenerateMHTMLCallback; | 46 typedef base::Callback<void(int64_t file_size)> GenerateMHTMLCallback; |
| 45 | 47 |
| 46 // Instructs the RenderFrames in |web_contents| to generate a MHTML | 48 // Instructs the RenderFrames in |web_contents| to generate a MHTML |
| 47 // representation of the current page. | 49 // representation of the current page. |
| 48 void SaveMHTML(WebContents* web_contents, | 50 void SaveMHTML(WebContents* web_contents, |
| 49 const MHTMLGenerationParams& params, | 51 const MHTMLGenerationParams& params, |
| 50 const GenerateMHTMLCallback& callback); | 52 const GenerateMHTMLCallback& callback); |
| 51 | 53 |
| 52 // Handler for FrameHostMsg_SerializeAsMHTMLResponse (a notification from the | 54 // Handler for FrameHostMsg_SerializeAsMHTMLResponse (a notification from the |
| 53 // renderer that the MHTML generation finished for a single frame). | 55 // renderer that the MHTML generation finished for a single frame). |
| 54 void OnSerializeAsMHTMLResponse( | 56 void OnSerializeAsMHTMLResponse( |
| 55 RenderFrameHostImpl* sender, | 57 RenderFrameHostImpl* sender, |
| 56 int job_id, | 58 int job_id, |
| 57 MhtmlSaveStatus save_status, | 59 MhtmlSaveStatus save_status, |
| 58 const std::set<std::string>& digests_of_uris_of_serialized_resources, | 60 const std::set<std::string>& digests_of_uris_of_serialized_resources, |
| 59 base::TimeDelta renderer_main_thread_time); | 61 base::TimeDelta renderer_main_thread_time); |
| 60 | 62 |
| 63 // Contained class that represents an extra data section. | |
|
Dmitry Titov
2017/03/18 00:58:34
This mechanism needs a great deal of comment, to e
Pete Williamson
2017/03/20 18:26:53
Added comments, LMK if I need more.
| |
| 64 struct MHTMLExtraSection { | |
|
Dmitry Titov
2017/03/18 00:58:34
Naming suggestion: MHTMLExtraSection -> ExtraPart.
Pete Williamson
2017/03/20 18:26:53
Done.
| |
| 65 std::string content_type; | |
| 66 std::string content_location; | |
| 67 std::string body; | |
| 68 }; | |
| 69 | |
| 70 // Helper class to put extra sections into the WebContents user data, and take | |
| 71 // them back out again. | |
| 72 class MHTMLExtraData : public base::SupportsUserData::Data { | |
| 73 public: | |
| 74 MHTMLExtraData(); | |
| 75 | |
|
Dmitry Titov
2017/03/18 00:58:34
extra empty line
Pete Williamson
2017/03/20 18:26:53
Done.
| |
| 76 ~MHTMLExtraData() override; | |
| 77 | |
| 78 std::vector<MHTMLExtraSection>* sections() { return §ions_; } | |
|
Dmitry Titov
2017/03/18 00:58:34
It feels that the access to the vector is not need
Pete Williamson
2017/03/20 18:26:53
Turns out I didn't really need this after all, I w
| |
| 79 | |
| 80 // Get the data string out of the web contents. | |
| 81 // The web contents retains ownership of the vector | |
| 82 static std::vector<MHTMLExtraSection>* FromWebContents( | |
| 83 content::WebContents* contents); | |
| 84 | |
| 85 // Stash the data string in the web contents user data. | |
| 86 static void AddToWebContents(content::WebContents* contents, | |
|
Dmitry Titov
2017/03/18 00:58:34
Not sure why this method is needed.
Pete Williamson
2017/03/20 18:26:53
This method is for adding a part to the vector sto
| |
| 87 MHTMLExtraSection& section); | |
| 88 | |
| 89 private: | |
| 90 std::vector<MHTMLExtraSection> sections_; | |
| 91 }; | |
| 92 | |
| 61 private: | 93 private: |
| 62 friend struct base::DefaultSingletonTraits<MHTMLGenerationManager>; | 94 friend struct base::DefaultSingletonTraits<MHTMLGenerationManager>; |
| 63 class Job; | 95 class Job; |
| 64 | 96 |
| 65 MHTMLGenerationManager(); | 97 MHTMLGenerationManager(); |
| 66 virtual ~MHTMLGenerationManager(); | 98 virtual ~MHTMLGenerationManager(); |
| 67 | 99 |
| 68 // Called on the file thread to create |file|. | 100 // Called on the file thread to create |file|. |
| 69 static base::File CreateFile(const base::FilePath& file_path); | 101 static base::File CreateFile(const base::FilePath& file_path); |
| 70 | 102 |
| (...skipping 23 matching lines...) Expand all Loading... | |
| 94 std::map<int, std::unique_ptr<Job>> id_to_job_; | 126 std::map<int, std::unique_ptr<Job>> id_to_job_; |
| 95 | 127 |
| 96 int next_job_id_; | 128 int next_job_id_; |
| 97 | 129 |
| 98 DISALLOW_COPY_AND_ASSIGN(MHTMLGenerationManager); | 130 DISALLOW_COPY_AND_ASSIGN(MHTMLGenerationManager); |
| 99 }; | 131 }; |
| 100 | 132 |
| 101 } // namespace content | 133 } // namespace content |
| 102 | 134 |
| 103 #endif // CONTENT_BROWSER_DOWNLOAD_MHTML_GENERATION_MANAGER_H_ | 135 #endif // CONTENT_BROWSER_DOWNLOAD_MHTML_GENERATION_MANAGER_H_ |
| OLD | NEW |