blob: fa88aa9e7115fbf8757c1628612746faa9cc82aa [file] [log] [blame]
// Copyright (c) 2012 The Chromium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#include "content/renderer/fetchers/multi_resolution_image_resource_fetcher.h"
#include "base/bind.h"
#include "base/bind_helpers.h"
#include "content/child/image_decoder.h"
#include "content/public/renderer/resource_fetcher.h"
#include "third_party/WebKit/public/platform/WebURLResponse.h"
#include "third_party/WebKit/public/web/WebFrame.h"
#include "third_party/WebKit/public/web/WebURLLoaderOptions.h"
#include "third_party/skia/include/core/SkBitmap.h"
#include "ui/gfx/geometry/size.h"
using blink::WebFrame;
using blink::WebURLLoaderOptions;
using blink::WebURLRequest;
using blink::WebURLResponse;
namespace content {
MultiResolutionImageResourceFetcher::MultiResolutionImageResourceFetcher(
const GURL& image_url,
WebFrame* frame,
int id,
WebURLRequest::RequestContext request_context,
blink::WebURLRequest::CachePolicy cache_policy,
const Callback& callback)
: callback_(callback),
id_(id),
http_status_code_(0),
image_url_(image_url) {
fetcher_.reset(ResourceFetcher::Create(image_url));
WebURLLoaderOptions options;
options.allowCredentials = true;
options.crossOriginRequestPolicy =
WebURLLoaderOptions::CrossOriginRequestPolicyAllow;
fetcher_->SetLoaderOptions(options);
// To prevent cache tainting, the favicon requests have to by-pass the service
// workers. This should ideally not happen or at least not all the time.
// See https://crbug.com/448427
if (request_context == WebURLRequest::RequestContextFavicon)
fetcher_->SetSkipServiceWorker(true);
fetcher_->SetCachePolicy(cache_policy);
fetcher_->Start(
frame,
request_context,
WebURLRequest::FrameTypeNone,
ResourceFetcher::FRAME_ASSOCIATED_LOADER,
base::Bind(&MultiResolutionImageResourceFetcher::OnURLFetchComplete,
base::Unretained(this)));
}
MultiResolutionImageResourceFetcher::~MultiResolutionImageResourceFetcher() {
}
void MultiResolutionImageResourceFetcher::OnURLFetchComplete(
const WebURLResponse& response,
const std::string& data) {
std::vector<SkBitmap> bitmaps;
if (!response.isNull()) {
http_status_code_ = response.httpStatusCode();
GURL url(response.url());
if (http_status_code_ == 200 || url.SchemeIsFile()) {
// Request succeeded, try to convert it to an image.
bitmaps = ImageDecoder::DecodeAll(
reinterpret_cast<const unsigned char*>(data.data()), data.size());
}
} // else case:
// If we get here, it means no image from server or couldn't decode the
// response as an image. The delegate will see an empty vector.
// Take a reference to the callback as running the callback may lead to our
// destruction.
Callback callback = callback_;
callback.Run(this, bitmaps);
}
} // namespace content