Commit 1fb40c33 authored by Sergio Villar Senin's avatar Sergio Villar Senin Committed by Commit Bot

[android] Migrate chrome/browser/android/logo_bridge.cc using SimpleURLLoader

It's currently using URLFetcher. It should use SimpleURLLoader
instead to make it eventually work with the network service.

Bug: 872878
Change-Id: I4e170cfc75febb512e35783b488071014b21d7b2
Reviewed-on: https://chromium-review.googlesource.com/1203910
Commit-Queue: Sergio Villar <svillar@igalia.com>
Reviewed-by: default avatarBernhard Bauer <bauerb@chromium.org>
Reviewed-by: default avatarMatt Menke <mmenke@chromium.org>
Cr-Commit-Position: refs/heads/master@{#588523}
parent 8c02a653
...@@ -16,11 +16,12 @@ ...@@ -16,11 +16,12 @@
#include "chrome/browser/search_provider_logos/logo_service_factory.h" #include "chrome/browser/search_provider_logos/logo_service_factory.h"
#include "components/search_provider_logos/logo_service.h" #include "components/search_provider_logos/logo_service.h"
#include "components/search_provider_logos/logo_tracker.h" #include "components/search_provider_logos/logo_tracker.h"
#include "content/public/browser/storage_partition.h"
#include "jni/LogoBridge_jni.h" #include "jni/LogoBridge_jni.h"
#include "net/url_request/url_fetcher.h" #include "net/http/http_status_code.h"
#include "net/url_request/url_fetcher_delegate.h" #include "services/network/public/cpp/resource_response_info.h"
#include "net/url_request/url_request_context_getter.h" #include "services/network/public/cpp/shared_url_loader_factory.h"
#include "net/url_request/url_request_status.h" #include "services/network/public/cpp/simple_url_loader.h"
#include "third_party/skia/include/core/SkBitmap.h" #include "third_party/skia/include/core/SkBitmap.h"
#include "ui/gfx/android/java_bitmap.h" #include "ui/gfx/android/java_bitmap.h"
#include "url/gurl.h" #include "url/gurl.h"
...@@ -108,73 +109,80 @@ class LogoObserverAndroid : public search_provider_logos::LogoObserver { ...@@ -108,73 +109,80 @@ class LogoObserverAndroid : public search_provider_logos::LogoObserver {
} // namespace } // namespace
class LogoBridge::AnimatedLogoFetcher : public net::URLFetcherDelegate { class LogoBridge::AnimatedLogoLoader {
public: public:
AnimatedLogoFetcher( explicit AnimatedLogoLoader(
const scoped_refptr<net::URLRequestContextGetter>& request_context) scoped_refptr<network::SharedURLLoaderFactory> factory)
: request_context_(request_context) {} : shared_url_loader_factory_(std::move(factory)) {}
~AnimatedLogoFetcher() override {}
void Start(JNIEnv* env, void Start(JNIEnv* env,
const GURL& url, const GURL& url,
const JavaParamRef<jobject>& j_callback) { const JavaParamRef<jobject>& j_callback) {
DCHECK(j_callback); DCHECK(j_callback);
if (fetcher_ && fetcher_->GetOriginalURL() == url) if (loader_ && url_ == url)
return; return;
url_ = url;
j_callback_.Reset(env, j_callback); j_callback_.Reset(env, j_callback);
fetcher_ = net::URLFetcher::Create(url, net::URLFetcher::GET, this); auto request = std::make_unique<network::ResourceRequest>();
fetcher_->SetRequestContext(request_context_.get()); request->url = url;
fetcher_->Start(); loader_ = network::SimpleURLLoader::Create(std::move(request),
NO_TRAFFIC_ANNOTATION_YET);
loader_->DownloadToStringOfUnboundedSizeUntilCrashAndDie(
shared_url_loader_factory_.get(),
base::BindOnce(&AnimatedLogoLoader::OnURLLoaderComplete,
base::Unretained(this)));
start_time_ = base::TimeTicks::Now(); start_time_ = base::TimeTicks::Now();
} }
private: private:
void OnURLFetchComplete(const net::URLFetcher* source) override { void OnURLLoaderComplete(std::unique_ptr<std::string> response_body) {
DCHECK_EQ(source, fetcher_.get()); DCHECK(loader_);
DCHECK(!j_callback_.is_null()); DCHECK(!j_callback_.is_null());
if (!source->GetStatus().is_success() || int response_code = -1;
(source->GetResponseCode() != 200)) { if (loader_->ResponseInfo() && loader_->ResponseInfo()->headers)
ClearFetcher(); response_code = loader_->ResponseInfo()->headers->response_code();
if (!response_body || response_code != net::HTTP_OK) {
ClearLoader();
return; return;
} }
UMA_HISTOGRAM_TIMES("NewTabPage.AnimatedLogoDownloadTime", UMA_HISTOGRAM_TIMES("NewTabPage.AnimatedLogoDownloadTime",
base::TimeTicks::Now() - start_time_); base::TimeTicks::Now() - start_time_);
std::string response;
source->GetResponseAsString(&response);
JNIEnv* env = base::android::AttachCurrentThread(); JNIEnv* env = base::android::AttachCurrentThread();
ScopedJavaLocalRef<jbyteArray> j_bytes = ScopedJavaLocalRef<jbyteArray> j_bytes = ToJavaByteArray(
ToJavaByteArray(env, reinterpret_cast<const uint8_t*>(response.data()), env, reinterpret_cast<const uint8_t*>(response_body.get()),
response.length()); response_body->size());
ScopedJavaLocalRef<jobject> j_gif_image = ScopedJavaLocalRef<jobject> j_gif_image =
Java_LogoBridge_createGifImage(env, j_bytes); Java_LogoBridge_createGifImage(env, j_bytes);
Java_AnimatedLogoCallback_onAnimatedLogoAvailable(env, j_callback_, Java_AnimatedLogoCallback_onAnimatedLogoAvailable(env, j_callback_,
j_gif_image); j_gif_image);
ClearFetcher(); ClearLoader();
} }
void ClearFetcher() { void ClearLoader() {
fetcher_.reset(); loader_.reset();
j_callback_.Reset(); j_callback_.Reset();
} }
scoped_refptr<net::URLRequestContextGetter> request_context_; scoped_refptr<network::SharedURLLoaderFactory> shared_url_loader_factory_;
base::android::ScopedJavaGlobalRef<jobject> j_callback_; base::android::ScopedJavaGlobalRef<jobject> j_callback_;
// The URLFetcher currently fetching the animated logo, or nullptr when not // The original url used for the request.
// fetching. GURL url_;
std::unique_ptr<net::URLFetcher> fetcher_;
// The SimpleURLLoader currently fetching the animated logo, or nullptr when
// not fetching.
std::unique_ptr<network::SimpleURLLoader> loader_;
// The time when the current fetch was started. // The time when the current fetch was started.
base::TimeTicks start_time_; base::TimeTicks start_time_;
DISALLOW_COPY_AND_ASSIGN(AnimatedLogoFetcher); DISALLOW_COPY_AND_ASSIGN(AnimatedLogoLoader);
}; };
static jlong JNI_LogoBridge_Init(JNIEnv* env, static jlong JNI_LogoBridge_Init(JNIEnv* env,
...@@ -191,8 +199,9 @@ LogoBridge::LogoBridge(const JavaRef<jobject>& j_profile) ...@@ -191,8 +199,9 @@ LogoBridge::LogoBridge(const JavaRef<jobject>& j_profile)
logo_service_ = LogoServiceFactory::GetForProfile(profile); logo_service_ = LogoServiceFactory::GetForProfile(profile);
animated_logo_fetcher_ = animated_logo_loader_ = std::make_unique<AnimatedLogoLoader>(
std::make_unique<AnimatedLogoFetcher>(profile->GetRequestContext()); content::BrowserContext::GetDefaultStoragePartition(profile)
->GetURLLoaderFactoryForBrowserProcess());
} }
LogoBridge::~LogoBridge() {} LogoBridge::~LogoBridge() {}
...@@ -215,5 +224,5 @@ void LogoBridge::GetAnimatedLogo(JNIEnv* env, ...@@ -215,5 +224,5 @@ void LogoBridge::GetAnimatedLogo(JNIEnv* env,
const JavaParamRef<jobject>& j_callback, const JavaParamRef<jobject>& j_callback,
const JavaParamRef<jstring>& j_url) { const JavaParamRef<jstring>& j_url) {
GURL url = GURL(ConvertJavaStringToUTF8(env, j_url)); GURL url = GURL(ConvertJavaStringToUTF8(env, j_url));
animated_logo_fetcher_->Start(env, url, j_callback); animated_logo_loader_->Start(env, url, j_callback);
} }
...@@ -48,13 +48,13 @@ class LogoBridge { ...@@ -48,13 +48,13 @@ class LogoBridge {
const base::android::JavaParamRef<jstring>& j_url); const base::android::JavaParamRef<jstring>& j_url);
private: private:
class AnimatedLogoFetcher; class AnimatedLogoLoader;
virtual ~LogoBridge(); virtual ~LogoBridge();
search_provider_logos::LogoService* logo_service_; search_provider_logos::LogoService* logo_service_;
std::unique_ptr<AnimatedLogoFetcher> animated_logo_fetcher_; std::unique_ptr<AnimatedLogoLoader> animated_logo_loader_;
base::WeakPtrFactory<LogoBridge> weak_ptr_factory_; base::WeakPtrFactory<LogoBridge> weak_ptr_factory_;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment