4 * Copyright (C) Gerald Carter <jerry@samba.org>
6 * This program is free software; you can redistribute it and/or modify
7 * it under the terms of the GNU General Public License as published by
8 * the Free Software Foundation; either version 3 of the License, or
9 * (at your option) any later version.
11 * This program is distributed in the hope that it will be useful,
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 * GNU General Public License for more details.
16 * You should have received a copy of the GNU General Public License
17 * along with this program; if not, see <http://www.gnu.org/licenses/>.
22 #include "system/filesys.h"
23 #include "winbindd/winbindd.h"
25 #include "idmap_hash.h"
28 XFILE
*lw_map_file
= NULL
;
30 /*********************************************************************
31 ********************************************************************/
33 static bool mapfile_open(void)
35 const char *mapfile_name
= NULL
;
37 /* If we have an open handle, just reset it */
40 return (x_tseek(lw_map_file
, 0, SEEK_SET
) == 0);
43 mapfile_name
= lp_parm_const_string(-1, "idmap_hash", "name_map", NULL
);
48 lw_map_file
= x_fopen(mapfile_name
, O_RDONLY
, 0);
50 DEBUG(0,("can't open idmap_hash:name_map (%s). Error %s\n",
51 mapfile_name
, strerror(errno
) ));
58 /*********************************************************************
59 ********************************************************************/
61 static bool mapfile_read_line(fstring key
, fstring value
)
70 if ((p
= x_fgets(buffer
, sizeof(buffer
)-1, lw_map_file
)) == NULL
) {
74 /* Strip newlines and carriage returns */
76 len
= strlen_m(buffer
) - 1;
77 while ((buffer
[len
] == '\n') || (buffer
[len
] == '\r')) {
82 if ((p
= strchr_m(buffer
, '=')) == NULL
) {
83 DEBUG(0,("idmap_hash: Bad line in name_map (%s)\n", buffer
));
90 strlcpy(key
, buffer
, sizeof(fstring
));
91 strlcpy(value
, p
, sizeof(fstring
));
95 if (!trim_char(key
, ' ', ' '))
98 if (!trim_char(value
, ' ', ' '))
104 /*********************************************************************
105 ********************************************************************/
107 static bool mapfile_close(void)
111 ret
= x_fclose(lw_map_file
);
119 /*********************************************************************
120 ********************************************************************/
122 NTSTATUS
mapfile_lookup_key(TALLOC_CTX
*ctx
, const char *value
, char **key
)
124 fstring r_key
, r_value
;
125 NTSTATUS ret
= NT_STATUS_NOT_FOUND
;
128 return NT_STATUS_OBJECT_PATH_NOT_FOUND
;
130 while (mapfile_read_line(r_key
, r_value
))
132 if (strequal(r_value
, value
)) {
135 /* We're done once finishing this block */
136 *key
= talloc_strdup(ctx
, r_key
);
138 ret
= NT_STATUS_NO_MEMORY
;
149 /*********************************************************************
150 ********************************************************************/
152 NTSTATUS
mapfile_lookup_value(TALLOC_CTX
*ctx
, const char *key
, char **value
)
154 fstring r_key
, r_value
;
155 NTSTATUS ret
= NT_STATUS_NOT_FOUND
;
158 return NT_STATUS_OBJECT_PATH_NOT_FOUND
;
160 while (mapfile_read_line(r_key
, r_value
))
162 if (strequal(r_key
, key
)) {
165 /* We're done once finishing this block */
166 *value
= talloc_strdup(ctx
, r_value
);
168 ret
= NT_STATUS_NO_MEMORY
;