1 // Copyright 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 // Interface to the invalidator, which is an object that receives 6 // invalidations for registered object IDs. The corresponding 7 // InvalidationHandler is notifier when such an event occurs. 8 9 #ifndef SYNC_NOTIFIER_INVALIDATOR_H_ 10 #define SYNC_NOTIFIER_INVALIDATOR_H_ 11 12 #include <string> 13 14 #include "sync/base/sync_export.h" 15 #include "sync/internal_api/public/base/model_type.h" 16 #include "sync/notifier/invalidation_util.h" 17 #include "sync/notifier/invalidator_state.h" 18 19 namespace syncer { 20 class InvalidationHandler; 21 22 class SYNC_EXPORT Invalidator { 23 public: 24 Invalidator() {} 25 virtual ~Invalidator() {} 26 27 // Clients should follow the pattern below: 28 // 29 // When starting the client: 30 // 31 // invalidator->RegisterHandler(client_handler); 32 // 33 // When the set of IDs to register changes for the client during its lifetime 34 // (i.e., between calls to RegisterHandler(client_handler) and 35 // UnregisterHandler(client_handler): 36 // 37 // invalidator->UpdateRegisteredIds(client_handler, client_ids); 38 // 39 // When shutting down the client for profile shutdown: 40 // 41 // invalidator->UnregisterHandler(client_handler); 42 // 43 // Note that there's no call to UpdateRegisteredIds() -- this is because the 44 // invalidation API persists registrations across browser restarts. 45 // 46 // When permanently shutting down the client, e.g. when disabling the related 47 // feature: 48 // 49 // invalidator->UpdateRegisteredIds(client_handler, ObjectIdSet()); 50 // invalidator->UnregisterHandler(client_handler); 51 // 52 // It is an error to have registered handlers when an invalidator is 53 // destroyed; clients must ensure that they unregister themselves 54 // before then. 55 56 // Starts sending notifications to |handler|. |handler| must not be NULL, 57 // and it must not already be registered. 58 virtual void RegisterHandler(InvalidationHandler* handler) = 0; 59 60 // Updates the set of ObjectIds associated with |handler|. |handler| must 61 // not be NULL, and must already be registered. An ID must be registered for 62 // at most one handler. 63 virtual void UpdateRegisteredIds(InvalidationHandler* handler, 64 const ObjectIdSet& ids) = 0; 65 66 // Stops sending notifications to |handler|. |handler| must not be NULL, and 67 // it must already be registered. Note that this doesn't unregister the IDs 68 // associated with |handler|. 69 virtual void UnregisterHandler(InvalidationHandler* handler) = 0; 70 71 // Returns the current invalidator state. When called from within 72 // InvalidationHandler::OnInvalidatorStateChange(), this must return 73 // the updated state. 74 virtual InvalidatorState GetInvalidatorState() const = 0; 75 76 // The observers won't be notified of any notifications until 77 // UpdateCredentials is called at least once. It can be called more than 78 // once. 79 virtual void UpdateCredentials( 80 const std::string& email, const std::string& token) = 0; 81 }; 82 } // namespace syncer 83 84 #endif // SYNC_NOTIFIER_INVALIDATOR_H_ 85