| // Copyright 2014 The Chromium Authors | 
 | // Use of this source code is governed by a BSD-style license that can be | 
 | // found in the LICENSE file. | 
 |  | 
 | #ifndef COMPONENTS_GCM_DRIVER_GCM_APP_HANDLER_H_ | 
 | #define COMPONENTS_GCM_DRIVER_GCM_APP_HANDLER_H_ | 
 |  | 
 | #include <string> | 
 |  | 
 | #include "components/gcm_driver/gcm_client.h" | 
 |  | 
 | namespace gcm { | 
 |  | 
 | // Defines the interface to provide handling and event routing logic for a given | 
 | // app. | 
 | class GCMAppHandler { | 
 |  public: | 
 |   GCMAppHandler(); | 
 |   virtual ~GCMAppHandler(); | 
 |  | 
 |   // Called to do all the cleanup when GCM is shutting down. | 
 |   // In the case that multiple apps share the same app handler, it should be | 
 |   // make safe for ShutdownHandler to be called multiple times. | 
 |   virtual void ShutdownHandler() = 0; | 
 |  | 
 |   // Called when the GCM store is reset (e.g. due to corruption), which changes | 
 |   // the device ID, invalidating all prior registrations. Any stored state | 
 |   // related to GCM registrations or InstanceIDs should be deleted. This should | 
 |   // only be considered a defense in depth, as this method will not be called if | 
 |   // the store is reset before this app handler is registered; hence it is | 
 |   // recommended to regularly revalidate any stored registrations/InstanceIDs. | 
 |   // TODO(johnme): GCMDriver doesn't yet provide an API for revalidating them. | 
 |   virtual void OnStoreReset() = 0; | 
 |  | 
 |   // Called when a GCM message has been received. | 
 |   virtual void OnMessage(const std::string& app_id, | 
 |                          const IncomingMessage& message) = 0; | 
 |  | 
 |   // Called when some GCM messages have been deleted from the server. | 
 |   virtual void OnMessagesDeleted(const std::string& app_id) = 0; | 
 |  | 
 |   // Called when a GCM message failed to be delivered. | 
 |   virtual void OnSendError( | 
 |       const std::string& app_id, | 
 |       const GCMClient::SendErrorDetails& send_error_details) = 0; | 
 |  | 
 |   // Called when a GCM message was received by GCM server. | 
 |   virtual void OnSendAcknowledged(const std::string& app_id, | 
 |                                   const std::string& message_id) = 0; | 
 |  | 
 |   // Called when a GCM message has been received but decryption failed. | 
 |   // |message_id| is a message identifier sent by the GCM server. | 
 |   // |error_message| is human-readable description of the error, for reporting | 
 |   // purposes. By default this handler does nothing. | 
 |   virtual void OnMessageDecryptionFailed(const std::string& app_id, | 
 |                                          const std::string& message_id, | 
 |                                          const std::string& error_message); | 
 |  | 
 |   // If no app handler has been added with the exact app_id of an incoming | 
 |   // event, all handlers will be asked (in arbitrary order) whether they can | 
 |   // handle the app_id, and the first to return true will receive the event. | 
 |   virtual bool CanHandle(const std::string& app_id) const; | 
 | }; | 
 |  | 
 | }  // namespace gcm | 
 |  | 
 | #endif  // COMPONENTS_GCM_DRIVER_GCM_APP_HANDLER_H_ |