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 "components/ntp_snippets/ntp_snippets_fetcher.h" | 5 #include "components/ntp_snippets/ntp_snippets_fetcher.h" |
| 6 | 6 |
| 7 #include <stdlib.h> | 7 #include <stdlib.h> |
| 8 | 8 |
| 9 #include "base/command_line.h" | 9 #include "base/command_line.h" |
| 10 #include "base/files/file_path.h" | 10 #include "base/files/file_path.h" |
| (...skipping 68 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 79 case NTPSnippetsFetcher::FetchResult::URL_REQUEST_STATUS_ERROR: | 79 case NTPSnippetsFetcher::FetchResult::URL_REQUEST_STATUS_ERROR: |
| 80 return "URLRequestStatus error"; | 80 return "URLRequestStatus error"; |
| 81 case NTPSnippetsFetcher::FetchResult::HTTP_ERROR: | 81 case NTPSnippetsFetcher::FetchResult::HTTP_ERROR: |
| 82 return "HTTP error"; | 82 return "HTTP error"; |
| 83 case NTPSnippetsFetcher::FetchResult::JSON_PARSE_ERROR: | 83 case NTPSnippetsFetcher::FetchResult::JSON_PARSE_ERROR: |
| 84 return "Received invalid JSON"; | 84 return "Received invalid JSON"; |
| 85 case NTPSnippetsFetcher::FetchResult::INVALID_SNIPPET_CONTENT_ERROR: | 85 case NTPSnippetsFetcher::FetchResult::INVALID_SNIPPET_CONTENT_ERROR: |
| 86 return "Invalid / empty list."; | 86 return "Invalid / empty list."; |
| 87 case NTPSnippetsFetcher::FetchResult::OAUTH_TOKEN_ERROR: | 87 case NTPSnippetsFetcher::FetchResult::OAUTH_TOKEN_ERROR: |
| 88 return "Error in obtaining an OAuth2 access token."; | 88 return "Error in obtaining an OAuth2 access token."; |
| 89 case NTPSnippetsFetcher::FetchResult::INTERACTIVE_QUOTA_ERROR: | |
| 90 return "Out of interactive quota."; | |
| 91 case NTPSnippetsFetcher::FetchResult::NON_INTERACTIVE_QUOTA_ERROR: | |
| 92 return "Out of non-interactive quota."; | |
| 89 case NTPSnippetsFetcher::FetchResult::RESULT_MAX: | 93 case NTPSnippetsFetcher::FetchResult::RESULT_MAX: |
| 90 break; | 94 break; |
| 91 } | 95 } |
| 92 NOTREACHED(); | 96 NOTREACHED(); |
| 93 return "Unknown error"; | 97 return "Unknown error"; |
| 94 } | 98 } |
| 95 | 99 |
| 96 std::string GetFetchEndpoint() { | 100 std::string GetFetchEndpoint() { |
| 97 std::string endpoint = variations::GetVariationParamValue( | 101 std::string endpoint = variations::GetVariationParamValue( |
| 98 ntp_snippets::kStudyName, kContentSuggestionsBackend); | 102 ntp_snippets::kStudyName, kContentSuggestionsBackend); |
| (...skipping 112 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 211 void NTPSnippetsFetcher::SetCallback( | 215 void NTPSnippetsFetcher::SetCallback( |
| 212 const SnippetsAvailableCallback& callback) { | 216 const SnippetsAvailableCallback& callback) { |
| 213 snippets_available_callback_ = callback; | 217 snippets_available_callback_ = callback; |
| 214 } | 218 } |
| 215 | 219 |
| 216 void NTPSnippetsFetcher::FetchSnippetsFromHosts( | 220 void NTPSnippetsFetcher::FetchSnippetsFromHosts( |
| 217 const std::set<std::string>& hosts, | 221 const std::set<std::string>& hosts, |
| 218 const std::string& language_code, | 222 const std::string& language_code, |
| 219 int count, | 223 int count, |
| 220 bool interactive_request) { | 224 bool interactive_request) { |
| 221 if (!request_throttler_.DemandQuotaForRequest(interactive_request)) | 225 if (!request_throttler_.DemandQuotaForRequest(interactive_request)) { |
| 226 FetchFinished( | |
| 227 OptionalSnippets(), | |
| 228 interactive_request ? | |
| 229 FetchResult::INTERACTIVE_QUOTA_ERROR : | |
| 230 FetchResult::NON_INTERACTIVE_QUOTA_ERROR, | |
| 231 /*extra_message=*/std::string()); | |
| 222 return; | 232 return; |
| 233 } | |
| 223 | 234 |
| 224 hosts_ = hosts; | 235 hosts_ = hosts; |
| 225 fetch_start_time_ = tick_clock_->NowTicks(); | 236 fetch_start_time_ = tick_clock_->NowTicks(); |
| 226 | 237 |
| 227 if (UsesHostRestrictions() && hosts_.empty()) { | 238 if (UsesHostRestrictions() && hosts_.empty()) { |
| 228 FetchFinished(OptionalSnippets(), FetchResult::EMPTY_HOSTS, | 239 FetchFinished(OptionalSnippets(), FetchResult::EMPTY_HOSTS, |
| 229 /*extra_message=*/std::string()); | 240 /*extra_message=*/std::string()); |
| 230 return; | 241 return; |
| 231 } | 242 } |
| 232 | 243 |
| (...skipping 348 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 581 | 592 |
| 582 void NTPSnippetsFetcher::FetchFinished(OptionalSnippets snippets, | 593 void NTPSnippetsFetcher::FetchFinished(OptionalSnippets snippets, |
| 583 FetchResult result, | 594 FetchResult result, |
| 584 const std::string& extra_message) { | 595 const std::string& extra_message) { |
| 585 DCHECK(result == FetchResult::SUCCESS || !snippets); | 596 DCHECK(result == FetchResult::SUCCESS || !snippets); |
| 586 last_status_ = FetchResultToString(result) + extra_message; | 597 last_status_ = FetchResultToString(result) + extra_message; |
| 587 | 598 |
| 588 // If the result is EMPTY_HOSTS or OAUTH_TOKEN_ERROR, we didn't actually send | 599 // If the result is EMPTY_HOSTS or OAUTH_TOKEN_ERROR, we didn't actually send |
| 589 // a network request, so don't record FetchTime in those cases. | 600 // a network request, so don't record FetchTime in those cases. |
| 590 if (result != FetchResult::EMPTY_HOSTS && | 601 if (result != FetchResult::EMPTY_HOSTS && |
| 591 result != FetchResult::OAUTH_TOKEN_ERROR) { | 602 result != FetchResult::OAUTH_TOKEN_ERROR) { |
|
Marc Treib
2016/08/25 11:58:27
You should probably add the new errors here, since
| |
| 592 UMA_HISTOGRAM_TIMES("NewTabPage.Snippets.FetchTime", | 603 UMA_HISTOGRAM_TIMES("NewTabPage.Snippets.FetchTime", |
| 593 tick_clock_->NowTicks() - fetch_start_time_); | 604 tick_clock_->NowTicks() - fetch_start_time_); |
| 594 } | 605 } |
| 595 UMA_HISTOGRAM_ENUMERATION("NewTabPage.Snippets.FetchResult", | 606 UMA_HISTOGRAM_ENUMERATION("NewTabPage.Snippets.FetchResult", |
| 596 static_cast<int>(result), | 607 static_cast<int>(result), |
| 597 static_cast<int>(FetchResult::RESULT_MAX)); | 608 static_cast<int>(FetchResult::RESULT_MAX)); |
| 598 | 609 |
| 599 if (!snippets_available_callback_.is_null()) | 610 if (!snippets_available_callback_.is_null()) |
| 600 snippets_available_callback_.Run(std::move(snippets)); | 611 snippets_available_callback_.Run(std::move(snippets)); |
| 601 } | 612 } |
| 602 | 613 |
| 603 } // namespace ntp_snippets | 614 } // namespace ntp_snippets |
| OLD | NEW |