Deleted Added
full compact
yp_dbwrite.c (15420) yp_dbwrite.c (16132)
1/*
2 * Copyright (c) 1995
3 * Bill Paul <wpaul@ctr.columbia.edu>. All rights reserved.
4 *
5 * Redistribution and use in source and binary forms, with or without
6 * modification, are permitted provided that the following conditions
7 * are met:
8 * 1. Redistributions of source code must retain the above copyright

--- 15 unchanged lines hidden (view full) ---

24 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
25 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
26 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
27 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
28 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
29 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
30 * SUCH DAMAGE.
31 *
1/*
2 * Copyright (c) 1995
3 * Bill Paul <wpaul@ctr.columbia.edu>. All rights reserved.
4 *
5 * Redistribution and use in source and binary forms, with or without
6 * modification, are permitted provided that the following conditions
7 * are met:
8 * 1. Redistributions of source code must retain the above copyright

--- 15 unchanged lines hidden (view full) ---

24 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
25 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
26 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
27 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
28 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
29 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
30 * SUCH DAMAGE.
31 *
32 * $Id: yp_dbwrite.c,v 1.9 1996/02/04 04:08:11 wpaul Exp wpaul $
32 * $Id: yp_dbwrite.c,v 1.10 1996/06/03 03:11:25 wpaul Exp $
33 *
34 */
35#include <stdio.h>
36#include <stdlib.h>
37#include <fcntl.h>
38#include <string.h>
39#include <limits.h>
40#include <unistd.h>
41#include <db.h>
42#include <sys/stat.h>
43#include <errno.h>
44#include <paths.h>
45#include <rpcsvc/yp.h>
46#include "ypxfr_extern.h"
47
48#ifndef lint
33 *
34 */
35#include <stdio.h>
36#include <stdlib.h>
37#include <fcntl.h>
38#include <string.h>
39#include <limits.h>
40#include <unistd.h>
41#include <db.h>
42#include <sys/stat.h>
43#include <errno.h>
44#include <paths.h>
45#include <rpcsvc/yp.h>
46#include "ypxfr_extern.h"
47
48#ifndef lint
49static const char rcsid[] = "$Id: yp_dbwrite.c,v 1.9 1996/02/04 04:08:11 wpaul Exp wpaul $";
49static const char rcsid[] = "$Id: yp_dbwrite.c,v 1.10 1996/06/03 03:11:25 wpaul Exp $";
50#endif
51
52#define PERM_SECURE (S_IRUSR|S_IWUSR)
53
54/*
55 * Open a DB database read/write
56 */
50#endif
51
52#define PERM_SECURE (S_IRUSR|S_IWUSR)
53
54/*
55 * Open a DB database read/write
56 */
57DB *yp_open_db_rw(domain, map)
57DB *yp_open_db_rw(domain, map, flags)
58 const char *domain;
59 const char *map;
58 const char *domain;
59 const char *map;
60 const int flags;
60{
61 DB *dbp;
62 char buf[1025];
63
64
65 yp_errno = YP_TRUE;
66
67 if (map[0] == '.' || strchr(map, '/')) {
68 yp_errno = YP_BADARGS;
69 return (NULL);
70 }
71
61{
62 DB *dbp;
63 char buf[1025];
64
65
66 yp_errno = YP_TRUE;
67
68 if (map[0] == '.' || strchr(map, '/')) {
69 yp_errno = YP_BADARGS;
70 return (NULL);
71 }
72
73#define FLAGS O_RDWR|O_EXLOCK|O_EXCL|O_CREAT
74
72 snprintf(buf, sizeof(buf), "%s/%s/%s", yp_dir, domain, map);
75 snprintf(buf, sizeof(buf), "%s/%s/%s", yp_dir, domain, map);
76 dbp = dbopen(buf,flags ? flags : FLAGS,PERM_SECURE,DB_HASH,&openinfo);
73
77
74 dbp = dbopen(buf,O_RDWR|O_EXLOCK|O_EXCL|O_CREAT, PERM_SECURE, DB_HASH, &openinfo);
75
76 if (dbp == NULL) {
77 switch(errno) {
78 case ENOENT:
79 yp_errno = YP_NOMAP;
80 break;
81 case EFTYPE:
82 yp_errno = YP_BADDB;
83 break;
84 default:
85 yp_errno = YP_YPERR;
86 break;
87 }
88 }
89
90 return (dbp);
91}
92
78 if (dbp == NULL) {
79 switch(errno) {
80 case ENOENT:
81 yp_errno = YP_NOMAP;
82 break;
83 case EFTYPE:
84 yp_errno = YP_BADDB;
85 break;
86 default:
87 yp_errno = YP_YPERR;
88 break;
89 }
90 }
91
92 return (dbp);
93}
94
93int yp_put_record(dbp,key,data)
95int yp_put_record(dbp,key,data,allow_overwrite)
94 DB *dbp;
95 DBT *key;
96 DBT *data;
96 DB *dbp;
97 DBT *key;
98 DBT *data;
99 int allow_overwrite;
97{
98 int rval;
99
100{
101 int rval;
102
100 if ((rval = (dbp->put)(dbp,key,data,R_NOOVERWRITE))) {
103 if ((rval = (dbp->put)(dbp,key,data, allow_overwrite ? 0 :
104 R_NOOVERWRITE))) {
101 switch(rval) {
102 case 1:
103 return(YP_FALSE);
104 break;
105 case -1:
106 default:
107 (void)(dbp->close)(dbp);
108 return(YP_BADDB);
109 break;
110 }
111 }
112
113 return(YP_TRUE);
114}
105 switch(rval) {
106 case 1:
107 return(YP_FALSE);
108 break;
109 case -1:
110 default:
111 (void)(dbp->close)(dbp);
112 return(YP_BADDB);
113 break;
114 }
115 }
116
117 return(YP_TRUE);
118}