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

Unified Diff: chrome/browser/policy/user_policy_identity_strategy.h

Issue 6520008: Device policy infrastructure (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Created 9 years, 10 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/policy/user_policy_identity_strategy.h
diff --git a/chrome/browser/policy/user_policy_identity_strategy.h b/chrome/browser/policy/user_policy_identity_strategy.h
new file mode 100644
index 0000000000000000000000000000000000000000..acb80a236de58fc8495e2cf449dcea8242ab956d
--- /dev/null
+++ b/chrome/browser/policy/user_policy_identity_strategy.h
@@ -0,0 +1,80 @@
+// Copyright (c) 2011 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_POLICY_USER_POLICY_IDENTITY_STRATEGY_H_
+#define CHROME_BROWSER_POLICY_USER_POLICY_IDENTITY_STRATEGY_H_
+#pragma once
+
+#include <string>
+
+#include "base/file_path.h"
+#include "base/ref_counted.h"
+#include "base/weak_ptr.h"
+#include "chrome/browser/policy/cloud_policy_identity_strategy.h"
+#include "chrome/common/notification_observer.h"
+#include "chrome/common/notification_registrar.h"
+
+class Profile;
+
+namespace policy {
+
+class DeviceManagementBackend;
+
+// A token provider implementation that provides a user device token for the
+// user corresponding to a given profile.
+class UserPolicyIdentityStrategy : public CloudPolicyIdentityStrategy,
+ public NotificationObserver {
+ public:
+ UserPolicyIdentityStrategy(Profile* profile,
+ const FilePath& token_cache_file);
+ virtual ~UserPolicyIdentityStrategy();
+
+ // CloudPolicyIdentityStrategy implementation:
+ virtual std::string GetDeviceToken();
+ virtual std::string GetDeviceID();
+ virtual bool GetCredentials(std::string* username,
+ std::string* auth_token);
+ virtual void OnDeviceTokenAvailable(const std::string& token);
+
+ private:
+ class TokenCache;
+
+ // Checks whether a new token should be fetched and if so, pokes the fetcher.
Mattias Nissler (ping if slow) 2011/02/15 10:15:16 Comment is not accurate. It doesn't poke the fetch
Jakob Kummerow 2011/02/21 12:12:15 Done.
+ void CheckAndTriggerFetch();
+
+ // Gets the current user.
+ std::string GetCurrentUser();
+
+ // Called from the token cache when the token has been loaded.
+ void OnCacheLoaded(const std::string& token, const std::string& device_id);
+
+ // NotificationObserver method overrides:
+ virtual void Observe(NotificationType type,
+ const NotificationSource& source,
+ const NotificationDetails& details);
+
+ // The profile this provider is associated with.
+ Profile* profile_;
+
+ // Keeps the on-disk copy of the token.
+ scoped_refptr<TokenCache> cache_;
+
+ // The device ID we use.
+ std::string device_id_;
+
+ // Current device token. Empty if not available.
+ std::string device_token_;
+
+ // Registers the provider for notification of successful Gaia logins.
+ NotificationRegistrar registrar_;
+
+ // Allows to construct weak ptrs.
+ base::WeakPtrFactory<UserPolicyIdentityStrategy> weak_ptr_factory_;
+
+ DISALLOW_COPY_AND_ASSIGN(UserPolicyIdentityStrategy);
+};
+
+} // namespace policy
+
+#endif // CHROME_BROWSER_POLICY_USER_POLICY_IDENTITY_STRATEGY_H_

Powered by Google App Engine
This is Rietveld 408576698