mirror of
https://github.com/apache/httpd.git
synced 2025-08-01 16:41:19 +00:00

apr_dbm does not provide thread-safe locking: * modules/dav/fs/mod_dav_fs.c (dav_fs_get_server_conf): Replaces dav_get_lockdb_path. (dav_fs_pre_config, dav_fs_child_init): New hooks. (dav_fs_post_config): Create & store the mutex here. (register_hooks): Register new hooks. * modules/dav/fs/repos.h: Expose new dav_fs_server_conf struct. * modules/dav/fs/lock.c (dav_fs_lockdb_cleanup): New cleanup which unlocks and closes the dbm handle. (dav_fs_really_open_lockdb): Lock the mutex here, register a cleanup. (dav_fs_open_lockdb): Adjust to use dav_fs_get_server_conf. (dav_fs_close_lockdb): Run the cleanup here. Github: closes #395 git-svn-id: https://svn.apache.org/repos/asf/httpd/httpd/trunk@1914438 13f79535-47bb-0310-9956-ffa450edef68
119 lines
4.7 KiB
C
119 lines
4.7 KiB
C
/* Licensed to the Apache Software Foundation (ASF) under one or more
|
|
* contributor license agreements. See the NOTICE file distributed with
|
|
* this work for additional information regarding copyright ownership.
|
|
* The ASF licenses this file to You under the Apache License, Version 2.0
|
|
* (the "License"); you may not use this file except in compliance with
|
|
* the License. You may obtain a copy of the License at
|
|
*
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
*
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
* See the License for the specific language governing permissions and
|
|
* limitations under the License.
|
|
*/
|
|
|
|
/**
|
|
* @file repos.h
|
|
* @brief Declarations for the filesystem repository implementation
|
|
*
|
|
* @addtogroup MOD_DAV
|
|
* @{
|
|
*/
|
|
|
|
#ifndef _DAV_FS_REPOS_H_
|
|
#define _DAV_FS_REPOS_H_
|
|
|
|
#include "util_mutex.h"
|
|
|
|
/* the subdirectory to hold all DAV-related information for a directory */
|
|
#define DAV_FS_STATE_DIR ".DAV"
|
|
#define DAV_FS_STATE_FILE_FOR_DIR ".state_for_dir"
|
|
#define DAV_FS_LOCK_NULL_FILE ".locknull"
|
|
#define DAV_FS_TMP_PREFIX ".davfs.tmp" /* prefix for tmp files */
|
|
|
|
#define DAV_FS_QUOTA_UNSET 0
|
|
#define DAV_FS_QUOTA_OFF -1
|
|
#define DAV_FS_QUOTA_NONE -2
|
|
|
|
#define DAV_FS_BYTES_ERROR -1
|
|
|
|
/* ensure that our state subdirectory is present */
|
|
void dav_fs_ensure_state_dir(apr_pool_t *p, const char *dirname);
|
|
|
|
/* return the storage pool associated with a resource */
|
|
apr_pool_t *dav_fs_pool(const dav_resource *resource);
|
|
|
|
/* return the full pathname for a resource */
|
|
const char *dav_fs_pathname(const dav_resource *resource);
|
|
|
|
/* same as dav_fs_pathname() with directories' trailing slash */
|
|
const char *dav_fs_fname(const dav_resource *resource);
|
|
|
|
/* return the size for a resource, -1 if unknown */
|
|
apr_off_t dav_fs_size(const dav_resource *resource);
|
|
|
|
|
|
/* return the directory and filename for a resource */
|
|
dav_error * dav_fs_dir_file_name(const dav_resource *resource,
|
|
const char **dirpath,
|
|
const char **fname);
|
|
|
|
/* return the list of locknull members in this resource's directory */
|
|
dav_error * dav_fs_get_locknull_members(const dav_resource *resource,
|
|
dav_buffer *pbuf);
|
|
|
|
|
|
/* DBM functions used by the repository and locking providers */
|
|
extern const dav_hooks_db dav_hooks_db_dbm;
|
|
|
|
dav_error * dav_dbm_open_direct(apr_pool_t *p, const char *pathname,
|
|
const char *dbmtype, int ro, dav_db **pdb);
|
|
void dav_dbm_get_statefiles(apr_pool_t *p, const char *fname,
|
|
const char **state1, const char **state2);
|
|
dav_error * dav_dbm_delete(dav_db *db, apr_datum_t key);
|
|
dav_error * dav_dbm_store(dav_db *db, apr_datum_t key, apr_datum_t value);
|
|
dav_error * dav_dbm_fetch(dav_db *db, apr_datum_t key, apr_datum_t *pvalue);
|
|
void dav_dbm_freedatum(dav_db *db, apr_datum_t data);
|
|
int dav_dbm_exists(dav_db *db, apr_datum_t key);
|
|
void dav_dbm_close(dav_db *db);
|
|
|
|
/* Per-server configuration. */
|
|
typedef struct {
|
|
const char *lockdb_path;
|
|
const char *lockdb_type;
|
|
apr_global_mutex_t *lockdb_mutex;
|
|
} dav_fs_server_conf;
|
|
|
|
/* Returns server configuration for the request. */
|
|
const dav_fs_server_conf *dav_fs_get_server_conf(const request_rec *r);
|
|
|
|
dav_error *dav_fs_get_quota(const request_rec *r, const char *path,
|
|
apr_off_t *quota_bytes);
|
|
apr_off_t dav_fs_get_used_bytes(request_rec *r, const char *path);
|
|
apr_off_t dav_fs_get_available_bytes(request_rec *r,
|
|
const char *path, int *fs_low);
|
|
|
|
const dav_hooks_locks *dav_fs_get_lock_hooks(request_rec *r);
|
|
const dav_hooks_propdb *dav_fs_get_propdb_hooks(request_rec *r);
|
|
|
|
void dav_fs_gather_propsets(apr_array_header_t *uris);
|
|
int dav_fs_find_liveprop(const dav_resource *resource,
|
|
const char *ns_uri, const char *name,
|
|
const dav_hooks_liveprop **hooks);
|
|
void dav_fs_insert_all_liveprops(request_rec *r, const dav_resource *resource,
|
|
dav_prop_insert what, apr_text_header *phdr);
|
|
int dav_fs_quota_precondition(request_rec *r,
|
|
dav_resource *src, const dav_resource *dst,
|
|
const apr_xml_doc *doc, dav_error **err);
|
|
int dav_fs_method_precondition(request_rec *r,
|
|
dav_resource *src, const dav_resource *dst,
|
|
const apr_xml_doc *doc, dav_error **err);
|
|
|
|
void dav_fs_register(apr_pool_t *p);
|
|
|
|
#endif /* _DAV_FS_REPOS_H_ */
|
|
/** @} */
|
|
|