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 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244
|
/*
* ProFTPD - FTP server daemon
* Copyright (c) 1997, 1998 Public Flood Software
* Copyright (c) 1999, 2000 MacGyver aka Habeeb J. Dihu <macgyver@tos.net>
* Copyright (c) 2001-2021 The ProFTPD Project team
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation; either version 2 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software
* Foundation, Inc., 51 Franklin Street, Suite 500, Boston, MA 02110-1335, USA.
*
* As a special exemption, Public Flood Software/MacGyver aka Habeeb J. Dihu
* and other respective copyright holders give permission to link this program
* with OpenSSL, and distribute the resulting executable, without including
* the source code for OpenSSL in the source distribution.
*/
/* Server, command and associated prototypes. */
#ifndef PR_DIRTREE_H
#define PR_DIRTREE_H
#include "pool.h"
#include "sets.h"
#include "table.h"
#include "configdb.h"
#include "netaddr.h"
struct conn_struc;
struct tcp_keepalive {
int keepalive_enabled;
int keepalive_idle;
int keepalive_count;
int keepalive_intvl;
};
typedef struct server_struc {
struct server_struc *next, *prev;
struct pool_rec *pool; /* Memory pool for this server */
xaset_t *set; /* Set holding all servers */
/* The label/name for this server configuration. */
const char *ServerName;
/* The address for this server configuration. */
const char *ServerAddress;
/* The fully qualified domain name for this server configuration. */
const char *ServerFQDN;
/* Port number to which to listen. A value of zero disables the server_rec.
*/
unsigned int ServerPort;
/* TCP settings: keepalive, max segment size, receive/send buffer sizes.
*/
struct tcp_keepalive *tcp_keepalive;
int tcp_mss_len, tcp_reuse_port;
/* If the tcp_rcvbuf_override/tcp_sndbuf_override flags are true, then
* the corresponding buffer lengths are to be configured as socket options
* via setsockopt(2).
*/
int tcp_rcvbuf_len;
unsigned char tcp_rcvbuf_override;
int tcp_sndbuf_len;
unsigned char tcp_sndbuf_override;
/* Administrator name */
const char *ServerAdmin;
/* Internal address of this server */
const pr_netaddr_t *addr;
/* The listener for this server. Note that this listener, and that
* pointed to by ipbind->ib_listener (where ipbind->ib_server points to
* this server_rec) are the same. Ideally, we'd only want one pointer to
* the listener around, and avoid the duplication. To do this would
* require further structural changes.
*/
struct conn_struc *listen;
/* Configuration details */
xaset_t *conf;
int config_type;
/* Internal server ID, automatically assigned */
unsigned int sid;
/* Private data for passing among modules for this vhost. */
pr_table_t *notes;
} server_rec;
typedef struct cmd_struc {
struct pool_rec *pool;
server_rec *server;
config_rec *config;
struct pool_rec *tmp_pool; /* Temporary pool which only exists
* while the cmd's handler is running
*/
unsigned int argc;
char *arg; /* entire argument (excluding command) */
void **argv;
char *group; /* Command grouping */
int cmd_class; /* The command class */
/* These are used to speed up symbol hashing/lookups in stash.c. */
int stash_index;
unsigned int stash_hash;
pr_table_t *notes; /* Private data for passing/retaining between handlers */
int cmd_id; /* Index into commands list, for faster comparisons */
/* If we detect that the client sent commands for a protocol OTHER than
* FTP, then this field will be FALSE; the protocol field will identify
* the detected protocol.
*/
int is_ftp;
const char *protocol;
} cmd_rec;
/* Operation codes for dir_* funcs */
#define OP_HIDE 1 /* Op for hiding dirs/files */
#define OP_COMMAND 2 /* Command operation */
/* For the Order directive */
#define ORDER_ALLOWDENY 0
#define ORDER_DENYALLOW 1
extern server_rec *main_server;
extern int tcpBackLog;
extern int SocketBindTight;
extern char ServerType;
extern unsigned long ServerMaxInstances;
extern int ServerUseReverseDNS;
/* These macros are used to help handle configuration in modules */
#define CONF_ERROR(x, s) return PR_ERROR_MSG((x),NULL,pstrcat((x)->tmp_pool, \
(x)->argv[0],": ",(s),NULL));
#define CHECK_ARGS(x, n) if ((n) > 0 && (x)->argc > 0 && (x)->argc-1 < (n)) \
CONF_ERROR(x,"missing parameters")
#define CHECK_VARARGS(x, n, m) if ((x)->argc - 1 < n || (x)->argc - 1 > m) \
CONF_ERROR(x,"missing parameters")
#define CHECK_HASARGS(x, n) ((x)->argc - 1) == (n)
#define CHECK_CONF(x,p) if (!check_context((x),(p))) \
CONF_ERROR((x), \
pstrcat((x)->tmp_pool,"directive not allowed in ", \
get_context_name((x)), \
" context",NULL))
#define CHECK_CMD_ARGS(x, n) \
if ((x)->argc != (n)) { \
pr_response_add_err(R_501, _("Invalid number of parameters")); \
return PR_ERROR((x)); \
}
#define CHECK_CMD_MIN_ARGS(x, n) \
if ((x)->argc < (n)) { \
pr_response_add_err(R_501, _("Invalid number of parameters")); \
return PR_ERROR((x)); \
}
/* Prototypes */
/* KLUDGE: disable umask() for not G_WRITE operations. Config/
* Directory walking code will be completely redesigned in 1.3,
* this is only necessary for performance reasons in 1.1/1.2
*/
void kludge_disable_umask(void);
void kludge_enable_umask(void);
int pr_define_add(const char *, int);
unsigned char pr_define_exists(const char *);
int fixup_servers(xaset_t *list);
xaset_t *get_dir_ctxt(pool *, char *);
/* Returns the buffer size to use for data transfers, regardless of IO
* direction.
*/
int pr_config_get_xfer_bufsz(void);
/* Returns the buffer size to use for data transfers given an IO direction
* (either PR_NETIO_IO_RD for reads/uploads, or PR_NETIO_IO_WR for
* writes/downloads).
*/
int pr_config_get_xfer_bufsz2(int);
/* Returns the buffer size to use for data transfers given an IO direction
* (either PR_NETIO_IO_RD for reads/uploads, or PR_NETIO_IO_WR for
* writes/downloads). This takes into account any server-specific buffer
* sizes, e.g. as configured via SocketOptions.
*/
int pr_config_get_server_xfer_bufsz(int);
config_rec *dir_match_path(pool *, char *);
void build_dyn_config(pool *, const char *, struct stat *, unsigned char);
unsigned char dir_hide_file(const char *);
int dir_check_full(pool *, cmd_rec *, const char *, const char *, int *);
int dir_check_limits(cmd_rec *, config_rec *, const char *, int);
int dir_check(pool *, cmd_rec *, const char *, const char *, int *);
int dir_check_canon(pool *, cmd_rec *, const char *, const char *, int *);
int is_dotdir(const char *);
int login_check_limits(xaset_t *, int, int, int *);
void resolve_anonymous_dirs(xaset_t *);
void resolve_deferred_dirs(server_rec *);
void fixup_dirs(server_rec *, int);
unsigned char check_context(cmd_rec *, int);
char *get_context_name(cmd_rec *);
int get_boolean(cmd_rec *, int);
const char *get_full_cmd(cmd_rec *);
/* Internal use only. */
void init_dirtree(void);
#ifdef PR_USE_DEVEL
void pr_dirs_dump(void (*)(const char *, ...), xaset_t *, char *);
#endif /* PR_USE_DEVEL */
#endif /* PR_DIRTREE_H */
|