Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright 2016 The Chromium Authors. All rights reserved. | 1 // Copyright 2016 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/permissions/permission_prompt_android.h" | 5 #include "chrome/browser/permissions/permission_prompt_android.h" |
| 6 | 6 |
| 7 #include "base/memory/ptr_util.h" | 7 #include "base/memory/ptr_util.h" |
| 8 #include "chrome/browser/infobars/infobar_service.h" | 8 #include "chrome/browser/infobars/infobar_service.h" |
| 9 #include "chrome/browser/permissions/grouped_permission_infobar_delegate_android .h" | 9 #include "chrome/browser/permissions/grouped_permission_infobar_delegate_android .h" |
| 10 #include "chrome/browser/permissions/permission_dialog_delegate.h" | 10 #include "chrome/browser/permissions/permission_dialog_delegate.h" |
| 11 #include "chrome/browser/permissions/permission_request.h" | 11 #include "chrome/browser/permissions/permission_request.h" |
| 12 #include "chrome/common/url_constants.h" | 12 #include "chrome/common/url_constants.h" |
| 13 #include "chrome/grit/generated_resources.h" | |
| 14 #include "chrome/grit/theme_resources.h" | |
| 13 #include "components/strings/grit/components_strings.h" | 15 #include "components/strings/grit/components_strings.h" |
| 16 #include "components/url_formatter/elide_url.h" | |
| 14 #include "ui/base/l10n/l10n_util.h" | 17 #include "ui/base/l10n/l10n_util.h" |
| 15 | 18 |
| 16 PermissionPromptAndroid::PermissionPromptAndroid( | 19 PermissionPromptAndroid::PermissionPromptAndroid( |
| 17 content::WebContents* web_contents) | 20 content::WebContents* web_contents) |
| 18 : web_contents_(web_contents), delegate_(nullptr) { | 21 : web_contents_(web_contents), delegate_(nullptr) { |
| 19 DCHECK(web_contents); | 22 DCHECK(web_contents); |
| 20 } | 23 } |
| 21 | 24 |
| 22 PermissionPromptAndroid::~PermissionPromptAndroid() {} | 25 PermissionPromptAndroid::~PermissionPromptAndroid() {} |
| 23 | 26 |
| (...skipping 77 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 101 return true; | 104 return true; |
| 102 } | 105 } |
| 103 | 106 |
| 104 ContentSettingsType PermissionPromptAndroid::GetContentSettingType( | 107 ContentSettingsType PermissionPromptAndroid::GetContentSettingType( |
| 105 size_t position) const { | 108 size_t position) const { |
| 106 const std::vector<PermissionRequest*>& requests = delegate_->Requests(); | 109 const std::vector<PermissionRequest*>& requests = delegate_->Requests(); |
| 107 DCHECK_LT(position, requests.size()); | 110 DCHECK_LT(position, requests.size()); |
| 108 return requests[position]->GetContentSettingsType(); | 111 return requests[position]->GetContentSettingsType(); |
| 109 } | 112 } |
| 110 | 113 |
| 111 int PermissionPromptAndroid::GetIconIdForPermission(size_t position) const { | 114 int PermissionPromptAndroid::GetIconId() const { |
| 112 const std::vector<PermissionRequest*>& requests = delegate_->Requests(); | 115 const std::vector<PermissionRequest*>& requests = delegate_->Requests(); |
| 113 DCHECK_LT(position, requests.size()); | 116 if (requests.size() == 1) |
| 114 return requests[position]->GetIconId(); | 117 return requests[0]->GetIconId(); |
| 118 DCHECK_EQ(static_cast<size_t>(2), requests.size()); | |
| 119 DCHECK_EQ(requests[0]->GetOrigin(), requests[1]->GetOrigin()); | |
|
raymes
2017/06/08 00:45:30
nit: perhaps add a helper function which checks th
Timothy Loh
2017/06/08 03:52:21
Done.
| |
| 120 return IDR_INFOBAR_MEDIA_STREAM_CAMERA; | |
| 115 } | 121 } |
| 116 | 122 |
| 117 base::string16 PermissionPromptAndroid::GetMessageText(size_t position) const { | 123 base::string16 PermissionPromptAndroid::GetMessageText() const { |
| 118 const std::vector<PermissionRequest*>& requests = delegate_->Requests(); | 124 const std::vector<PermissionRequest*>& requests = delegate_->Requests(); |
| 119 DCHECK_LT(position, requests.size()); | 125 if (requests.size() == 1) |
| 120 return requests[position]->GetMessageText(); | 126 return requests[0]->GetMessageText(); |
|
raymes
2017/06/08 00:45:30
We previously added a note in PermissionRequestImp
Timothy Loh
2017/06/08 03:52:21
Good catch, removed.
| |
| 121 } | 127 DCHECK_EQ(static_cast<size_t>(2), requests.size()); |
| 122 | 128 DCHECK_EQ(requests[0]->GetOrigin(), requests[1]->GetOrigin()); |
| 123 base::string16 PermissionPromptAndroid::GetMessageTextFragment( | 129 return l10n_util::GetStringFUTF16( |
| 124 size_t position) const { | 130 IDS_MEDIA_CAPTURE_AUDIO_AND_VIDEO, |
| 125 const std::vector<PermissionRequest*>& requests = delegate_->Requests(); | 131 url_formatter::FormatUrlForSecurityDisplay( |
| 126 DCHECK_LT(position, requests.size()); | 132 requests[0]->GetOrigin(), |
| 127 return requests[position]->GetMessageTextFragment(); | 133 url_formatter::SchemeDisplay::OMIT_CRYPTOGRAPHIC)); |
| 128 } | 134 } |
| 129 | 135 |
| 130 base::string16 PermissionPromptAndroid::GetLinkText() const { | 136 base::string16 PermissionPromptAndroid::GetLinkText() const { |
| 131 if (GetContentSettingType(0) == | 137 if (GetContentSettingType(0) == |
| 132 CONTENT_SETTINGS_TYPE_PROTECTED_MEDIA_IDENTIFIER) { | 138 CONTENT_SETTINGS_TYPE_PROTECTED_MEDIA_IDENTIFIER) { |
| 133 return l10n_util::GetStringUTF16(IDS_LEARN_MORE); | 139 return l10n_util::GetStringUTF16(IDS_LEARN_MORE); |
| 134 } | 140 } |
| 135 return base::string16(); | 141 return base::string16(); |
| 136 } | 142 } |
| 137 | 143 |
| 138 GURL PermissionPromptAndroid::GetLinkURL() const { | 144 GURL PermissionPromptAndroid::GetLinkURL() const { |
| 139 if (GetContentSettingType(0) == | 145 if (GetContentSettingType(0) == |
| 140 CONTENT_SETTINGS_TYPE_PROTECTED_MEDIA_IDENTIFIER) { | 146 CONTENT_SETTINGS_TYPE_PROTECTED_MEDIA_IDENTIFIER) { |
| 141 return GURL(chrome::kEnhancedPlaybackNotificationLearnMoreURL); | 147 return GURL(chrome::kEnhancedPlaybackNotificationLearnMoreURL); |
| 142 } | 148 } |
| 143 return GURL(); | 149 return GURL(); |
| 144 } | 150 } |
| 145 | 151 |
| 146 // static | 152 // static |
| 147 std::unique_ptr<PermissionPrompt> PermissionPrompt::Create( | 153 std::unique_ptr<PermissionPrompt> PermissionPrompt::Create( |
| 148 content::WebContents* web_contents) { | 154 content::WebContents* web_contents) { |
| 149 return base::MakeUnique<PermissionPromptAndroid>(web_contents); | 155 return base::MakeUnique<PermissionPromptAndroid>(web_contents); |
| 150 } | 156 } |
| OLD | NEW |