| OLD | NEW |
| 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 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/chrome_quota_permission_context.h" | 5 #include "chrome/browser/chrome_quota_permission_context.h" |
| 6 | 6 |
| 7 #include <stdint.h> | 7 #include <stdint.h> |
| 8 | 8 |
| 9 #include <string> | 9 #include <string> |
| 10 | 10 |
| (...skipping 32 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 43 const int64_t kRequestLargeQuotaThreshold = 5 * 1024 * 1024; | 43 const int64_t kRequestLargeQuotaThreshold = 5 * 1024 * 1024; |
| 44 #endif | 44 #endif |
| 45 | 45 |
| 46 // QuotaPermissionRequest --------------------------------------------- | 46 // QuotaPermissionRequest --------------------------------------------- |
| 47 | 47 |
| 48 class QuotaPermissionRequest : public PermissionRequest { | 48 class QuotaPermissionRequest : public PermissionRequest { |
| 49 public: | 49 public: |
| 50 QuotaPermissionRequest( | 50 QuotaPermissionRequest( |
| 51 ChromeQuotaPermissionContext* context, | 51 ChromeQuotaPermissionContext* context, |
| 52 const GURL& origin_url, | 52 const GURL& origin_url, |
| 53 int64_t requested_quota, |
| 53 const content::QuotaPermissionContext::PermissionCallback& callback); | 54 const content::QuotaPermissionContext::PermissionCallback& callback); |
| 54 | 55 |
| 55 ~QuotaPermissionRequest() override; | 56 ~QuotaPermissionRequest() override; |
| 56 | 57 |
| 57 private: | 58 private: |
| 58 // PermissionRequest: | 59 // PermissionRequest: |
| 59 IconId GetIconId() const override; | 60 IconId GetIconId() const override; |
| 61 base::string16 GetMessageText() const override; |
| 60 base::string16 GetMessageTextFragment() const override; | 62 base::string16 GetMessageTextFragment() const override; |
| 61 GURL GetOrigin() const override; | 63 GURL GetOrigin() const override; |
| 62 void PermissionGranted() override; | 64 void PermissionGranted() override; |
| 63 void PermissionDenied() override; | 65 void PermissionDenied() override; |
| 64 void Cancelled() override; | 66 void Cancelled() override; |
| 65 void RequestFinished() override; | 67 void RequestFinished() override; |
| 66 PermissionRequestType GetPermissionRequestType() const override; | 68 PermissionRequestType GetPermissionRequestType() const override; |
| 67 | 69 |
| 68 scoped_refptr<ChromeQuotaPermissionContext> context_; | 70 scoped_refptr<ChromeQuotaPermissionContext> context_; |
| 69 GURL origin_url_; | 71 GURL origin_url_; |
| 72 int64_t requested_quota_; |
| 70 content::QuotaPermissionContext::PermissionCallback callback_; | 73 content::QuotaPermissionContext::PermissionCallback callback_; |
| 71 | 74 |
| 72 DISALLOW_COPY_AND_ASSIGN(QuotaPermissionRequest); | 75 DISALLOW_COPY_AND_ASSIGN(QuotaPermissionRequest); |
| 73 }; | 76 }; |
| 74 | 77 |
| 75 QuotaPermissionRequest::QuotaPermissionRequest( | 78 QuotaPermissionRequest::QuotaPermissionRequest( |
| 76 ChromeQuotaPermissionContext* context, | 79 ChromeQuotaPermissionContext* context, |
| 77 const GURL& origin_url, | 80 const GURL& origin_url, |
| 81 int64_t requested_quota, |
| 78 const content::QuotaPermissionContext::PermissionCallback& callback) | 82 const content::QuotaPermissionContext::PermissionCallback& callback) |
| 79 : context_(context), | 83 : context_(context), |
| 80 origin_url_(origin_url), | 84 origin_url_(origin_url), |
| 85 requested_quota_(requested_quota), |
| 81 callback_(callback) {} | 86 callback_(callback) {} |
| 82 | 87 |
| 83 QuotaPermissionRequest::~QuotaPermissionRequest() {} | 88 QuotaPermissionRequest::~QuotaPermissionRequest() {} |
| 84 | 89 |
| 85 PermissionRequest::IconId QuotaPermissionRequest::GetIconId() const { | 90 PermissionRequest::IconId QuotaPermissionRequest::GetIconId() const { |
| 86 // TODO(gbillock): get the proper image here | 91 // TODO(gbillock): get the proper image here |
| 87 #if defined(OS_ANDROID) | 92 #if defined(OS_ANDROID) |
| 88 return IDR_ANDROID_INFOBAR_WARNING; | 93 return IDR_ANDROID_INFOBAR_WARNING; |
| 89 #else | 94 #else |
| 90 return ui::kWarningIcon; | 95 return ui::kWarningIcon; |
| 91 #endif | 96 #endif |
| 92 } | 97 } |
| 93 | 98 |
| 99 base::string16 QuotaPermissionRequest::GetMessageText() const { |
| 100 #if !defined(OS_ANDROID) |
| 101 NOTREACHED(); |
| 102 #endif |
| 103 // If the site requested larger quota than this threshold, show a different |
| 104 // message to the user. |
| 105 return l10n_util::GetStringFUTF16( |
| 106 (requested_quota_ > kRequestLargeQuotaThreshold |
| 107 ? IDS_REQUEST_LARGE_QUOTA_INFOBAR_QUESTION |
| 108 : IDS_REQUEST_QUOTA_INFOBAR_QUESTION), |
| 109 url_formatter::FormatUrlForSecurityDisplay(origin_url_)); |
| 110 } |
| 111 |
| 94 base::string16 QuotaPermissionRequest::GetMessageTextFragment() const { | 112 base::string16 QuotaPermissionRequest::GetMessageTextFragment() const { |
| 95 return l10n_util::GetStringUTF16(IDS_REQUEST_QUOTA_PERMISSION_FRAGMENT); | 113 return l10n_util::GetStringUTF16(IDS_REQUEST_QUOTA_PERMISSION_FRAGMENT); |
| 96 } | 114 } |
| 97 | 115 |
| 98 GURL QuotaPermissionRequest::GetOrigin() const { | 116 GURL QuotaPermissionRequest::GetOrigin() const { |
| 99 return origin_url_; | 117 return origin_url_; |
| 100 } | 118 } |
| 101 | 119 |
| 102 void QuotaPermissionRequest::PermissionGranted() { | 120 void QuotaPermissionRequest::PermissionGranted() { |
| 103 context_->DispatchCallbackOnIOThread( | 121 context_->DispatchCallbackOnIOThread( |
| (...skipping 157 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 261 LOG(WARNING) << "Attempt to request quota tabless renderer: " | 279 LOG(WARNING) << "Attempt to request quota tabless renderer: " |
| 262 << render_process_id << "," << params.render_frame_id; | 280 << render_process_id << "," << params.render_frame_id; |
| 263 DispatchCallbackOnIOThread(callback, QUOTA_PERMISSION_RESPONSE_CANCELLED); | 281 DispatchCallbackOnIOThread(callback, QUOTA_PERMISSION_RESPONSE_CANCELLED); |
| 264 return; | 282 return; |
| 265 } | 283 } |
| 266 | 284 |
| 267 if (PermissionRequestManager::IsEnabled()) { | 285 if (PermissionRequestManager::IsEnabled()) { |
| 268 PermissionRequestManager* permission_request_manager = | 286 PermissionRequestManager* permission_request_manager = |
| 269 PermissionRequestManager::FromWebContents(web_contents); | 287 PermissionRequestManager::FromWebContents(web_contents); |
| 270 if (permission_request_manager) { | 288 if (permission_request_manager) { |
| 271 permission_request_manager->AddRequest( | 289 permission_request_manager->AddRequest(new QuotaPermissionRequest( |
| 272 new QuotaPermissionRequest(this, params.origin_url, callback)); | 290 this, params.origin_url, params.requested_size, callback)); |
| 273 return; | 291 return; |
| 274 } | 292 } |
| 275 #if defined(OS_ANDROID) | 293 #if defined(OS_ANDROID) |
| 276 } else { | 294 } else { |
| 277 InfoBarService* infobar_service = | 295 InfoBarService* infobar_service = |
| 278 InfoBarService::FromWebContents(web_contents); | 296 InfoBarService::FromWebContents(web_contents); |
| 279 if (infobar_service) { | 297 if (infobar_service) { |
| 280 RequestQuotaInfoBarDelegate::Create(infobar_service, this, | 298 RequestQuotaInfoBarDelegate::Create(infobar_service, this, |
| 281 params.origin_url, | 299 params.origin_url, |
| 282 params.requested_size, callback); | 300 params.requested_size, callback); |
| (...skipping 19 matching lines...) Expand all Loading... |
| 302 base::BindOnce( | 320 base::BindOnce( |
| 303 &ChromeQuotaPermissionContext::DispatchCallbackOnIOThread, this, | 321 &ChromeQuotaPermissionContext::DispatchCallbackOnIOThread, this, |
| 304 callback, response)); | 322 callback, response)); |
| 305 return; | 323 return; |
| 306 } | 324 } |
| 307 | 325 |
| 308 callback.Run(response); | 326 callback.Run(response); |
| 309 } | 327 } |
| 310 | 328 |
| 311 ChromeQuotaPermissionContext::~ChromeQuotaPermissionContext() {} | 329 ChromeQuotaPermissionContext::~ChromeQuotaPermissionContext() {} |
| OLD | NEW |