Home | History | Annotate | Download | only in renderer_host
      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 #ifndef CONTENT_BROWSER_RENDERER_HOST_SOCKET_STREAM_HOST_H_
      6 #define CONTENT_BROWSER_RENDERER_HOST_SOCKET_STREAM_HOST_H_
      7 
      8 #include <vector>
      9 
     10 #include "base/memory/ref_counted.h"
     11 #include "net/socket_stream/socket_stream.h"
     12 
     13 class GURL;
     14 
     15 namespace net {
     16 class SocketStreamJob;
     17 class URLRequestContext;
     18 class SSLInfo;
     19 }  // namespace net
     20 
     21 namespace content {
     22 
     23 // Host of SocketStreamHandle.  Each SocketStreamHandle will have an unique
     24 // socket_id assigned by SocketStreamHost constructor.  If socket id is
     25 // kNoSocketId, there is no SocketStreamHost.  Each SocketStreamHost has
     26 // SocketStream to manage bi-directional communication over socket stream.  The
     27 // lifetime of an instance of this class is completely controlled by the
     28 // SocketStreamDispatcherHost.
     29 class SocketStreamHost {
     30  public:
     31   SocketStreamHost(net::SocketStream::Delegate* delegate,
     32                    int render_view_id,
     33                    int socket_id);
     34   ~SocketStreamHost();
     35 
     36   // Gets socket_id associated with |socket|.
     37   static int SocketIdFromSocketStream(const net::SocketStream* socket);
     38 
     39   int render_view_id() const { return render_view_id_; }
     40   int socket_id() const { return socket_id_; }
     41 
     42   // Starts to open connection to |url|.
     43   void Connect(const GURL& url, net::URLRequestContext* request_context);
     44 
     45   // Sends |data| over the socket stream.
     46   // socket stream must be open to send data.
     47   // Returns true if the data is put in transmit buffer in socket stream.
     48   // Returns false otherwise (transmit buffer exceeds limit, or socket
     49   // stream is closed).
     50   bool SendData(const std::vector<char>& data);
     51 
     52   // Closes the socket stream.
     53   void Close();
     54 
     55   // Following CancelWithError, CancelWithSSLError, and ContinueDespiteError
     56   // will be called by net::SocketStream::Delegate in OnSSLCertificateError.
     57   // CancelWithError Cancels the connection because of an error.
     58   // |error| is net::Error which represents the error.
     59   void CancelWithError(int error);
     60 
     61   // Cancels the connection because of receiving a certificate with an error.
     62   void CancelWithSSLError(const net::SSLInfo& ssl_info);
     63 
     64   // Continue to establish the connection in spite of an error.
     65   void ContinueDespiteError();
     66 
     67  private:
     68   net::SocketStream::Delegate* delegate_;
     69   int render_view_id_;
     70   int socket_id_;
     71 
     72   scoped_refptr<net::SocketStreamJob> job_;
     73 
     74   DISALLOW_COPY_AND_ASSIGN(SocketStreamHost);
     75 };
     76 
     77 }  // namespace content
     78 
     79 #endif  // CONTENT_BROWSER_RENDERER_HOST_SOCKET_STREAM_HOST_H_
     80