Mercurial > dovecot > original-hg > dovecot-1.2
view src/master/master-settings.h @ 3912:fc0b638330a4 HEAD
Added mbox_min_index_size setting.
author | Timo Sirainen <tss@iki.fi> |
---|---|
date | Thu, 19 Jan 2006 01:14:43 +0200 |
parents | 411f20e72a8f |
children | 40a461d554e6 |
line wrap: on
line source
#ifndef __MASTER_SETTINGS_H #define __MASTER_SETTINGS_H #include "network.h" enum mail_protocol { MAIL_PROTOCOL_ANY, MAIL_PROTOCOL_IMAP, MAIL_PROTOCOL_POP3, MAIL_PROTOCOL_LDA }; struct settings { struct server_settings *server; enum mail_protocol protocol; /* common */ const char *base_dir; const char *log_path; const char *info_log_path; const char *log_timestamp; const char *syslog_facility; /* general */ const char *protocols; const char *listen; const char *ssl_listen; bool ssl_disable; const char *ssl_ca_file; const char *ssl_cert_file; const char *ssl_key_file; const char *ssl_key_password; unsigned int ssl_parameters_regenerate; const char *ssl_cipher_list; bool ssl_verify_client_cert; bool disable_plaintext_auth; bool verbose_ssl; /* login */ const char *login_dir; const char *login_executable; const char *login_user; const char *login_greeting; const char *login_log_format_elements; const char *login_log_format; bool login_process_per_connection; bool login_chroot; bool login_greeting_capability; unsigned int login_process_size; unsigned int login_processes_count; unsigned int login_max_processes_count; unsigned int login_max_logging_users; /* mail */ const char *valid_chroot_dirs; const char *mail_chroot; unsigned int max_mail_processes; bool verbose_proctitle; unsigned int first_valid_uid, last_valid_uid; unsigned int first_valid_gid, last_valid_gid; const char *mail_extra_groups; const char *default_mail_env; const char *mail_cache_fields; const char *mail_never_cache_fields; unsigned int mail_cache_min_mail_count; unsigned int mailbox_idle_check_interval; bool mail_debug; bool mail_full_filesystem_access; unsigned int mail_max_keyword_length; bool mail_save_crlf; bool mail_read_mmaped; bool mmap_disable; bool mmap_no_write; const char *lock_method; bool maildir_stat_dirs; bool maildir_copy_with_hardlinks; const char *mbox_read_locks; const char *mbox_write_locks; unsigned int mbox_lock_timeout; unsigned int mbox_dotlock_change_timeout; unsigned int mbox_min_index_size; bool mbox_dirty_syncs; bool mbox_very_dirty_syncs; bool mbox_lazy_writes; unsigned int dbox_rotate_size; unsigned int dbox_rotate_min_size; unsigned int dbox_rotate_days; unsigned int umask; bool mail_drop_priv_before_exec; const char *mail_executable; unsigned int mail_process_size; bool mail_use_modules; const char *mail_modules; const char *mail_log_prefix; /* imap */ unsigned int imap_max_line_length; const char *imap_capability; const char *imap_client_workarounds; /* pop3 */ bool pop3_no_flag_updates; bool pop3_enable_last; bool pop3_reuse_xuidl; const char *pop3_uidl_format; const char *pop3_client_workarounds; const char *pop3_logout_format; /* .. */ uid_t login_uid; int listen_fd, ssl_listen_fd; struct ip_addr listen_ip, ssl_listen_ip; unsigned int listen_port, ssl_listen_port; }; struct socket_settings { const char *path; unsigned int mode; const char *user; const char *group; }; struct auth_socket_settings { struct auth_settings *parent; struct auth_socket_settings *next; const char *type; struct socket_settings master; struct socket_settings client; }; struct auth_passdb_settings { struct auth_settings *parent; struct auth_passdb_settings *next; const char *driver; const char *args; bool deny; }; struct auth_userdb_settings { struct auth_settings *parent; struct auth_userdb_settings *next; const char *driver; const char *args; }; struct auth_settings { struct server_settings *parent; struct auth_settings *next; const char *name; const char *mechanisms; const char *realms; const char *default_realm; unsigned int cache_size; unsigned int cache_ttl; const char *executable; const char *user; const char *chroot; const char *username_chars; const char *username_translation; const char *anonymous_username; const char *krb5_keytab; bool verbose, debug; bool ssl_require_client_cert; bool ssl_username_from_cert; unsigned int count; unsigned int worker_max_count; unsigned int process_size; /* .. */ uid_t uid; gid_t gid; struct auth_passdb_settings *passdbs; struct auth_userdb_settings *userdbs; struct auth_socket_settings *sockets; }; struct namespace_settings { struct server_settings *parent; struct namespace_settings *next; const char *type; const char *separator; const char *prefix; const char *location; bool inbox; bool hidden; }; struct server_settings { struct server_settings *next; const char *name; struct settings *defaults; struct settings *imap; struct settings *pop3; struct auth_settings *auths; struct auth_settings auth_defaults; struct namespace_settings *namespaces; gid_t login_gid; }; extern struct server_settings *settings_root; bool master_settings_read(const char *path, bool nochecks); void master_settings_init(void); void master_settings_deinit(void); #endif