auth/credentials: don't ignore "client use kerberos" and --use-kerberos for machine...
[Samba.git] / source3 / lib / lsa.c
blob1c24a42d8ef0ac9549b15aaa46342664b3c832a6
1 /*
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 ***************************************************************************/
22 #include "replace.h"
23 #include "lib/util/data_blob.h"
24 #include "lib/util/time.h"
25 #include "libcli/security/dom_sid.h"
26 #include "librpc/gen_ndr/lsa.h"
27 #include "lsa.h"
29 int init_lsa_ref_domain_list(TALLOC_CTX *mem_ctx,
30 struct lsa_RefDomainList *ref,
31 const char *dom_name,
32 struct dom_sid *dom_sid)
34 int num = 0;
36 if (dom_name != NULL) {
37 for (num = 0; num < ref->count; num++) {
38 if (dom_sid_equal(dom_sid, ref->domains[num].sid)) {
39 return num;
42 } else {
43 num = ref->count;
46 if (num >= LSA_REF_DOMAIN_LIST_MULTIPLIER) {
47 /* index not found, already at maximum domain limit */
48 return -1;
51 ref->count = num + 1;
52 ref->max_size = LSA_REF_DOMAIN_LIST_MULTIPLIER;
54 ref->domains = talloc_realloc(mem_ctx, ref->domains,
55 struct lsa_DomainInfo, ref->count);
56 if (!ref->domains) {
57 return -1;
60 ZERO_STRUCT(ref->domains[num]);
62 ref->domains[num].name.string = talloc_strdup(mem_ctx, dom_name);
63 if (!ref->domains[num].name.string) {
64 return -1;
67 ref->domains[num].sid = dom_sid_dup(mem_ctx, dom_sid);
68 if (!ref->domains[num].sid) {
69 return -1;
72 return num;