Chromium Code Reviews| Index: content/browser/service_worker/service_worker_version.cc |
| diff --git a/content/browser/service_worker/service_worker_version.cc b/content/browser/service_worker/service_worker_version.cc |
| index 337e676375282f1ea3cf4ccee6738d735cd5aef8..3d6204db5e9f89cfc71d8c79c3a4f8dabd29e363 100644 |
| --- a/content/browser/service_worker/service_worker_version.cc |
| +++ b/content/browser/service_worker/service_worker_version.cc |
| @@ -34,6 +34,7 @@ |
| #include "content/browser/service_worker/service_worker_context_wrapper.h" |
| #include "content/browser/service_worker/service_worker_metrics.h" |
| #include "content/browser/service_worker/service_worker_registration.h" |
| +#include "content/common/origin_trials/trial_token_validator.h" |
| #include "content/common/service_worker/embedded_worker_messages.h" |
| #include "content/common/service_worker/embedded_worker_start_params.h" |
| #include "content/common/service_worker/service_worker_messages.h" |
| @@ -700,6 +701,12 @@ void ServiceWorkerVersion::Doom() { |
| context_->storage()->PurgeResources(resources); |
| } |
| +void ServiceWorkerVersion::SetValidOriginTrialTokens( |
| + const TrialTokenValidator::FeatureToTokensMap& tokens) { |
| + origin_trial_tokens_ = |
| + TrialTokenValidator::GetValidTokens(url::Origin(scope()), tokens); |
| +} |
| + |
| void ServiceWorkerVersion::SetDevToolsAttached(bool attached) { |
| embedded_worker()->set_devtools_attached(attached); |
| if (stop_when_devtools_detached_ && !attached) { |
| @@ -741,6 +748,18 @@ void ServiceWorkerVersion::SetDevToolsAttached(bool attached) { |
| void ServiceWorkerVersion::SetMainScriptHttpResponseInfo( |
| const net::HttpResponseInfo& http_info) { |
| main_script_http_info_.reset(new net::HttpResponseInfo(http_info)); |
| + |
| + // Updates |origin_trial_tokens_| if it is not set yet. This happens when: |
| + // 1) The worer is a new one. |
| + // OR |
| + // 2) The worker is an existing one but the entry in ServiceWorkerDatabase |
| + // was written by old version Chrome, so |origin_trial_tokens| wasn't set |
| + // in the entry. |
|
falken
2016/10/07 03:35:22
same nits as above
horo
2016/10/07 05:33:32
Done.
|
| + if (!origin_trial_tokens_) { |
| + origin_trial_tokens_ = TrialTokenValidator::GetValidTokensFromHeaders( |
| + url::Origin(scope()), http_info.headers.get()); |
| + } |
| + |
| FOR_EACH_OBSERVER(Listener, listeners_, |
| OnMainScriptHttpResponseInfoSet(this)); |
| } |