1
0
mirror of https://github.com/samba-team/samba.git synced 2025-01-22 22:04:08 +03:00
Gerald (Jerry) Carter d6de32db2f winbindd: Add support for name aliasing.
* Add support user and group name aliasing by expanding
  the ws_name_replace() and ws_name_return() functions.
  The lookup path is
     aliases -> qualified name -> SID
     SID -> fully qualified name -> alias
  In other words, the name aliasing support is a thin layer
  built on top of SID/NAME translation.

* Rename the ws_name_XX() functions to normalize_name_map()
  and normalize_name_unmap().  Chaneg interface to return
  NTSTATUS rather than char *.

* Add associated cache validation functions.
2008-09-16 10:27:49 -07:00

101 lines
2.8 KiB
C

/*
Unix SMB/CIFS implementation.
Idmap NSS headers
Copyright (C) Gerald Carter 2006
This library is free software; you can redistribute it and/or
modify it under the terms of the GNU Lesser General Public
License as published by the Free Software Foundation; either
version 3 of the License, or (at your option) any later version.
This library is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
Library General Public License for more details.
You should have received a copy of the GNU Lesser General Public License
along with this program. If not, see <http://www.gnu.org/licenses/>.
*/
#ifndef _IDMAP_NSS_H
#define _IDMAP_NSS_H
#ifndef HAVE_LDAP
# ifndef LDAPMessage
# define LDAPMessage void
# endif
#endif
/* The interface version specifier */
#define SMB_NSS_INFO_INTERFACE_VERSION 1
/* List of available backends. All backends must
register themselves */
struct nss_function_entry {
struct nss_function_entry *prev, *next;
const char *name;
struct nss_info_methods *methods;
};
/* List of configured domains. Each domain points
back to its configured backend. */
struct nss_domain_entry {
struct nss_domain_entry *prev, *next;
const char *domain;
NTSTATUS init_status;
struct nss_function_entry *backend;
/* hold state on a per domain basis */
void *state;
};
/* API */
struct nss_info_methods {
NTSTATUS (*init)( struct nss_domain_entry *e );
NTSTATUS (*get_nss_info)( struct nss_domain_entry *e,
const DOM_SID *sid,
TALLOC_CTX *ctx,
ADS_STRUCT *ads, LDAPMessage *msg,
char **homedir, char **shell, char **gecos, gid_t *p_gid);
NTSTATUS (*map_to_alias)( TALLOC_CTX *mem_ctx, const char *domain,
const char *name, char **alias );
NTSTATUS (*map_from_alias)( TALLOC_CTX *mem_ctx, const char *domain,
const char *alias, char **name );
NTSTATUS (*close_fn)( void );
};
/* The following definitions come from nsswitch/nss_info.c */
NTSTATUS smb_register_idmap_nss(int version,
const char *name,
struct nss_info_methods *methods);
NTSTATUS nss_init( const char **nss_list );
NTSTATUS nss_get_info( const char *domain, const DOM_SID *user_sid,
TALLOC_CTX *ctx,
ADS_STRUCT *ads, LDAPMessage *msg,
char **homedir, char **shell, char **gecos,
gid_t *p_gid);
NTSTATUS nss_map_to_alias( TALLOC_CTX *mem_ctx, const char *domain,
const char *name, char **alias );
NTSTATUS nss_map_from_alias( TALLOC_CTX *mem_ctx, const char *domain,
const char *alias, char **name );
NTSTATUS nss_close( const char *parameters );
#endif /* _IDMAP_NSS_H_ */