Set default mimeType for BufferJob
This commit is contained in:
parent
30dca2b4e1
commit
f4fe60d126
2 changed files with 24 additions and 1 deletions
|
@ -8,10 +8,24 @@
|
||||||
|
|
||||||
#include "atom/common/atom_constants.h"
|
#include "atom/common/atom_constants.h"
|
||||||
#include "base/strings/string_number_conversions.h"
|
#include "base/strings/string_number_conversions.h"
|
||||||
|
#include "base/strings/utf_string_conversions.h"
|
||||||
|
#include "net/base/mime_util.h"
|
||||||
#include "net/base/net_errors.h"
|
#include "net/base/net_errors.h"
|
||||||
|
|
||||||
namespace atom {
|
namespace atom {
|
||||||
|
|
||||||
|
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
|
||||||
|
|
||||||
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),
|
||||||
|
@ -30,6 +44,15 @@ void URLRequestBufferJob::StartAsync(std::unique_ptr<base::Value> options) {
|
||||||
options->GetAsBinary(&binary);
|
options->GetAsBinary(&binary);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
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) {
|
if (!binary) {
|
||||||
NotifyStartError(net::URLRequestStatus(
|
NotifyStartError(net::URLRequestStatus(
|
||||||
net::URLRequestStatus::FAILED, net::ERR_NOT_IMPLEMENTED));
|
net::URLRequestStatus::FAILED, net::ERR_NOT_IMPLEMENTED));
|
||||||
|
|
|
@ -227,7 +227,7 @@ app.once('ready', function () {
|
||||||
if (err) {
|
if (err) {
|
||||||
return callback(-6) // FILE_NOT_FOUND
|
return callback(-6) // FILE_NOT_FOUND
|
||||||
} else {
|
} else {
|
||||||
return callback({mimeType: 'text/html', data: content})
|
return callback(content)
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue