2014-10-31 18:17:05 +00:00
|
|
|
// Copyright (c) 2014 GitHub, Inc.
|
2014-09-23 11:14:30 +00:00
|
|
|
// Use of this source code is governed by the MIT license that can be
|
|
|
|
// found in the LICENSE file.
|
|
|
|
|
|
|
|
#ifndef ATOM_BROWSER_NET_ASAR_URL_REQUEST_ASAR_JOB_H_
|
|
|
|
#define ATOM_BROWSER_NET_ASAR_URL_REQUEST_ASAR_JOB_H_
|
|
|
|
|
2015-02-12 09:23:49 +00:00
|
|
|
#include <memory>
|
2014-09-23 12:30:07 +00:00
|
|
|
#include <string>
|
|
|
|
|
2015-08-12 07:18:31 +00:00
|
|
|
#include "atom/browser/net/js_asker.h"
|
2014-09-23 11:14:30 +00:00
|
|
|
#include "atom/common/asar/archive.h"
|
|
|
|
#include "base/files/file_path.h"
|
|
|
|
#include "base/memory/ref_counted.h"
|
|
|
|
#include "base/memory/weak_ptr.h"
|
2015-08-12 07:18:31 +00:00
|
|
|
#include "net/http/http_byte_range.h"
|
2014-09-23 11:14:30 +00:00
|
|
|
#include "net/url_request/url_request_job.h"
|
|
|
|
|
|
|
|
namespace base {
|
|
|
|
class TaskRunner;
|
|
|
|
}
|
|
|
|
|
2014-09-23 12:30:07 +00:00
|
|
|
namespace net {
|
|
|
|
class FileStream;
|
|
|
|
}
|
|
|
|
|
2014-09-23 11:14:30 +00:00
|
|
|
namespace asar {
|
|
|
|
|
2015-03-20 12:34:58 +00:00
|
|
|
// Createa a request job according to the file path.
|
|
|
|
net::URLRequestJob* CreateJobFromPath(
|
|
|
|
const base::FilePath& full_path,
|
|
|
|
net::URLRequest* request,
|
|
|
|
net::NetworkDelegate* network_delegate,
|
|
|
|
const scoped_refptr<base::TaskRunner> file_task_runner);
|
|
|
|
|
2014-09-23 11:14:30 +00:00
|
|
|
class URLRequestAsarJob : public net::URLRequestJob {
|
|
|
|
public:
|
|
|
|
URLRequestAsarJob(net::URLRequest* request,
|
2015-08-12 07:18:31 +00:00
|
|
|
net::NetworkDelegate* network_delegate);
|
|
|
|
|
|
|
|
void Initialize(const scoped_refptr<base::TaskRunner> file_task_runner,
|
|
|
|
const base::FilePath& file_path);
|
|
|
|
|
|
|
|
protected:
|
|
|
|
virtual ~URLRequestAsarJob();
|
|
|
|
|
|
|
|
void InitializeAsarJob(const scoped_refptr<base::TaskRunner> file_task_runner,
|
|
|
|
std::shared_ptr<Archive> archive,
|
|
|
|
const base::FilePath& file_path,
|
|
|
|
const Archive::FileInfo& file_info);
|
|
|
|
void InitializeFileJob(const scoped_refptr<base::TaskRunner> file_task_runner,
|
|
|
|
const base::FilePath& file_path);
|
2014-09-23 11:14:30 +00:00
|
|
|
|
|
|
|
// net::URLRequestJob:
|
2015-01-10 01:24:36 +00:00
|
|
|
void Start() override;
|
|
|
|
void Kill() override;
|
2016-03-08 14:28:53 +00:00
|
|
|
int ReadRawData(net::IOBuffer* buf, int buf_size) override;
|
2015-08-12 07:18:31 +00:00
|
|
|
bool IsRedirectResponse(GURL* location, int* http_status_code) override;
|
|
|
|
net::Filter* SetupFilter() const override;
|
2015-01-10 01:24:36 +00:00
|
|
|
bool GetMimeType(std::string* mime_type) const override;
|
2015-08-12 07:18:31 +00:00
|
|
|
void SetExtraRequestHeaders(const net::HttpRequestHeaders& headers) override;
|
2015-12-08 19:21:46 +00:00
|
|
|
int GetResponseCode() const override;
|
|
|
|
void GetResponseInfo(net::HttpResponseInfo* info) override;
|
2014-09-23 11:14:30 +00:00
|
|
|
|
|
|
|
private:
|
2015-08-12 07:18:31 +00:00
|
|
|
// Meta information about the file. It's used as a member in the
|
|
|
|
// URLRequestFileJob and also passed between threads because disk access is
|
|
|
|
// necessary to obtain it.
|
|
|
|
struct FileMetaInfo {
|
|
|
|
FileMetaInfo();
|
|
|
|
|
|
|
|
// Size of the file.
|
2016-03-08 14:28:53 +00:00
|
|
|
int64_t file_size;
|
2015-08-12 07:18:31 +00:00
|
|
|
// Mime type associated with the file.
|
|
|
|
std::string mime_type;
|
|
|
|
// Result returned from GetMimeTypeFromFile(), i.e. flag showing whether
|
|
|
|
// obtaining of the mime type was successful.
|
|
|
|
bool mime_type_result;
|
|
|
|
// Flag showing whether the file exists.
|
|
|
|
bool file_exists;
|
|
|
|
// Flag showing whether the file name actually refers to a directory.
|
|
|
|
bool is_directory;
|
|
|
|
};
|
|
|
|
|
|
|
|
// Fetches file info on a background thread.
|
|
|
|
static void FetchMetaInfo(const base::FilePath& file_path,
|
|
|
|
FileMetaInfo* meta_info);
|
|
|
|
|
|
|
|
// Callback after fetching file info on a background thread.
|
|
|
|
void DidFetchMetaInfo(const FileMetaInfo* meta_info);
|
|
|
|
|
|
|
|
|
2014-09-23 12:30:07 +00:00
|
|
|
// Callback after opening file on a background thread.
|
|
|
|
void DidOpen(int result);
|
|
|
|
|
|
|
|
// Callback after seeking to the beginning of |byte_range_| in the file
|
|
|
|
// on a background thread.
|
2016-03-08 14:28:53 +00:00
|
|
|
void DidSeek(int64_t result);
|
2014-09-23 12:30:07 +00:00
|
|
|
|
|
|
|
// Callback after data is asynchronously read from the file into |buf|.
|
|
|
|
void DidRead(scoped_refptr<net::IOBuffer> buf, int result);
|
|
|
|
|
2015-08-12 07:18:31 +00:00
|
|
|
// The type of this job.
|
|
|
|
enum JobType {
|
|
|
|
TYPE_ERROR,
|
|
|
|
TYPE_ASAR,
|
|
|
|
TYPE_FILE,
|
|
|
|
};
|
|
|
|
JobType type_;
|
|
|
|
|
2015-02-12 09:23:49 +00:00
|
|
|
std::shared_ptr<Archive> archive_;
|
2014-09-23 11:14:30 +00:00
|
|
|
base::FilePath file_path_;
|
2015-03-20 12:34:58 +00:00
|
|
|
Archive::FileInfo file_info_;
|
2014-09-23 12:30:07 +00:00
|
|
|
|
|
|
|
scoped_ptr<net::FileStream> stream_;
|
2015-08-12 07:18:31 +00:00
|
|
|
FileMetaInfo meta_info_;
|
|
|
|
scoped_refptr<base::TaskRunner> file_task_runner_;
|
2014-09-23 13:48:40 +00:00
|
|
|
|
2015-08-12 07:18:31 +00:00
|
|
|
net::HttpByteRange byte_range_;
|
2016-03-08 14:28:53 +00:00
|
|
|
int64_t remaining_bytes_;
|
|
|
|
|
|
|
|
net::Error range_parse_result_;
|
2014-09-23 11:14:30 +00:00
|
|
|
|
|
|
|
base::WeakPtrFactory<URLRequestAsarJob> weak_ptr_factory_;
|
|
|
|
|
|
|
|
DISALLOW_COPY_AND_ASSIGN(URLRequestAsarJob);
|
|
|
|
};
|
|
|
|
|
|
|
|
} // namespace asar
|
|
|
|
|
|
|
|
#endif // ATOM_BROWSER_NET_ASAR_URL_REQUEST_ASAR_JOB_H_
|