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

Side by Side Diff: sync/internal_api/js_sync_encryption_handler_observer.cc

Issue 10827266: [Sync] Add SyncEncryptionHandler (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Fix Created 8 years, 4 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
(Empty)
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 #include "sync/internal_api/js_sync_encryption_handler_observer.h"
6
7 #include <cstddef>
8
9 #include "base/location.h"
10 #include "base/logging.h"
11 #include "base/string_number_conversions.h"
12 #include "base/values.h"
13 #include "sync/internal_api/public/base/model_type.h"
14 #include "sync/internal_api/public/util/sync_string_conversions.h"
15 #include "sync/js/js_arg_list.h"
16 #include "sync/js/js_event_details.h"
17 #include "sync/js/js_event_handler.h"
18 #include "sync/util/cryptographer.h"
19
20 namespace syncer {
21
22 JsSyncEncryptionHandlerObserver::JsSyncEncryptionHandlerObserver() {}
23
24 JsSyncEncryptionHandlerObserver::~JsSyncEncryptionHandlerObserver() {}
25
26 void JsSyncEncryptionHandlerObserver::SetJsEventHandler(
27 const WeakHandle<JsEventHandler>& event_handler) {
28 event_handler_ = event_handler;
29 }
30
31 void JsSyncEncryptionHandlerObserver::OnPassphraseRequired(
32 PassphraseRequiredReason reason,
33 const sync_pb::EncryptedData& pending_keys) {
34 if (!event_handler_.IsInitialized()) {
35 return;
36 }
37 DictionaryValue details;
38 details.SetString("reason",
39 PassphraseRequiredReasonToString(reason));
40 HandleJsEvent(FROM_HERE, "onPassphraseRequired", JsEventDetails(&details));
41 }
42
43 void JsSyncEncryptionHandlerObserver::OnPassphraseAccepted() {
44 if (!event_handler_.IsInitialized()) {
45 return;
46 }
47 DictionaryValue details;
48 HandleJsEvent(FROM_HERE, "onPassphraseAccepted", JsEventDetails(&details));
49 }
50
51 void JsSyncEncryptionHandlerObserver::OnBootstrapTokenUpdated(
52 const std::string& boostrap_token) {
53 if (!event_handler_.IsInitialized()) {
54 return;
55 }
56 DictionaryValue details;
57 details.SetString("bootstrapToken", "<redacted>");
58 HandleJsEvent(FROM_HERE, "OnBootstrapTokenUpdated", JsEventDetails(&details));
59 }
60
61 void JsSyncEncryptionHandlerObserver::OnEncryptedTypesChanged(
62 ModelTypeSet encrypted_types,
63 bool encrypt_everything) {
64 if (!event_handler_.IsInitialized()) {
65 return;
66 }
67 DictionaryValue details;
68 details.Set("encryptedTypes",
69 ModelTypeSetToValue(encrypted_types));
70 details.SetBoolean("encryptEverything", encrypt_everything);
71 HandleJsEvent(FROM_HERE,
72 "onEncryptedTypesChanged", JsEventDetails(&details));
73 }
74
75 void JsSyncEncryptionHandlerObserver::OnEncryptionComplete() {
76 if (!event_handler_.IsInitialized()) {
77 return;
78 }
79 DictionaryValue details;
80 HandleJsEvent(FROM_HERE, "onEncryptionComplete", JsEventDetails());
81 }
82
83 void JsSyncEncryptionHandlerObserver::OnCryptographerStateChanged(
84 Cryptographer* cryptographer) {
85 if (!event_handler_.IsInitialized()) {
86 return;
87 }
88 DictionaryValue details;
89 details.SetBoolean("ready",
90 cryptographer->is_ready());
91 details.SetBoolean("hasPendingKeys",
92 cryptographer->has_pending_keys());
93 HandleJsEvent(FROM_HERE,
94 "onCryptographerStateChanged",
95 JsEventDetails(&details));
96 }
97
98 void JsSyncEncryptionHandlerObserver::HandleJsEvent(
99 const tracked_objects::Location& from_here,
100 const std::string& name, const JsEventDetails& details) {
101 if (!event_handler_.IsInitialized()) {
102 NOTREACHED();
103 return;
104 }
105 event_handler_.Call(from_here,
106 &JsEventHandler::HandleJsEvent, name, details);
107 }
108
109 } // namespace syncer
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698