winbindd: Use dom_sid_str_buf
[nivanova/samba-autobuild/.git] / source3 / winbindd / idmap_rw.c
1 /*
2  * Unix SMB/CIFS implementation.
3  *
4  * ID mapping: abstract r/w new-mapping mechanism
5  *
6  * Copyright (C) Michael Adam 2010
7  *
8  * This program is free software; you can redistribute it and/or modify
9  * it under the terms of the GNU General Public License as published by
10  * the Free Software Foundation; either version 3 of the License, or
11  * (at your option) any later version.
12  *
13  * This program is distributed in the hope that it will be useful,
14  * but WITHOUT ANY WARRANTY; without even the implied warranty of
15  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
16  * GNU General Public License for more details.
17  *
18  * You should have received a copy of the GNU General Public License
19  * along with this program.  If not, see <http://www.gnu.org/licenses/>.
20  */
21
22 #include "includes.h"
23 #include "winbindd.h"
24 #include "idmap.h"
25 #include "idmap_rw.h"
26 #include "libcli/security/dom_sid.h"
27
28 #undef DBGC_CLASS
29 #define DBGC_CLASS DBGC_IDMAP
30
31 NTSTATUS idmap_rw_new_mapping(struct idmap_domain *dom,
32                               struct idmap_rw_ops *ops,
33                               struct id_map *map)
34 {
35         struct dom_sid_buf buf;
36         NTSTATUS status;
37
38         if (map == NULL) {
39                 return NT_STATUS_INVALID_PARAMETER;
40         }
41
42         if ((map->xid.type != ID_TYPE_UID) && (map->xid.type != ID_TYPE_GID)) {
43                 return NT_STATUS_INVALID_PARAMETER;
44         }
45
46         if (map->sid == NULL) {
47                 return NT_STATUS_INVALID_PARAMETER;
48         }
49
50         status = ops->get_new_id(dom, &map->xid);
51
52         if (!NT_STATUS_IS_OK(status)) {
53                 DEBUG(3, ("Could not allocate id: %s\n", nt_errstr(status)));
54                 return status;
55         }
56
57         DEBUG(10, ("Setting mapping: %s <-> %s %lu\n",
58                    dom_sid_str_buf(map->sid, &buf),
59                    (map->xid.type == ID_TYPE_UID) ? "UID" : "GID",
60                    (unsigned long)map->xid.id));
61
62         map->status = ID_MAPPED;
63         status = ops->set_mapping(dom, map);
64
65         if (NT_STATUS_EQUAL(status, NT_STATUS_OBJECT_NAME_COLLISION)) {
66                 struct id_map *ids[2];
67                 DEBUG(5, ("Mapping for %s exists - retrying to map sid\n",
68                           dom_sid_str_buf(map->sid, &buf)));
69                 ids[0] = map;
70                 ids[1] = NULL;
71                 status = dom->methods->sids_to_unixids(dom, ids);
72         }
73
74         if (!NT_STATUS_IS_OK(status)) {
75                 DEBUG(3, ("Could not store the new mapping: %s\n",
76                           nt_errstr(status)));
77                 return status;
78         }
79
80         return NT_STATUS_OK;
81 }