| OLD | NEW |
| (Empty) |
| 1 // Copyright 2013 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 #ifndef CHROME_BROWSER_EXTENSIONS_API_SOCKETS_UDP_UDP_SOCKET_EVENT_DISPATCHER_H_ | |
| 6 #define CHROME_BROWSER_EXTENSIONS_API_SOCKETS_UDP_UDP_SOCKET_EVENT_DISPATCHER_H_ | |
| 7 | |
| 8 #include "chrome/browser/extensions/api/api_resource_manager.h" | |
| 9 #include "chrome/browser/extensions/api/sockets_udp/sockets_udp_api.h" | |
| 10 | |
| 11 namespace content { | |
| 12 class BrowserContext; | |
| 13 } | |
| 14 | |
| 15 namespace extensions { | |
| 16 struct Event; | |
| 17 class ResumableUDPSocket; | |
| 18 } | |
| 19 | |
| 20 namespace extensions { | |
| 21 namespace api { | |
| 22 | |
| 23 // Dispatch events related to "sockets.udp" sockets from callback on native | |
| 24 // socket instances. There is one instance per profile. | |
| 25 class UDPSocketEventDispatcher | |
| 26 : public BrowserContextKeyedAPI, | |
| 27 public base::SupportsWeakPtr<UDPSocketEventDispatcher> { | |
| 28 public: | |
| 29 explicit UDPSocketEventDispatcher(content::BrowserContext* context); | |
| 30 virtual ~UDPSocketEventDispatcher(); | |
| 31 | |
| 32 // Socket is active, start receving from it. | |
| 33 void OnSocketBind(const std::string& extension_id, int socket_id); | |
| 34 | |
| 35 // Socket is active again, start receiving data from it. | |
| 36 void OnSocketResume(const std::string& extension_id, int socket_id); | |
| 37 | |
| 38 // BrowserContextKeyedAPI implementation. | |
| 39 static BrowserContextKeyedAPIFactory<UDPSocketEventDispatcher>* | |
| 40 GetFactoryInstance(); | |
| 41 | |
| 42 // Convenience method to get the SocketEventDispatcher for a profile. | |
| 43 static UDPSocketEventDispatcher* Get(content::BrowserContext* context); | |
| 44 | |
| 45 private: | |
| 46 typedef ApiResourceManager<ResumableUDPSocket>::ApiResourceData SocketData; | |
| 47 friend class BrowserContextKeyedAPIFactory<UDPSocketEventDispatcher>; | |
| 48 // BrowserContextKeyedAPI implementation. | |
| 49 static const char* service_name() { | |
| 50 return "UDPSocketEventDispatcher"; | |
| 51 } | |
| 52 static const bool kServiceHasOwnInstanceInIncognito = true; | |
| 53 static const bool kServiceIsNULLWhileTesting = true; | |
| 54 | |
| 55 // base::Bind supports methods with up to 6 parameters. ReceiveParams is used | |
| 56 // as a workaround that limitation for invoking StartReceive. | |
| 57 struct ReceiveParams { | |
| 58 ReceiveParams(); | |
| 59 ~ReceiveParams(); | |
| 60 | |
| 61 content::BrowserThread::ID thread_id; | |
| 62 void* browser_context_id; | |
| 63 std::string extension_id; | |
| 64 scoped_refptr<SocketData> sockets; | |
| 65 int socket_id; | |
| 66 }; | |
| 67 | |
| 68 // Start a receive and register a callback. | |
| 69 static void StartReceive(const ReceiveParams& params); | |
| 70 | |
| 71 // Called when socket receive data. | |
| 72 static void ReceiveCallback(const ReceiveParams& params, | |
| 73 int bytes_read, | |
| 74 scoped_refptr<net::IOBuffer> io_buffer, | |
| 75 const std::string& address, | |
| 76 int port); | |
| 77 | |
| 78 // Post an extension event from IO to UI thread | |
| 79 static void PostEvent(const ReceiveParams& params, scoped_ptr<Event> event); | |
| 80 | |
| 81 // Dispatch an extension event on to EventRouter instance on UI thread. | |
| 82 static void DispatchEvent(void* browser_context_id, | |
| 83 const std::string& extension_id, | |
| 84 scoped_ptr<Event> event); | |
| 85 | |
| 86 // Usually IO thread (except for unit testing). | |
| 87 content::BrowserThread::ID thread_id_; | |
| 88 content::BrowserContext* const browser_context_; | |
| 89 scoped_refptr<SocketData> sockets_; | |
| 90 }; | |
| 91 | |
| 92 } // namespace api | |
| 93 } // namespace extensions | |
| 94 | |
| 95 #endif // CHROME_BROWSER_EXTENSIONS_API_SOCKETS_UDP_UDP_SOCKET_EVENT_DISPATCHER
_H_ | |
| OLD | NEW |