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

Side by Side Diff: chrome/browser/password_manager/native_backend_kwallet_x.h

Issue 7835021: Linux: use our spiffy new DBus client library for KWallet, instead of dbus-glib. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src/
Patch Set: '' Created 9 years, 3 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 | Annotate | Revision Log
OLDNEW
1 // Copyright (c) 2011 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2011 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_PASSWORD_MANAGER_NATIVE_BACKEND_KWALLET_X_H_ 5 #ifndef CHROME_BROWSER_PASSWORD_MANAGER_NATIVE_BACKEND_KWALLET_X_H_
6 #define CHROME_BROWSER_PASSWORD_MANAGER_NATIVE_BACKEND_KWALLET_X_H_ 6 #define CHROME_BROWSER_PASSWORD_MANAGER_NATIVE_BACKEND_KWALLET_X_H_
7 #pragma once 7 #pragma once
8 8
9 #include <dbus/dbus-glib.h>
10 #include <glib.h>
11
12 #include <string> 9 #include <string>
13 10
14 #include "base/basictypes.h" 11 #include "base/basictypes.h"
12 #include "base/memory/ref_counted.h"
15 #include "base/time.h" 13 #include "base/time.h"
16 #include "chrome/browser/password_manager/password_store_x.h" 14 #include "chrome/browser/password_manager/password_store_x.h"
17 #include "chrome/browser/profiles/profile.h" 15 #include "chrome/browser/profiles/profile.h"
18 16
19 class Pickle; 17 class Pickle;
20 class PrefService; 18 class PrefService;
21 19
22 namespace webkit_glue { 20 namespace webkit_glue {
23 struct PasswordForm; 21 struct PasswordForm;
24 } 22 }
25 23
24 namespace base {
25 class WaitableEvent;
26 }
27
28 namespace dbus {
29 class Bus;
30 class ObjectProxy;
31 }
32
26 // NativeBackend implementation using KWallet. 33 // NativeBackend implementation using KWallet.
27 class NativeBackendKWallet : public PasswordStoreX::NativeBackend { 34 class NativeBackendKWallet : public PasswordStoreX::NativeBackend {
28 public: 35 public:
29 NativeBackendKWallet(LocalProfileId id, PrefService* prefs); 36 NativeBackendKWallet(LocalProfileId id, PrefService* prefs);
30 37
31 virtual ~NativeBackendKWallet(); 38 virtual ~NativeBackendKWallet();
32 39
33 virtual bool Init() OVERRIDE; 40 virtual bool Init() OVERRIDE;
34 41
35 // Implements NativeBackend interface. 42 // Implements NativeBackend interface.
36 virtual bool AddLogin(const webkit_glue::PasswordForm& form) OVERRIDE; 43 virtual bool AddLogin(const webkit_glue::PasswordForm& form) OVERRIDE;
37 virtual bool UpdateLogin(const webkit_glue::PasswordForm& form) OVERRIDE; 44 virtual bool UpdateLogin(const webkit_glue::PasswordForm& form) OVERRIDE;
38 virtual bool RemoveLogin(const webkit_glue::PasswordForm& form) OVERRIDE; 45 virtual bool RemoveLogin(const webkit_glue::PasswordForm& form) OVERRIDE;
39 virtual bool RemoveLoginsCreatedBetween( 46 virtual bool RemoveLoginsCreatedBetween(
40 const base::Time& delete_begin, const base::Time& delete_end) OVERRIDE; 47 const base::Time& delete_begin, const base::Time& delete_end) OVERRIDE;
41 virtual bool GetLogins(const webkit_glue::PasswordForm& form, 48 virtual bool GetLogins(const webkit_glue::PasswordForm& form,
42 PasswordFormList* forms) OVERRIDE; 49 PasswordFormList* forms) OVERRIDE;
43 virtual bool GetLoginsCreatedBetween(const base::Time& delete_begin, 50 virtual bool GetLoginsCreatedBetween(const base::Time& delete_begin,
44 const base::Time& delete_end, 51 const base::Time& delete_end,
45 PasswordFormList* forms) OVERRIDE; 52 PasswordFormList* forms) OVERRIDE;
46 virtual bool GetAutofillableLogins(PasswordFormList* forms) OVERRIDE; 53 virtual bool GetAutofillableLogins(PasswordFormList* forms) OVERRIDE;
47 virtual bool GetBlacklistLogins(PasswordFormList* forms) OVERRIDE; 54 virtual bool GetBlacklistLogins(PasswordFormList* forms) OVERRIDE;
48 55
56 protected:
57 // Internally used by Init(), but also for testing to provide a mock bus.
58 bool InitWithBus(dbus::Bus* bus);
59
49 private: 60 private:
50 // Initialization. 61 // Initialization.
62 void InitOnDBThread(base::WaitableEvent* event, bool* success);
51 bool StartKWalletd(); 63 bool StartKWalletd();
52 bool InitWallet(); 64 bool InitWallet();
53 65
54 // Reads PasswordForms from the wallet that match the given signon_realm. 66 // Reads PasswordForms from the wallet that match the given signon_realm.
55 bool GetLoginsList(PasswordFormList* forms, 67 bool GetLoginsList(PasswordFormList* forms,
56 const std::string& signon_realm, 68 const std::string& signon_realm,
57 int wallet_handle); 69 int wallet_handle);
58 70
59 // Reads PasswordForms from the wallet with the given autofillability state. 71 // Reads PasswordForms from the wallet with the given autofillability state.
60 bool GetLoginsList(PasswordFormList* forms, 72 bool GetLoginsList(PasswordFormList* forms,
61 bool autofillable, 73 bool autofillable,
62 int wallet_handle); 74 int wallet_handle);
63 75
64 // Reads PasswordForms from the wallet created in the given time range. 76 // Reads PasswordForms from the wallet created in the given time range.
65 bool GetLoginsList(PasswordFormList* forms, 77 bool GetLoginsList(PasswordFormList* forms,
66 const base::Time& begin, 78 const base::Time& begin,
67 const base::Time& end, 79 const base::Time& end,
68 int wallet_handle); 80 int wallet_handle);
69 81
70 // Helper for some of the above GetLoginsList() methods. 82 // Helper for some of the above GetLoginsList() methods.
71 bool GetAllLogins(PasswordFormList* forms, int wallet_handle); 83 bool GetAllLogins(PasswordFormList* forms, int wallet_handle);
72 84
73 // Writes a list of PasswordForms to the wallet with the given signon_realm. 85 // Writes a list of PasswordForms to the wallet with the given signon_realm.
74 // Overwrites any existing list for this signon_realm. Removes the entry if 86 // Overwrites any existing list for this signon_realm. Removes the entry if
75 // |forms| is empty. Returns true on success. 87 // |forms| is empty. Returns true on success.
76 bool SetLoginsList(const PasswordFormList& forms, 88 bool SetLoginsList(const PasswordFormList& forms,
77 const std::string& signon_realm, 89 const std::string& signon_realm,
78 int wallet_handle); 90 int wallet_handle);
79 91
80 // Checks if the last DBus call returned an error. If it did, logs the error
81 // message, frees it and returns true.
82 // This must be called after every DBus call.
83 bool CheckError();
84
85 // Opens the wallet and ensures that the "Chrome Form Data" folder exists. 92 // Opens the wallet and ensures that the "Chrome Form Data" folder exists.
86 // Returns kInvalidWalletHandle on error. 93 // Returns kInvalidWalletHandle on error.
87 int WalletHandle(); 94 int WalletHandle();
88 95
89 // Compares two PasswordForms and returns true if they are the same. 96 // Compares two PasswordForms and returns true if they are the same.
90 // If |update_check| is false, we only check the fields that are checked by 97 // If |update_check| is false, we only check the fields that are checked by
91 // LoginDatabase::UpdateLogin() when updating logins; otherwise, we check the 98 // LoginDatabase::UpdateLogin() when updating logins; otherwise, we check the
92 // fields that are checked by LoginDatabase::RemoveLogin() for removing them. 99 // fields that are checked by LoginDatabase::RemoveLogin() for removing them.
93 static bool CompareForms(const webkit_glue::PasswordForm& a, 100 static bool CompareForms(const webkit_glue::PasswordForm& a,
94 const webkit_glue::PasswordForm& b, 101 const webkit_glue::PasswordForm& b,
95 bool update_check); 102 bool update_check);
96 103
97 // Serializes a list of PasswordForms to be stored in the wallet. 104 // Serializes a list of PasswordForms to be stored in the wallet.
98 static void SerializeValue(const PasswordFormList& forms, Pickle* pickle); 105 static void SerializeValue(const PasswordFormList& forms, Pickle* pickle);
99 106
100 // Checks a serialized list of PasswordForms for sanity. Returns true if OK. 107 // Checks a serialized list of PasswordForms for sanity. Returns true if OK.
101 // Note that |realm| is only used for generating a useful warning message. 108 // Note that |realm| is only used for generating a useful warning message.
102 static bool CheckSerializedValue(const GArray* byte_array, const char* realm); 109 static bool CheckSerializedValue(const uint8_t* byte_array, size_t length,
110 const std::string& realm);
103 111
104 // Deserializes a list of PasswordForms from the wallet. 112 // Deserializes a list of PasswordForms from the wallet.
105 static void DeserializeValue(const std::string& signon_realm, 113 static void DeserializeValue(const std::string& signon_realm,
106 const Pickle& pickle, 114 const Pickle& pickle,
107 PasswordFormList* forms); 115 PasswordFormList* forms);
108 116
109 // Convenience function to read a GURL from a Pickle. Assumes the URL has 117 // Convenience function to read a GURL from a Pickle. Assumes the URL has
110 // been written as a std::string. Returns true on success. 118 // been written as a std::string. Returns true on success.
111 static bool ReadGURL(const Pickle& pickle, void** iter, GURL* url); 119 static bool ReadGURL(const Pickle& pickle, void** iter, GURL* url);
112 120
113 // In case the fields in the pickle ever change, version them so we can try to 121 // In case the fields in the pickle ever change, version them so we can try to
114 // read old pickles. (Note: do not eat old pickles past the expiration date.) 122 // read old pickles. (Note: do not eat old pickles past the expiration date.)
115 static const int kPickleVersion = 0; 123 static const int kPickleVersion = 0;
116 124
117 // Name of the folder to store passwords in. 125 // Name of the folder to store passwords in.
118 static const char kKWalletFolder[]; 126 static const char kKWalletFolder[];
119 127
120 // DBus stuff. 128 // DBus service, path, and interface names for klauncher and kwalletd.
121 static const char kKWalletServiceName[]; 129 static const char kKWalletServiceName[];
122 static const char kKWalletPath[]; 130 static const char kKWalletPath[];
123 static const char kKWalletInterface[]; 131 static const char kKWalletInterface[];
124 static const char kKLauncherServiceName[]; 132 static const char kKLauncherServiceName[];
125 static const char kKLauncherPath[]; 133 static const char kKLauncherPath[];
126 static const char kKLauncherInterface[]; 134 static const char kKLauncherInterface[];
127 135
128 // Invalid handle returned by WalletHandle(). 136 // Invalid handle returned by WalletHandle().
129 static const int kInvalidKWalletHandle = -1; 137 static const int kInvalidKWalletHandle = -1;
130 138
131 // Generates a profile-specific folder name based on profile_id_. 139 // Generates a profile-specific folder name based on profile_id_.
132 std::string GetProfileSpecificFolderName() const; 140 std::string GetProfileSpecificFolderName() const;
133 141
134 // Migrates non-profile-specific logins to be profile-specific. 142 // Migrates non-profile-specific logins to be profile-specific.
135 void MigrateToProfileSpecificLogins(); 143 void MigrateToProfileSpecificLogins();
136 144
137 // The local profile id, used to generate the folder name. 145 // The local profile id, used to generate the folder name.
138 const LocalProfileId profile_id_; 146 const LocalProfileId profile_id_;
139 147
140 // The pref service to use for persistent migration settings. 148 // The pref service to use for persistent migration settings.
141 PrefService* prefs_; 149 PrefService* prefs_;
142 150
143 // The KWallet folder name, possibly based on the local profile id. 151 // The KWallet folder name, possibly based on the local profile id.
144 std::string folder_name_; 152 std::string folder_name_;
145 153
146 // True once MigrateToProfileSpecificLogins() has been attempted. 154 // True once MigrateToProfileSpecificLogins() has been attempted.
147 bool migrate_tried_; 155 bool migrate_tried_;
148 156
149 // Error from the last DBus call. NULL when there's no error. Freed and 157 // DBus handle for communication with klauncher and kwalletd.
150 // cleared by CheckError(). 158 scoped_refptr<dbus::Bus> session_bus_;
151 GError* error_; 159 // Object proxy for kwalletd. We do not own this.
152 // Connection to the DBus session bus. 160 dbus::ObjectProxy* kwallet_proxy_;
153 DBusGConnection* connection_;
154 // Proxy to the kwallet DBus service.
155 DBusGProxy* proxy_;
156 161
157 // The name of the wallet we've opened. Set during Init(). 162 // The name of the wallet we've opened. Set during Init().
158 std::string wallet_name_; 163 std::string wallet_name_;
159 // The application name (e.g. "Chromium"), shown in KWallet auth dialogs. 164 // The application name (e.g. "Chromium"), shown in KWallet auth dialogs.
160 const std::string app_name_; 165 const std::string app_name_;
161 166
162 DISALLOW_COPY_AND_ASSIGN(NativeBackendKWallet); 167 DISALLOW_COPY_AND_ASSIGN(NativeBackendKWallet);
163 }; 168 };
164 169
165 #endif // CHROME_BROWSER_PASSWORD_MANAGER_NATIVE_BACKEND_KWALLET_X_H_ 170 #endif // CHROME_BROWSER_PASSWORD_MANAGER_NATIVE_BACKEND_KWALLET_X_H_
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698