electron/atom/browser/net/url_request_buffer_job.cc

100 lines
3 KiB
C++
Raw Normal View History

2015-03-16 12:53:45 +00:00
// Copyright (c) 2013 GitHub, Inc.
// Use of this source code is governed by the MIT license that can be
// found in the LICENSE file.
#include "atom/browser/net/url_request_buffer_job.h"
#include <string>
2015-12-01 08:21:15 +00:00
#include "atom/common/atom_constants.h"
#include "base/strings/string_number_conversions.h"
2016-05-28 13:36:22 +00:00
#include "base/strings/utf_string_conversions.h"
#include "net/base/mime_util.h"
2015-03-16 12:53:45 +00:00
#include "net/base/net_errors.h"
namespace atom {
2016-05-28 13:36:22 +00:00
namespace {
std::string GetExtFromURL(const GURL& url) {
std::string spec = url.spec();
size_t index = spec.find_last_of('.');
if (index == std::string::npos || index == spec.size())
return std::string();
return spec.substr(index + 1, spec.size() - index - 1);
}
} // namespace
2018-04-18 01:55:30 +00:00
URLRequestBufferJob::URLRequestBufferJob(net::URLRequest* request,
net::NetworkDelegate* network_delegate)
: JsAsker<net::URLRequestSimpleJob>(request, network_delegate),
2018-04-18 01:55:30 +00:00
status_code_(net::HTTP_NOT_IMPLEMENTED) {}
2016-05-23 01:59:39 +00:00
void URLRequestBufferJob::StartAsync(std::unique_ptr<base::Value> options) {
const base::Value* binary = nullptr;
2017-04-05 08:34:53 +00:00
if (options->IsType(base::Value::Type::DICTIONARY)) {
base::DictionaryValue* dict =
static_cast<base::DictionaryValue*>(options.get());
dict->GetString("mimeType", &mime_type_);
dict->GetString("charset", &charset_);
dict->GetBinary("data", &binary);
2017-04-05 08:34:53 +00:00
} else if (options->IsType(base::Value::Type::BINARY)) {
binary = options.get();
}
2016-05-28 13:36:22 +00:00
if (mime_type_.empty()) {
std::string ext = GetExtFromURL(request()->url());
#if defined(OS_WIN)
net::GetWellKnownMimeTypeFromExtension(base::UTF8ToUTF16(ext), &mime_type_);
#else
net::GetWellKnownMimeTypeFromExtension(ext, &mime_type_);
#endif
}
if (!binary) {
2018-04-18 01:55:30 +00:00
NotifyStartError(net::URLRequestStatus(net::URLRequestStatus::FAILED,
net::ERR_NOT_IMPLEMENTED));
return;
}
data_ = new base::RefCountedBytes(
reinterpret_cast<const unsigned char*>(binary->GetBlob().data()),
binary->GetBlob().size());
status_code_ = net::HTTP_OK;
net::URLRequestSimpleJob::Start();
2015-03-16 12:53:45 +00:00
}
void URLRequestBufferJob::GetResponseInfo(net::HttpResponseInfo* info) {
std::string status("HTTP/1.1 200 OK");
status.append(base::IntToString(status_code_));
status.append(" ");
status.append(net::GetHttpReasonPhrase(status_code_));
status.append("\0\0", 2);
auto* headers = new net::HttpResponseHeaders(status);
2015-12-01 08:21:15 +00:00
headers->AddHeader(kCORSHeader);
if (!mime_type_.empty()) {
std::string content_type_header(net::HttpRequestHeaders::kContentType);
content_type_header.append(": ");
content_type_header.append(mime_type_);
headers->AddHeader(content_type_header);
}
info->headers = headers;
}
2015-03-16 12:53:45 +00:00
int URLRequestBufferJob::GetRefCountedData(
std::string* mime_type,
std::string* charset,
scoped_refptr<base::RefCountedMemory>* data,
const net::CompletionCallback& callback) const {
*mime_type = mime_type_;
*charset = charset_;
*data = data_;
2015-03-16 12:53:45 +00:00
return net::OK;
}
} // namespace atom