/*
- * $Id: cnid.c,v 1.2 2005-04-28 20:49:57 bfernhomberg Exp $
+ * $Id: cnid.c,v 1.8 2009-11-24 11:40:11 didg Exp $
*
* Copyright (c) 2003 the Netatalk Team
* Copyright (c) 2003 Rafal Lewczuk <rlewczuk@pronet.pl>
static sigset_t sigblockset;
static const struct itimerval none = {{0, 0}, {0, 0}};
-static struct itimerval savetimer;
/* Registers new CNID backend module. */
struct _cnid_db *db;
cnid_module *mod = NULL;
struct list_head *ptr;
- uid_t uid; /* uninitialized, OK 310105 */
- gid_t gid;
+ uid_t uid = -1;
+ gid_t gid = -1;
list_for_each(ptr, &modules) {
if (0 == strcmp(list_entry(ptr, cnid_module, db_list)->name, type)) {
return NULL;
}
/* FIXME should module know about it ? */
- if (flags) {
+ if ((flags & CNID_FLAG_NODEV)) {
db->flags |= CNID_FLAG_NODEV;
}
db->flags |= mod->flags;
sigaddset(&sigblockset, SIGTERM);
sigaddset(&sigblockset, SIGHUP);
sigaddset(&sigblockset, SIGUSR1);
+ sigaddset(&sigblockset, SIGUSR2);
sigaddset(&sigblockset, SIGALRM);
}
{
if ((flags & CNID_FLAG_BLOCK)) {
sigprocmask(SIG_BLOCK, &sigblockset, NULL);
- setitimer(ITIMER_REAL, &none, &savetimer);
}
}
static void unblock_signal(u_int32_t flags)
{
if ((flags & CNID_FLAG_BLOCK)) {
- setitimer(ITIMER_REAL, &savetimer, NULL);
sigprocmask(SIG_UNBLOCK, &sigblockset, NULL);
}
}
/* --------------- */
cnid_t cnid_add(struct _cnid_db *cdb, const struct stat *st, const cnid_t did,
- char *name, const int len, cnid_t hint)
+ char *name, const size_t len, cnid_t hint)
{
cnid_t ret;
/* --------------- */
-cnid_t cnid_get(struct _cnid_db *cdb, const cnid_t did, char *name,const int len)
+cnid_t cnid_get(struct _cnid_db *cdb, const cnid_t did, char *name,const size_t len)
{
cnid_t ret;
}
/* --------------- */
-int cnid_getstamp(struct _cnid_db *cdb, void *buffer, const int len)
+int cnid_getstamp(struct _cnid_db *cdb, void *buffer, const size_t len)
{
cnid_t ret;
time_t t;
/* --------------- */
cnid_t cnid_lookup(struct _cnid_db *cdb, const struct stat *st, const cnid_t did,
- char *name, const int len)
+ char *name, const size_t len)
{
cnid_t ret;
}
/* --------------- */
-char *cnid_resolve(struct _cnid_db *cdb, cnid_t *id, void *buffer, u_int32_t len)
+char *cnid_resolve(struct _cnid_db *cdb, cnid_t *id, void *buffer, size_t len)
{
char *ret;
block_signal(cdb->flags);
ret = cdb->cnid_resolve(cdb, id, buffer, len);
unblock_signal(cdb->flags);
+ if (ret && !strcmp(ret, "..")) {
+ LOG(log_error, logtype_afpd, "cnid_resolve: name is '..', corrupted db? ");
+ ret = NULL;
+ }
return ret;
}
/* --------------- */
int cnid_update (struct _cnid_db *cdb, const cnid_t id, const struct stat *st,
- const cnid_t did, char *name, const int len)
+ const cnid_t did, char *name, const size_t len)
{
int ret;
/* --------------- */
cnid_t cnid_rebuild_add(struct _cnid_db *cdb, const struct stat *st, const cnid_t did,
- const char *name, const int len, cnid_t hint)
+ char *name, const size_t len, cnid_t hint)
{
cnid_t ret;