2005-09-22 18:35:08 +00:00
/*
Unix SMB / CIFS implementation .
Main winbindd samba3 server routines
Copyright ( C ) Stefan Metzmacher 2005
Copyright ( C ) Volker Lendecke 2005
2005-10-28 13:42:00 +00:00
Copyright ( C ) Andrew Bartlett < abartlet @ samba . org > 2005
2009-01-15 10:14:55 +01:00
Copyright ( C ) Kai Blin 2009
2005-09-22 18:35:08 +00:00
This program is free software ; you can redistribute it and / or modify
it under the terms of the GNU General Public License as published by
2007-07-10 02:07:03 +00:00
the Free Software Foundation ; either version 3 of the License , or
2005-09-22 18:35:08 +00:00
( at your option ) any later version .
This program 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 General Public License for more details .
You should have received a copy of the GNU General Public License
2007-07-10 02:07:03 +00:00
along with this program . If not , see < http : //www.gnu.org/licenses/>.
2005-09-22 18:35:08 +00:00
*/
# include "includes.h"
# include "winbind/wb_server.h"
2007-12-02 21:32:08 +01:00
# include "param/param.h"
2007-07-31 23:43:59 +00:00
# include "winbind/wb_helper.h"
2005-09-25 21:01:56 +00:00
# include "libcli/composite/composite.h"
2006-02-23 15:52:24 +00:00
# include "version.h"
2009-10-02 21:31:05 +10:00
# include "librpc/gen_ndr/ndr_netlogon.h"
2006-04-02 12:02:01 +00:00
# include "libcli/security/security.h"
2011-02-08 10:45:39 +01:00
# include "../libcli/auth/pam_errors.h"
2008-04-15 16:29:13 +02:00
# include "auth/credentials/credentials.h"
# include "smbd/service_task.h"
2005-09-22 18:35:08 +00:00
2009-10-02 21:31:05 +10:00
/*
support the old Samba3 TXT form of the info3
*/
static NTSTATUS wb_samba3_append_info3_as_txt ( TALLOC_CTX * mem_ctx ,
struct wbsrv_samba3_call * s3call ,
DATA_BLOB info3b )
{
struct netr_SamInfo3 * info3 ;
char * ex ;
uint32_t i ;
enum ndr_err_code ndr_err ;
info3 = talloc ( mem_ctx , struct netr_SamInfo3 ) ;
NT_STATUS_HAVE_NO_MEMORY ( info3 ) ;
/* The Samba3 protocol has a redundent 4 bytes at the start */
info3b . data + = 4 ;
info3b . length - = 4 ;
ndr_err = ndr_pull_struct_blob ( & info3b ,
mem_ctx ,
info3 ,
( ndr_pull_flags_fn_t ) ndr_pull_netr_SamInfo3 ) ;
if ( ! NDR_ERR_CODE_IS_SUCCESS ( ndr_err ) ) {
return ndr_map_error2ntstatus ( ndr_err ) ;
}
2010-05-14 17:31:33 +10:00
s3call - > response - > data . auth . info3 . logon_time =
2011-10-21 16:10:43 -04:00
nt_time_to_unix ( info3 - > base . logon_time ) ;
2010-05-14 17:31:33 +10:00
s3call - > response - > data . auth . info3 . logoff_time =
2011-10-21 16:10:43 -04:00
nt_time_to_unix ( info3 - > base . logoff_time ) ;
2010-05-14 17:31:33 +10:00
s3call - > response - > data . auth . info3 . kickoff_time =
2011-10-21 16:10:43 -04:00
nt_time_to_unix ( info3 - > base . kickoff_time ) ;
2010-05-14 17:31:33 +10:00
s3call - > response - > data . auth . info3 . pass_last_set_time =
2009-10-02 21:31:05 +10:00
nt_time_to_unix ( info3 - > base . last_password_change ) ;
2010-05-14 17:31:33 +10:00
s3call - > response - > data . auth . info3 . pass_can_change_time =
2009-10-02 21:31:05 +10:00
nt_time_to_unix ( info3 - > base . allow_password_change ) ;
2010-05-14 17:31:33 +10:00
s3call - > response - > data . auth . info3 . pass_must_change_time =
2009-10-02 21:31:05 +10:00
nt_time_to_unix ( info3 - > base . force_password_change ) ;
2010-05-14 17:31:33 +10:00
s3call - > response - > data . auth . info3 . logon_count = info3 - > base . logon_count ;
s3call - > response - > data . auth . info3 . bad_pw_count = info3 - > base . bad_password_count ;
2009-10-02 21:31:05 +10:00
2010-05-14 17:31:33 +10:00
s3call - > response - > data . auth . info3 . user_rid = info3 - > base . rid ;
s3call - > response - > data . auth . info3 . group_rid = info3 - > base . primary_gid ;
fstrcpy ( s3call - > response - > data . auth . info3 . dom_sid , dom_sid_string ( mem_ctx , info3 - > base . domain_sid ) ) ;
2009-10-02 21:31:05 +10:00
2010-05-14 17:31:33 +10:00
s3call - > response - > data . auth . info3 . num_groups = info3 - > base . groups . count ;
s3call - > response - > data . auth . info3 . user_flgs = info3 - > base . user_flags ;
2009-10-02 21:31:05 +10:00
2010-05-14 17:31:33 +10:00
s3call - > response - > data . auth . info3 . acct_flags = info3 - > base . acct_flags ;
s3call - > response - > data . auth . info3 . num_other_sids = info3 - > sidcount ;
2009-10-02 21:31:05 +10:00
2010-05-14 17:31:33 +10:00
fstrcpy ( s3call - > response - > data . auth . info3 . user_name ,
2009-10-02 21:31:05 +10:00
info3 - > base . account_name . string ) ;
2010-05-14 17:31:33 +10:00
fstrcpy ( s3call - > response - > data . auth . info3 . full_name ,
2009-10-02 21:31:05 +10:00
info3 - > base . full_name . string ) ;
2010-05-14 17:31:33 +10:00
fstrcpy ( s3call - > response - > data . auth . info3 . logon_script ,
2009-10-02 21:31:05 +10:00
info3 - > base . logon_script . string ) ;
2010-05-14 17:31:33 +10:00
fstrcpy ( s3call - > response - > data . auth . info3 . profile_path ,
2009-10-02 21:31:05 +10:00
info3 - > base . profile_path . string ) ;
2010-05-14 17:31:33 +10:00
fstrcpy ( s3call - > response - > data . auth . info3 . home_dir ,
2009-10-02 21:31:05 +10:00
info3 - > base . home_directory . string ) ;
2010-05-14 17:31:33 +10:00
fstrcpy ( s3call - > response - > data . auth . info3 . dir_drive ,
2009-10-02 21:31:05 +10:00
info3 - > base . home_drive . string ) ;
2010-05-14 17:31:33 +10:00
fstrcpy ( s3call - > response - > data . auth . info3 . logon_srv ,
2009-10-02 21:31:05 +10:00
info3 - > base . logon_server . string ) ;
2010-05-14 17:31:33 +10:00
fstrcpy ( s3call - > response - > data . auth . info3 . logon_dom ,
2011-10-21 16:10:43 -04:00
info3 - > base . logon_domain . string ) ;
2009-10-02 21:31:05 +10:00
ex = talloc_strdup ( mem_ctx , " " ) ;
NT_STATUS_HAVE_NO_MEMORY ( ex ) ;
for ( i = 0 ; i < info3 - > base . groups . count ; i + + ) {
ex = talloc_asprintf_append_buffer ( ex , " 0x%08X:0x%08X \n " ,
info3 - > base . groups . rids [ i ] . rid ,
info3 - > base . groups . rids [ i ] . attributes ) ;
NT_STATUS_HAVE_NO_MEMORY ( ex ) ;
}
for ( i = 0 ; i < info3 - > sidcount ; i + + ) {
char * sid ;
sid = dom_sid_string ( mem_ctx , info3 - > sids [ i ] . sid ) ;
NT_STATUS_HAVE_NO_MEMORY ( sid ) ;
ex = talloc_asprintf_append_buffer ( ex , " %s:0x%08X \n " ,
sid ,
info3 - > sids [ i ] . attributes ) ;
NT_STATUS_HAVE_NO_MEMORY ( ex ) ;
talloc_free ( sid ) ;
}
2010-05-14 17:31:33 +10:00
s3call - > response - > extra_data . data = ex ;
s3call - > response - > length + = talloc_get_size ( ex ) ;
2009-10-02 21:31:05 +10:00
return NT_STATUS_OK ;
}
2005-10-31 05:45:19 +00:00
/*
Send off the reply to an async Samba3 query , handling filling in the PAM , NTSTATUS and string errors .
*/
2005-10-31 04:17:51 +00:00
static void wbsrv_samba3_async_auth_epilogue ( NTSTATUS status ,
struct wbsrv_samba3_call * s3call )
2005-10-23 11:21:15 +00:00
{
2010-05-14 17:31:33 +10:00
struct winbindd_response * resp = s3call - > response ;
2005-10-23 11:21:15 +00:00
if ( ! NT_STATUS_IS_OK ( status ) ) {
resp - > result = WINBINDD_ERROR ;
2005-10-31 04:17:51 +00:00
} else {
resp - > result = WINBINDD_OK ;
}
2008-04-16 16:11:17 +02:00
WBSRV_SAMBA3_SET_STRING ( resp - > data . auth . nt_status_string ,
nt_errstr ( status ) ) ;
WBSRV_SAMBA3_SET_STRING ( resp - > data . auth . error_string ,
get_friendly_nt_error_msg ( status ) ) ;
2005-10-31 04:17:51 +00:00
resp - > data . auth . pam_error = nt_status_to_pam ( status ) ;
resp - > data . auth . nt_status = NT_STATUS_V ( status ) ;
2006-01-12 09:38:35 +00:00
wbsrv_samba3_send_reply ( s3call ) ;
2005-10-31 04:17:51 +00:00
}
2005-10-31 05:45:19 +00:00
/*
Send of a generic reply to a Samba3 query
*/
2005-10-31 04:17:51 +00:00
static void wbsrv_samba3_async_epilogue ( NTSTATUS status ,
struct wbsrv_samba3_call * s3call )
{
2010-05-14 17:31:33 +10:00
struct winbindd_response * resp = s3call - > response ;
2005-10-31 04:17:51 +00:00
if ( NT_STATUS_IS_OK ( status ) ) {
resp - > result = WINBINDD_OK ;
} else {
resp - > result = WINBINDD_ERROR ;
2005-10-23 11:21:15 +00:00
}
2006-01-12 09:38:35 +00:00
wbsrv_samba3_send_reply ( s3call ) ;
2005-10-23 11:21:15 +00:00
}
2005-10-31 05:45:19 +00:00
/*
Boilerplate commands , simple queries without network traffic
*/
2005-09-22 18:35:08 +00:00
NTSTATUS wbsrv_samba3_interface_version ( struct wbsrv_samba3_call * s3call )
{
2010-05-14 17:31:33 +10:00
s3call - > response - > result = WINBINDD_OK ;
s3call - > response - > data . interface_version = WINBIND_INTERFACE_VERSION ;
2005-09-22 18:35:08 +00:00
return NT_STATUS_OK ;
}
2005-09-26 13:42:42 +00:00
NTSTATUS wbsrv_samba3_info ( struct wbsrv_samba3_call * s3call )
{
2010-05-14 17:31:33 +10:00
s3call - > response - > result = WINBINDD_OK ;
2010-07-16 14:32:42 +10:00
s3call - > response - > data . info . winbind_separator = * lpcfg_winbind_separator ( s3call - > wbconn - > lp_ctx ) ;
2010-05-14 17:31:33 +10:00
WBSRV_SAMBA3_SET_STRING ( s3call - > response - > data . info . samba_version ,
2005-10-23 11:21:15 +00:00
SAMBA_VERSION_STRING ) ;
2005-09-26 13:42:42 +00:00
return NT_STATUS_OK ;
}
NTSTATUS wbsrv_samba3_domain_name ( struct wbsrv_samba3_call * s3call )
{
2010-05-14 17:31:33 +10:00
s3call - > response - > result = WINBINDD_OK ;
WBSRV_SAMBA3_SET_STRING ( s3call - > response - > data . domain_name ,
2010-07-16 14:32:42 +10:00
lpcfg_workgroup ( s3call - > wbconn - > lp_ctx ) ) ;
2005-09-26 13:42:42 +00:00
return NT_STATUS_OK ;
}
NTSTATUS wbsrv_samba3_netbios_name ( struct wbsrv_samba3_call * s3call )
{
2010-05-14 17:31:33 +10:00
s3call - > response - > result = WINBINDD_OK ;
WBSRV_SAMBA3_SET_STRING ( s3call - > response - > data . netbios_name ,
2010-07-16 14:32:42 +10:00
lpcfg_netbios_name ( s3call - > wbconn - > lp_ctx ) ) ;
2005-09-26 13:42:42 +00:00
return NT_STATUS_OK ;
}
2005-09-22 18:35:08 +00:00
NTSTATUS wbsrv_samba3_priv_pipe_dir ( struct wbsrv_samba3_call * s3call )
{
2010-04-15 09:24:56 +02:00
struct loadparm_context * lp_ctx = s3call - > wbconn - > listen_socket - > service - > task - > lp_ctx ;
2010-07-16 14:32:42 +10:00
const char * priv_socket_dir = lpcfg_winbindd_privileged_socket_directory ( lp_ctx ) ;
2010-04-15 09:24:56 +02:00
2010-05-14 17:31:33 +10:00
s3call - > response - > result = WINBINDD_OK ;
s3call - > response - > extra_data . data = discard_const ( priv_socket_dir ) ;
2009-01-02 22:46:08 +01:00
2010-05-14 17:31:33 +10:00
s3call - > response - > length + = strlen ( priv_socket_dir ) + 1 ;
2005-09-22 18:35:08 +00:00
return NT_STATUS_OK ;
}
NTSTATUS wbsrv_samba3_ping ( struct wbsrv_samba3_call * s3call )
{
2010-05-14 17:31:33 +10:00
s3call - > response - > result = WINBINDD_OK ;
2005-09-22 18:35:08 +00:00
return NT_STATUS_OK ;
}
2005-09-25 21:01:56 +00:00
2009-08-13 09:42:14 +02:00
NTSTATUS wbsrv_samba3_domain_info ( struct wbsrv_samba3_call * s3call )
{
2009-08-18 21:48:41 +02:00
DEBUG ( 5 , ( " wbsrv_samba3_domain_info called, stub \n " ) ) ;
2010-05-14 17:31:33 +10:00
s3call - > response - > result = WINBINDD_OK ;
fstrcpy ( s3call - > response - > data . domain_info . name ,
s3call - > request - > domain_name ) ;
fstrcpy ( s3call - > response - > data . domain_info . alt_name ,
s3call - > request - > domain_name ) ;
fstrcpy ( s3call - > response - > data . domain_info . sid , " S-1-2-3-4 " ) ;
s3call - > response - > data . domain_info . native_mode = false ;
s3call - > response - > data . domain_info . active_directory = false ;
s3call - > response - > data . domain_info . primary = false ;
2009-08-13 09:42:14 +02:00
return NT_STATUS_OK ;
}
2008-04-15 16:29:13 +02:00
/* Plaintext authentication
This interface is used by ntlm_auth in it ' s ' basic ' authentication
mode , as well as by pam_winbind to authenticate users where we are
given a plaintext password .
2005-10-31 05:45:19 +00:00
*/
2008-04-15 16:29:13 +02:00
static void check_machacc_recv ( struct composite_context * ctx ) ;
2005-10-03 13:46:11 +00:00
NTSTATUS wbsrv_samba3_check_machacc ( struct wbsrv_samba3_call * s3call )
2005-09-25 21:01:56 +00:00
{
2008-04-15 16:29:13 +02:00
NTSTATUS status ;
struct cli_credentials * creds ;
2005-10-01 16:36:04 +00:00
struct composite_context * ctx ;
2008-04-15 16:29:13 +02:00
struct wbsrv_service * service =
s3call - > wbconn - > listen_socket - > service ;
/* Create a credentials structure */
creds = cli_credentials_init ( s3call ) ;
if ( creds = = NULL ) {
return NT_STATUS_NO_MEMORY ;
}
2005-10-01 16:36:04 +00:00
2008-04-15 16:29:13 +02:00
cli_credentials_set_conf ( creds , service - > task - > lp_ctx ) ;
/* Connect the machine account to the credentials */
status = cli_credentials_set_machine_account ( creds , service - > task - > lp_ctx ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
talloc_free ( creds ) ;
return status ;
}
ctx = wb_cmd_pam_auth_send ( s3call , service , creds ) ;
if ( ! ctx ) {
talloc_free ( creds ) ;
return NT_STATUS_NO_MEMORY ;
}
2005-10-01 16:36:04 +00:00
2008-04-15 16:29:13 +02:00
ctx - > async . fn = check_machacc_recv ;
2005-10-01 16:36:04 +00:00
ctx - > async . private_data = s3call ;
2008-04-15 16:29:13 +02:00
s3call - > flags | = WBSRV_CALL_FLAGS_REPLY_ASYNC ;
2005-10-08 16:25:00 +00:00
return NT_STATUS_OK ;
2005-09-25 21:01:56 +00:00
}
2008-04-15 16:29:13 +02:00
static void check_machacc_recv ( struct composite_context * ctx )
2005-10-03 13:46:11 +00:00
{
struct wbsrv_samba3_call * s3call =
2005-10-08 16:25:00 +00:00
talloc_get_type ( ctx - > async . private_data ,
2005-10-03 13:46:11 +00:00
struct wbsrv_samba3_call ) ;
NTSTATUS status ;
2009-10-02 22:17:42 +10:00
status = wb_cmd_pam_auth_recv ( ctx , s3call , NULL , NULL , NULL , NULL ) ;
2008-04-15 16:29:13 +02:00
if ( ! NT_STATUS_IS_OK ( status ) ) goto done ;
2005-10-23 11:21:15 +00:00
2008-04-15 16:29:13 +02:00
done :
2005-10-31 04:17:51 +00:00
wbsrv_samba3_async_auth_epilogue ( status , s3call ) ;
2005-09-25 21:01:56 +00:00
}
2005-10-03 17:36:49 +00:00
2005-10-31 05:45:19 +00:00
/*
Find the name of a suitable domain controller , by query on the
netlogon pipe to the DC .
*/
2005-10-15 22:01:15 +00:00
static void getdcname_recv_dc ( struct composite_context * ctx ) ;
NTSTATUS wbsrv_samba3_getdcname ( struct wbsrv_samba3_call * s3call )
{
struct composite_context * ctx ;
2005-10-19 13:45:44 +00:00
struct wbsrv_service * service =
2006-01-12 09:38:35 +00:00
s3call - > wbconn - > listen_socket - > service ;
2005-10-15 22:01:15 +00:00
DEBUG ( 5 , ( " wbsrv_samba3_getdcname called \n " ) ) ;
2005-11-05 09:34:07 +00:00
ctx = wb_cmd_getdcname_send ( s3call , service ,
2010-05-14 17:31:33 +10:00
s3call - > request - > domain_name ) ;
2005-10-15 22:01:15 +00:00
NT_STATUS_HAVE_NO_MEMORY ( ctx ) ;
ctx - > async . fn = getdcname_recv_dc ;
ctx - > async . private_data = s3call ;
2006-01-12 09:38:35 +00:00
s3call - > flags | = WBSRV_CALL_FLAGS_REPLY_ASYNC ;
2005-10-15 22:01:15 +00:00
return NT_STATUS_OK ;
}
static void getdcname_recv_dc ( struct composite_context * ctx )
{
struct wbsrv_samba3_call * s3call =
talloc_get_type ( ctx - > async . private_data ,
struct wbsrv_samba3_call ) ;
const char * dcname ;
NTSTATUS status ;
status = wb_cmd_getdcname_recv ( ctx , s3call , & dcname ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) goto done ;
2010-05-14 17:31:33 +10:00
s3call - > response - > result = WINBINDD_OK ;
WBSRV_SAMBA3_SET_STRING ( s3call - > response - > data . dc_name , dcname ) ;
2005-10-15 22:01:15 +00:00
2005-10-16 12:43:09 +00:00
done :
2005-10-23 11:21:15 +00:00
wbsrv_samba3_async_epilogue ( status , s3call ) ;
2005-10-16 12:43:09 +00:00
}
2005-10-31 05:45:19 +00:00
/*
Lookup a user ' s domain groups
*/
2005-10-16 12:43:09 +00:00
static void userdomgroups_recv_groups ( struct composite_context * ctx ) ;
NTSTATUS wbsrv_samba3_userdomgroups ( struct wbsrv_samba3_call * s3call )
{
struct composite_context * ctx ;
struct dom_sid * sid ;
DEBUG ( 5 , ( " wbsrv_samba3_userdomgroups called \n " ) ) ;
2010-05-14 17:31:33 +10:00
sid = dom_sid_parse_talloc ( s3call , s3call - > request - > data . sid ) ;
2005-10-16 12:43:09 +00:00
if ( sid = = NULL ) {
DEBUG ( 5 , ( " Could not parse sid %s \n " ,
2010-05-14 17:31:33 +10:00
s3call - > request - > data . sid ) ) ;
2005-10-16 12:43:09 +00:00
return NT_STATUS_NO_MEMORY ;
}
2005-10-19 13:45:44 +00:00
ctx = wb_cmd_userdomgroups_send (
2006-01-12 09:38:35 +00:00
s3call , s3call - > wbconn - > listen_socket - > service , sid ) ;
2005-10-16 12:43:09 +00:00
NT_STATUS_HAVE_NO_MEMORY ( ctx ) ;
ctx - > async . fn = userdomgroups_recv_groups ;
ctx - > async . private_data = s3call ;
2006-01-12 09:38:35 +00:00
s3call - > flags | = WBSRV_CALL_FLAGS_REPLY_ASYNC ;
2005-10-16 12:43:09 +00:00
return NT_STATUS_OK ;
}
static void userdomgroups_recv_groups ( struct composite_context * ctx )
{
struct wbsrv_samba3_call * s3call =
talloc_get_type ( ctx - > async . private_data ,
struct wbsrv_samba3_call ) ;
2010-03-09 17:54:12 +01:00
uint32_t i , num_sids ;
2005-10-16 12:43:09 +00:00
struct dom_sid * * sids ;
char * sids_string ;
NTSTATUS status ;
status = wb_cmd_userdomgroups_recv ( ctx , s3call , & num_sids , & sids ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) goto done ;
sids_string = talloc_strdup ( s3call , " " ) ;
if ( sids_string = = NULL ) {
status = NT_STATUS_NO_MEMORY ;
goto done ;
}
for ( i = 0 ; i < num_sids ; i + + ) {
2007-09-14 23:21:00 +00:00
sids_string = talloc_asprintf_append_buffer (
2005-10-16 12:43:09 +00:00
sids_string , " %s \n " , dom_sid_string ( s3call , sids [ i ] ) ) ;
}
if ( sids_string = = NULL ) {
status = NT_STATUS_NO_MEMORY ;
goto done ;
}
2010-05-14 17:31:33 +10:00
s3call - > response - > result = WINBINDD_OK ;
s3call - > response - > extra_data . data = sids_string ;
s3call - > response - > length + = strlen ( sids_string ) + 1 ;
s3call - > response - > data . num_entries = num_sids ;
2005-10-16 12:43:09 +00:00
2005-10-15 22:01:15 +00:00
done :
2005-10-23 11:21:15 +00:00
wbsrv_samba3_async_epilogue ( status , s3call ) ;
2005-10-15 22:01:15 +00:00
}
2005-10-31 05:45:19 +00:00
/*
Lookup the list of SIDs for a user
*/
2005-10-19 13:45:44 +00:00
static void usersids_recv_sids ( struct composite_context * ctx ) ;
NTSTATUS wbsrv_samba3_usersids ( struct wbsrv_samba3_call * s3call )
{
struct composite_context * ctx ;
struct dom_sid * sid ;
DEBUG ( 5 , ( " wbsrv_samba3_usersids called \n " ) ) ;
2010-05-14 17:31:33 +10:00
sid = dom_sid_parse_talloc ( s3call , s3call - > request - > data . sid ) ;
2005-10-19 13:45:44 +00:00
if ( sid = = NULL ) {
DEBUG ( 5 , ( " Could not parse sid %s \n " ,
2010-05-14 17:31:33 +10:00
s3call - > request - > data . sid ) ) ;
2005-10-19 13:45:44 +00:00
return NT_STATUS_NO_MEMORY ;
}
ctx = wb_cmd_usersids_send (
2006-01-12 09:38:35 +00:00
s3call , s3call - > wbconn - > listen_socket - > service , sid ) ;
2005-10-19 13:45:44 +00:00
NT_STATUS_HAVE_NO_MEMORY ( ctx ) ;
ctx - > async . fn = usersids_recv_sids ;
ctx - > async . private_data = s3call ;
2006-01-12 09:38:35 +00:00
s3call - > flags | = WBSRV_CALL_FLAGS_REPLY_ASYNC ;
2005-10-19 13:45:44 +00:00
return NT_STATUS_OK ;
}
static void usersids_recv_sids ( struct composite_context * ctx )
{
struct wbsrv_samba3_call * s3call =
talloc_get_type ( ctx - > async . private_data ,
struct wbsrv_samba3_call ) ;
2010-03-09 17:54:12 +01:00
uint32_t i , num_sids ;
2005-10-19 13:45:44 +00:00
struct dom_sid * * sids ;
char * sids_string ;
NTSTATUS status ;
status = wb_cmd_usersids_recv ( ctx , s3call , & num_sids , & sids ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) goto done ;
sids_string = talloc_strdup ( s3call , " " ) ;
if ( sids_string = = NULL ) {
status = NT_STATUS_NO_MEMORY ;
goto done ;
}
for ( i = 0 ; i < num_sids ; i + + ) {
2007-09-14 23:21:00 +00:00
sids_string = talloc_asprintf_append_buffer (
2005-10-19 13:45:44 +00:00
sids_string , " %s \n " , dom_sid_string ( s3call , sids [ i ] ) ) ;
if ( sids_string = = NULL ) {
status = NT_STATUS_NO_MEMORY ;
goto done ;
}
}
2010-05-14 17:31:33 +10:00
s3call - > response - > result = WINBINDD_OK ;
s3call - > response - > extra_data . data = sids_string ;
s3call - > response - > length + = strlen ( sids_string ) ;
s3call - > response - > data . num_entries = num_sids ;
2005-10-19 13:45:44 +00:00
/* Hmmmm. Nasty protocol -- who invented the zeros between the
* SIDs ? Hmmm . Could have been me - - vl */
while ( * sids_string ! = ' \0 ' ) {
if ( ( * sids_string ) = = ' \n ' ) {
* sids_string = ' \0 ' ;
}
sids_string + = 1 ;
}
done :
2005-10-23 11:21:15 +00:00
wbsrv_samba3_async_epilogue ( status , s3call ) ;
2005-10-19 13:45:44 +00:00
}
2005-10-31 05:45:19 +00:00
/*
Lookup a DOMAIN \ \ user style name , and return a SID
*/
2005-10-07 19:08:51 +00:00
static void lookupname_recv_sid ( struct composite_context * ctx ) ;
2005-10-03 17:36:49 +00:00
NTSTATUS wbsrv_samba3_lookupname ( struct wbsrv_samba3_call * s3call )
{
struct composite_context * ctx ;
2005-10-19 13:45:44 +00:00
struct wbsrv_service * service =
2006-01-12 09:38:35 +00:00
s3call - > wbconn - > listen_socket - > service ;
2005-10-03 17:36:49 +00:00
DEBUG ( 5 , ( " wbsrv_samba3_lookupname called \n " ) ) ;
2005-10-31 20:28:08 +00:00
ctx = wb_cmd_lookupname_send ( s3call , service ,
2010-05-14 17:31:33 +10:00
s3call - > request - > data . name . dom_name ,
s3call - > request - > data . name . name ) ;
2005-10-03 17:36:49 +00:00
NT_STATUS_HAVE_NO_MEMORY ( ctx ) ;
/* setup the callbacks */
2005-10-08 16:25:00 +00:00
ctx - > async . fn = lookupname_recv_sid ;
ctx - > async . private_data = s3call ;
2006-01-12 09:38:35 +00:00
s3call - > flags | = WBSRV_CALL_FLAGS_REPLY_ASYNC ;
2005-10-03 17:36:49 +00:00
return NT_STATUS_OK ;
}
2005-10-07 19:08:51 +00:00
static void lookupname_recv_sid ( struct composite_context * ctx )
{
2005-10-08 16:25:00 +00:00
struct wbsrv_samba3_call * s3call =
2005-10-07 19:08:51 +00:00
talloc_get_type ( ctx - > async . private_data ,
2005-10-08 16:25:00 +00:00
struct wbsrv_samba3_call ) ;
2005-10-07 19:08:51 +00:00
struct wb_sid_object * sid ;
2005-10-08 16:25:00 +00:00
NTSTATUS status ;
2005-10-07 19:08:51 +00:00
2005-10-08 16:25:00 +00:00
status = wb_cmd_lookupname_recv ( ctx , s3call , & sid ) ;
2005-10-07 19:08:51 +00:00
if ( ! NT_STATUS_IS_OK ( status ) ) goto done ;
2010-05-14 17:31:33 +10:00
s3call - > response - > result = WINBINDD_OK ;
s3call - > response - > data . sid . type = sid - > type ;
WBSRV_SAMBA3_SET_STRING ( s3call - > response - > data . sid . sid ,
2005-10-08 16:25:00 +00:00
dom_sid_string ( s3call , sid - > sid ) ) ;
2005-10-07 19:08:51 +00:00
done :
2005-10-23 11:21:15 +00:00
wbsrv_samba3_async_epilogue ( status , s3call ) ;
2005-10-07 19:08:51 +00:00
}
2005-10-09 12:13:05 +00:00
2005-10-31 05:45:19 +00:00
/*
Lookup a SID , and return a DOMAIN \ \ user style name
*/
2005-10-19 13:45:44 +00:00
static void lookupsid_recv_name ( struct composite_context * ctx ) ;
NTSTATUS wbsrv_samba3_lookupsid ( struct wbsrv_samba3_call * s3call )
{
struct composite_context * ctx ;
struct wbsrv_service * service =
2006-01-12 09:38:35 +00:00
s3call - > wbconn - > listen_socket - > service ;
2005-10-19 13:45:44 +00:00
struct dom_sid * sid ;
DEBUG ( 5 , ( " wbsrv_samba3_lookupsid called \n " ) ) ;
2010-05-14 17:31:33 +10:00
sid = dom_sid_parse_talloc ( s3call , s3call - > request - > data . sid ) ;
2005-10-19 13:45:44 +00:00
if ( sid = = NULL ) {
DEBUG ( 5 , ( " Could not parse sid %s \n " ,
2010-05-14 17:31:33 +10:00
s3call - > request - > data . sid ) ) ;
2005-10-19 13:45:44 +00:00
return NT_STATUS_NO_MEMORY ;
}
2005-10-31 20:28:08 +00:00
ctx = wb_cmd_lookupsid_send ( s3call , service , sid ) ;
2005-10-19 13:45:44 +00:00
NT_STATUS_HAVE_NO_MEMORY ( ctx ) ;
/* setup the callbacks */
ctx - > async . fn = lookupsid_recv_name ;
ctx - > async . private_data = s3call ;
2006-01-12 09:38:35 +00:00
s3call - > flags | = WBSRV_CALL_FLAGS_REPLY_ASYNC ;
2005-10-19 13:45:44 +00:00
return NT_STATUS_OK ;
}
static void lookupsid_recv_name ( struct composite_context * ctx )
{
struct wbsrv_samba3_call * s3call =
talloc_get_type ( ctx - > async . private_data ,
struct wbsrv_samba3_call ) ;
struct wb_sid_object * sid ;
NTSTATUS status ;
status = wb_cmd_lookupsid_recv ( ctx , s3call , & sid ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) goto done ;
2010-05-14 17:31:33 +10:00
s3call - > response - > result = WINBINDD_OK ;
s3call - > response - > data . name . type = sid - > type ;
WBSRV_SAMBA3_SET_STRING ( s3call - > response - > data . name . dom_name ,
2005-10-19 13:45:44 +00:00
sid - > domain ) ;
2010-05-14 17:31:33 +10:00
WBSRV_SAMBA3_SET_STRING ( s3call - > response - > data . name . name , sid - > name ) ;
2005-10-19 13:45:44 +00:00
done :
2005-10-23 11:21:15 +00:00
wbsrv_samba3_async_epilogue ( status , s3call ) ;
2005-10-19 13:45:44 +00:00
}
2010-03-03 23:29:15 +03:00
/*
This is a stub function in order to limit error message in the pam_winbind module
*/
NTSTATUS wbsrv_samba3_pam_logoff ( struct wbsrv_samba3_call * s3call )
{
NTSTATUS status ;
2010-05-14 17:31:33 +10:00
struct winbindd_response * resp = s3call - > response ;
2010-03-03 23:29:15 +03:00
status = NT_STATUS_OK ;
DEBUG ( 5 , ( " wbsrv_samba3_pam_logoff called \n " ) ) ;
DEBUG ( 10 , ( " Winbind logoff not implemented \n " ) ) ;
resp - > result = WINBINDD_OK ;
WBSRV_SAMBA3_SET_STRING ( resp - > data . auth . nt_status_string ,
nt_errstr ( status ) ) ;
WBSRV_SAMBA3_SET_STRING ( resp - > data . auth . error_string ,
get_friendly_nt_error_msg ( status ) ) ;
resp - > data . auth . pam_error = nt_status_to_pam ( status ) ;
resp - > data . auth . nt_status = NT_STATUS_V ( status ) ;
DEBUG ( 5 , ( " wbsrv_samba3_pam_logoff called \n " ) ) ;
return NT_STATUS_OK ;
}
2005-10-31 05:45:19 +00:00
/*
Challenge - response authentication . This interface is used by
ntlm_auth and the smbd auth subsystem to pass NTLM authentication
requests along a common pipe to the domain controller .
The return value ( in the async reply ) may include the ' info3 '
( effectivly most things you would want to know about the user ) , or
the NT and LM session keys seperated .
*/
2005-10-14 21:05:45 +00:00
static void pam_auth_crap_recv ( struct composite_context * ctx ) ;
NTSTATUS wbsrv_samba3_pam_auth_crap ( struct wbsrv_samba3_call * s3call )
{
struct composite_context * ctx ;
2005-11-05 09:34:07 +00:00
struct wbsrv_service * service =
2006-01-12 09:38:35 +00:00
s3call - > wbconn - > listen_socket - > service ;
2005-10-12 20:22:45 +00:00
DATA_BLOB chal , nt_resp , lm_resp ;
DEBUG ( 5 , ( " wbsrv_samba3_pam_auth_crap called \n " ) ) ;
2010-05-14 17:31:33 +10:00
chal . data = s3call - > request - > data . auth_crap . chal ;
chal . length = sizeof ( s3call - > request - > data . auth_crap . chal ) ;
nt_resp . data = ( uint8_t * ) s3call - > request - > data . auth_crap . nt_resp ;
nt_resp . length = s3call - > request - > data . auth_crap . nt_resp_len ;
lm_resp . data = ( uint8_t * ) s3call - > request - > data . auth_crap . lm_resp ;
lm_resp . length = s3call - > request - > data . auth_crap . lm_resp_len ;
2005-10-12 20:22:45 +00:00
2005-10-14 21:05:45 +00:00
ctx = wb_cmd_pam_auth_crap_send (
2005-11-05 09:34:07 +00:00
s3call , service ,
2010-05-14 17:31:33 +10:00
s3call - > request - > data . auth_crap . logon_parameters ,
s3call - > request - > data . auth_crap . domain ,
s3call - > request - > data . auth_crap . user ,
s3call - > request - > data . auth_crap . workstation ,
2005-10-14 21:05:45 +00:00
chal , nt_resp , lm_resp ) ;
NT_STATUS_HAVE_NO_MEMORY ( ctx ) ;
ctx - > async . fn = pam_auth_crap_recv ;
ctx - > async . private_data = s3call ;
2006-01-12 09:38:35 +00:00
s3call - > flags | = WBSRV_CALL_FLAGS_REPLY_ASYNC ;
2005-10-14 21:05:45 +00:00
return NT_STATUS_OK ;
}
static void pam_auth_crap_recv ( struct composite_context * ctx )
{
struct wbsrv_samba3_call * s3call =
talloc_get_type ( ctx - > async . private_data ,
struct wbsrv_samba3_call ) ;
NTSTATUS status ;
DATA_BLOB info3 ;
struct netr_UserSessionKey user_session_key ;
struct netr_LMSessionKey lm_key ;
2005-10-28 13:42:00 +00:00
char * unix_username ;
2005-10-14 21:05:45 +00:00
status = wb_cmd_pam_auth_crap_recv ( ctx , s3call , & info3 ,
2005-10-28 13:42:00 +00:00
& user_session_key , & lm_key , & unix_username ) ;
2005-10-14 21:05:45 +00:00
if ( ! NT_STATUS_IS_OK ( status ) ) goto done ;
2010-05-14 17:31:33 +10:00
if ( s3call - > request - > flags & WBFLAG_PAM_USER_SESSION_KEY ) {
memcpy ( s3call - > response - > data . auth . user_session_key ,
2005-10-14 21:05:45 +00:00
& user_session_key . key ,
2010-05-14 17:31:33 +10:00
sizeof ( s3call - > response - > data . auth . user_session_key ) ) ;
2005-10-14 21:05:45 +00:00
}
2010-05-14 17:31:33 +10:00
if ( s3call - > request - > flags & WBFLAG_PAM_INFO3_TEXT ) {
2009-10-02 21:31:05 +10:00
status = wb_samba3_append_info3_as_txt ( ctx , s3call , info3 ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
DEBUG ( 10 , ( " Failed to append INFO3 (TXT): %s \n " ,
nt_errstr ( status ) ) ) ;
goto done ;
}
}
2010-05-14 17:31:33 +10:00
if ( s3call - > request - > flags & WBFLAG_PAM_INFO3_NDR ) {
s3call - > response - > extra_data . data = info3 . data ;
s3call - > response - > length + = info3 . length ;
2005-10-14 21:05:45 +00:00
}
2010-05-14 17:31:33 +10:00
if ( s3call - > request - > flags & WBFLAG_PAM_LMKEY ) {
memcpy ( s3call - > response - > data . auth . first_8_lm_hash ,
2005-10-14 21:05:45 +00:00
lm_key . key ,
2010-05-14 17:31:33 +10:00
sizeof ( s3call - > response - > data . auth . first_8_lm_hash ) ) ;
2005-10-14 21:05:45 +00:00
}
2010-05-14 17:31:33 +10:00
if ( s3call - > request - > flags & WBFLAG_PAM_UNIX_NAME ) {
WBSRV_SAMBA3_SET_STRING ( s3call - > response - > data . auth . unix_username , unix_username ) ;
2005-10-28 13:42:00 +00:00
}
done :
2005-10-31 04:17:51 +00:00
wbsrv_samba3_async_auth_epilogue ( status , s3call ) ;
2005-10-28 13:42:00 +00:00
}
2005-10-31 05:45:19 +00:00
/* Plaintext authentication
This interface is used by ntlm_auth in it ' s ' basic ' authentication
mode , as well as by pam_winbind to authenticate users where we are
given a plaintext password .
*/
2005-10-28 13:42:00 +00:00
static void pam_auth_recv ( struct composite_context * ctx ) ;
NTSTATUS wbsrv_samba3_pam_auth ( struct wbsrv_samba3_call * s3call )
{
struct composite_context * ctx ;
2005-11-05 09:34:07 +00:00
struct wbsrv_service * service =
2006-01-12 09:38:35 +00:00
s3call - > wbconn - > listen_socket - > service ;
2008-04-15 16:29:13 +02:00
struct cli_credentials * credentials ;
2005-10-28 13:42:00 +00:00
char * user , * domain ;
2005-11-05 09:34:07 +00:00
2007-12-03 21:25:17 +01:00
if ( ! wb_samba3_split_username ( s3call , s3call - > wbconn - > lp_ctx ,
2010-05-14 17:31:33 +10:00
s3call - > request - > data . auth . user ,
2005-10-28 13:42:00 +00:00
& domain , & user ) ) {
return NT_STATUS_NO_SUCH_USER ;
}
2008-04-15 16:29:13 +02:00
credentials = cli_credentials_init ( s3call ) ;
if ( ! credentials ) {
return NT_STATUS_NO_MEMORY ;
}
cli_credentials_set_conf ( credentials , service - > task - > lp_ctx ) ;
cli_credentials_set_domain ( credentials , domain , CRED_SPECIFIED ) ;
cli_credentials_set_username ( credentials , user , CRED_SPECIFIED ) ;
2010-05-14 17:31:33 +10:00
cli_credentials_set_password ( credentials , s3call - > request - > data . auth . pass , CRED_SPECIFIED ) ;
2008-04-15 16:29:13 +02:00
ctx = wb_cmd_pam_auth_send ( s3call , service , credentials ) ;
2005-10-28 13:42:00 +00:00
NT_STATUS_HAVE_NO_MEMORY ( ctx ) ;
ctx - > async . fn = pam_auth_recv ;
ctx - > async . private_data = s3call ;
2006-01-12 09:38:35 +00:00
s3call - > flags | = WBSRV_CALL_FLAGS_REPLY_ASYNC ;
2005-10-28 13:42:00 +00:00
return NT_STATUS_OK ;
}
static void pam_auth_recv ( struct composite_context * ctx )
{
struct wbsrv_samba3_call * s3call =
talloc_get_type ( ctx - > async . private_data ,
struct wbsrv_samba3_call ) ;
NTSTATUS status ;
2009-10-02 22:17:42 +10:00
DATA_BLOB info3 ;
struct netr_UserSessionKey user_session_key ;
struct netr_LMSessionKey lm_key ;
char * unix_username ;
2005-10-28 13:42:00 +00:00
2009-10-02 22:17:42 +10:00
status = wb_cmd_pam_auth_recv ( ctx , s3call , & info3 ,
& user_session_key , & lm_key , & unix_username ) ;
2005-10-28 13:42:00 +00:00
if ( ! NT_STATUS_IS_OK ( status ) ) goto done ;
2010-05-14 17:31:33 +10:00
if ( s3call - > request - > flags & WBFLAG_PAM_USER_SESSION_KEY ) {
memcpy ( s3call - > response - > data . auth . user_session_key ,
2009-10-02 22:17:42 +10:00
& user_session_key . key ,
2010-05-14 17:31:33 +10:00
sizeof ( s3call - > response - > data . auth . user_session_key ) ) ;
2009-10-02 22:17:42 +10:00
}
2010-05-14 17:31:33 +10:00
if ( s3call - > request - > flags & WBFLAG_PAM_INFO3_TEXT ) {
2009-10-02 22:17:42 +10:00
status = wb_samba3_append_info3_as_txt ( ctx , s3call , info3 ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
DEBUG ( 10 , ( " Failed to append INFO3 (TXT): %s \n " ,
nt_errstr ( status ) ) ) ;
goto done ;
}
}
2010-05-14 17:31:33 +10:00
if ( s3call - > request - > flags & WBFLAG_PAM_INFO3_NDR ) {
s3call - > response - > extra_data . data = info3 . data ;
s3call - > response - > length + = info3 . length ;
2009-10-02 22:17:42 +10:00
}
2010-05-14 17:31:33 +10:00
if ( s3call - > request - > flags & WBFLAG_PAM_LMKEY ) {
memcpy ( s3call - > response - > data . auth . first_8_lm_hash ,
2009-10-02 22:17:42 +10:00
lm_key . key ,
2010-05-14 17:31:33 +10:00
sizeof ( s3call - > response - > data . auth . first_8_lm_hash ) ) ;
2009-10-02 22:17:42 +10:00
}
2010-05-14 17:31:33 +10:00
if ( s3call - > request - > flags & WBFLAG_PAM_UNIX_NAME ) {
WBSRV_SAMBA3_SET_STRING ( s3call - > response - > data . auth . unix_username , unix_username ) ;
2009-10-02 22:17:42 +10:00
}
2005-10-14 21:05:45 +00:00
done :
2005-10-31 04:17:51 +00:00
wbsrv_samba3_async_auth_epilogue ( status , s3call ) ;
2005-10-09 12:13:05 +00:00
}
2005-10-19 21:53:03 +00:00
2005-10-31 05:45:19 +00:00
/*
List trusted domains
*/
2005-10-19 21:53:03 +00:00
static void list_trustdom_recv_doms ( struct composite_context * ctx ) ;
NTSTATUS wbsrv_samba3_list_trustdom ( struct wbsrv_samba3_call * s3call )
{
struct composite_context * ctx ;
struct wbsrv_service * service =
2006-01-12 09:38:35 +00:00
s3call - > wbconn - > listen_socket - > service ;
2005-10-19 21:53:03 +00:00
DEBUG ( 5 , ( " wbsrv_samba3_list_trustdom called \n " ) ) ;
2005-11-05 09:34:07 +00:00
ctx = wb_cmd_list_trustdoms_send ( s3call , service ) ;
2005-10-19 21:53:03 +00:00
NT_STATUS_HAVE_NO_MEMORY ( ctx ) ;
ctx - > async . fn = list_trustdom_recv_doms ;
ctx - > async . private_data = s3call ;
2006-01-12 09:38:35 +00:00
s3call - > flags | = WBSRV_CALL_FLAGS_REPLY_ASYNC ;
2005-10-19 21:53:03 +00:00
return NT_STATUS_OK ;
}
static void list_trustdom_recv_doms ( struct composite_context * ctx )
{
struct wbsrv_samba3_call * s3call =
talloc_get_type ( ctx - > async . private_data ,
struct wbsrv_samba3_call ) ;
2010-03-09 17:54:12 +01:00
uint32_t i , num_domains ;
2005-10-19 21:53:03 +00:00
struct wb_dom_info * * domains ;
NTSTATUS status ;
char * result ;
status = wb_cmd_list_trustdoms_recv ( ctx , s3call , & num_domains ,
& domains ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) goto done ;
result = talloc_strdup ( s3call , " " ) ;
if ( result = = NULL ) {
status = NT_STATUS_NO_MEMORY ;
goto done ;
}
for ( i = 0 ; i < num_domains ; i + + ) {
2007-09-14 23:21:00 +00:00
result = talloc_asprintf_append_buffer (
2005-10-19 21:53:03 +00:00
result , " %s \\ %s \\ %s " ,
domains [ i ] - > name , domains [ i ] - > name ,
dom_sid_string ( s3call , domains [ i ] - > sid ) ) ;
}
if ( result = = NULL ) {
status = NT_STATUS_NO_MEMORY ;
goto done ;
}
2010-05-14 17:31:33 +10:00
s3call - > response - > result = WINBINDD_OK ;
2005-10-19 21:53:03 +00:00
if ( num_domains > 0 ) {
2010-05-14 17:31:33 +10:00
s3call - > response - > extra_data . data = result ;
s3call - > response - > length + = strlen ( result ) + 1 ;
s3call - > response - > data . num_entries = num_domains ;
2005-10-19 21:53:03 +00:00
}
done :
2005-10-23 11:21:15 +00:00
wbsrv_samba3_async_epilogue ( status , s3call ) ;
2005-10-19 21:53:03 +00:00
}
2007-06-29 11:07:19 +00:00
2009-01-15 10:14:55 +01:00
/* list groups */
static void list_groups_recv ( struct composite_context * ctx ) ;
NTSTATUS wbsrv_samba3_list_groups ( struct wbsrv_samba3_call * s3call )
{
struct composite_context * ctx ;
struct wbsrv_service * service = s3call - > wbconn - > listen_socket - > service ;
DEBUG ( 5 , ( " wbsrv_samba4_list_groups called \n " ) ) ;
ctx = wb_cmd_list_groups_send ( s3call , service ,
2010-05-14 17:31:33 +10:00
s3call - > request - > domain_name ) ;
2009-01-15 10:14:55 +01:00
NT_STATUS_HAVE_NO_MEMORY ( ctx ) ;
ctx - > async . fn = list_groups_recv ;
ctx - > async . private_data = s3call ;
s3call - > flags | = WBSRV_CALL_FLAGS_REPLY_ASYNC ;
return NT_STATUS_OK ;
}
static void list_groups_recv ( struct composite_context * ctx )
{
struct wbsrv_samba3_call * s3call = talloc_get_type_abort (
ctx - > async . private_data ,
struct wbsrv_samba3_call ) ;
uint32_t extra_data_len ;
char * extra_data ;
2010-04-19 16:08:41 +02:00
uint32_t num_groups ;
2009-01-15 10:14:55 +01:00
NTSTATUS status ;
DEBUG ( 5 , ( " list_groups_recv called \n " ) ) ;
status = wb_cmd_list_groups_recv ( ctx , s3call , & extra_data_len ,
2010-04-19 16:08:41 +02:00
& extra_data , & num_groups ) ;
2009-01-15 10:14:55 +01:00
if ( NT_STATUS_IS_OK ( status ) ) {
2010-05-14 17:31:33 +10:00
s3call - > response - > extra_data . data = extra_data ;
s3call - > response - > length + = extra_data_len ;
2009-01-15 10:14:55 +01:00
if ( extra_data ) {
2010-05-14 17:31:33 +10:00
s3call - > response - > length + = 1 ;
s3call - > response - > data . num_entries = num_groups ;
2009-01-15 10:14:55 +01:00
}
}
wbsrv_samba3_async_epilogue ( status , s3call ) ;
}
2007-08-16 10:40:04 +00:00
/* List users */
static void list_users_recv ( struct composite_context * ctx ) ;
NTSTATUS wbsrv_samba3_list_users ( struct wbsrv_samba3_call * s3call )
{
struct composite_context * ctx ;
struct wbsrv_service * service =
s3call - > wbconn - > listen_socket - > service ;
DEBUG ( 5 , ( " wbsrv_samba3_list_users called \n " ) ) ;
ctx = wb_cmd_list_users_send ( s3call , service ,
2010-05-14 17:31:33 +10:00
s3call - > request - > domain_name ) ;
2007-08-16 10:40:04 +00:00
NT_STATUS_HAVE_NO_MEMORY ( ctx ) ;
ctx - > async . fn = list_users_recv ;
ctx - > async . private_data = s3call ;
s3call - > flags | = WBSRV_CALL_FLAGS_REPLY_ASYNC ;
return NT_STATUS_OK ;
}
static void list_users_recv ( struct composite_context * ctx )
{
struct wbsrv_samba3_call * s3call =
talloc_get_type ( ctx - > async . private_data ,
struct wbsrv_samba3_call ) ;
uint32_t extra_data_len ;
2007-08-20 11:29:17 +00:00
char * extra_data ;
2010-04-19 16:08:59 +02:00
uint32_t num_users ;
2007-08-16 10:40:04 +00:00
NTSTATUS status ;
DEBUG ( 5 , ( " list_users_recv called \n " ) ) ;
status = wb_cmd_list_users_recv ( ctx , s3call , & extra_data_len ,
2010-04-19 16:08:59 +02:00
& extra_data , & num_users ) ;
2007-08-16 10:40:04 +00:00
if ( NT_STATUS_IS_OK ( status ) ) {
2010-05-14 17:31:33 +10:00
s3call - > response - > extra_data . data = extra_data ;
s3call - > response - > length + = extra_data_len ;
2008-04-18 11:37:43 +02:00
if ( extra_data ) {
2010-05-14 17:31:33 +10:00
s3call - > response - > length + = 1 ;
s3call - > response - > data . num_entries = num_users ;
2008-04-18 11:37:43 +02:00
}
2007-08-16 10:40:04 +00:00
}
wbsrv_samba3_async_epilogue ( status , s3call ) ;
}
2007-06-29 11:07:19 +00:00
/* NSS calls */
2007-08-13 15:49:09 +00:00
static void getpwnam_recv ( struct composite_context * ctx ) ;
2007-06-29 11:07:19 +00:00
NTSTATUS wbsrv_samba3_getpwnam ( struct wbsrv_samba3_call * s3call )
{
2007-08-13 15:49:09 +00:00
struct composite_context * ctx ;
struct wbsrv_service * service =
s3call - > wbconn - > listen_socket - > service ;
2007-06-29 11:07:19 +00:00
DEBUG ( 5 , ( " wbsrv_samba3_getpwnam called \n " ) ) ;
2007-08-13 15:49:09 +00:00
ctx = wb_cmd_getpwnam_send ( s3call , service ,
2010-05-14 17:31:33 +10:00
s3call - > request - > data . username ) ;
2007-08-13 15:49:09 +00:00
NT_STATUS_HAVE_NO_MEMORY ( ctx ) ;
ctx - > async . fn = getpwnam_recv ;
ctx - > async . private_data = s3call ;
s3call - > flags | = WBSRV_CALL_FLAGS_REPLY_ASYNC ;
2007-06-29 11:07:19 +00:00
return NT_STATUS_OK ;
}
2007-08-13 15:49:09 +00:00
static void getpwnam_recv ( struct composite_context * ctx )
{
struct wbsrv_samba3_call * s3call =
talloc_get_type ( ctx - > async . private_data ,
struct wbsrv_samba3_call ) ;
NTSTATUS status ;
struct winbindd_pw * pw ;
DEBUG ( 5 , ( " getpwnam_recv called \n " ) ) ;
status = wb_cmd_getpwnam_recv ( ctx , s3call , & pw ) ;
if ( NT_STATUS_IS_OK ( status ) )
2010-05-14 17:31:33 +10:00
s3call - > response - > data . pw = * pw ;
2007-08-13 15:49:09 +00:00
wbsrv_samba3_async_epilogue ( status , s3call ) ;
}
2007-08-13 16:34:29 +00:00
static void getpwuid_recv ( struct composite_context * ctx ) ;
2007-06-29 11:07:19 +00:00
NTSTATUS wbsrv_samba3_getpwuid ( struct wbsrv_samba3_call * s3call )
{
2007-08-13 16:34:29 +00:00
struct composite_context * ctx ;
struct wbsrv_service * service = s3call - > wbconn - > listen_socket - > service ;
2007-06-29 11:07:19 +00:00
DEBUG ( 5 , ( " wbsrv_samba3_getpwuid called \n " ) ) ;
2007-08-13 16:34:29 +00:00
ctx = wb_cmd_getpwuid_send ( s3call , service ,
2010-05-14 17:31:33 +10:00
s3call - > request - > data . uid ) ;
2007-08-13 16:34:29 +00:00
NT_STATUS_HAVE_NO_MEMORY ( ctx ) ;
ctx - > async . fn = getpwuid_recv ;
ctx - > async . private_data = s3call ;
s3call - > flags | = WBSRV_CALL_FLAGS_REPLY_ASYNC ;
2007-06-29 11:07:19 +00:00
return NT_STATUS_OK ;
}
2007-08-13 16:34:29 +00:00
static void getpwuid_recv ( struct composite_context * ctx )
{
struct wbsrv_samba3_call * s3call =
talloc_get_type ( ctx - > async . private_data ,
struct wbsrv_samba3_call ) ;
NTSTATUS status ;
struct winbindd_pw * pw ;
DEBUG ( 5 , ( " getpwuid_recv called \n " ) ) ;
status = wb_cmd_getpwuid_recv ( ctx , s3call , & pw ) ;
if ( NT_STATUS_IS_OK ( status ) )
2010-05-14 17:31:33 +10:00
s3call - > response - > data . pw = * pw ;
2007-08-13 16:34:29 +00:00
wbsrv_samba3_async_epilogue ( status , s3call ) ;
}
2007-08-20 11:38:00 +00:00
static void setpwent_recv ( struct composite_context * ctx ) ;
2007-06-29 11:07:19 +00:00
NTSTATUS wbsrv_samba3_setpwent ( struct wbsrv_samba3_call * s3call )
{
2007-08-20 11:38:00 +00:00
struct composite_context * ctx ;
struct wbsrv_service * service = s3call - > wbconn - > listen_socket - > service ;
2007-06-29 11:07:19 +00:00
DEBUG ( 5 , ( " wbsrv_samba3_setpwent called \n " ) ) ;
2007-08-20 11:38:00 +00:00
ctx = wb_cmd_setpwent_send ( s3call , service ) ;
NT_STATUS_HAVE_NO_MEMORY ( ctx ) ;
ctx - > async . fn = setpwent_recv ;
ctx - > async . private_data = s3call ;
s3call - > flags | = WBSRV_CALL_FLAGS_REPLY_ASYNC ;
2007-06-29 11:07:19 +00:00
return NT_STATUS_OK ;
}
2007-08-20 11:38:00 +00:00
static void setpwent_recv ( struct composite_context * ctx )
{
struct wbsrv_samba3_call * s3call =
talloc_get_type ( ctx - > async . private_data ,
struct wbsrv_samba3_call ) ;
NTSTATUS status ;
struct wbsrv_pwent * pwent ;
DEBUG ( 5 , ( " setpwent_recv called \n " ) ) ;
status = wb_cmd_setpwent_recv ( ctx , s3call - > wbconn , & pwent ) ;
if ( NT_STATUS_IS_OK ( status ) ) {
s3call - > wbconn - > protocol_private_data = pwent ;
}
wbsrv_samba3_async_epilogue ( status , s3call ) ;
}
2007-08-20 11:51:01 +00:00
static void getpwent_recv ( struct composite_context * ctx ) ;
2007-06-29 11:07:19 +00:00
NTSTATUS wbsrv_samba3_getpwent ( struct wbsrv_samba3_call * s3call )
{
2007-08-20 11:51:01 +00:00
struct composite_context * ctx ;
struct wbsrv_service * service = s3call - > wbconn - > listen_socket - > service ;
struct wbsrv_pwent * pwent ;
2007-06-29 11:07:19 +00:00
DEBUG ( 5 , ( " wbsrv_samba3_getpwent called \n " ) ) ;
2007-08-20 11:51:01 +00:00
NT_STATUS_HAVE_NO_MEMORY ( s3call - > wbconn - > protocol_private_data ) ;
pwent = talloc_get_type ( s3call - > wbconn - > protocol_private_data ,
struct wbsrv_pwent ) ;
NT_STATUS_HAVE_NO_MEMORY ( pwent ) ;
ctx = wb_cmd_getpwent_send ( s3call , service , pwent ,
2010-05-14 17:31:33 +10:00
s3call - > request - > data . num_entries ) ;
2007-08-20 11:51:01 +00:00
NT_STATUS_HAVE_NO_MEMORY ( ctx ) ;
ctx - > async . fn = getpwent_recv ;
ctx - > async . private_data = s3call ;
s3call - > flags | = WBSRV_CALL_FLAGS_REPLY_ASYNC ;
2007-06-29 11:07:19 +00:00
return NT_STATUS_OK ;
}
2007-08-20 11:51:01 +00:00
static void getpwent_recv ( struct composite_context * ctx )
{
struct wbsrv_samba3_call * s3call =
talloc_get_type ( ctx - > async . private_data ,
struct wbsrv_samba3_call ) ;
NTSTATUS status ;
struct winbindd_pw * pw ;
uint32_t num_users ;
DEBUG ( 5 , ( " getpwent_recv called \n " ) ) ;
status = wb_cmd_getpwent_recv ( ctx , s3call , & pw , & num_users ) ;
if ( NT_STATUS_IS_OK ( status ) ) {
uint32_t extra_len = sizeof ( struct winbindd_pw ) * num_users ;
2010-05-14 17:31:33 +10:00
s3call - > response - > data . num_entries = num_users ;
s3call - > response - > extra_data . data = pw ;
s3call - > response - > length + = extra_len ;
2007-08-20 11:51:01 +00:00
}
wbsrv_samba3_async_epilogue ( status , s3call ) ;
}
2007-06-29 11:07:19 +00:00
NTSTATUS wbsrv_samba3_endpwent ( struct wbsrv_samba3_call * s3call )
{
2007-08-20 11:41:36 +00:00
struct wbsrv_pwent * pwent =
talloc_get_type ( s3call - > wbconn - > protocol_private_data ,
struct wbsrv_pwent ) ;
2007-06-29 11:07:19 +00:00
DEBUG ( 5 , ( " wbsrv_samba3_endpwent called \n " ) ) ;
2007-08-20 11:41:36 +00:00
talloc_free ( pwent ) ;
s3call - > wbconn - > protocol_private_data = NULL ;
2010-05-14 17:31:33 +10:00
s3call - > response - > result = WINBINDD_OK ;
2007-06-29 11:07:19 +00:00
return NT_STATUS_OK ;
}
2008-12-26 10:36:29 +01:00
static void getgrnam_recv ( struct composite_context * ctx ) ;
2007-06-29 11:07:19 +00:00
NTSTATUS wbsrv_samba3_getgrnam ( struct wbsrv_samba3_call * s3call )
{
2008-12-26 10:36:29 +01:00
struct composite_context * ctx ;
struct wbsrv_service * service =
s3call - > wbconn - > listen_socket - > service ;
2007-06-29 11:07:19 +00:00
DEBUG ( 5 , ( " wbsrv_samba3_getgrnam called \n " ) ) ;
2008-12-26 10:36:29 +01:00
ctx = wb_cmd_getgrnam_send ( s3call , service ,
2010-05-14 17:31:33 +10:00
s3call - > request - > data . groupname ) ;
2008-12-26 10:36:29 +01:00
NT_STATUS_HAVE_NO_MEMORY ( ctx ) ;
ctx - > async . fn = getgrnam_recv ;
ctx - > async . private_data = s3call ;
s3call - > flags | = WBSRV_CALL_FLAGS_REPLY_ASYNC ;
2007-06-29 11:07:19 +00:00
return NT_STATUS_OK ;
}
2008-12-26 10:36:29 +01:00
static void getgrnam_recv ( struct composite_context * ctx )
{
struct wbsrv_samba3_call * s3call =
talloc_get_type ( ctx - > async . private_data ,
struct wbsrv_samba3_call ) ;
NTSTATUS status ;
struct winbindd_gr * gr ;
DEBUG ( 5 , ( " getgrnam_recv called \n " ) ) ;
status = wb_cmd_getgrnam_recv ( ctx , s3call , & gr ) ;
if ( NT_STATUS_IS_OK ( status ) )
2010-05-14 17:31:33 +10:00
s3call - > response - > data . gr = * gr ;
2008-12-26 10:36:29 +01:00
wbsrv_samba3_async_epilogue ( status , s3call ) ;
}
2008-12-26 12:45:50 +01:00
static void getgrgid_recv ( struct composite_context * ctx ) ;
2007-06-29 11:07:19 +00:00
NTSTATUS wbsrv_samba3_getgrgid ( struct wbsrv_samba3_call * s3call )
{
2008-12-26 12:45:50 +01:00
struct composite_context * ctx ;
struct wbsrv_service * service = s3call - > wbconn - > listen_socket - > service ;
2007-06-29 11:07:19 +00:00
DEBUG ( 5 , ( " wbsrv_samba3_getgrgid called \n " ) ) ;
2008-12-26 12:45:50 +01:00
ctx = wb_cmd_getgrgid_send ( s3call , service ,
2010-05-14 17:31:33 +10:00
s3call - > request - > data . gid ) ;
2008-12-26 12:45:50 +01:00
NT_STATUS_HAVE_NO_MEMORY ( ctx ) ;
ctx - > async . fn = getgrgid_recv ;
ctx - > async . private_data = s3call ;
s3call - > flags | = WBSRV_CALL_FLAGS_REPLY_ASYNC ;
2007-06-29 11:07:19 +00:00
return NT_STATUS_OK ;
}
2008-12-26 12:45:50 +01:00
static void getgrgid_recv ( struct composite_context * ctx )
{
struct wbsrv_samba3_call * s3call =
talloc_get_type ( ctx - > async . private_data ,
struct wbsrv_samba3_call ) ;
NTSTATUS status ;
struct winbindd_gr * gr ;
DEBUG ( 5 , ( " getgrgid_recv called \n " ) ) ;
status = wb_cmd_getgrgid_recv ( ctx , s3call , & gr ) ;
if ( NT_STATUS_IS_OK ( status ) )
2010-05-14 17:31:33 +10:00
s3call - > response - > data . gr = * gr ;
2008-12-26 12:45:50 +01:00
wbsrv_samba3_async_epilogue ( status , s3call ) ;
}
2010-03-04 03:05:06 +03:00
static void getgroups_recv ( struct composite_context * ctx ) ;
2007-06-29 11:07:19 +00:00
NTSTATUS wbsrv_samba3_getgroups ( struct wbsrv_samba3_call * s3call )
{
2010-03-04 03:05:06 +03:00
struct composite_context * ctx ;
struct wbsrv_service * service = s3call - > wbconn - > listen_socket - > service ;
2007-06-29 11:07:19 +00:00
DEBUG ( 5 , ( " wbsrv_samba3_getgroups called \n " ) ) ;
2010-03-04 03:05:06 +03:00
/* S3 code do the same so why not ... */
2010-05-14 17:31:33 +10:00
s3call - > request - > data . username [ sizeof ( s3call - > request - > data . username ) - 1 ] = ' \0 ' ;
ctx = wb_cmd_getgroups_send ( s3call , service , s3call - > request - > data . username ) ;
2010-03-04 03:05:06 +03:00
NT_STATUS_HAVE_NO_MEMORY ( ctx ) ;
ctx - > async . fn = getgroups_recv ;
ctx - > async . private_data = s3call ;
s3call - > flags | = WBSRV_CALL_FLAGS_REPLY_ASYNC ;
2007-06-29 11:07:19 +00:00
return NT_STATUS_OK ;
}
2010-03-04 03:05:06 +03:00
static void getgroups_recv ( struct composite_context * ctx )
2010-03-04 02:46:36 +03:00
{
struct wbsrv_samba3_call * s3call =
talloc_get_type ( ctx - > async . private_data ,
struct wbsrv_samba3_call ) ;
2010-03-04 03:05:06 +03:00
gid_t * gids ;
uint32_t num_groups ;
2010-03-04 02:46:36 +03:00
NTSTATUS status ;
2010-03-04 03:05:06 +03:00
DEBUG ( 5 , ( " getgroups_recv called \n " ) ) ;
2010-03-04 02:46:36 +03:00
2010-03-04 03:05:06 +03:00
status = wb_cmd_getgroups_recv ( ctx , s3call , & gids , & num_groups ) ;
2010-03-04 02:46:36 +03:00
if ( NT_STATUS_IS_OK ( status ) ) {
2010-03-04 03:05:06 +03:00
uint32_t extra_len = sizeof ( gid_t ) * num_groups ;
2010-05-14 17:31:33 +10:00
s3call - > response - > data . num_entries = num_groups ;
s3call - > response - > extra_data . data = gids ;
s3call - > response - > length + = extra_len ;
2010-03-04 03:05:06 +03:00
} else {
2010-05-14 17:31:33 +10:00
s3call - > response - > result = WINBINDD_ERROR ;
2010-03-04 02:46:36 +03:00
}
wbsrv_samba3_async_epilogue ( status , s3call ) ;
}
2010-03-04 03:05:06 +03:00
static void setgrent_recv ( struct composite_context * ctx ) ;
2007-06-29 11:07:19 +00:00
NTSTATUS wbsrv_samba3_setgrent ( struct wbsrv_samba3_call * s3call )
{
2010-03-04 02:46:36 +03:00
struct composite_context * ctx ;
struct wbsrv_service * service = s3call - > wbconn - > listen_socket - > service ;
2007-06-29 11:07:19 +00:00
DEBUG ( 5 , ( " wbsrv_samba3_setgrent called \n " ) ) ;
2010-03-04 02:46:36 +03:00
ctx = wb_cmd_setgrent_send ( s3call , service ) ;
NT_STATUS_HAVE_NO_MEMORY ( ctx ) ;
ctx - > async . fn = setgrent_recv ;
ctx - > async . private_data = s3call ;
s3call - > flags | = WBSRV_CALL_FLAGS_REPLY_ASYNC ;
2007-06-29 11:07:19 +00:00
return NT_STATUS_OK ;
}
2010-03-04 03:05:06 +03:00
static void setgrent_recv ( struct composite_context * ctx )
2010-03-04 02:46:36 +03:00
{
struct wbsrv_samba3_call * s3call =
talloc_get_type ( ctx - > async . private_data ,
struct wbsrv_samba3_call ) ;
NTSTATUS status ;
2010-03-04 03:05:06 +03:00
struct wbsrv_grent * grent ;
2010-03-04 02:46:36 +03:00
2010-03-04 03:05:06 +03:00
DEBUG ( 5 , ( " setpwent_recv called \n " ) ) ;
2010-03-04 02:46:36 +03:00
2010-03-04 03:05:06 +03:00
status = wb_cmd_setgrent_recv ( ctx , s3call - > wbconn , & grent ) ;
2010-03-04 02:46:36 +03:00
if ( NT_STATUS_IS_OK ( status ) ) {
2010-03-04 03:05:06 +03:00
s3call - > wbconn - > protocol_private_data = grent ;
2010-03-04 02:46:36 +03:00
}
wbsrv_samba3_async_epilogue ( status , s3call ) ;
}
2010-03-04 03:05:06 +03:00
static void getgrent_recv ( struct composite_context * ctx ) ;
2007-06-29 11:07:19 +00:00
NTSTATUS wbsrv_samba3_getgrent ( struct wbsrv_samba3_call * s3call )
{
2010-03-04 02:46:36 +03:00
struct composite_context * ctx ;
struct wbsrv_service * service = s3call - > wbconn - > listen_socket - > service ;
struct wbsrv_grent * grent ;
2007-06-29 11:07:19 +00:00
DEBUG ( 5 , ( " wbsrv_samba3_getgrent called \n " ) ) ;
2010-03-04 02:46:36 +03:00
NT_STATUS_HAVE_NO_MEMORY ( s3call - > wbconn - > protocol_private_data ) ;
grent = talloc_get_type ( s3call - > wbconn - > protocol_private_data ,
struct wbsrv_grent ) ;
NT_STATUS_HAVE_NO_MEMORY ( grent ) ;
ctx = wb_cmd_getgrent_send ( s3call , service , grent ,
2010-05-14 17:31:33 +10:00
s3call - > request - > data . num_entries ) ;
2010-03-04 02:46:36 +03:00
NT_STATUS_HAVE_NO_MEMORY ( ctx ) ;
ctx - > async . fn = getgrent_recv ;
ctx - > async . private_data = s3call ;
s3call - > flags | = WBSRV_CALL_FLAGS_REPLY_ASYNC ;
2007-06-29 11:07:19 +00:00
return NT_STATUS_OK ;
}
2010-03-04 03:05:06 +03:00
static void getgrent_recv ( struct composite_context * ctx )
{
struct wbsrv_samba3_call * s3call =
talloc_get_type ( ctx - > async . private_data ,
struct wbsrv_samba3_call ) ;
NTSTATUS status ;
struct winbindd_gr * gr ;
uint32_t num_groups ;
DEBUG ( 5 , ( " getgrent_recv called \n " ) ) ;
status = wb_cmd_getgrent_recv ( ctx , s3call , & gr , & num_groups ) ;
if ( NT_STATUS_IS_OK ( status ) ) {
uint32_t extra_len = sizeof ( struct winbindd_gr ) * num_groups ;
2010-05-14 17:31:33 +10:00
s3call - > response - > data . num_entries = num_groups ;
s3call - > response - > extra_data . data = gr ;
s3call - > response - > length + = extra_len ;
2010-03-04 03:05:06 +03:00
}
wbsrv_samba3_async_epilogue ( status , s3call ) ;
}
2007-06-29 11:07:19 +00:00
NTSTATUS wbsrv_samba3_endgrent ( struct wbsrv_samba3_call * s3call )
{
DEBUG ( 5 , ( " wbsrv_samba3_endgrent called \n " ) ) ;
2010-05-14 17:31:33 +10:00
s3call - > response - > result = WINBINDD_OK ;
2007-06-29 11:07:19 +00:00
return NT_STATUS_OK ;
}
2007-08-13 15:58:41 +00:00
static void sid2uid_recv ( struct composite_context * ctx ) ;
NTSTATUS wbsrv_samba3_sid2uid ( struct wbsrv_samba3_call * s3call )
{
struct composite_context * ctx ;
struct wbsrv_service * service =
s3call - > wbconn - > listen_socket - > service ;
struct dom_sid * sid ;
2007-08-16 09:01:59 +00:00
DEBUG ( 5 , ( " wbsrv_samba3_sid2uid called \n " ) ) ;
2007-08-13 15:58:41 +00:00
2010-05-14 17:31:33 +10:00
sid = dom_sid_parse_talloc ( s3call , s3call - > request - > data . sid ) ;
2007-08-13 15:58:41 +00:00
NT_STATUS_HAVE_NO_MEMORY ( sid ) ;
ctx = wb_sid2uid_send ( s3call , service , sid ) ;
NT_STATUS_HAVE_NO_MEMORY ( ctx ) ;
ctx - > async . fn = sid2uid_recv ;
ctx - > async . private_data = s3call ;
s3call - > flags | = WBSRV_CALL_FLAGS_REPLY_ASYNC ;
return NT_STATUS_OK ;
}
static void sid2uid_recv ( struct composite_context * ctx )
{
struct wbsrv_samba3_call * s3call =
talloc_get_type ( ctx - > async . private_data ,
struct wbsrv_samba3_call ) ;
NTSTATUS status ;
2007-08-14 07:21:10 +00:00
DEBUG ( 5 , ( " sid2uid_recv called \n " ) ) ;
2007-08-13 15:58:41 +00:00
2010-05-14 17:31:33 +10:00
status = wb_sid2uid_recv ( ctx , & s3call - > response - > data . uid ) ;
2007-08-13 15:58:41 +00:00
wbsrv_samba3_async_epilogue ( status , s3call ) ;
}
static void sid2gid_recv ( struct composite_context * ctx ) ;
NTSTATUS wbsrv_samba3_sid2gid ( struct wbsrv_samba3_call * s3call )
{
struct composite_context * ctx ;
struct wbsrv_service * service =
s3call - > wbconn - > listen_socket - > service ;
struct dom_sid * sid ;
2007-08-14 07:21:10 +00:00
DEBUG ( 5 , ( " wbsrv_samba3_sid2gid called \n " ) ) ;
2007-08-13 15:58:41 +00:00
2010-05-14 17:31:33 +10:00
sid = dom_sid_parse_talloc ( s3call , s3call - > request - > data . sid ) ;
2007-08-13 15:58:41 +00:00
NT_STATUS_HAVE_NO_MEMORY ( sid ) ;
ctx = wb_sid2gid_send ( s3call , service , sid ) ;
NT_STATUS_HAVE_NO_MEMORY ( ctx ) ;
ctx - > async . fn = sid2gid_recv ;
ctx - > async . private_data = s3call ;
s3call - > flags | = WBSRV_CALL_FLAGS_REPLY_ASYNC ;
return NT_STATUS_OK ;
}
static void sid2gid_recv ( struct composite_context * ctx )
{
struct wbsrv_samba3_call * s3call =
talloc_get_type ( ctx - > async . private_data ,
struct wbsrv_samba3_call ) ;
NTSTATUS status ;
2007-08-14 07:21:10 +00:00
DEBUG ( 5 , ( " sid2gid_recv called \n " ) ) ;
2007-08-13 15:58:41 +00:00
2010-05-14 17:31:33 +10:00
status = wb_sid2gid_recv ( ctx , & s3call - > response - > data . gid ) ;
2007-08-13 15:58:41 +00:00
wbsrv_samba3_async_epilogue ( status , s3call ) ;
}
2007-08-13 16:07:47 +00:00
static void uid2sid_recv ( struct composite_context * ctx ) ;
NTSTATUS wbsrv_samba3_uid2sid ( struct wbsrv_samba3_call * s3call )
{
struct composite_context * ctx ;
struct wbsrv_service * service =
s3call - > wbconn - > listen_socket - > service ;
DEBUG ( 5 , ( " wbsrv_samba3_uid2sid called \n " ) ) ;
2010-05-14 17:31:33 +10:00
ctx = wb_uid2sid_send ( s3call , service , s3call - > request - > data . uid ) ;
2007-08-13 16:07:47 +00:00
NT_STATUS_HAVE_NO_MEMORY ( ctx ) ;
ctx - > async . fn = uid2sid_recv ;
ctx - > async . private_data = s3call ;
s3call - > flags | = WBSRV_CALL_FLAGS_REPLY_ASYNC ;
return NT_STATUS_OK ;
}
static void uid2sid_recv ( struct composite_context * ctx )
{
struct wbsrv_samba3_call * s3call =
talloc_get_type ( ctx - > async . private_data ,
struct wbsrv_samba3_call ) ;
NTSTATUS status ;
struct dom_sid * sid ;
char * sid_str ;
DEBUG ( 5 , ( " uid2sid_recv called \n " ) ) ;
status = wb_uid2sid_recv ( ctx , s3call , & sid ) ;
if ( NT_STATUS_IS_OK ( status ) ) {
sid_str = dom_sid_string ( s3call , sid ) ;
/* If the conversion failed, bail out with a failure. */
if ( sid_str = = NULL )
wbsrv_samba3_async_epilogue ( NT_STATUS_NO_MEMORY , s3call ) ;
/* But we assume this worked, so we'll set the string. Work
* done . */
2010-05-14 17:31:33 +10:00
WBSRV_SAMBA3_SET_STRING ( s3call - > response - > data . sid . sid , sid_str ) ;
s3call - > response - > data . sid . type = SID_NAME_USER ;
2007-08-13 16:07:47 +00:00
}
wbsrv_samba3_async_epilogue ( status , s3call ) ;
}
2007-08-13 16:20:26 +00:00
static void gid2sid_recv ( struct composite_context * ctx ) ;
NTSTATUS wbsrv_samba3_gid2sid ( struct wbsrv_samba3_call * s3call )
{
struct composite_context * ctx ;
struct wbsrv_service * service =
s3call - > wbconn - > listen_socket - > service ;
DEBUG ( 5 , ( " wbsrv_samba3_gid2sid called \n " ) ) ;
2010-05-14 17:31:33 +10:00
ctx = wb_gid2sid_send ( s3call , service , s3call - > request - > data . gid ) ;
2007-08-13 16:20:26 +00:00
NT_STATUS_HAVE_NO_MEMORY ( ctx ) ;
ctx - > async . fn = gid2sid_recv ;
ctx - > async . private_data = s3call ;
s3call - > flags | = WBSRV_CALL_FLAGS_REPLY_ASYNC ;
return NT_STATUS_OK ;
}
static void gid2sid_recv ( struct composite_context * ctx )
{
struct wbsrv_samba3_call * s3call =
talloc_get_type ( ctx - > async . private_data ,
struct wbsrv_samba3_call ) ;
NTSTATUS status ;
struct dom_sid * sid ;
char * sid_str ;
DEBUG ( 5 , ( " gid2sid_recv called \n " ) ) ;
status = wb_gid2sid_recv ( ctx , s3call , & sid ) ;
if ( NT_STATUS_IS_OK ( status ) ) {
sid_str = dom_sid_string ( s3call , sid ) ;
if ( sid_str = = NULL )
wbsrv_samba3_async_epilogue ( NT_STATUS_NO_MEMORY , s3call ) ;
2010-05-14 17:31:33 +10:00
WBSRV_SAMBA3_SET_STRING ( s3call - > response - > data . sid . sid , sid_str ) ;
s3call - > response - > data . sid . type = SID_NAME_DOMAIN ;
2007-08-13 16:20:26 +00:00
}
wbsrv_samba3_async_epilogue ( status , s3call ) ;
}
2011-07-26 10:52:59 +10:00
static void sids2xids_recv ( struct composite_context * ctx )
{
struct wbsrv_samba3_call * s3call =
talloc_get_type ( ctx - > async . private_data ,
struct wbsrv_samba3_call ) ;
NTSTATUS status ;
struct id_map * ids ;
unsigned i , count ;
struct winbindd_response * resp = s3call - > response ;
DEBUG ( 5 , ( " sids2xids_recv called \n " ) ) ;
status = wb_sids2xids_recv ( ctx , & ids , & count ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
goto done ;
}
/* fill in extra_data with the list of IDs. Each is prefixed
* by ' U ' or ' G ' for user and group , and followed by a
* newline */
resp - > extra_data . data = talloc_strdup ( resp , " " ) ;
if ( resp - > extra_data . data = = NULL ) {
status = NT_STATUS_NO_MEMORY ;
goto done ;
}
for ( i = 0 ; i < count ; i + + ) {
char type_char = ' * ' ;
if ( ids [ i ] . status ! = ID_MAPPED ) {
resp - > extra_data . data = talloc_asprintf_append_buffer ( resp - > extra_data . data , " \n " ) ;
if ( resp - > extra_data . data = = NULL ) {
status = NT_STATUS_NO_MEMORY ;
goto done ;
}
continue ;
}
switch ( ids [ i ] . xid . type ) {
case ID_TYPE_UID :
type_char = ' U ' ;
break ;
case ID_TYPE_GID :
type_char = ' G ' ;
break ;
case ID_TYPE_BOTH :
type_char = ' B ' ;
break ;
case ID_TYPE_NOT_SPECIFIED :
type_char = ' N ' ;
break ;
}
resp - > extra_data . data = talloc_asprintf_append_buffer ( resp - > extra_data . data , " %c%u \n " ,
type_char , ( unsigned ) ids [ i ] . xid . id ) ;
if ( resp - > extra_data . data = = NULL ) {
status = NT_STATUS_NO_MEMORY ;
goto done ;
}
}
resp - > length + = strlen ( resp - > extra_data . data ) + 1 ;
done :
wbsrv_samba3_async_epilogue ( status , s3call ) ;
}
NTSTATUS wbsrv_samba3_sids2xids ( struct wbsrv_samba3_call * s3call )
{
struct composite_context * ctx ;
struct wbsrv_service * service =
s3call - > wbconn - > listen_socket - > service ;
struct id_map * ids = NULL ;
unsigned count = 0 ;
char * saveptr = NULL ;
char * sidstr ;
DEBUG ( 5 , ( " wbsrv_samba3_sids2xids called \n " ) ) ;
for ( sidstr = strtok_r ( s3call - > request - > extra_data . data , " \n " , & saveptr ) ;
sidstr ;
sidstr = strtok_r ( NULL , " \n " , & saveptr ) ) {
count + = 1 ;
ids = talloc_realloc ( s3call , ids , struct id_map , count ) ;
NT_STATUS_HAVE_NO_MEMORY ( ids ) ;
ids [ count - 1 ] . sid = dom_sid_parse_talloc ( ids , sidstr ) ;
NT_STATUS_HAVE_NO_MEMORY ( ids - > sid ) ;
}
ctx = wb_sids2xids_send ( s3call , service , count , ids ) ;
NT_STATUS_HAVE_NO_MEMORY ( ctx ) ;
ctx - > async . fn = sids2xids_recv ;
ctx - > async . private_data = s3call ;
s3call - > flags | = WBSRV_CALL_FLAGS_REPLY_ASYNC ;
return NT_STATUS_OK ;
}