blob: 5a5d80e869f402aa27e064ef1b313ec6dd0dd843 [file] [log] [blame]
// Copyright (c) 2012 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_SYNC_GLUE_PASSWORD_CHANGE_PROCESSOR_H_
#define CHROME_BROWSER_SYNC_GLUE_PASSWORD_CHANGE_PROCESSOR_H_
#include "chrome/browser/sync/glue/change_processor.h"
#include "base/basictypes.h"
#include "base/compiler_specific.h"
#include "chrome/browser/sync/glue/data_type_error_handler.h"
#include "chrome/browser/sync/glue/password_model_associator.h"
#include "chrome/browser/sync/glue/sync_backend_host.h"
#include "content/public/browser/notification_observer.h"
#include "content/public/browser/notification_registrar.h"
#include "content/public/browser/notification_types.h"
class PasswordStore;
namespace base {
class MessageLoop;
}
namespace browser_sync {
class DataTypeErrorHandler;
// This class is responsible for taking changes from the password backend and
// applying them to the sync API 'syncable' model, and vice versa. All
// operations and use of this class are from the DB thread on Windows and Linux,
// or the password thread on Mac.
class PasswordChangeProcessor : public ChangeProcessor,
public content::NotificationObserver {
public:
PasswordChangeProcessor(PasswordModelAssociator* model_associator,
PasswordStore* password_store,
DataTypeErrorHandler* error_handler);
virtual ~PasswordChangeProcessor();
// content::NotificationObserver implementation.
// Passwords -> sync API model change application.
virtual void Observe(int type,
const content::NotificationSource& source,
const content::NotificationDetails& details) OVERRIDE;
// sync API model -> WebDataService change application.
virtual void ApplyChangesFromSyncModel(
const syncer::BaseTransaction* trans,
int64 model_version,
const syncer::ImmutableChangeRecordList& changes) OVERRIDE;
// Commit changes buffered during ApplyChanges. We must commit them to the
// password store only after the sync API transaction is released, else there
// is risk of deadlock due to the password store posting tasks to the UI
// thread (http://crbug.com/70658).
virtual void CommitChangesFromSyncModel() OVERRIDE;
// Stop processing changes and wait for being destroyed.
void Disconnect();
protected:
virtual void StartImpl(Profile* profile) OVERRIDE;
private:
friend class ScopedStopObserving<PasswordChangeProcessor>;
void StartObserving();
void StopObserving();
// Registers to observe password change for the first time.
void InitObserving();
// The two models should be associated according to this ModelAssociator.
PasswordModelAssociator* model_associator_;
// The model we are processing changes from. This is owned by the
// WebDataService which is kept alive by our data type controller
// holding a reference.
scoped_refptr<PasswordStore> password_store_;
// Buffers used between ApplyChangesFromSyncModel and
// CommitChangesFromSyncModel.
PasswordModelAssociator::PasswordVector new_passwords_;
PasswordModelAssociator::PasswordVector updated_passwords_;
PasswordModelAssociator::PasswordVector deleted_passwords_;
content::NotificationRegistrar notification_registrar_;
base::MessageLoop* expected_loop_;
// If disconnected is true, local/sync changes are dropped without modifying
// sync/local models.
bool disconnected_;
base::Lock disconnect_lock_;
DISALLOW_COPY_AND_ASSIGN(PasswordChangeProcessor);
};
} // namespace browser_sync
#endif // CHROME_BROWSER_SYNC_GLUE_PASSWORD_CHANGE_PROCESSOR_H_