root/chrome/browser/prefs/pref_hash_calculator.h

/* [<][>][^][v][top][bottom][index][help] */

INCLUDED FROM


// Copyright 2013 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_PREFS_PREF_HASH_CALCULATOR_H_
#define CHROME_BROWSER_PREFS_PREF_HASH_CALCULATOR_H_

#include <string>

#include "base/basictypes.h"
#include "base/callback.h"
#include "base/memory/scoped_ptr.h"

namespace base {
class Value;
}  // namespace base

// Calculates and validates preference value hashes.
class PrefHashCalculator {
 public:
  enum ValidationResult {
    INVALID,
    VALID,
    // Valid under a deprecated but as secure algorithm.
    VALID_SECURE_LEGACY,
    // Valid under a deprecated and less secure algorithm.
    VALID_WEAK_LEGACY,
  };

  typedef base::Callback<std::string(const std::string& modern_device_id)>
      GetLegacyDeviceIdCallback;

  // Constructs a PrefHashCalculator using |seed| and |device_id|. The same
  // parameters must be used in order to successfully validate generated hashes.
  // |device_id| may be empty.
  PrefHashCalculator(const std::string& seed, const std::string& device_id);

  // Same as the constructor above, but also specifies that
  // |get_legacy_device_id_callback| should be used rather than the default to
  // obtain the legacy device id if required.
  PrefHashCalculator(
      const std::string& seed,
      const std::string& device_id,
      const GetLegacyDeviceIdCallback& get_legacy_device_id_callback);

  ~PrefHashCalculator();

  // Calculates a hash value for the supplied preference |path| and |value|.
  // |value| may be null if the preference has no value.
  std::string Calculate(const std::string& path, const base::Value* value)
      const;

  // Validates the provided preference hash using current and legacy hashing
  // algorithms.
  ValidationResult Validate(const std::string& path,
                            const base::Value* value,
                            const std::string& hash) const;

 private:
  // Returns the legacy device id based off of |raw_device_id_|. This method
  // lazily gets the legacy device id via |get_legacy_device_id_callback_| and
  // caches the result in |legacy_device_id_instance_| for future retrievals.
  std::string RetrieveLegacyDeviceId() const;

  const std::string seed_;
  const std::string device_id_;

  // The raw device id from which the legacy device id will be derived if
  // required.
  const std::string raw_device_id_;

  const GetLegacyDeviceIdCallback get_legacy_device_id_callback_;

  // A cache for the legacy device id which is hard to compute and thus lazily
  // computed when/if required (computing the original value for this instance
  // is allowed in const methods).
  mutable scoped_ptr<const std::string> legacy_device_id_instance_;

  DISALLOW_COPY_AND_ASSIGN(PrefHashCalculator);
};

#endif  // CHROME_BROWSER_PREFS_PREF_HASH_CALCULATOR_H_

/* [<][>][^][v][top][bottom][index][help] */