Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(57)

Side by Side Diff: chrome/browser/media/android/remote/remote_media_player_bridge.cc

Issue 1907413002: [Android,MediaFling] Fix the encoding issue with already encoded URLs for abc13.com/live (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Updated test cases Created 4 years, 8 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
1 // Copyright 2013 The Chromium Authors. All rights reserved. 1 // Copyright 2013 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 #include "chrome/browser/media/android/remote/remote_media_player_bridge.h" 5 #include "chrome/browser/media/android/remote/remote_media_player_bridge.h"
6 6
7 #include <utility> 7 #include <utility>
8 8
9 #include "base/android/jni_android.h" 9 #include "base/android/jni_android.h"
10 #include "base/android/jni_string.h" 10 #include "base/android/jni_string.h"
11 #include "chrome/browser/media/android/remote/record_cast_action.h" 11 #include "chrome/browser/media/android/remote/record_cast_action.h"
12 #include "chrome/browser/media/android/remote/remote_media_player_manager.h" 12 #include "chrome/browser/media/android/remote/remote_media_player_manager.h"
13 #include "content/public/browser/android/content_view_core.h" 13 #include "content/public/browser/android/content_view_core.h"
14 #include "content/public/browser/browser_thread.h" 14 #include "content/public/browser/browser_thread.h"
15 #include "content/public/browser/web_contents.h" 15 #include "content/public/browser/web_contents.h"
16 #include "jni/RemoteMediaPlayerBridge_jni.h" 16 #include "jni/RemoteMediaPlayerBridge_jni.h"
17 #include "media/base/android/media_common_android.h" 17 #include "media/base/android/media_common_android.h"
18 #include "media/base/android/media_resource_getter.h" 18 #include "media/base/android/media_resource_getter.h"
19 #include "media/base/timestamp_constants.h" 19 #include "media/base/timestamp_constants.h"
20 #include "net/base/escape.h"
20 #include "third_party/skia/include/core/SkBitmap.h" 21 #include "third_party/skia/include/core/SkBitmap.h"
21 #include "ui/gfx/android/java_bitmap.h" 22 #include "ui/gfx/android/java_bitmap.h"
22 23
23 using base::android::ConvertUTF8ToJavaString; 24 using base::android::ConvertUTF8ToJavaString;
24 using base::android::ConvertJavaStringToUTF8; 25 using base::android::ConvertJavaStringToUTF8;
25 using base::android::ScopedJavaLocalRef; 26 using base::android::ScopedJavaLocalRef;
26 using base::android::AttachCurrentThread; 27 using base::android::AttachCurrentThread;
27 using content::BrowserThread; 28 using content::BrowserThread;
28 using media::MediaPlayerAndroid; 29 using media::MediaPlayerAndroid;
29 30
(...skipping 28 matching lines...) Expand all
58 url_(manager->GetLocalPlayer(player_id)->GetUrl()), 59 url_(manager->GetLocalPlayer(player_id)->GetUrl()),
59 first_party_for_cookies_( 60 first_party_for_cookies_(
60 manager->GetLocalPlayer(player_id)->GetFirstPartyForCookies()), 61 manager->GetLocalPlayer(player_id)->GetFirstPartyForCookies()),
61 user_agent_(user_agent), 62 user_agent_(user_agent),
62 weak_factory_(this) { 63 weak_factory_(this) {
63 DCHECK_CURRENTLY_ON(BrowserThread::UI); 64 DCHECK_CURRENTLY_ON(BrowserThread::UI);
64 JNIEnv* env = base::android::AttachCurrentThread(); 65 JNIEnv* env = base::android::AttachCurrentThread();
65 CHECK(env); 66 CHECK(env);
66 ScopedJavaLocalRef<jstring> j_url_string; 67 ScopedJavaLocalRef<jstring> j_url_string;
67 if (url_.is_valid()) { 68 if (url_.is_valid()) {
69 // Escape the URL to make it safe to use. Don't escape existing escape
70 // sequences though.
71 std::string escaped_url = net::EscapeExternalHandlerValue(url_.spec());
68 // Create a Java String for the URL. 72 // Create a Java String for the URL.
69 j_url_string = ConvertUTF8ToJavaString(env, url_.spec()); 73 j_url_string = ConvertUTF8ToJavaString(env, escaped_url);
70 } 74 }
71 ScopedJavaLocalRef<jstring> j_frame_url_string; 75 ScopedJavaLocalRef<jstring> j_frame_url_string;
72 GURL frameUrl = GetLocalPlayer()->frame_url(); 76 GURL frameUrl = GetLocalPlayer()->frame_url();
73 if (frameUrl.is_valid()) { 77 if (frameUrl.is_valid()) {
74 // Create a Java String for the URL. 78 // Create a Java String for the URL.
75 j_frame_url_string = ConvertUTF8ToJavaString(env, frameUrl.spec()); 79 j_frame_url_string = ConvertUTF8ToJavaString(env, frameUrl.spec());
76 } 80 }
77 java_bridge_.Reset(Java_RemoteMediaPlayerBridge_create( 81 java_bridge_.Reset(Java_RemoteMediaPlayerBridge_create(
78 env, reinterpret_cast<intptr_t>(this), j_url_string.obj(), 82 env, reinterpret_cast<intptr_t>(this), j_url_string.obj(),
79 j_frame_url_string.obj(), 83 j_frame_url_string.obj(),
(...skipping 400 matching lines...) Expand 10 before | Expand all | Expand 10 after
480 Java_RemoteMediaPlayerBridge_setCookies( 484 Java_RemoteMediaPlayerBridge_setCookies(
481 env, java_bridge_.obj(), ConvertUTF8ToJavaString(env, cookies).obj()); 485 env, java_bridge_.obj(), ConvertUTF8ToJavaString(env, cookies).obj());
482 } 486 }
483 487
484 MediaPlayerAndroid* RemoteMediaPlayerBridge::GetLocalPlayer() { 488 MediaPlayerAndroid* RemoteMediaPlayerBridge::GetLocalPlayer() {
485 return static_cast<RemoteMediaPlayerManager*>(manager())->GetLocalPlayer( 489 return static_cast<RemoteMediaPlayerManager*>(manager())->GetLocalPlayer(
486 player_id()); 490 player_id());
487 } 491 }
488 492
489 } // namespace remote_media 493 } // namespace remote_media
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698