2 Unix SMB/CIFS implementation.
3 Password and authentication handling
4 Copyright (C) Andrew Bartlett 2002
5 Copyright (C) Jelmer Vernooij 2002
7 This program is free software; you can redistribute it and/or modify
8 it under the terms of the GNU General Public License as published by
9 the Free Software Foundation; either version 2 of the License, or
10 (at your option) any later version.
12 This program is distributed in the hope that it will be useful,
13 but WITHOUT ANY WARRANTY; without even the implied warranty of
14 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15 GNU General Public License for more details.
17 You should have received a copy of the GNU General Public License
18 along with this program; if not, write to the Free Software
19 Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
25 #define DBGC_CLASS DBGC_PASSDB
27 static struct pdb_init_function_entry *backends = NULL;
29 static void lazy_initialize_passdb(void)
31 static BOOL initialized = False;
32 if(initialized)return;
37 static struct pdb_init_function_entry *pdb_find_backend_entry(const char *name);
39 NTSTATUS smb_register_passdb(int version, const char *name, pdb_init_function init)
41 struct pdb_init_function_entry *entry = backends;
43 if(version != PASSDB_INTERFACE_VERSION) {
44 DEBUG(0,("Can't register passdb backend!\n"
45 "You tried to register a passdb module with PASSDB_INTERFACE_VERSION %d, "
46 "while this version of samba uses version %d\n",
47 version,PASSDB_INTERFACE_VERSION));
48 return NT_STATUS_OBJECT_TYPE_MISMATCH;
52 return NT_STATUS_INVALID_PARAMETER;
55 DEBUG(5,("Attempting to register passdb backend %s\n", name));
57 /* Check for duplicates */
58 if (pdb_find_backend_entry(name)) {
59 DEBUG(0,("There already is a passdb backend registered with the name %s!\n", name));
60 return NT_STATUS_OBJECT_NAME_COLLISION;
63 entry = smb_xmalloc(sizeof(struct pdb_init_function_entry));
64 entry->name = smb_xstrdup(name);
67 DLIST_ADD(backends, entry);
68 DEBUG(5,("Successfully added passdb backend '%s'\n", name));
72 static struct pdb_init_function_entry *pdb_find_backend_entry(const char *name)
74 struct pdb_init_function_entry *entry = backends;
77 if (strcmp(entry->name, name)==0) return entry;
84 static NTSTATUS context_setsampwent(struct pdb_context *context, BOOL update)
86 NTSTATUS ret = NT_STATUS_UNSUCCESSFUL;
89 DEBUG(0, ("invalid pdb_context specified!\n"));
93 context->pwent_methods = context->pdb_methods;
95 if (!context->pwent_methods) {
96 /* No passdbs at all */
100 while (NT_STATUS_IS_ERR(ret = context->pwent_methods->setsampwent(context->pwent_methods, update))) {
101 context->pwent_methods = context->pwent_methods->next;
102 if (context->pwent_methods == NULL)
103 return NT_STATUS_UNSUCCESSFUL;
108 static void context_endsampwent(struct pdb_context *context)
111 DEBUG(0, ("invalid pdb_context specified!\n"));
115 if (context->pwent_methods && context->pwent_methods->endsampwent)
116 context->pwent_methods->endsampwent(context->pwent_methods);
118 /* So we won't get strange data when calling getsampwent now */
119 context->pwent_methods = NULL;
122 static NTSTATUS context_getsampwent(struct pdb_context *context, SAM_ACCOUNT *user)
124 NTSTATUS ret = NT_STATUS_UNSUCCESSFUL;
126 if ((!context) || (!context->pwent_methods)) {
127 DEBUG(0, ("invalid pdb_context specified!\n"));
130 /* Loop until we find something useful */
131 while (NT_STATUS_IS_ERR(ret = context->pwent_methods->getsampwent(context->pwent_methods, user))) {
133 context->pwent_methods->endsampwent(context->pwent_methods);
135 context->pwent_methods = context->pwent_methods->next;
137 /* All methods are checked now. There are no more entries */
138 if (context->pwent_methods == NULL)
141 context->pwent_methods->setsampwent(context->pwent_methods, False);
143 user->methods = context->pwent_methods;
147 static NTSTATUS context_getsampwnam(struct pdb_context *context, SAM_ACCOUNT *sam_acct, const char *username)
149 NTSTATUS ret = NT_STATUS_UNSUCCESSFUL;
151 struct pdb_methods *curmethods;
153 DEBUG(0, ("invalid pdb_context specified!\n"));
156 curmethods = context->pdb_methods;
158 if (NT_STATUS_IS_OK(ret = curmethods->getsampwnam(curmethods, sam_acct, username))) {
159 sam_acct->methods = curmethods;
162 curmethods = curmethods->next;
168 static NTSTATUS context_getsampwsid(struct pdb_context *context, SAM_ACCOUNT *sam_acct, const DOM_SID *sid)
170 NTSTATUS ret = NT_STATUS_UNSUCCESSFUL;
172 struct pdb_methods *curmethods;
174 DEBUG(0, ("invalid pdb_context specified!\n"));
178 curmethods = context->pdb_methods;
181 if (NT_STATUS_IS_OK(ret = curmethods->getsampwsid(curmethods, sam_acct, sid))) {
182 sam_acct->methods = curmethods;
185 curmethods = curmethods->next;
191 static NTSTATUS context_add_sam_account(struct pdb_context *context, SAM_ACCOUNT *sam_acct)
193 NTSTATUS ret = NT_STATUS_UNSUCCESSFUL;
195 if ((!context) || (!context->pdb_methods)) {
196 DEBUG(0, ("invalid pdb_context specified!\n"));
200 /** @todo This is where a 're-read on add' should be done */
201 /* We now add a new account to the first database listed.
204 return context->pdb_methods->add_sam_account(context->pdb_methods, sam_acct);
207 static NTSTATUS context_update_sam_account(struct pdb_context *context, SAM_ACCOUNT *sam_acct)
209 NTSTATUS ret = NT_STATUS_UNSUCCESSFUL;
212 DEBUG(0, ("invalid pdb_context specified!\n"));
216 if (!sam_acct || !sam_acct->methods){
217 DEBUG(0, ("invalid sam_acct specified\n"));
221 /** @todo This is where a 're-read on update' should be done */
223 return sam_acct->methods->update_sam_account(sam_acct->methods, sam_acct);
226 static NTSTATUS context_delete_sam_account(struct pdb_context *context, SAM_ACCOUNT *sam_acct)
228 NTSTATUS ret = NT_STATUS_UNSUCCESSFUL;
230 struct pdb_methods *pdb_selected;
232 DEBUG(0, ("invalid pdb_context specified!\n"));
236 if (!sam_acct->methods){
237 pdb_selected = context->pdb_methods;
238 /* There's no passdb backend specified for this account.
239 * Try to delete it in every passdb available
240 * Needed to delete accounts in smbpasswd that are not
243 while (pdb_selected){
244 if (NT_STATUS_IS_OK(ret = pdb_selected->delete_sam_account(pdb_selected, sam_acct))) {
247 pdb_selected = pdb_selected->next;
252 if (!sam_acct->methods->delete_sam_account){
253 DEBUG(0,("invalid sam_acct->methods->delete_sam_account\n"));
257 return sam_acct->methods->delete_sam_account(sam_acct->methods, sam_acct);
260 static NTSTATUS context_getgrsid(struct pdb_context *context,
261 GROUP_MAP *map, DOM_SID sid)
263 NTSTATUS ret = NT_STATUS_UNSUCCESSFUL;
265 struct pdb_methods *curmethods;
267 DEBUG(0, ("invalid pdb_context specified!\n"));
270 curmethods = context->pdb_methods;
272 ret = curmethods->getgrsid(curmethods, map, sid);
273 if (NT_STATUS_IS_OK(ret)) {
274 map->methods = curmethods;
277 curmethods = curmethods->next;
283 static NTSTATUS context_getgrgid(struct pdb_context *context,
284 GROUP_MAP *map, gid_t gid)
286 NTSTATUS ret = NT_STATUS_UNSUCCESSFUL;
288 struct pdb_methods *curmethods;
290 DEBUG(0, ("invalid pdb_context specified!\n"));
293 curmethods = context->pdb_methods;
295 ret = curmethods->getgrgid(curmethods, map, gid);
296 if (NT_STATUS_IS_OK(ret)) {
297 map->methods = curmethods;
300 curmethods = curmethods->next;
306 static NTSTATUS context_getgrnam(struct pdb_context *context,
307 GROUP_MAP *map, const char *name)
309 NTSTATUS ret = NT_STATUS_UNSUCCESSFUL;
311 struct pdb_methods *curmethods;
313 DEBUG(0, ("invalid pdb_context specified!\n"));
316 curmethods = context->pdb_methods;
318 ret = curmethods->getgrnam(curmethods, map, name);
319 if (NT_STATUS_IS_OK(ret)) {
320 map->methods = curmethods;
323 curmethods = curmethods->next;
329 static NTSTATUS context_add_group_mapping_entry(struct pdb_context *context,
332 NTSTATUS ret = NT_STATUS_UNSUCCESSFUL;
334 if ((!context) || (!context->pdb_methods)) {
335 DEBUG(0, ("invalid pdb_context specified!\n"));
339 return context->pdb_methods->add_group_mapping_entry(context->pdb_methods,
343 static NTSTATUS context_update_group_mapping_entry(struct pdb_context *context,
346 NTSTATUS ret = NT_STATUS_UNSUCCESSFUL;
348 if ((!context) || (!context->pdb_methods)) {
349 DEBUG(0, ("invalid pdb_context specified!\n"));
354 pdb_methods->update_group_mapping_entry(context->pdb_methods, map);
357 static NTSTATUS context_delete_group_mapping_entry(struct pdb_context *context,
360 NTSTATUS ret = NT_STATUS_UNSUCCESSFUL;
362 if ((!context) || (!context->pdb_methods)) {
363 DEBUG(0, ("invalid pdb_context specified!\n"));
368 pdb_methods->delete_group_mapping_entry(context->pdb_methods, sid);
371 static NTSTATUS context_enum_group_mapping(struct pdb_context *context,
372 enum SID_NAME_USE sid_name_use,
373 GROUP_MAP **rmap, int *num_entries,
376 NTSTATUS ret = NT_STATUS_UNSUCCESSFUL;
378 if ((!context) || (!context->pdb_methods)) {
379 DEBUG(0, ("invalid pdb_context specified!\n"));
383 return context->pdb_methods->enum_group_mapping(context->pdb_methods,
385 num_entries, unix_only);
388 static NTSTATUS context_gettrustpwent(struct pdb_context *context,
389 SAM_TRUST_PASSWD *trust)
391 NTSTATUS ret = NT_STATUS_UNSUCCESSFUL;
392 struct pdb_methods *cur_methods;
395 DEBUG(0, ("invalid pdb_context specified!\n"));
399 cur_methods = context->pdb_methods;
401 while (cur_methods) {
402 ret = cur_methods->gettrustpwent(cur_methods, trust);
403 if (NT_STATUS_IS_OK(ret)) {
404 trust->methods = cur_methods;
407 cur_methods = cur_methods->next;
413 static NTSTATUS context_gettrustpwsid(struct pdb_context *context,
414 SAM_TRUST_PASSWD *trust,
417 NTSTATUS ret = NT_STATUS_UNSUCCESSFUL;
418 struct pdb_methods *cur_methods;
421 DEBUG(0, ("invalid pdb_context specified!\n"));
425 cur_methods = context->pdb_methods;
427 while (cur_methods) {
428 ret = cur_methods->gettrustpwsid(cur_methods, trust, sid);
429 if (NT_STATUS_IS_OK(ret)) {
430 trust->methods = cur_methods;
433 cur_methods = cur_methods->next;
439 static NTSTATUS context_add_trust_passwd(struct pdb_context *context,
440 SAM_TRUST_PASSWD *trust)
442 NTSTATUS ret = NT_STATUS_UNSUCCESSFUL;
443 struct pdb_methods *methods;
446 DEBUG(0, ("invalid pdb_context specified!\n"));
450 return context->pdb_methods->add_trust_passwd(context->pdb_methods, trust);
453 static NTSTATUS context_update_trust_passwd(struct pdb_context *context,
454 SAM_TRUST_PASSWD *trust)
456 NTSTATUS ret = NT_STATUS_UNSUCCESSFUL;
457 struct pdb_methods *methods;
460 DEBUG(0, ("invalid pdb_context specified!\n"));
464 if (!trust || !trust->methods) {
465 DEBUG(0, ("invalid trust pointer specified!\n"));
469 return trust->methods->update_trust_passwd(trust->methods, trust);
472 static NTSTATUS context_delete_trust_passwd(struct pdb_context *context,
473 SAM_TRUST_PASSWD *trust)
475 NTSTATUS ret = NT_STATUS_UNSUCCESSFUL;
476 struct pdb_methods *methods;
479 DEBUG(0, ("invalid pdb_context specified!\n"));
483 if (!trust || !trust->methods) {
484 DEBUG(0, ("invalid trust pointer specified!\n"));
488 return trust->methods->delete_trust_passwd(trust->methods, trust);
491 /******************************************************************
492 Free and cleanup a pdb context, any associated data and anything
493 that the attached modules might have associated.
494 *******************************************************************/
496 static void free_pdb_context(struct pdb_context **context)
498 struct pdb_methods *pdb_selected = (*context)->pdb_methods;
500 while (pdb_selected){
501 if(pdb_selected->free_private_data)
502 pdb_selected->free_private_data(&(pdb_selected->private_data));
503 pdb_selected = pdb_selected->next;
506 talloc_destroy((*context)->mem_ctx);
510 /******************************************************************
511 Make a pdb_methods from scratch
512 *******************************************************************/
514 static NTSTATUS make_pdb_methods_name(struct pdb_methods **methods, struct pdb_context *context, const char *selected)
516 char *module_name = smb_xstrdup(selected);
517 char *module_location = NULL, *p;
518 struct pdb_init_function_entry *entry;
519 NTSTATUS nt_status = NT_STATUS_UNSUCCESSFUL;
521 lazy_initialize_passdb();
523 p = strchr(module_name, ':');
527 module_location = p+1;
528 trim_char(module_location, ' ', ' ');
531 trim_char(module_name, ' ', ' ');
534 DEBUG(5,("Attempting to find an passdb backend to match %s (%s)\n", selected, module_name));
536 entry = pdb_find_backend_entry(module_name);
538 /* Try to find a module that contains this module */
540 DEBUG(2,("No builtin backend found, trying to load plugin\n"));
541 if(NT_STATUS_IS_OK(smb_probe_module("pdb", module_name)) && !(entry = pdb_find_backend_entry(module_name))) {
542 DEBUG(0,("Plugin is available, but doesn't register passdb backend %s\n", module_name));
543 SAFE_FREE(module_name);
544 return NT_STATUS_UNSUCCESSFUL;
548 /* No such backend found */
550 DEBUG(0,("No builtin nor plugin backend for %s found\n", module_name));
551 SAFE_FREE(module_name);
552 return NT_STATUS_INVALID_PARAMETER;
555 DEBUG(5,("Found pdb backend %s\n", module_name));
556 nt_status = entry->init(context, methods, module_location);
557 if (NT_STATUS_IS_OK(nt_status)) {
558 DEBUG(5,("pdb backend %s has a valid init\n", selected));
560 DEBUG(0,("pdb backend %s did not correctly init (error was %s)\n", selected, nt_errstr(nt_status)));
562 SAFE_FREE(module_name);
566 /******************************************************************
567 Make a pdb_context from scratch.
568 *******************************************************************/
570 static NTSTATUS make_pdb_context(struct pdb_context **context)
574 mem_ctx = talloc_init("pdb_context internal allocation context");
577 DEBUG(0, ("make_pdb_context: talloc init failed!\n"));
578 return NT_STATUS_NO_MEMORY;
581 *context = talloc(mem_ctx, sizeof(**context));
583 DEBUG(0, ("make_pdb_context: talloc failed!\n"));
584 return NT_STATUS_NO_MEMORY;
587 ZERO_STRUCTP(*context);
589 (*context)->mem_ctx = mem_ctx;
591 (*context)->pdb_setsampwent = context_setsampwent;
592 (*context)->pdb_endsampwent = context_endsampwent;
593 (*context)->pdb_getsampwent = context_getsampwent;
594 (*context)->pdb_getsampwnam = context_getsampwnam;
595 (*context)->pdb_getsampwsid = context_getsampwsid;
596 (*context)->pdb_add_sam_account = context_add_sam_account;
597 (*context)->pdb_update_sam_account = context_update_sam_account;
598 (*context)->pdb_delete_sam_account = context_delete_sam_account;
599 (*context)->pdb_getgrsid = context_getgrsid;
600 (*context)->pdb_getgrgid = context_getgrgid;
601 (*context)->pdb_getgrnam = context_getgrnam;
602 (*context)->pdb_add_group_mapping_entry = context_add_group_mapping_entry;
603 (*context)->pdb_update_group_mapping_entry = context_update_group_mapping_entry;
604 (*context)->pdb_delete_group_mapping_entry = context_delete_group_mapping_entry;
605 (*context)->pdb_enum_group_mapping = context_enum_group_mapping;
606 (*context)->pdb_gettrustpwent = context_gettrustpwent;
607 (*context)->pdb_gettrustpwsid = context_gettrustpwsid;
608 (*context)->pdb_add_trust_passwd = context_add_trust_passwd;
609 (*context)->pdb_update_trust_passwd = context_update_trust_passwd;
610 (*context)->pdb_delete_trust_passwd = context_delete_trust_passwd;
612 (*context)->free_fn = free_pdb_context;
618 /******************************************************************
619 Make a pdb_context, given an array of strings
620 *******************************************************************/
622 NTSTATUS make_pdb_context_list(struct pdb_context **context, const char **selected)
625 struct pdb_methods *curmethods, *tmpmethods;
626 NTSTATUS nt_status = NT_STATUS_UNSUCCESSFUL;
627 BOOL have_guest = False;
629 if (!NT_STATUS_IS_OK(nt_status = make_pdb_context(context))) {
634 DEBUG(0, ("ERROR: empty passdb backend list!\n"));
639 if (strcmp(selected[i], "guest") == 0) {
642 /* Try to initialise pdb */
643 DEBUG(5,("Trying to load: %s\n", selected[i]));
644 if (!NT_STATUS_IS_OK(nt_status = make_pdb_methods_name(&curmethods, *context, selected[i]))) {
645 DEBUG(1, ("Loading %s failed!\n", selected[i]));
646 free_pdb_context(context);
649 curmethods->parent = *context;
650 DLIST_ADD_END((*context)->pdb_methods, curmethods, tmpmethods);
657 if ( (lp_guestaccount() == NULL) ||
658 (*lp_guestaccount() == '\0') ) {
659 /* We explicitly don't want guest access. No idea what
660 else that breaks, but be it that way. */
664 if (!NT_STATUS_IS_OK(nt_status = make_pdb_methods_name(&curmethods,
667 DEBUG(1, ("Loading guest module failed!\n"));
668 free_pdb_context(context);
672 curmethods->parent = *context;
673 DLIST_ADD_END((*context)->pdb_methods, curmethods, tmpmethods);
678 /******************************************************************
679 Make a pdb_context, given a text string.
680 *******************************************************************/
682 NTSTATUS make_pdb_context_string(struct pdb_context **context, const char *selected)
685 char **newsel = str_list_make(selected, NULL);
686 ret = make_pdb_context_list(context, (const char **)newsel);
687 str_list_free(&newsel);
691 /******************************************************************
692 Return an already initialised pdb_context, to facilitate backward
693 compatibility (see functions below).
694 *******************************************************************/
696 static struct pdb_context *pdb_get_static_context(BOOL reload)
698 static struct pdb_context *pdb_context = NULL;
700 if ((pdb_context) && (reload)) {
701 pdb_context->free_fn(&pdb_context);
702 if (!NT_STATUS_IS_OK(make_pdb_context_list(&pdb_context, lp_passdb_backend()))) {
708 if (!NT_STATUS_IS_OK(make_pdb_context_list(&pdb_context, lp_passdb_backend()))) {
716 /******************************************************************
717 Backward compatibility functions for the original passdb interface
718 *******************************************************************/
720 BOOL pdb_setsampwent(BOOL update)
722 struct pdb_context *pdb_context = pdb_get_static_context(False);
728 return NT_STATUS_IS_OK(pdb_context->pdb_setsampwent(pdb_context, update));
731 void pdb_endsampwent(void)
733 struct pdb_context *pdb_context = pdb_get_static_context(False);
739 pdb_context->pdb_endsampwent(pdb_context);
742 BOOL pdb_getsampwent(SAM_ACCOUNT *user)
744 struct pdb_context *pdb_context = pdb_get_static_context(False);
750 return NT_STATUS_IS_OK(pdb_context->pdb_getsampwent(pdb_context, user));
753 BOOL pdb_getsampwnam(SAM_ACCOUNT *sam_acct, const char *username)
755 struct pdb_context *pdb_context = pdb_get_static_context(False);
761 return NT_STATUS_IS_OK(pdb_context->pdb_getsampwnam(pdb_context, sam_acct, username));
764 BOOL pdb_getsampwsid(SAM_ACCOUNT *sam_acct, const DOM_SID *sid)
766 struct pdb_context *pdb_context = pdb_get_static_context(False);
772 return NT_STATUS_IS_OK(pdb_context->pdb_getsampwsid(pdb_context, sam_acct, sid));
775 BOOL pdb_add_sam_account(SAM_ACCOUNT *sam_acct)
777 struct pdb_context *pdb_context = pdb_get_static_context(False);
783 return NT_STATUS_IS_OK(pdb_context->pdb_add_sam_account(pdb_context, sam_acct));
786 BOOL pdb_update_sam_account(SAM_ACCOUNT *sam_acct)
788 struct pdb_context *pdb_context = pdb_get_static_context(False);
794 return NT_STATUS_IS_OK(pdb_context->pdb_update_sam_account(pdb_context, sam_acct));
797 BOOL pdb_delete_sam_account(SAM_ACCOUNT *sam_acct)
799 struct pdb_context *pdb_context = pdb_get_static_context(False);
805 return NT_STATUS_IS_OK(pdb_context->pdb_delete_sam_account(pdb_context, sam_acct));
808 BOOL pdb_getgrsid(GROUP_MAP *map, DOM_SID sid)
810 struct pdb_context *pdb_context = pdb_get_static_context(False);
816 return NT_STATUS_IS_OK(pdb_context->
817 pdb_getgrsid(pdb_context, map, sid));
820 BOOL pdb_getgrgid(GROUP_MAP *map, gid_t gid)
822 struct pdb_context *pdb_context = pdb_get_static_context(False);
828 return NT_STATUS_IS_OK(pdb_context->
829 pdb_getgrgid(pdb_context, map, gid));
832 BOOL pdb_getgrnam(GROUP_MAP *map, char *name)
834 struct pdb_context *pdb_context = pdb_get_static_context(False);
840 return NT_STATUS_IS_OK(pdb_context->
841 pdb_getgrnam(pdb_context, map, name));
844 BOOL pdb_add_group_mapping_entry(GROUP_MAP *map)
846 struct pdb_context *pdb_context = pdb_get_static_context(False);
852 return NT_STATUS_IS_OK(pdb_context->
853 pdb_add_group_mapping_entry(pdb_context, map));
856 BOOL pdb_update_group_mapping_entry(GROUP_MAP *map)
858 struct pdb_context *pdb_context = pdb_get_static_context(False);
864 return NT_STATUS_IS_OK(pdb_context->
865 pdb_update_group_mapping_entry(pdb_context, map));
868 BOOL pdb_delete_group_mapping_entry(DOM_SID sid)
870 struct pdb_context *pdb_context = pdb_get_static_context(False);
876 return NT_STATUS_IS_OK(pdb_context->
877 pdb_delete_group_mapping_entry(pdb_context, sid));
880 BOOL pdb_enum_group_mapping(enum SID_NAME_USE sid_name_use, GROUP_MAP **rmap,
881 int *num_entries, BOOL unix_only)
883 struct pdb_context *pdb_context = pdb_get_static_context(False);
889 return NT_STATUS_IS_OK(pdb_context->
890 pdb_enum_group_mapping(pdb_context, sid_name_use,
891 rmap, num_entries, unix_only));
894 /***************************************************************
895 Initialize the static context (at smbd startup etc).
897 If uninitialised, context will auto-init on first use.
898 ***************************************************************/
900 BOOL initialize_password_db(BOOL reload)
902 return (pdb_get_static_context(reload) != NULL);
906 /***************************************************************************
907 Default implementations of some functions.
908 ****************************************************************************/
910 static NTSTATUS pdb_default_getsampwnam (struct pdb_methods *methods, SAM_ACCOUNT *user, const char *sname)
912 return NT_STATUS_NO_SUCH_USER;
915 static NTSTATUS pdb_default_getsampwsid(struct pdb_methods *my_methods, SAM_ACCOUNT * user, const DOM_SID *sid)
917 return NT_STATUS_NO_SUCH_USER;
920 static NTSTATUS pdb_default_add_sam_account (struct pdb_methods *methods, SAM_ACCOUNT *newpwd)
922 DEBUG(0,("this backend (%s) should not be listed as the first passdb backend! You can't add users to it.\n", methods->name));
923 return NT_STATUS_NOT_IMPLEMENTED;
926 static NTSTATUS pdb_default_update_sam_account (struct pdb_methods *methods, SAM_ACCOUNT *newpwd)
928 return NT_STATUS_NOT_IMPLEMENTED;
931 static NTSTATUS pdb_default_delete_sam_account (struct pdb_methods *methods, SAM_ACCOUNT *pwd)
933 return NT_STATUS_NOT_IMPLEMENTED;
936 static NTSTATUS pdb_default_setsampwent(struct pdb_methods *methods, BOOL update)
938 return NT_STATUS_NOT_IMPLEMENTED;
941 static NTSTATUS pdb_default_getsampwent(struct pdb_methods *methods, SAM_ACCOUNT *user)
943 return NT_STATUS_NOT_IMPLEMENTED;
946 static void pdb_default_endsampwent(struct pdb_methods *methods)
948 return; /* NT_STATUS_NOT_IMPLEMENTED; */
951 static NTSTATUS pdb_default_gettrustpwent(struct pdb_methods *methods, SAM_TRUST_PASSWD* trust)
953 return NT_STATUS_NOT_IMPLEMENTED;
956 static NTSTATUS pdb_default_gettrustpwsid(struct pdb_methods *methods, SAM_TRUST_PASSWD* trust,
959 return NT_STATUS_NOT_IMPLEMENTED;
962 static NTSTATUS pdb_default_add_trust_passwd(struct pdb_methods *methods, const SAM_TRUST_PASSWD* trust)
964 return NT_STATUS_NOT_IMPLEMENTED;
967 static NTSTATUS pdb_default_update_trust_passwd(struct pdb_methods *methods, const SAM_TRUST_PASSWD* trust)
969 return NT_STATUS_NOT_IMPLEMENTED;
972 static NTSTATUS pdb_default_delete_trust_passwd(struct pdb_methods *methods, const SAM_TRUST_PASSWD* trust)
974 return NT_STATUS_NOT_IMPLEMENTED;
978 NTSTATUS make_pdb_methods(TALLOC_CTX *mem_ctx, PDB_METHODS **methods)
980 *methods = talloc(mem_ctx, sizeof(struct pdb_methods));
983 return NT_STATUS_NO_MEMORY;
986 ZERO_STRUCTP(*methods);
988 (*methods)->setsampwent = pdb_default_setsampwent;
989 (*methods)->endsampwent = pdb_default_endsampwent;
990 (*methods)->getsampwent = pdb_default_getsampwent;
991 (*methods)->getsampwnam = pdb_default_getsampwnam;
992 (*methods)->getsampwsid = pdb_default_getsampwsid;
993 (*methods)->add_sam_account = pdb_default_add_sam_account;
994 (*methods)->update_sam_account = pdb_default_update_sam_account;
995 (*methods)->delete_sam_account = pdb_default_delete_sam_account;
997 (*methods)->getgrsid = pdb_default_getgrsid;
998 (*methods)->getgrgid = pdb_default_getgrgid;
999 (*methods)->getgrnam = pdb_default_getgrnam;
1000 (*methods)->add_group_mapping_entry = pdb_default_add_group_mapping_entry;
1001 (*methods)->update_group_mapping_entry = pdb_default_update_group_mapping_entry;
1002 (*methods)->delete_group_mapping_entry = pdb_default_delete_group_mapping_entry;
1003 (*methods)->enum_group_mapping = pdb_default_enum_group_mapping;
1005 (*methods)->gettrustpwent = pdb_default_gettrustpwent;
1006 (*methods)->gettrustpwsid = pdb_default_gettrustpwsid;
1007 (*methods)->add_trust_passwd = pdb_default_add_trust_passwd;
1008 (*methods)->update_trust_passwd = pdb_default_update_trust_passwd;
1009 (*methods)->delete_trust_passwd = pdb_default_delete_trust_passwd;
1011 return NT_STATUS_OK;