summaryrefslogtreecommitdiffstats
path: root/netwerk/protocol/ftp/nsFtpControlConnection.h
blob: c29e23eeedd4b8d9c4bfab40671d107cb7c0aeb8 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
/* -*- Mode: C++; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
/* vim:set et ts=4 sts=2 sw=2 cin: */
/* This Source Code Form is subject to the terms of the Mozilla Public
 * License, v. 2.0. If a copy of the MPL was not distributed with this
 * file, You can obtain one at http://mozilla.org/MPL/2.0/. */

#ifndef nsFtpControlConnection_h___
#define nsFtpControlConnection_h___

#include "nsCOMPtr.h"

#include "nsISocketTransport.h"
#include "nsIAsyncInputStream.h"
#include "nsString.h"
#include "mozilla/Attributes.h"

class nsIOutputStream;
class nsIProxyInfo;
class nsITransportEventSink;

class nsFtpControlConnectionListener : public nsISupports {
 public:
  /**
   * Called when a chunk of data arrives on the control connection.
   * @param data
   *        The new data or null if an error occurred.
   * @param dataLen
   *        The data length in bytes.
   */
  virtual void OnControlDataAvailable(const char* data, uint32_t dataLen) = 0;

  /**
   * Called when an error occurs on the control connection.
   * @param status
   *        A failure code providing more info about the error.
   */
  virtual void OnControlError(nsresult status) = 0;
};

class nsFtpControlConnection final : public nsIInputStreamCallback {
  ~nsFtpControlConnection();

 public:
  NS_DECL_ISUPPORTS
  NS_DECL_NSIINPUTSTREAMCALLBACK

  nsFtpControlConnection(const nsACString& host, uint32_t port);

  nsresult Connect(nsIProxyInfo* proxyInfo, nsITransportEventSink* eventSink);
  nsresult Disconnect(nsresult status);
  nsresult Write(const nsACString& command);

  bool IsAlive();

  nsITransport* Transport() { return mSocket; }

  /**
   * Call this function to be notified asynchronously when there is data
   * available for the socket.  The listener passed to this method replaces
   * any existing listener, and the listener can be null to disconnect the
   * previous listener.
   */
  nsresult WaitData(nsFtpControlConnectionListener* listener);

  uint32_t mServerType;  // what kind of server is it.
  nsString mPassword;
  int32_t mSuspendedWrite;
  nsCString mPwd;
  uint32_t mSessionId;
  bool mUseUTF8;

 private:
  nsCString mHost;
  uint32_t mPort;

  nsCOMPtr<nsISocketTransport> mSocket;
  nsCOMPtr<nsIOutputStream> mSocketOutput;
  nsCOMPtr<nsIAsyncInputStream> mSocketInput;

  RefPtr<nsFtpControlConnectionListener> mListener;
};

#endif