• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
4 
5 #ifndef COMPONENTS_POLICY_CORE_COMMON_CLOUD_CLOUD_POLICY_STORE_H_
6 #define COMPONENTS_POLICY_CORE_COMMON_CLOUD_CLOUD_POLICY_STORE_H_
7 
8 #include "base/basictypes.h"
9 #include "base/memory/scoped_ptr.h"
10 #include "base/memory/weak_ptr.h"
11 #include "base/observer_list.h"
12 #include "components/policy/core/common/cloud/cloud_policy_validator.h"
13 #include "components/policy/core/common/policy_map.h"
14 #include "components/policy/policy_export.h"
15 #include "policy/proto/device_management_backend.pb.h"
16 
17 namespace policy {
18 
19 class CloudExternalDataManager;
20 
21 // Defines the low-level interface used by the cloud policy code to:
22 //   1. Validate policy blobs that should be applied locally
23 //   2. Persist policy blobs
24 //   3. Decode policy blobs to PolicyMap representation
25 class POLICY_EXPORT CloudPolicyStore {
26  public:
27   // Status codes.
28   enum Status {
29     // Everything is in good order.
30     STATUS_OK,
31     // Loading policy from the underlying data store failed.
32     STATUS_LOAD_ERROR,
33     // Failed to store policy to the data store.
34     STATUS_STORE_ERROR,
35     // Failed to parse the policy read from the data store.
36     STATUS_PARSE_ERROR,
37     // Failed to serialize policy for storage.
38     STATUS_SERIALIZE_ERROR,
39     // Validation error.
40     STATUS_VALIDATION_ERROR,
41     // Store cannot accept policy (e.g. non-enterprise device).
42     STATUS_BAD_STATE,
43   };
44 
45   // Callbacks for policy store events. Most importantly, policy updates.
46   class POLICY_EXPORT Observer {
47    public:
48     virtual ~Observer();
49 
50     // Called on changes to store->policy() and/or store->policy_map().
51     virtual void OnStoreLoaded(CloudPolicyStore* store) = 0;
52 
53     // Called upon encountering errors.
54     virtual void OnStoreError(CloudPolicyStore* store) = 0;
55   };
56 
57   CloudPolicyStore();
58   virtual ~CloudPolicyStore();
59 
60   // Indicates whether the store has been fully initialized. This is
61   // accomplished by calling Load() after startup.
is_initialized()62   bool is_initialized() const { return is_initialized_; }
63 
external_data_manager()64   base::WeakPtr<CloudExternalDataManager> external_data_manager() const {
65     return external_data_manager_;
66   }
67 
policy_map()68   const PolicyMap& policy_map() const { return policy_map_; }
has_policy()69   bool has_policy() const {
70     return policy_.get() != NULL;
71   }
policy()72   const enterprise_management::PolicyData* policy() const {
73     return policy_.get();
74   }
is_managed()75   bool is_managed() const {
76     return policy_.get() &&
77            policy_->state() == enterprise_management::PolicyData::ACTIVE;
78   }
status()79   Status status() const { return status_; }
validation_status()80   CloudPolicyValidatorBase::Status validation_status() const {
81     return validation_status_;
82   }
83 
84   // Store a new policy blob. Pending load/store operations will be canceled.
85   // The store operation may proceed asynchronously and observers are notified
86   // once the operation finishes. If successful, OnStoreLoaded() will be invoked
87   // on the observers and the updated policy can be read through policy().
88   // Errors generate OnStoreError() notifications.
89   // |invalidation_version| is the invalidation version of the policy to be
90   // stored.
91   void Store(
92       const enterprise_management::PolicyFetchResponse& policy,
93       int64 invalidation_version);
94 
95   virtual void Store(
96       const enterprise_management::PolicyFetchResponse& policy) = 0;
97 
98   // Load the current policy blob from persistent storage. Pending load/store
99   // operations will be canceled. This may trigger asynchronous operations.
100   // Upon success, OnStoreLoaded() will be called on the registered observers.
101   // Otherwise, OnStoreError() reports the reason for failure.
102   virtual void Load() = 0;
103 
104   // Registers an observer to be notified when policy changes.
105   void AddObserver(Observer* observer);
106 
107   // Removes the specified observer.
108   void RemoveObserver(Observer* observer);
109 
110   // The invalidation version of the last policy stored. This value can be read
111   // by observers to determine which version of the policy is now available.
invalidation_version()112   int64 invalidation_version() {
113     return invalidation_version_;
114   }
115 
116   // Indicate that external data referenced by policies in this store is managed
117   // by |external_data_manager|. The |external_data_manager| will be notified
118   // about policy changes before any other observers.
119   void SetExternalDataManager(
120       base::WeakPtr<CloudExternalDataManager> external_data_manager);
121 
122   // Replaces |policy_map_| and calls the registered observers, simulating a
123   // successful load of |policy_map| from persistent storage.
124   // TODO(bartfab): This override is only needed because there are no policies
125   // that reference external data and therefore, no ExternalDataFetchers in the
126   // |policy_map_|. Once the first such policy is added, use that policy in
127   // tests and remove the override.
128   void SetPolicyMapForTesting(const PolicyMap& policy_map);
129 
130  protected:
131   // Invokes the corresponding callback on all registered observers.
132   void NotifyStoreLoaded();
133   void NotifyStoreError();
134 
135   // Manages external data referenced by policies.
136   base::WeakPtr<CloudExternalDataManager> external_data_manager_;
137 
138   // Decoded version of the currently effective policy.
139   PolicyMap policy_map_;
140 
141   // Currently effective policy.
142   scoped_ptr<enterprise_management::PolicyData> policy_;
143 
144   // Latest status code.
145   Status status_;
146 
147   // Latest validation status.
148   CloudPolicyValidatorBase::Status validation_status_;
149 
150   // The invalidation version of the last policy stored.
151   int64 invalidation_version_;
152 
153  private:
154   // Whether the store has completed asynchronous initialization, which is
155   // triggered by calling Load().
156   bool is_initialized_;
157 
158   ObserverList<Observer, true> observers_;
159 
160   DISALLOW_COPY_AND_ASSIGN(CloudPolicyStore);
161 };
162 
163 }  // namespace policy
164 
165 #endif  // COMPONENTS_POLICY_CORE_COMMON_CLOUD_CLOUD_POLICY_STORE_H_
166