003 File Manager
Current Path:
/usr/local/include/proftpd
usr
/
local
/
include
/
proftpd
/
📁
..
📄
acconfig.h
(2.79 KB)
📄
ascii.h
(2.61 KB)
📄
auth.h
(6.23 KB)
📄
bindings.h
(7.84 KB)
📄
buildstamp.h
(50 B)
📄
ccan-json.h
(3.59 KB)
📄
child.h
(1.48 KB)
📄
class.h
(3.02 KB)
📄
cmd.h
(4.33 KB)
📄
compat.h
(2.03 KB)
📄
conf.h
(3.61 KB)
📄
config.h
(33.97 KB)
📄
configdb.h
(5.58 KB)
📄
ctrls.h
(7.92 KB)
📄
data.h
(2.52 KB)
📄
default_paths.h
(2.97 KB)
📄
dirtree.h
(7.45 KB)
📄
display.h
(2.46 KB)
📄
encode.h
(3.67 KB)
📄
env.h
(1.87 KB)
📄
error.h
(18.45 KB)
📄
event.h
(3.5 KB)
📄
expr.h
(2.16 KB)
📄
feat.h
(1.27 KB)
📄
filter.h
(2.06 KB)
📄
fsio.h
(18.58 KB)
📄
ftp.h
(8.92 KB)
📄
glibc-glob.h
(7.12 KB)
📄
hanson-tpl.h
(4.4 KB)
📄
help.h
(1.24 KB)
📄
ident.h
(1.3 KB)
📄
inet.h
(5.13 KB)
📄
jot.h
(8.44 KB)
📄
json.h
(5.34 KB)
📄
lastlog.h
(1.62 KB)
📄
libsupp.h
(3.42 KB)
📄
log.h
(6.66 KB)
📄
logfmt.h
(3.3 KB)
📄
memcache.h
(4.94 KB)
📄
mkhome.h
(1.53 KB)
📄
mod_ctrls.h
(3.38 KB)
📄
mod_dnsbl.h
(1.36 KB)
📄
mod_quotatab.h
(6.11 KB)
📄
mod_sftp.h
(8.98 KB)
📄
mod_snmp.h
(2.22 KB)
📄
mod_sql.h
(3.71 KB)
📄
mod_tls.h
(6.33 KB)
📄
mod_wrap2.h
(2.63 KB)
📄
modules.h
(6.3 KB)
📄
netacl.h
(2.51 KB)
📄
netaddr.h
(15.58 KB)
📄
netio.h
(7.98 KB)
📄
openbsd-blowfish.h
(2.88 KB)
📄
options.h
(8.12 KB)
📄
os.h
(7.03 KB)
📄
parser.h
(5.94 KB)
📄
pidfile.h
(1.3 KB)
📄
pool.h
(3.49 KB)
📄
pr-syslog.h
(3.47 KB)
📄
privs.h
(2.55 KB)
📄
proctitle.h
(1.64 KB)
📄
proftpd.h
(9.46 KB)
📄
random.h
(1.29 KB)
📄
redis.h
(15.21 KB)
📄
regexp.h
(3.15 KB)
📄
response.h
(3.07 KB)
📄
rlimit.h
(1.83 KB)
📄
scoreboard.h
(4.57 KB)
📄
session.h
(4.27 KB)
📄
sets.h
(1.94 KB)
📄
signals.h
(1.42 KB)
📄
stash.h
(2.12 KB)
📄
str.h
(5.37 KB)
📄
support.h
(4.39 KB)
📄
table.h
(11.43 KB)
📄
throttle.h
(1.26 KB)
📄
timers.h
(3.29 KB)
📄
trace.h
(2.36 KB)
📄
utf8.h
(1.37 KB)
📄
var.h
(4.32 KB)
📄
version.h
(1.59 KB)
📄
xferlog.h
(1.34 KB)
Editing: configdb.h
/* * ProFTPD - FTP server daemon * Copyright (c) 2014-2016 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. */ /* Configuration database API. */ #ifndef PR_CONFIGDB_H #define PR_CONFIGDB_H #include "pool.h" #include "sets.h" #include "table.h" typedef struct config_struc config_rec; struct server_struc; struct config_struc { struct config_struc *next, *prev; int config_type; unsigned int config_id; struct pool_rec *pool; /* Memory pool for this object */ xaset_t *set; /* The set we are stored in */ char *name; unsigned int argc; void **argv; long flags; /* Flags */ struct server_struc *server; /* Server this config element is attached to */ config_rec *parent; /* Our parent configuration record */ xaset_t *subset; /* Sub-configuration */ }; #define CONF_ROOT (1 << 0) /* No conf record */ #define CONF_DIR (1 << 1) /* Per-Dir configuration */ #define CONF_ANON (1 << 2) /* Anon. FTP configuration */ #define CONF_LIMIT (1 << 3) /* Limits commands available */ #define CONF_VIRTUAL (1 << 4) /* Virtual host */ #define CONF_DYNDIR (1 << 5) /* .ftpaccess file */ #define CONF_GLOBAL (1 << 6) /* "Global" context (applies to main server and ALL virtualhosts */ #define CONF_CLASS (1 << 7) /* Class context */ #define CONF_NAMED (1 << 8) /* Named virtual host */ #define CONF_USERDATA (1 << 14) /* Runtime user data */ #define CONF_PARAM (1 << 15) /* config/args pair */ /* config_rec flags */ #define CF_MERGEDOWN (1 << 0) /* Merge option down */ #define CF_MERGEDOWN_MULTI (1 << 1) /* Merge down, allowing multiple instances */ #define CF_DYNAMIC (1 << 2) /* Dynamically added entry */ #define CF_DEFER (1 << 3) /* Defer hashing until authentication */ #define CF_SILENT (1 << 4) /* Do not print a config dump when merging */ #define CF_MULTI (1 << 5) /* Allow multiple instances, but do not merge down */ /* The following macro determines the "highest" level available for * configuration directives. If a current dir_config is available, it's * subset is used, otherwise anon config or main server */ #define CURRENT_CONF (session.dir_config ? session.dir_config->subset \ : (session.anon_config ? session.anon_config->subset \ : main_server ? main_server->conf : NULL)) #define TOPLEVEL_CONF (session.anon_config ? session.anon_config->subset : (main_server ? main_server->conf : NULL)) /* Prototypes */ config_rec *add_config_set(xaset_t **, const char *); config_rec *add_config(struct server_struc *, const char *); config_rec *add_config_param(const char *, unsigned int, ...); config_rec *add_config_param_str(const char *, unsigned int, ...); config_rec *add_config_param_set(xaset_t **, const char *, unsigned int, ...); config_rec *pr_conf_add_server_config_param_str(struct server_struc *, const char *, unsigned int, ...); /* Flags used when searching for specific config_recs in the in-memory * config database, particularly when 'recurse' is TRUE. */ #define PR_CONFIG_FIND_FL_SKIP_ANON 0x001 #define PR_CONFIG_FIND_FL_SKIP_DIR 0x002 #define PR_CONFIG_FIND_FL_SKIP_LIMIT 0x004 #define PR_CONFIG_FIND_FL_SKIP_DYNDIR 0x008 config_rec *find_config_next(config_rec *, config_rec *, int, const char *, int); config_rec *find_config_next2(config_rec *, config_rec *, int, const char *, int, unsigned long); config_rec *find_config(xaset_t *, int, const char *, int); config_rec *find_config2(xaset_t *, int, const char *, int, unsigned long); void find_config_set_top(config_rec *); int remove_config(xaset_t *set, const char *name, int recurse); #define PR_CONFIG_FL_INSERT_HEAD 0x001 #define PR_CONFIG_FL_PRESERVE_ENTRY 0x002 config_rec *pr_config_add_set(xaset_t **, const char *, int); config_rec *pr_config_add(struct server_struc *, const char *, int); int pr_config_remove(xaset_t *set, const char *name, int flags, int recurse); /* Returns the assigned ID for the provided directive name, or zero * if no ID mapping was found. */ unsigned int pr_config_get_id(const char *name); /* Assigns a unique ID for the given configuration directive. The * mapping of directive to ID is stored in a lookup table, so that * searching of the config database by directive name can be done using * ID comparisons rather than string comparisons. * * Returns the ID assigned for the given directive, or zero if there was an * error. */ unsigned int pr_config_set_id(const char *name); void *get_param_ptr(xaset_t *, const char *, int); void *get_param_ptr_next(const char *, int); void pr_config_merge_down(xaset_t *, int); void pr_config_dump(void (*)(const char *, ...), xaset_t *, char *); /* Internal use only. */ void init_config(void); #endif /* PR_CONFIGDB_H */
Upload File
Create Folder