2 * Helper functions related to the LSA server
4 * This program is free software; you can redistribute it and/or modify
5 * it under the terms of the GNU General Public License as published by
6 * the Free Software Foundation; either version 3 of the License, or
7 * (at your option) any later version.
9 * This program is distributed in the hope that it will be useful,
10 * but WITHOUT ANY WARRANTY; without even the implied warranty of
11 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12 * GNU General Public License for more details.
14 * You should have received a copy of the GNU General Public License
15 * along with this program; if not, see <http://www.gnu.org/licenses/>.
18 /***************************************************************************
19 init_lsa_ref_domain_list - adds a domain if it's not already in, returns index.
20 ***************************************************************************/
23 #include "libcli/security/dom_sid.h"
24 #include "librpc/gen_ndr/lsa.h"
27 int init_lsa_ref_domain_list(TALLOC_CTX
*mem_ctx
,
28 struct lsa_RefDomainList
*ref
,
30 struct dom_sid
*dom_sid
)
34 if (dom_name
!= NULL
) {
35 for (num
= 0; num
< ref
->count
; num
++) {
36 if (dom_sid_equal(dom_sid
, ref
->domains
[num
].sid
)) {
44 if (num
>= LSA_REF_DOMAIN_LIST_MULTIPLIER
) {
45 /* index not found, already at maximum domain limit */
50 ref
->max_size
= LSA_REF_DOMAIN_LIST_MULTIPLIER
;
52 ref
->domains
= talloc_realloc(mem_ctx
, ref
->domains
,
53 struct lsa_DomainInfo
, ref
->count
);
58 ZERO_STRUCT(ref
->domains
[num
]);
60 ref
->domains
[num
].name
.string
= talloc_strdup(mem_ctx
, dom_name
);
61 if (!ref
->domains
[num
].name
.string
) {
65 ref
->domains
[num
].sid
= dom_sid_dup(mem_ctx
, dom_sid
);
66 if (!ref
->domains
[num
].sid
) {