blob: c1626a6de5a8c1f7b765385a8de60b8f32cb278a [file] [log] [blame]
[email protected]df006cbc2014-01-22 18:36:201// Copyright 2014 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
[email protected]44828772014-06-06 02:56:525#ifndef COMPONENTS_INVALIDATION_GCM_NETWORK_CHANNEL_DELEGATE_H_
6#define COMPONENTS_INVALIDATION_GCM_NETWORK_CHANNEL_DELEGATE_H_
[email protected]df006cbc2014-01-22 18:36:207
8#include <string>
9
10#include "base/callback.h"
[email protected]cd57f372014-06-09 17:13:0611#include "components/gcm_driver/gcm_client.h"
[email protected]df006cbc2014-01-22 18:36:2012
13class GoogleServiceAuthError;
14
15namespace syncer {
16
17// Delegate for GCMNetworkChannel.
18// GCMNetworkChannel needs Register to register with GCM client and obtain gcm
19// registration id. This id is used for building URL to cache invalidation
20// endpoint.
21// It needs RequestToken and InvalidateToken to get access token to include it
22// in HTTP message to server.
23// GCMNetworkChannel lives on IO thread therefore calls will be made on IO
24// thread and callbacks should be invoked there as well.
25class GCMNetworkChannelDelegate {
26 public:
27 typedef base::Callback<void(const GoogleServiceAuthError& error,
28 const std::string& token)> RequestTokenCallback;
29 typedef base::Callback<void(const std::string& registration_id,
30 gcm::GCMClient::Result result)> RegisterCallback;
[email protected]88af1242014-03-12 22:02:0931 typedef base::Callback<void(const std::string& message,
32 const std::string& echo_token)> MessageCallback;
[email protected]afff1752014-06-20 04:42:1033 typedef base::Callback<void(bool online)> ConnectionStateCallback;
[email protected]df006cbc2014-01-22 18:36:2034
35 virtual ~GCMNetworkChannelDelegate() {}
36
[email protected]dd507f52014-06-19 01:27:5637 virtual void Initialize(ConnectionStateCallback callback) = 0;
[email protected]df006cbc2014-01-22 18:36:2038 // Request access token. Callback should be called either with access token or
39 // error code.
40 virtual void RequestToken(RequestTokenCallback callback) = 0;
41 // Invalidate access token that was rejected by server.
42 virtual void InvalidateToken(const std::string& token) = 0;
43
[email protected]df84c532014-04-25 15:36:5444 // Request registration_id from GCMService. Callback should be called with
45 // either registration id or error code.
[email protected]df006cbc2014-01-22 18:36:2046 virtual void Register(RegisterCallback callback) = 0;
[email protected]88af1242014-03-12 22:02:0947 // Provide callback for incoming messages from GCM.
48 virtual void SetMessageReceiver(MessageCallback callback) = 0;
[email protected]df006cbc2014-01-22 18:36:2049};
50} // namespace syncer
51
[email protected]44828772014-06-06 02:56:5252#endif // COMPONENTS_INVALIDATION_GCM_NETWORK_CHANNEL_DELEGATE_H_