summaryrefslogtreecommitdiffstats
path: root/chrome/browser/sync/engine/syncer_command.cc
diff options
context:
space:
mode:
Diffstat (limited to 'chrome/browser/sync/engine/syncer_command.cc')
-rw-r--r--chrome/browser/sync/engine/syncer_command.cc54
1 files changed, 54 insertions, 0 deletions
diff --git a/chrome/browser/sync/engine/syncer_command.cc b/chrome/browser/sync/engine/syncer_command.cc
new file mode 100644
index 0000000..9f05b64
--- /dev/null
+++ b/chrome/browser/sync/engine/syncer_command.cc
@@ -0,0 +1,54 @@
+// Copyright (c) 2009 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.
+
+#include "chrome/browser/sync/engine/syncer_command.h"
+
+#include "chrome/browser/sync/engine/net/server_connection_manager.h"
+#include "chrome/browser/sync/engine/syncer_session.h"
+#include "chrome/browser/sync/engine/syncer_status.h"
+#include "chrome/browser/sync/syncable/directory_manager.h"
+#include "chrome/browser/sync/util/event_sys-inl.h"
+#include "chrome/browser/sync/util/sync_types.h"
+
+namespace browser_sync {
+
+SyncerCommand::SyncerCommand() {}
+SyncerCommand::~SyncerCommand() {}
+
+void SyncerCommand::Execute(SyncerSession *session) {
+ ExecuteImpl(session);
+ SendNotifications(session);
+}
+
+void SyncerCommand::SendNotifications(SyncerSession *session) {
+ syncable::ScopedDirLookup dir(session->dirman(), session->account_name());
+ if (!dir.good()) {
+ LOG(ERROR) << "Scoped dir lookup failed!";
+ return;
+ }
+
+ SyncerStatus status(session);
+
+ if (status.IsDirty()) {
+ SyncerEvent event = { SyncerEvent::STATUS_CHANGED};
+ event.last_session = session;
+ session->syncer_event_channel()->NotifyListeners(event);
+ if (status.over_quota()) {
+ SyncerEvent quota_event = {SyncerEvent::OVER_QUOTA};
+ quota_event.last_session = session;
+ session->syncer_event_channel()->NotifyListeners(quota_event);
+ }
+ status.SetClean();
+ }
+ if (status.IsAuthDirty()) {
+ ServerConnectionEvent event;
+ event.what_happened = ServerConnectionEvent::STATUS_CHANGED;
+ event.server_reachable = true;
+ event.connection_code = HttpResponse::SYNC_AUTH_ERROR;
+ session->connection_manager()->channel()->NotifyListeners(event);
+ status.SetAuthClean();
+ }
+}
+
+} // namespace browser_sync