PNG  IHDR* pHYs+ IDATx]n#; cdLb Ǚ[at¤_:uP}>!Usă cag޿ ֵNu`ݼTâabO7uL&y^wFٝA"l[|ŲHLN밪4*sG3|Dv}?+y߉{OuOAt4Jj.u]Gz*҉sP'VQKbA1u\`& Af;HWj hsO;ogTu uj7S3/QzUr&wS`M$X_L7r2;aE+ώ%vikDA:dR+%KzƉo>eOth$z%: :{WwaQ:wz%4foɹE[9<]#ERINƻv溂E%P1i01 |Jvҗ&{b?9g=^wζXn/lK::90KwrюO\!ջ3uzuGv^;騢wq<Iatv09:tt~hEG`v;3@MNZD.1]L:{ծI3`L(÷ba")Y.iljCɄae#I"1 `3*Bdz>j<fU40⨬%O$3cGt]j%Fߠ_twJ;ABU8vP3uEԑwQ V:h%))LfraqX-ۿX]v-\9I gl8tzX ]ecm)-cgʒ#Uw=Wlێn(0hPP/ӨtQ“&J35 $=]r1{tLuǮ*i0_;NƝ8;-vݏr8+U-kruȕYr0RnC]*ެ(M:]gE;{]tg(#ZJ9y>utRDRMdr9㪩̞zֹb<ģ&wzJM"iI( .ꮅX)Qw:9,i좜\Ԛi7&N0:asϓc];=ΗOӣ APqz93 y $)A*kVHZwBƺnWNaby>XMN*45~ղM6Nvm;A=jֲ.~1}(9`KJ/V F9[=`~[;sRuk]rєT!)iQO)Y$V ی ۤmzWz5IM Zb )ˆC`6 rRa}qNmUfDsWuˤV{ Pݝ'=Kֳbg,UҘVz2ﴻnjNgBb{? ߮tcsͻQuxVCIY۠:(V뺕 ٥2;t`@Fo{Z9`;]wMzU~%UA蛚dI vGq\r82iu +St`cR.6U/M9IENDB`/* * ProFTPD - FTP server daemon * Copyright (c) 2014-2022 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); config_rec *pr_config_alloc(pool *p, const char *name, int config_type); #define PR_CONFIG_FL_INSERT_HEAD 0x001 #define PR_CONFIG_FL_PRESERVE_ENTRY 0x002 config_rec *pr_config_add_config_to_set(xaset_t *set, config_rec *c, int flags); 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 */