• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
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
3 // found in the LICENSE file.
4 
5 #ifndef NET_BASE_UPLOAD_FILE_ELEMENT_READER_H_
6 #define NET_BASE_UPLOAD_FILE_ELEMENT_READER_H_
7 
8 #include "base/compiler_specific.h"
9 #include "base/files/file_path.h"
10 #include "base/gtest_prod_util.h"
11 #include "base/memory/ref_counted.h"
12 #include "base/memory/scoped_ptr.h"
13 #include "base/memory/weak_ptr.h"
14 #include "base/time/time.h"
15 #include "net/base/upload_element_reader.h"
16 
17 namespace base {
18 class TaskRunner;
19 }
20 
21 namespace net {
22 
23 class FileStream;
24 
25 // An UploadElementReader implementation for file.
26 class NET_EXPORT UploadFileElementReader : public UploadElementReader {
27  public:
28   // |task_runner| is used to perform file operations. It must not be NULL.
29   UploadFileElementReader(base::TaskRunner* task_runner,
30                           const base::FilePath& path,
31                           uint64 range_offset,
32                           uint64 range_length,
33                           const base::Time& expected_modification_time);
34   virtual ~UploadFileElementReader();
35 
path()36   const base::FilePath& path() const { return path_; }
range_offset()37   uint64 range_offset() const { return range_offset_; }
range_length()38   uint64 range_length() const { return range_length_; }
expected_modification_time()39   const base::Time& expected_modification_time() const {
40     return expected_modification_time_;
41   }
42 
43   // UploadElementReader overrides:
44   virtual const UploadFileElementReader* AsFileReader() const OVERRIDE;
45   virtual int Init(const CompletionCallback& callback) OVERRIDE;
46   virtual uint64 GetContentLength() const OVERRIDE;
47   virtual uint64 BytesRemaining() const OVERRIDE;
48   virtual int Read(IOBuffer* buf,
49                    int buf_length,
50                    const CompletionCallback& callback) OVERRIDE;
51 
52  private:
53   // Deletes FileStream with |task_runner| to avoid blocking the IO thread.
54   // This class is used as a template argument of scoped_ptr.
55   class FileStreamDeleter {
56    public:
57     explicit FileStreamDeleter(base::TaskRunner* task_runner);
58     ~FileStreamDeleter();
59     void operator() (FileStream* file_stream) const;
60 
61    private:
62     scoped_refptr<base::TaskRunner> task_runner_;
63   };
64 
65   typedef scoped_ptr<FileStream, FileStreamDeleter> ScopedFileStreamPtr;
66 
67   FRIEND_TEST_ALL_PREFIXES(UploadDataStreamTest, FileSmallerThanLength);
68   FRIEND_TEST_ALL_PREFIXES(HttpNetworkTransactionTest,
69                            UploadFileSmallerThanLength);
70   FRIEND_TEST_ALL_PREFIXES(HttpNetworkTransactionSpdy2Test,
71                            UploadFileSmallerThanLength);
72   FRIEND_TEST_ALL_PREFIXES(HttpNetworkTransactionSpdy3Test,
73                            UploadFileSmallerThanLength);
74 
75   // Resets this instance to the uninitialized state.
76   void Reset();
77 
78   // This method is used to implement Init().
79   void OnInitCompleted(ScopedFileStreamPtr* file_stream,
80                        uint64* content_length,
81                        const CompletionCallback& callback,
82                        int result);
83 
84   // This method is used to implement Read().
85   void OnReadCompleted(ScopedFileStreamPtr file_stream,
86                        const CompletionCallback& callback,
87                        int result);
88 
89   // Sets an value to override the result for GetContentLength().
90   // Used for tests.
91   struct NET_EXPORT_PRIVATE ScopedOverridingContentLengthForTests {
92     ScopedOverridingContentLengthForTests(uint64 value);
93     ~ScopedOverridingContentLengthForTests();
94   };
95 
96   scoped_refptr<base::TaskRunner> task_runner_;
97   const base::FilePath path_;
98   const uint64 range_offset_;
99   const uint64 range_length_;
100   const base::Time expected_modification_time_;
101   ScopedFileStreamPtr file_stream_;
102   uint64 content_length_;
103   uint64 bytes_remaining_;
104   base::WeakPtrFactory<UploadFileElementReader> weak_ptr_factory_;
105 
106   DISALLOW_COPY_AND_ASSIGN(UploadFileElementReader);
107 };
108 
109 // An UploadElementReader implementation for file which performs file operation
110 // synchronously.
111 // Use this class only if the thread is IO allowed.
112 class NET_EXPORT UploadFileElementReaderSync : public UploadElementReader {
113  public:
114   UploadFileElementReaderSync(const base::FilePath& path,
115                               uint64 range_offset,
116                               uint64 range_length,
117                               const base::Time& expected_modification_time);
118   virtual ~UploadFileElementReaderSync();
119 
120   // UploadElementReader overrides:
121   virtual int Init(const CompletionCallback& callback) OVERRIDE;
122   virtual uint64 GetContentLength() const OVERRIDE;
123   virtual uint64 BytesRemaining() const OVERRIDE;
124   virtual int Read(IOBuffer* buf,
125                    int buf_length,
126                    const CompletionCallback& callback) OVERRIDE;
127 
128  private:
129   const base::FilePath path_;
130   const uint64 range_offset_;
131   const uint64 range_length_;
132   const base::Time expected_modification_time_;
133   scoped_ptr<FileStream> file_stream_;
134   uint64 content_length_;
135   uint64 bytes_remaining_;
136 
137   DISALLOW_COPY_AND_ASSIGN(UploadFileElementReaderSync);
138 };
139 
140 }  // namespace net
141 
142 #endif  // NET_BASE_UPLOAD_FILE_ELEMENT_READER_H_
143