Viewing file: dirtree.h (7.43 KB) -rw-r--r-- Select action/file-type: (+) | (+) | (+) | Code (+) | Session (+) | (+) | SDB (+) | (+) | (+) | (+) | (+) | (+) |
/* * 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-2017 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"
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;
/* 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 perfomance 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 */
|