ftpd.h 3.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123
  1. #ifndef _PRO_FTPD_H_
  2. #define _PRO_FTPD_H_
  3. /*
  4. * Copyright (C) 2004-2005 by egnite Software GmbH. All rights reserved.
  5. *
  6. * Redistribution and use in source and binary forms, with or without
  7. * modification, are permitted provided that the following conditions
  8. * are met:
  9. *
  10. * 1. Redistributions of source code must retain the above copyright
  11. * notice, this list of conditions and the following disclaimer.
  12. * 2. Redistributions in binary form must reproduce the above copyright
  13. * notice, this list of conditions and the following disclaimer in the
  14. * documentation and/or other materials provided with the distribution.
  15. * 3. Neither the name of the copyright holders nor the names of
  16. * contributors may be used to endorse or promote products derived
  17. * from this software without specific prior written permission.
  18. *
  19. * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
  20. * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
  21. * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
  22. * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
  23. * COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
  24. * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
  25. * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS
  26. * OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
  27. * AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
  28. * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF
  29. * THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
  30. * SUCH DAMAGE.
  31. *
  32. * For additional information see http://www.ethernut.de/
  33. */
  34. /*!
  35. * \file pro/ftpd.h
  36. * \brief FTP protocol definitions for daemons.
  37. *
  38. * \verbatim
  39. *
  40. * $Log$
  41. * Revision 1.2 2008/08/11 07:00:24 haraldkipp
  42. * BSD types replaced by stdint types (feature request #1282721).
  43. *
  44. * Revision 1.1 2005/02/05 20:38:51 haraldkipp
  45. * First release
  46. *
  47. *
  48. * \endverbatim
  49. */
  50. /*!
  51. * \addtogroup xgFTPD
  52. */
  53. /*@{*/
  54. /*!
  55. * \name FTP Server Configuration
  56. *
  57. * The Nut/OS Configurator may be used to override the default values.
  58. */
  59. /*@{*/
  60. /*!
  61. * \brief UDP port of DHCP server.
  62. *
  63. * \showinitializer
  64. */
  65. #ifndef FTP_MAX_CMDBUF
  66. #define FTP_MAX_CMDBUF 128
  67. #endif
  68. /*@}*/
  69. /*!
  70. * \brief FTP session information structure.
  71. */
  72. typedef struct {
  73. /*! \brief Telnet socket of this session. */
  74. TCPSOCKET *ftp_sock;
  75. /*! \brief Stream associated to the Telnet socket. */
  76. FILE *ftp_stream;
  77. /*! \brief Current working directory for this session. */
  78. char *ftp_cwd;
  79. /*! \brief Target IP for data transfer. */
  80. uint32_t ftp_data_ip;
  81. /*! \brief TCP port for data transfer. */
  82. uint16_t ftp_data_port;
  83. /*! \brief Maximum TCP segment size for data transfer. */
  84. uint16_t ftp_maxseg;
  85. /*! \brief Login status.
  86. *
  87. * - 0: Not logged in.
  88. * - 1: Got user's name, but no password.
  89. * - 2: Logged in.
  90. */
  91. reg_t ftp_login;
  92. /*! \brief FTP data transfer mode.
  93. *
  94. * - 0: ASCII mode.
  95. * - 1: Binary mode.
  96. */
  97. reg_t ftp_tran_mode;
  98. /*! \brief FTP data transfer connection type.
  99. *
  100. * - 0: Active.
  101. * - 1: Passive.
  102. */
  103. reg_t ftp_passive;
  104. /*! \brief Source file for renaming.
  105. * NULL if no "RNFR" has been send or rename is finished.
  106. */
  107. char * ftp_renamesource;
  108. } FTPSESSION;
  109. /*@}*/
  110. extern int NutRegisterFtpRoot(const char *path);
  111. extern int NutFtpServerSession(TCPSOCKET * sock);
  112. #endif