|
Subversion
|
Go to the documentation of this file.
33 #include <apr_pools.h>
75 #define SVN_CONFIG_CATEGORY_SERVERS "servers"
76 #define SVN_CONFIG_SECTION_GROUPS "groups"
77 #define SVN_CONFIG_SECTION_GLOBAL "global"
78 #define SVN_CONFIG_OPTION_HTTP_PROXY_HOST "http-proxy-host"
79 #define SVN_CONFIG_OPTION_HTTP_PROXY_PORT "http-proxy-port"
80 #define SVN_CONFIG_OPTION_HTTP_PROXY_USERNAME "http-proxy-username"
81 #define SVN_CONFIG_OPTION_HTTP_PROXY_PASSWORD "http-proxy-password"
82 #define SVN_CONFIG_OPTION_HTTP_PROXY_EXCEPTIONS "http-proxy-exceptions"
83 #define SVN_CONFIG_OPTION_HTTP_TIMEOUT "http-timeout"
84 #define SVN_CONFIG_OPTION_HTTP_COMPRESSION "http-compression"
86 #define SVN_CONFIG_OPTION_NEON_DEBUG_MASK "neon-debug-mask"
88 #define SVN_CONFIG_OPTION_HTTP_AUTH_TYPES "http-auth-types"
89 #define SVN_CONFIG_OPTION_SSL_AUTHORITY_FILES "ssl-authority-files"
90 #define SVN_CONFIG_OPTION_SSL_TRUST_DEFAULT_CA "ssl-trust-default-ca"
91 #define SVN_CONFIG_OPTION_SSL_CLIENT_CERT_FILE "ssl-client-cert-file"
92 #define SVN_CONFIG_OPTION_SSL_CLIENT_CERT_PASSWORD "ssl-client-cert-password"
95 #define SVN_CONFIG_OPTION_SSL_PKCS11_PROVIDER "ssl-pkcs11-provider"
97 #define SVN_CONFIG_OPTION_HTTP_LIBRARY "http-library"
99 #define SVN_CONFIG_OPTION_STORE_PASSWORDS "store-passwords"
101 #define SVN_CONFIG_OPTION_STORE_PLAINTEXT_PASSWORDS "store-plaintext-passwords"
102 #define SVN_CONFIG_OPTION_STORE_AUTH_CREDS "store-auth-creds"
104 #define SVN_CONFIG_OPTION_STORE_SSL_CLIENT_CERT_PP "store-ssl-client-cert-pp"
106 #define SVN_CONFIG_OPTION_STORE_SSL_CLIENT_CERT_PP_PLAINTEXT \
107 "store-ssl-client-cert-pp-plaintext"
108 #define SVN_CONFIG_OPTION_USERNAME "username"
110 #define SVN_CONFIG_OPTION_HTTP_BULK_UPDATES "http-bulk-updates"
112 #define SVN_CONFIG_OPTION_HTTP_MAX_CONNECTIONS "http-max-connections"
114 #define SVN_CONFIG_OPTION_HTTP_CHUNKED_REQUESTS "http-chunked-requests"
117 #define SVN_CONFIG_OPTION_SERF_LOG_COMPONENTS "serf-log-components"
119 #define SVN_CONFIG_OPTION_SERF_LOG_LEVEL "serf-log-level"
122 #define SVN_CONFIG_CATEGORY_CONFIG "config"
123 #define SVN_CONFIG_SECTION_AUTH "auth"
125 #define SVN_CONFIG_OPTION_PASSWORD_STORES "password-stores"
127 #define SVN_CONFIG_OPTION_KWALLET_WALLET "kwallet-wallet"
129 #define SVN_CONFIG_OPTION_KWALLET_SVN_APPLICATION_NAME_WITH_PID "kwallet-svn-application-name-with-pid"
131 #define SVN_CONFIG_OPTION_SSL_CLIENT_CERT_FILE_PROMPT "ssl-client-cert-file-prompt"
134 #define SVN_CONFIG_SECTION_HELPERS "helpers"
135 #define SVN_CONFIG_OPTION_EDITOR_CMD "editor-cmd"
136 #define SVN_CONFIG_OPTION_DIFF_CMD "diff-cmd"
138 #define SVN_CONFIG_OPTION_DIFF_EXTENSIONS "diff-extensions"
139 #define SVN_CONFIG_OPTION_DIFF3_CMD "diff3-cmd"
140 #define SVN_CONFIG_OPTION_DIFF3_HAS_PROGRAM_ARG "diff3-has-program-arg"
142 #define SVN_CONFIG_OPTION_MERGE_TOOL_CMD "merge-tool-cmd"
143 #define SVN_CONFIG_SECTION_MISCELLANY "miscellany"
144 #define SVN_CONFIG_OPTION_GLOBAL_IGNORES "global-ignores"
145 #define SVN_CONFIG_OPTION_LOG_ENCODING "log-encoding"
146 #define SVN_CONFIG_OPTION_USE_COMMIT_TIMES "use-commit-times"
148 #define SVN_CONFIG_OPTION_TEMPLATE_ROOT "template-root"
149 #define SVN_CONFIG_OPTION_ENABLE_AUTO_PROPS "enable-auto-props"
151 #define SVN_CONFIG_OPTION_ENABLE_MAGIC_FILE "enable-magic-file"
153 #define SVN_CONFIG_OPTION_NO_UNLOCK "no-unlock"
155 #define SVN_CONFIG_OPTION_MIMETYPES_FILE "mime-types-file"
157 #define SVN_CONFIG_OPTION_PRESERVED_CF_EXTS "preserved-conflict-file-exts"
159 #define SVN_CONFIG_OPTION_INTERACTIVE_CONFLICTS "interactive-conflicts"
161 #define SVN_CONFIG_OPTION_MEMORY_CACHE_SIZE "memory-cache-size"
163 #define SVN_CONFIG_OPTION_DIFF_IGNORE_CONTENT_TYPE "diff-ignore-content-type"
164 #define SVN_CONFIG_SECTION_TUNNELS "tunnels"
165 #define SVN_CONFIG_SECTION_AUTO_PROPS "auto-props"
167 #define SVN_CONFIG_SECTION_WORKING_COPY "working-copy"
169 #define SVN_CONFIG_OPTION_SQLITE_EXCLUSIVE "exclusive-locking"
171 #define SVN_CONFIG_OPTION_SQLITE_EXCLUSIVE_CLIENTS "exclusive-locking-clients"
173 #define SVN_CONFIG_OPTION_SQLITE_BUSY_TIMEOUT "busy-timeout"
182 #define SVN_CONFIG_SECTION_GENERAL "general"
183 #define SVN_CONFIG_OPTION_ANON_ACCESS "anon-access"
184 #define SVN_CONFIG_OPTION_AUTH_ACCESS "auth-access"
185 #define SVN_CONFIG_OPTION_PASSWORD_DB "password-db"
186 #define SVN_CONFIG_OPTION_REALM "realm"
187 #define SVN_CONFIG_OPTION_AUTHZ_DB "authz-db"
189 #define SVN_CONFIG_OPTION_GROUPS_DB "groups-db"
191 #define SVN_CONFIG_OPTION_FORCE_USERNAME_CASE "force-username-case"
193 #define SVN_CONFIG_OPTION_HOOKS_ENV "hooks-env"
195 #define SVN_CONFIG_SECTION_SASL "sasl"
197 #define SVN_CONFIG_OPTION_USE_SASL "use-sasl"
199 #define SVN_CONFIG_OPTION_MIN_SSF "min-encryption"
201 #define SVN_CONFIG_OPTION_MAX_SSF "max-encryption"
204 #define SVN_CONFIG_SECTION_USERS "users"
213 #ifndef DOXYGEN_SHOULD_SKIP_THIS
214 #define SVN_CONFIG__DEFAULT_GLOBAL_IGNORES_LINE_1 \
215 "*.o *.lo *.la *.al .libs *.so *.so.[0-9]* *.a *.pyc *.pyo __pycache__"
216 #define SVN_CONFIG__DEFAULT_GLOBAL_IGNORES_LINE_2 \
217 "*.rej *~ #*# .#* .*.swp .DS_Store [Tt]humbs.db"
220 #define SVN_CONFIG_DEFAULT_GLOBAL_IGNORES \
221 SVN_CONFIG__DEFAULT_GLOBAL_IGNORES_LINE_1 " " \
222 SVN_CONFIG__DEFAULT_GLOBAL_IGNORES_LINE_2
224 #define SVN_CONFIG_TRUE "TRUE"
225 #define SVN_CONFIG_FALSE "FALSE"
226 #define SVN_CONFIG_ASK "ASK"
231 #define SVN_CONFIG_DEFAULT_OPTION_STORE_PASSWORDS TRUE
232 #define SVN_CONFIG_DEFAULT_OPTION_STORE_PLAINTEXT_PASSWORDS SVN_CONFIG_ASK
233 #define SVN_CONFIG_DEFAULT_OPTION_STORE_AUTH_CREDS TRUE
234 #define SVN_CONFIG_DEFAULT_OPTION_STORE_SSL_CLIENT_CERT_PP TRUE
235 #define SVN_CONFIG_DEFAULT_OPTION_STORE_SSL_CLIENT_CERT_PP_PLAINTEXT \
237 #define SVN_CONFIG_DEFAULT_OPTION_HTTP_MAX_CONNECTIONS 4
255 const char *config_dir,
273 apr_pool_t *result_pool);
285 apr_pool_t *result_pool);
307 apr_pool_t *result_pool);
321 apr_pool_t *result_pool);
333 apr_pool_t *result_pool);
352 apr_pool_t *result_pool);
384 const char *default_value);
436 apr_int64_t default_value);
472 const char* default_value);
492 const char *unknown_value,
540 void *baton, apr_pool_t *pool);
608 const char *section);
618 const char *master_section,
631 const char* server_group,
632 const char* option_name,
633 const char* default_value);
645 const char *server_group,
646 const char *option_name,
647 apr_int64_t default_value,
648 apr_int64_t *result_value,
665 const char *server_group,
666 const char *option_name,
716 #define SVN_CONFIG_REALMSTRING_KEY "svn:realmstring"
721 #define SVN_CONFIG_AUTHN_USERNAME_KEY "username"
728 #define SVN_CONFIG_AUTHN_PASSWORD_KEY "password"
735 #define SVN_CONFIG_AUTHN_PASSPHRASE_KEY "passphrase"
741 #define SVN_CONFIG_AUTHN_PASSTYPE_KEY "passtype"
748 #define SVN_CONFIG_AUTHN_ASCII_CERT_KEY "ascii_cert"
755 #define SVN_CONFIG_AUTHN_FAILURES_KEY "failures"
777 const char *cred_kind,
778 const char *realmstring,
779 const char *config_dir,
796 const char *cred_kind,
797 const char *realmstring,
798 const char *config_dir,
826 const char *cred_kind,
827 const char *realmstring,
829 apr_pool_t *scratch_pool);
863 apr_pool_t *scratch_pool);
885 const char *config_dir,
906 apr_hash_t *src_hash,
int svn_config_enumerate(svn_config_t *cfg, const char *section, svn_config_enumerator_t callback, void *baton)
Similar to svn_config_enumerate2(), but uses a memory pool of cfg instead of one that is explicitly p...
svn_error_t * svn_config_write_auth_data(apr_hash_t *hash, const char *cred_kind, const char *realmstring, const char *config_dir, apr_pool_t *pool)
Use cred_kind and realmstring to create or overwrite a file within the ~/.subversion/auth/ area.
svn_boolean_t(* svn_config_section_enumerator_t)(const char *name, void *baton)
Similar to svn_config_section_enumerator2_t, but is not provided with a memory pool argument.
svn_error_t * svn_config_get_yes_no_ask(svn_config_t *cfg, const char **valuep, const char *section, const char *option, const char *default_value)
Like svn_config_get(), but only for yes/no/ask values.
void svn_config_get(svn_config_t *cfg, const char **valuep, const char *section, const char *option, const char *default_value)
Find the value of a (section, option) pair in cfg, set *valuep to the value.
int svn_config_enumerate_sections(svn_config_t *cfg, svn_config_section_enumerator_t callback, void *baton)
Similar to svn_config_enumerate_sections2(), but uses a memory pool of cfg instead of one that is exp...
svn_boolean_t(* svn_config_enumerator_t)(const char *name, const char *value, void *baton)
Similar to svn_config_enumerator2_t, but is not provided with a memory pool argument.
const char * svn_config_find_group(svn_config_t *cfg, const char *key, const char *master_section, apr_pool_t *pool)
Enumerate the group master_section in cfg.
svn_error_t *(* svn_config_auth_walk_func_t)(svn_boolean_t *delete_cred, void *walk_baton, const char *cred_kind, const char *realmstring, apr_hash_t *hash, apr_pool_t *scratch_pool)
Callback for svn_config_walk_auth_data().
svn_boolean_t(* svn_config_enumerator2_t)(const char *name, const char *value, void *baton, apr_pool_t *pool)
A callback function used in enumerating config options.
svn_error_t * svn_config_dup(svn_config_t **cfgp, const svn_config_t *src, apr_pool_t *pool)
Create a deep copy of the config object src and return it in cfgp, allocating the memory in pool.
svn_error_t * svn_config_read3(svn_config_t **cfgp, const char *file, svn_boolean_t must_exist, svn_boolean_t section_names_case_sensitive, svn_boolean_t option_names_case_sensitive, apr_pool_t *result_pool)
Read configuration data from file (a file or registry path) into *cfgp, allocated in pool.
svn_error_t * svn_config_get_int64(svn_config_t *cfg, apr_int64_t *valuep, const char *section, const char *option, apr_int64_t default_value)
Like svn_config_get(), but for 64-bit signed integers.
int svn_config_enumerate_sections2(svn_config_t *cfg, svn_config_section_enumerator2_t callback, void *baton, apr_pool_t *pool)
Enumerate the sections, passing baton and the current section's name to callback.
svn_error_t * svn_config_read_auth_data(apr_hash_t **hash, const char *cred_kind, const char *realmstring, const char *config_dir, apr_pool_t *pool)
Use cred_kind and realmstring to locate a file within the ~/.subversion/auth/ area.
void svn_config_set(svn_config_t *cfg, const char *section, const char *option, const char *value)
Add or replace the value of a (section, option) pair in cfg with value.
svn_tristate_t
Generic three-state property to represent an unknown value for values that are just like booleans.
struct svn_stream_t svn_stream_t
An abstract stream of bytes–either incoming or outgoing or both.
svn_error_t * svn_config_get_bool(svn_config_t *cfg, svn_boolean_t *valuep, const char *section, const char *option, svn_boolean_t default_value)
Like svn_config_get(), but for boolean values.
svn_boolean_t(* svn_config_section_enumerator2_t)(const char *name, void *baton, apr_pool_t *pool)
A callback function used in enumerating config sections.
svn_error_t * svn_config_get_tristate(svn_config_t *cfg, svn_tristate_t *valuep, const char *section, const char *option, const char *unknown_value, svn_tristate_t default_value)
Like svn_config_get_bool(), but for tristate values.
svn_error_t * svn_config_create2(svn_config_t **cfgp, svn_boolean_t section_names_case_sensitive, svn_boolean_t option_names_case_sensitive, apr_pool_t *result_pool)
Set *cfgp to an empty svn_config_t structure, allocated in result_pool.
svn_error_t * svn_config_parse(svn_config_t **cfgp, svn_stream_t *stream, svn_boolean_t section_names_case_sensitive, svn_boolean_t option_names_case_sensitive, apr_pool_t *result_pool)
Read configuration data from stream into *cfgp, allocated in result_pool.
int svn_config_enumerate2(svn_config_t *cfg, const char *section, svn_config_enumerator2_t callback, void *baton, apr_pool_t *pool)
Enumerate the options in section, passing baton and the current option's name and value to callback.
const char * svn_config_get_server_setting(svn_config_t *cfg, const char *server_group, const char *option_name, const char *default_value)
Retrieve value corresponding to option_name in cfg, or return default_value if none is found.
void svn_config_set_int64(svn_config_t *cfg, const char *section, const char *option, apr_int64_t value)
Like svn_config_set(), but for 64-bit signed integers.
struct svn_config_t svn_config_t
Opaque structure describing a set of configuration options.
svn_error_t * svn_config_walk_auth_data(const char *config_dir, svn_config_auth_walk_func_t walk_func, void *walk_baton, apr_pool_t *scratch_pool)
Call walk_func with walk_baton and information describing each credential cached within the Subversio...
svn_error_t * svn_config_copy_config(apr_hash_t **cfg_hash, apr_hash_t *src_hash, apr_pool_t *pool)
Create a deep copy of the config hash src_hash and return it in cfg_hash, allocating the memory in po...
svn_error_t * svn_config_get_server_setting_int(svn_config_t *cfg, const char *server_group, const char *option_name, apr_int64_t default_value, apr_int64_t *result_value, apr_pool_t *pool)
Retrieve value into result_value corresponding to option_name for a given server_group in cfg,...
svn_error_t * svn_config_read(svn_config_t **cfgp, const char *file, svn_boolean_t must_exist, apr_pool_t *result_pool)
Similar to svn_config_read2, but always passes FALSE to section_names_case_sensitive.
int svn_boolean_t
YABT: Yet Another Boolean Type.
#define SVN_DEPRECATED
Macro used to mark deprecated functions.
svn_error_t * svn_config_get_config(apr_hash_t **cfg_hash, const char *config_dir, apr_pool_t *pool)
Read configuration information from the standard sources and merge it into the hash *cfg_hash.
svn_boolean_t svn_config_has_section(svn_config_t *cfg, const char *section)
Return TRUE if section exists in cfg, FALSE otherwise.
svn_error_t * svn_config_ensure(const char *config_dir, apr_pool_t *pool)
Try to ensure that the user's ~/.subversion/ area exists, and create no-op template files for any abs...
svn_error_t * svn_config_merge(svn_config_t *cfg, const char *file, svn_boolean_t must_exist)
Like svn_config_read(), but merges the configuration data from file (a file or registry path) into *c...
General file I/O for Subversion.
svn_error_t * svn_config_read2(svn_config_t **cfgp, const char *file, svn_boolean_t must_exist, svn_boolean_t section_names_case_sensitive, apr_pool_t *result_pool)
Similar to svn_config_read3, but always passes FALSE to option_names_case_sensitive.
void svn_config_set_bool(svn_config_t *cfg, const char *section, const char *option, svn_boolean_t value)
Like svn_config_set(), but for boolean values.
svn_error_t * svn_config_create(svn_config_t **cfgp, svn_boolean_t section_names_case_sensitive, apr_pool_t *result_pool)
Similar to svn_config_create2, but always passes FALSE to option_names_case_sensitive.
svn_error_t * svn_config_get_server_setting_bool(svn_config_t *cfg, svn_boolean_t *valuep, const char *server_group, const char *option_name, svn_boolean_t default_value)
Set *valuep according to option_name for a given server_group in cfg, or set to default_value if no v...
svn_error_t * svn_config_get_user_config_path(const char **path, const char *config_dir, const char *fname, apr_pool_t *pool)
Put the absolute path to the user's configuration directory, or to a file within that directory,...