#ifndef _WINBINDD_H
#define _WINBINDD_H
#include "nterr.h"
#include "winbindd_nss.h"
#ifdef HAVE_LIBNSCD
#include "libnscd.h"
#endif
#ifdef HAVE_SYS_MMAN_H
#include <sys/mman.h>
#endif
#undef DBGC_CLASS
#define DBGC_CLASS DBGC_WINBIND
#define WB_REPLACE_CHAR '_'
#define EVENT_FD_READ 1
#define EVENT_FD_WRITE 2
struct fd_event {
struct fd_event *next, *prev;
int fd;
int flags;
void (*handler)(struct fd_event *fde, int flags);
void *data;
size_t length, done;
void (*finished)(void *private_data, BOOL success);
void *private_data;
};
struct sid_ctr {
DOM_SID *sid;
BOOL finished;
const char *domain;
const char *name;
enum lsa_SidType type;
};
struct winbindd_cli_state {
struct winbindd_cli_state *prev, *next;
int sock;
struct fd_event fd_event;
pid_t pid;
BOOL finished;
BOOL write_extra_data;
time_t last_access;
BOOL privileged;
TALLOC_CTX *mem_ctx;
struct winbindd_request request;
struct winbindd_response response;
BOOL getpwent_initialized;
BOOL getgrent_initialized;
struct getent_state *getpwent_state;
struct getent_state *getgrent_state;
};
struct getent_state {
struct getent_state *prev, *next;
void *sam_entries;
uint32 sam_entry_index, num_sam_entries;
BOOL got_sam_entries;
fstring domain_name;
};
struct getpwent_user {
fstring name;
fstring gecos;
fstring homedir;
fstring shell;
DOM_SID user_sid;
DOM_SID group_sid;
};
typedef struct {
char *acct_name;
char *full_name;
char *homedir;
char *shell;
gid_t primary_gid;
DOM_SID user_sid;
DOM_SID group_sid;
} WINBIND_USERINFO;
struct winbindd_cm_conn {
struct cli_state *cli;
struct rpc_pipe_client *samr_pipe;
POLICY_HND sam_connect_handle, sam_domain_handle;
struct rpc_pipe_client *lsa_pipe;
POLICY_HND lsa_policy;
struct rpc_pipe_client *netlogon_pipe;
};
struct winbindd_async_request;
struct winbindd_child {
struct winbindd_child *next, *prev;
pid_t pid;
struct winbindd_domain *domain;
pstring logfilename;
struct fd_event event;
struct timed_event *lockout_policy_event;
struct winbindd_async_request *requests;
};
struct winbindd_domain {
fstring name;
fstring alt_name;
fstring forest_name;
DOM_SID sid;
BOOL initialized;
BOOL native_mode;
BOOL active_directory;
BOOL primary;
BOOL internal;
BOOL online;
time_t startup_time;
BOOL startup;
struct winbindd_methods *methods;
struct winbindd_methods *backend;
void *private_data;
fstring dcname;
struct sockaddr_in dcaddr;
time_t last_seq_check;
uint32 sequence_number;
NTSTATUS last_status;
struct winbindd_cm_conn conn;
struct winbindd_child child;
uint32 check_online_timeout;
struct timed_event *check_online_event;
struct winbindd_domain *prev, *next;
};
struct winbindd_methods {
BOOL consistent;
NTSTATUS (*query_user_list)(struct winbindd_domain *domain,
TALLOC_CTX *mem_ctx,
uint32 *num_entries,
WINBIND_USERINFO **info);
NTSTATUS (*enum_dom_groups)(struct winbindd_domain *domain,
TALLOC_CTX *mem_ctx,
uint32 *num_entries,
struct acct_info **info);
NTSTATUS (*enum_local_groups)(struct winbindd_domain *domain,
TALLOC_CTX *mem_ctx,
uint32 *num_entries,
struct acct_info **info);
NTSTATUS (*name_to_sid)(struct winbindd_domain *domain,
TALLOC_CTX *mem_ctx,
const char *domain_name,
const char *name,
DOM_SID *sid,
enum lsa_SidType *type);
NTSTATUS (*sid_to_name)(struct winbindd_domain *domain,
TALLOC_CTX *mem_ctx,
const DOM_SID *sid,
char **domain_name,
char **name,
enum lsa_SidType *type);
NTSTATUS (*rids_to_names)(struct winbindd_domain *domain,
TALLOC_CTX *mem_ctx,
const DOM_SID *domain_sid,
uint32 *rids,
size_t num_rids,
char **domain_name,
char ***names,
enum lsa_SidType **types);
NTSTATUS (*query_user)(struct winbindd_domain *domain,
TALLOC_CTX *mem_ctx,
const DOM_SID *user_sid,
WINBIND_USERINFO *user_info);
NTSTATUS (*lookup_usergroups)(struct winbindd_domain *domain,
TALLOC_CTX *mem_ctx,
const DOM_SID *user_sid,
uint32 *num_groups, DOM_SID **user_gids);
NTSTATUS (*lookup_useraliases)(struct winbindd_domain *domain,
TALLOC_CTX *mem_ctx,
uint32 num_sids,
const DOM_SID *sids,
uint32 *num_aliases,
uint32 **alias_rids);
NTSTATUS (*lookup_groupmem)(struct winbindd_domain *domain,
TALLOC_CTX *mem_ctx,
const DOM_SID *group_sid,
uint32 *num_names,
DOM_SID **sid_mem, char ***names,
uint32 **name_types);
NTSTATUS (*sequence_number)(struct winbindd_domain *domain, uint32 *seq);
NTSTATUS (*lockout_policy)(struct winbindd_domain *domain,
TALLOC_CTX *mem_ctx,
SAM_UNK_INFO_12 *lockout_policy);
NTSTATUS (*password_policy)(struct winbindd_domain *domain,
TALLOC_CTX *mem_ctx,
SAM_UNK_INFO_1 *password_policy);
NTSTATUS (*trusted_domains)(struct winbindd_domain *domain,
TALLOC_CTX *mem_ctx,
uint32 *num_domains,
char ***names,
char ***alt_names,
DOM_SID **dom_sids);
};
typedef struct {
struct cli_state *cli;
POLICY_HND pol;
} CLI_POLICY_HND;
struct winbindd_idmap_methods {
BOOL (*init)(void);
BOOL (*get_sid_from_uid)(uid_t uid, DOM_SID *sid);
BOOL (*get_sid_from_gid)(gid_t gid, DOM_SID *sid);
BOOL (*get_uid_from_sid)(DOM_SID *sid, uid_t *uid);
BOOL (*get_gid_from_sid)(DOM_SID *sid, gid_t *gid);
BOOL (*close)(void);
void (*status)(void);
};
#include "nsswitch/winbindd_proto.h"
#define WINBINDD_ESTABLISH_LOOP 30
#define WINBINDD_RESCAN_FREQ 300
#define WINBINDD_PAM_AUTH_KRB5_RENEW_TIME 2592000
#define DOM_SEQUENCE_NONE ((uint32)-1)
#endif