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

Unified Diff: chrome/browser/metrics/variations/variations_http_header_provider.h

Issue 366373002: [Variations] Bring variations_http_header_provider to variations component (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: fix BUILD.gn Created 6 years, 5 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 side-by-side diff with in-line comments
Download patch
Index: chrome/browser/metrics/variations/variations_http_header_provider.h
diff --git a/chrome/browser/metrics/variations/variations_http_header_provider.h b/chrome/browser/metrics/variations/variations_http_header_provider.h
deleted file mode 100644
index 4b7d9a81793d7f9160eb8b0d97868dae49288051..0000000000000000000000000000000000000000
--- a/chrome/browser/metrics/variations/variations_http_header_provider.h
+++ /dev/null
@@ -1,115 +0,0 @@
-// Copyright (c) 2012 The Chromium Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style license that can be
-// found in the LICENSE file.
-
-#ifndef CHROME_BROWSER_METRICS_VARIATIONS_VARIATIONS_HTTP_HEADER_PROVIDER_H_
-#define CHROME_BROWSER_METRICS_VARIATIONS_VARIATIONS_HTTP_HEADER_PROVIDER_H_
-
-#include <set>
-#include <string>
-
-#include "base/basictypes.h"
-#include "base/gtest_prod_util.h"
-#include "base/metrics/field_trial.h"
-#include "base/synchronization/lock.h"
-#include "components/variations/variations_associated_data.h"
-
-namespace content {
-class ResourceContext;
-}
-
-namespace net {
-class HttpRequestHeaders;
-}
-
-class GURL;
-class Profile;
-class ProfileIOData;
-
-template <typename T> struct DefaultSingletonTraits;
-
-namespace chrome_variations {
-
-// A helper class for maintaining Chrome experiments and metrics state
-// transmitted in custom HTTP request headers.
-// This class is a thread-safe singleton.
-class VariationsHttpHeaderProvider : base::FieldTrialList::Observer {
- public:
- static VariationsHttpHeaderProvider* GetInstance();
-
- // Adds Chrome experiment and metrics state as custom headers to |headers|.
- // Some headers may not be set given the |incognito| mode or whether
- // the user has |uma_enabled|. Also, we never transmit headers to non-Google
- // sites, which is checked based on the destination |url|.
- void AppendHeaders(const GURL& url,
- bool incognito,
- bool uma_enabled,
- net::HttpRequestHeaders* headers);
-
- // Sets *additional* variation ids and trigger variation ids to be encoded in
- // the X-Client-Data request header. This is intended for development use to
- // force a server side experiment id. |variation_ids| should be a
- // comma-separated string of numeric experiment ids. If an id is prefixed
- // with "t" it will be treated as a trigger experiment id.
- bool SetDefaultVariationIds(const std::string& variation_ids);
-
- private:
- friend struct DefaultSingletonTraits<VariationsHttpHeaderProvider>;
-
- FRIEND_TEST_ALL_PREFIXES(VariationsHttpHeaderProviderTest,
- ShouldAppendHeaders);
- FRIEND_TEST_ALL_PREFIXES(VariationsHttpHeaderProviderTest,
- SetDefaultVariationIds_Valid);
- FRIEND_TEST_ALL_PREFIXES(VariationsHttpHeaderProviderTest,
- SetDefaultVariationIds_Invalid);
- FRIEND_TEST_ALL_PREFIXES(VariationsHttpHeaderProviderTest,
- OnFieldTrialGroupFinalized);
-
- VariationsHttpHeaderProvider();
- virtual ~VariationsHttpHeaderProvider();
-
- // base::FieldTrialList::Observer implementation.
- // This will add the variation ID associated with |trial_name| and
- // |group_name| to the variation ID cache.
- virtual void OnFieldTrialGroupFinalized(
- const std::string& trial_name,
- const std::string& group_name) OVERRIDE;
-
- // Prepares the variation IDs cache with initial values if not already done.
- // This method also registers the caller with the FieldTrialList to receive
- // new variation IDs.
- void InitVariationIDsCacheIfNeeded();
-
- // Takes whatever is currently in |variation_ids_set_| and recreates
- // |variation_ids_header_| with it. Assumes the the |lock_| is currently
- // held.
- void UpdateVariationIDsHeaderValue();
-
- // Checks whether variation headers should be appended to requests to the
- // specified |url|. Returns true for google.<TLD> and youtube.<TLD> URLs.
- static bool ShouldAppendHeaders(const GURL& url);
-
- // Guards |variation_ids_cache_initialized_|, |variation_ids_set_| and
- // |variation_ids_header_|.
- base::Lock lock_;
-
- // Whether or not we've initialized the cache.
- bool variation_ids_cache_initialized_;
-
- // Keep a cache of variation IDs that are transmitted in headers to Google.
- // This consists of a list of valid IDs, and the actual transmitted header.
- std::set<chrome_variations::VariationID> variation_ids_set_;
- std::set<chrome_variations::VariationID> variation_trigger_ids_set_;
-
- // Provides the google experiment ids forced from command line.
- std::set<chrome_variations::VariationID> default_variation_ids_set_;
- std::set<chrome_variations::VariationID> default_trigger_id_set_;
-
- std::string variation_ids_header_;
-
- DISALLOW_COPY_AND_ASSIGN(VariationsHttpHeaderProvider);
-};
-
-} // namespace chrome_variations
-
-#endif // CHROME_BROWSER_METRICS_VARIATIONS_VARIATIONS_HTTP_HEADER_PROVIDER_H_

Powered by Google App Engine
This is Rietveld 408576698