]> arthur.barton.de Git - netatalk.git/blob - etc/cnid_dbd/dbd_delete.c
Fixes a serious error in the way recovery was run on db_env opening.
[netatalk.git] / etc / cnid_dbd / dbd_delete.c
1 /*
2  * $Id: dbd_delete.c,v 1.4 2009-05-06 11:54:24 franklahm Exp $
3  *
4  * Copyright (C) Joerg Lenneis 2003
5  * All Rights Reserved.  See COPYING.
6  */
7
8 #ifdef HAVE_CONFIG_H
9 #include "config.h"
10 #endif /* HAVE_CONFIG_H */
11
12 #include <string.h>
13 #include <errno.h>
14 #include <netatalk/endian.h>
15 #include <atalk/logger.h>
16 #include <atalk/cnid_dbd_private.h>
17
18 #include "dbif.h"
19 #include "dbd.h"
20 #include "pack.h"
21
22 int dbd_delete(DBD *dbd, struct cnid_dbd_rqst *rqst, struct cnid_dbd_rply *rply)
23 {
24     DBT key;
25     int rc;
26
27     memset(&key, 0, sizeof(key));
28
29     rply->namelen = 0;
30
31     key.data = (void *) &rqst->cnid;
32     key.size = sizeof(rqst->cnid);
33
34     if ((rc = dbif_del(dbd, DBIF_CNID, &key, 0)) < 0) {
35         LOG(log_error, logtype_cnid, "dbd_delete: Unable to delete entry for CNID %u", ntohl(rqst->cnid));
36         rply->result = CNID_DBD_RES_ERR_DB;
37         return -1;
38     }
39
40     if (rc) {
41         LOG(log_debug, logtype_cnid, "cnid_delete: CNID %u deleted", ntohl(rqst->cnid));
42         rply->result = CNID_DBD_RES_OK;
43     } else {
44         LOG(log_debug, logtype_cnid, "cnid_delete: CNID %u not in database", ntohl(rqst->cnid));
45         rply->result = CNID_DBD_RES_NOTFOUND;
46     }
47     return 1;
48 }