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

Side by Side Diff: chrome/browser/android/policy/policy_manager.h

Issue 1220683008: Move AppRestriction to Policy code out of //chrome (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Fix imports & compilation Created 5 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 unified diff | Download patch
OLDNEW
1 // Copyright 2015 The Chromium Authors. All rights reserved. 1 // Copyright 2015 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 #ifndef CHROME_BROWSER_ANDROID_POLICY_POLICY_MANAGER_H_ 5 #ifndef CHROME_BROWSER_ANDROID_POLICY_POLICY_MANAGER_H_
6 #define CHROME_BROWSER_ANDROID_POLICY_POLICY_MANAGER_H_ 6 #define CHROME_BROWSER_ANDROID_POLICY_POLICY_MANAGER_H_
7 7
8 #include <jni.h> 8 #include <jni.h>
9 9
10 #include "base/android/jni_weak_ref.h" 10 #include "base/android/jni_weak_ref.h"
11 #include "components/policy/core/common/policy_bundle.h" 11 #include "components/policy/core/browser/android/app_restrictions_importer.h"
12 #include "components/policy/core/common/policy_provider_android_delegate.h" 12 #include "components/policy/core/common/policy_provider_android_delegate.h"
13 13
14 namespace policy { 14 class PolicyManager : public policy::AppRestrictionsImporter,
15 15 public policy::PolicyProviderAndroidDelegate {
16 class PolicyProviderAndroid;
17 class Schema;
18
19 } // namespace policy
20
21 class PolicyManager : public policy::PolicyProviderAndroidDelegate {
22 public: 16 public:
23 PolicyManager(JNIEnv* env, jobject obj); 17 PolicyManager(JNIEnv* env, jobject obj);
24 18
25 // Called from Java:
26 void SetPolicyBoolean(JNIEnv* env,
27 jobject obj,
28 jstring policyKey,
29 jboolean value);
30 void SetPolicyInteger(JNIEnv* env,
31 jobject obj,
32 jstring policyKey,
33 jint value);
34 void SetPolicyString(JNIEnv* env,
35 jobject obj,
36 jstring policyKey,
37 jstring value);
38 void SetPolicyStringArray(JNIEnv* env,
39 jobject obj,
40 jstring policyKey,
41 jobjectArray value);
42 void FlushPolicies(JNIEnv* env, jobject obj);
43
44 void Destroy(JNIEnv* env, jobject obj); 19 void Destroy(JNIEnv* env, jobject obj);
45 20
46 // Converts the passed in value to the type desired by the schema. If the 21 // AppRestrictionsImporter:
bartfab (slow) 2015/07/03 16:55:47 1: Why are these two methods public? 2: Nit: Prefi
dgn 2015/07/06 17:34:02 Made them private.
47 // value is not convertible, it is returned unchanged, so the policy system 22 policy::Schema GetPolicySchema(const std::string& key) override;
48 // can report the error. 23 policy::PolicyProviderAndroid* GetPolicyProvider() override;
49 // Note that this method will only look at the type of the schema, not at any
50 // additional restrictions, or the schema for value's items or properties in
51 // the case of a list or dictionary value.
52 // This method takes ownership of the passed in value, and the caller takes
53 // ownership of the return value.
54 // Public for testing.
55 static base::Value* ConvertValueToSchema(base::Value* raw_value,
56 const policy::Schema& schema);
57 24
58 // PolicyProviderAndroidDelegate: 25 // PolicyProviderAndroidDelegate:
59 void RefreshPolicies() override; 26 void RefreshPolicies() override;
60 void PolicyProviderShutdown() override; 27 void PolicyProviderShutdown() override;
61 28
62 private: 29 private:
63 ~PolicyManager() override; 30 ~PolicyManager() override;
bartfab (slow) 2015/07/03 16:55:47 Nit: There should be no need to override the destr
dgn 2015/07/06 17:34:02 Done.
64 31
65 JavaObjectWeakGlobalRef weak_java_policy_manager_; 32 JavaObjectWeakGlobalRef weak_java_policy_manager_;
66 33
67 scoped_ptr<policy::PolicyBundle> policy_bundle_;
68 policy::PolicyProviderAndroid* policy_provider_; 34 policy::PolicyProviderAndroid* policy_provider_;
bartfab (slow) 2015/07/03 16:55:47 Nit: Forward-declare |policy::PolicyProviderAndroi
dgn 2015/07/06 17:34:02 Done.
69 35
70 void SetPolicyValue(const std::string& key, base::Value* value);
71
72 DISALLOW_COPY_AND_ASSIGN(PolicyManager); 36 DISALLOW_COPY_AND_ASSIGN(PolicyManager);
bartfab (slow) 2015/07/03 16:55:47 Nit: #include "base/macros.h"
dgn 2015/07/06 17:34:02 Done.
73 }; 37 };
74 38
75 // Register native methods 39 // Register native methods
76 bool RegisterPolicyManager(JNIEnv* env); 40 bool RegisterPolicyManager(JNIEnv* env);
77 41
78 #endif // CHROME_BROWSER_ANDROID_POLICY_POLICY_MANAGER_H_ 42 #endif // CHROME_BROWSER_ANDROID_POLICY_POLICY_MANAGER_H_
OLDNEW
« no previous file with comments | « no previous file | chrome/browser/android/policy/policy_manager.cc » ('j') | chrome/browser/android/policy/policy_manager.cc » ('J')

Powered by Google App Engine
This is Rietveld 408576698