protocol: respect provided mimetype in generated response headers
This commit is contained in:
parent
6615787775
commit
57c910faef
5 changed files with 57 additions and 1 deletions
|
@ -6,13 +6,15 @@
|
||||||
|
|
||||||
#include <string>
|
#include <string>
|
||||||
|
|
||||||
|
#include "base/strings/string_number_conversions.h"
|
||||||
#include "net/base/net_errors.h"
|
#include "net/base/net_errors.h"
|
||||||
|
|
||||||
namespace atom {
|
namespace atom {
|
||||||
|
|
||||||
URLRequestBufferJob::URLRequestBufferJob(
|
URLRequestBufferJob::URLRequestBufferJob(
|
||||||
net::URLRequest* request, net::NetworkDelegate* network_delegate)
|
net::URLRequest* request, net::NetworkDelegate* network_delegate)
|
||||||
: JsAsker<net::URLRequestSimpleJob>(request, network_delegate) {
|
: JsAsker<net::URLRequestSimpleJob>(request, network_delegate),
|
||||||
|
status_code_(net::HTTP_NOT_IMPLEMENTED) {
|
||||||
}
|
}
|
||||||
|
|
||||||
void URLRequestBufferJob::StartAsync(scoped_ptr<base::Value> options) {
|
void URLRequestBufferJob::StartAsync(scoped_ptr<base::Value> options) {
|
||||||
|
@ -36,9 +38,28 @@ void URLRequestBufferJob::StartAsync(scoped_ptr<base::Value> options) {
|
||||||
data_ = new base::RefCountedBytes(
|
data_ = new base::RefCountedBytes(
|
||||||
reinterpret_cast<const unsigned char*>(binary->GetBuffer()),
|
reinterpret_cast<const unsigned char*>(binary->GetBuffer()),
|
||||||
binary->GetSize());
|
binary->GetSize());
|
||||||
|
status_code_ = net::HTTP_OK;
|
||||||
net::URLRequestSimpleJob::Start();
|
net::URLRequestSimpleJob::Start();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void URLRequestBufferJob::GetResponseInfo(net::HttpResponseInfo* info) {
|
||||||
|
std::string status("HTTP/1.1 ");
|
||||||
|
status.append(base::IntToString(status_code_));
|
||||||
|
status.append(" ");
|
||||||
|
status.append(net::GetHttpReasonPhrase(status_code_));
|
||||||
|
status.append("\0\0", 2);
|
||||||
|
net::HttpResponseHeaders* headers = new net::HttpResponseHeaders(status);
|
||||||
|
|
||||||
|
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;
|
||||||
|
}
|
||||||
|
|
||||||
int URLRequestBufferJob::GetRefCountedData(
|
int URLRequestBufferJob::GetRefCountedData(
|
||||||
std::string* mime_type,
|
std::string* mime_type,
|
||||||
std::string* charset,
|
std::string* charset,
|
||||||
|
|
|
@ -9,6 +9,7 @@
|
||||||
|
|
||||||
#include "atom/browser/net/js_asker.h"
|
#include "atom/browser/net/js_asker.h"
|
||||||
#include "base/memory/ref_counted_memory.h"
|
#include "base/memory/ref_counted_memory.h"
|
||||||
|
#include "net/http/http_status_code.h"
|
||||||
#include "net/url_request/url_request_simple_job.h"
|
#include "net/url_request/url_request_simple_job.h"
|
||||||
|
|
||||||
namespace atom {
|
namespace atom {
|
||||||
|
@ -20,6 +21,9 @@ class URLRequestBufferJob : public JsAsker<net::URLRequestSimpleJob> {
|
||||||
// JsAsker:
|
// JsAsker:
|
||||||
void StartAsync(scoped_ptr<base::Value> options) override;
|
void StartAsync(scoped_ptr<base::Value> options) override;
|
||||||
|
|
||||||
|
// URLRequestJob:
|
||||||
|
void GetResponseInfo(net::HttpResponseInfo* info) override;
|
||||||
|
|
||||||
// URLRequestSimpleJob:
|
// URLRequestSimpleJob:
|
||||||
int GetRefCountedData(std::string* mime_type,
|
int GetRefCountedData(std::string* mime_type,
|
||||||
std::string* charset,
|
std::string* charset,
|
||||||
|
@ -30,6 +34,7 @@ class URLRequestBufferJob : public JsAsker<net::URLRequestSimpleJob> {
|
||||||
std::string mime_type_;
|
std::string mime_type_;
|
||||||
std::string charset_;
|
std::string charset_;
|
||||||
scoped_refptr<base::RefCountedBytes> data_;
|
scoped_refptr<base::RefCountedBytes> data_;
|
||||||
|
net::HttpStatusCode status_code_;
|
||||||
|
|
||||||
DISALLOW_COPY_AND_ASSIGN(URLRequestBufferJob);
|
DISALLOW_COPY_AND_ASSIGN(URLRequestBufferJob);
|
||||||
};
|
};
|
||||||
|
|
|
@ -28,6 +28,20 @@ void URLRequestStringJob::StartAsync(scoped_ptr<base::Value> options) {
|
||||||
net::URLRequestSimpleJob::Start();
|
net::URLRequestSimpleJob::Start();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void URLRequestStringJob::GetResponseInfo(net::HttpResponseInfo* info) {
|
||||||
|
std::string status("HTTP/1.1 200 OK");
|
||||||
|
net::HttpResponseHeaders* headers = new net::HttpResponseHeaders(status);
|
||||||
|
|
||||||
|
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;
|
||||||
|
}
|
||||||
|
|
||||||
int URLRequestStringJob::GetData(
|
int URLRequestStringJob::GetData(
|
||||||
std::string* mime_type,
|
std::string* mime_type,
|
||||||
std::string* charset,
|
std::string* charset,
|
||||||
|
|
|
@ -19,6 +19,9 @@ class URLRequestStringJob : public JsAsker<net::URLRequestSimpleJob> {
|
||||||
// JsAsker:
|
// JsAsker:
|
||||||
void StartAsync(scoped_ptr<base::Value> options) override;
|
void StartAsync(scoped_ptr<base::Value> options) override;
|
||||||
|
|
||||||
|
// URLRequestJob:
|
||||||
|
void GetResponseInfo(net::HttpResponseInfo* info) override;
|
||||||
|
|
||||||
// URLRequestSimpleJob:
|
// URLRequestSimpleJob:
|
||||||
int GetData(std::string* mime_type,
|
int GetData(std::string* mime_type,
|
||||||
std::string* charset,
|
std::string* charset,
|
||||||
|
|
|
@ -318,6 +318,19 @@ describe 'protocol module', ->
|
||||||
error: (xhr, errorType, error) ->
|
error: (xhr, errorType, error) ->
|
||||||
done(error)
|
done(error)
|
||||||
|
|
||||||
|
it 'can set content-type', (done) ->
|
||||||
|
handler = (request, callback) ->
|
||||||
|
callback({mimeType: 'application/json', data: '{"value": 1}'})
|
||||||
|
protocol.interceptStringProtocol 'http', handler, (error) ->
|
||||||
|
$.ajax
|
||||||
|
url: 'http://fake-host'
|
||||||
|
success: (data) ->
|
||||||
|
assert.equal typeof(data), 'object'
|
||||||
|
assert.equal data.value, 1
|
||||||
|
done()
|
||||||
|
error: (xhr, errorType, error) ->
|
||||||
|
done(error)
|
||||||
|
|
||||||
describe 'protocol.interceptBufferProtocol', ->
|
describe 'protocol.interceptBufferProtocol', ->
|
||||||
it 'can intercept http protocol', (done) ->
|
it 'can intercept http protocol', (done) ->
|
||||||
handler = (request, callback) -> callback(new Buffer(text))
|
handler = (request, callback) -> callback(new Buffer(text))
|
||||||
|
|
Loading…
Reference in a new issue