2008-02-07 14:40:39 +01:00
/*
Unix SMB / CIFS implementation .
SAMR Pipe utility functions .
2008-02-07 14:40:39 +01:00
Copyright ( C ) Luke Kenneth Casson Leighton 1996 - 1998
Copyright ( C ) Gerald ( Jerry ) Carter 2000 - 2001
Copyright ( C ) Andrew Bartlett 2001 - 2002
Copyright ( C ) Stefan ( metze ) Metzmacher 2002
2008-02-07 14:40:39 +01: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-09 19:25:36 +00:00
the Free Software Foundation ; either version 3 of the License , or
( at your option ) any later version .
2008-02-07 14:40:39 +01:00
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 .
2008-02-07 14:40:39 +01:00
You should have received a copy of the GNU General Public License
2007-07-10 00:52:41 +00:00
along with this program . If not , see < http : //www.gnu.org/licenses/>.
*/
# include "includes.h"
# undef DBGC_CLASS
# define DBGC_CLASS DBGC_RPC_SRV
# define STRING_CHANGED (old_string && !new_string) ||\
( ! old_string & & new_string ) | | \
( old_string & & new_string & & ( strcmp ( old_string , new_string ) ! = 0 ) )
# define STRING_CHANGED_NC(s1,s2) ((s1) && !(s2)) ||\
( ! ( s1 ) & & ( s2 ) ) | | \
( ( s1 ) & & ( s2 ) & & ( strcmp ( ( s1 ) , ( s2 ) ) ! = 0 ) )
/*************************************************************
2008-02-11 21:09:21 +01:00
Copies a struct samr_UserInfo20 to a struct samu
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
2008-02-11 21:09:21 +01:00
void copy_id20_to_sam_passwd ( struct samu * to ,
struct samr_UserInfo20 * from )
{
const char * old_string ;
char * new_string ;
DATA_BLOB mung ;
2008-01-19 02:12:35 +01:00
if ( from = = NULL | | to = = NULL )
return ;
2008-01-19 02:12:35 +01:00
2008-02-11 21:09:21 +01:00
#if 0
if ( from - > hdr_munged_dial . buffer ) {
old_string = pdb_get_munged_dial ( to ) ;
mung . length = from - > hdr_munged_dial . uni_str_len ;
mung . data = ( uint8 * ) from - > uni_munged_dial . buffer ;
2007-01-05 14:52:10 +00:00
mung . free = NULL ;
2004-05-07 08:42:13 +00:00
new_string = ( mung . length = = 0 ) ?
2008-01-19 02:12:35 +01:00
NULL : base64_encode_data_blob ( talloc_tos ( ) , mung ) ;
DEBUG ( 10 , ( " INFO_20 UNI_MUNGED_DIAL: %s -> %s \n " , old_string , new_string ) ) ;
if ( STRING_CHANGED_NC ( old_string , new_string ) )
pdb_set_munged_dial ( to , new_string , PDB_CHANGED ) ;
2007-10-28 19:15:08 +01:00
TALLOC_FREE ( new_string ) ;
}
2008-02-11 21:09:21 +01:00
# endif
}
/*************************************************************
2008-02-11 21:09:21 +01:00
Copies a struct samr_UserInfo21 to a struct samu
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
2008-02-11 21:09:21 +01:00
void copy_id21_to_sam_passwd ( struct samu * to ,
struct samr_UserInfo21 * from )
{
time_t unix_time , stored_time ;
const char * old_string , * new_string ;
DATA_BLOB mung ;
2008-02-07 14:40:39 +01:00
if ( from = = NULL | | to = = NULL )
return ;
if ( from - > fields_present & ACCT_LAST_LOGON ) {
2008-02-11 21:09:21 +01:00
unix_time = nt_time_to_unix ( from - > last_logon ) ;
stored_time = pdb_get_logon_time ( to ) ;
DEBUG ( 10 , ( " INFO_21 LOGON_TIME: %lu -> %lu \n " , ( long unsigned int ) stored_time , ( long unsigned int ) unix_time ) ) ;
2008-02-07 14:40:39 +01:00
if ( stored_time ! = unix_time )
pdb_set_logon_time ( to , unix_time , PDB_CHANGED ) ;
}
if ( from - > fields_present & ACCT_LAST_LOGOFF ) {
2008-02-11 21:09:21 +01:00
unix_time = nt_time_to_unix ( from - > last_logoff ) ;
stored_time = pdb_get_logoff_time ( to ) ;
DEBUG ( 10 , ( " INFO_21 LOGOFF_TIME: %lu -> %lu \n " , ( long unsigned int ) stored_time , ( long unsigned int ) unix_time ) ) ;
2008-02-07 14:40:39 +01:00
if ( stored_time ! = unix_time )
pdb_set_logoff_time ( to , unix_time , PDB_CHANGED ) ;
}
if ( from - > fields_present & ACCT_EXPIRY ) {
2008-02-11 21:09:21 +01:00
unix_time = nt_time_to_unix ( from - > acct_expiry ) ;
stored_time = pdb_get_kickoff_time ( to ) ;
DEBUG ( 10 , ( " INFO_21 KICKOFF_TIME: %lu -> %lu \n " , ( long unsigned int ) stored_time , ( long unsigned int ) unix_time ) ) ;
2008-02-07 14:40:39 +01:00
if ( stored_time ! = unix_time )
pdb_set_kickoff_time ( to , unix_time , PDB_CHANGED ) ;
2008-02-07 14:40:39 +01:00
}
if ( from - > fields_present & ACCT_LAST_PWD_CHANGE ) {
2008-02-11 21:09:21 +01:00
unix_time = nt_time_to_unix ( from - > last_password_change ) ;
stored_time = pdb_get_pass_last_set_time ( to ) ;
DEBUG ( 10 , ( " INFO_21 PASS_LAST_SET: %lu -> %lu \n " , ( long unsigned int ) stored_time , ( long unsigned int ) unix_time ) ) ;
2008-02-07 14:40:39 +01:00
if ( stored_time ! = unix_time )
pdb_set_pass_last_set_time ( to , unix_time , PDB_CHANGED ) ;
}
if ( ( from - > fields_present & ACCT_USERNAME ) & &
2008-02-11 21:09:21 +01:00
( from - > account_name . string ) ) {
old_string = pdb_get_username ( to ) ;
2008-02-11 21:09:21 +01:00
new_string = from - > account_name . string ;
DEBUG ( 10 , ( " INFO_21 UNI_USER_NAME: %s -> %s \n " , old_string , new_string ) ) ;
if ( STRING_CHANGED )
pdb_set_username ( to , new_string , PDB_CHANGED ) ;
}
if ( ( from - > fields_present & ACCT_FULL_NAME ) & &
2008-02-11 21:09:21 +01:00
( from - > full_name . string ) ) {
old_string = pdb_get_fullname ( to ) ;
2008-02-11 21:09:21 +01:00
new_string = from - > full_name . string ;
DEBUG ( 10 , ( " INFO_21 UNI_FULL_NAME: %s -> %s \n " , old_string , new_string ) ) ;
if ( STRING_CHANGED )
pdb_set_fullname ( to , new_string , PDB_CHANGED ) ;
}
2008-02-07 14:40:39 +01:00
if ( ( from - > fields_present & ACCT_HOME_DIR ) & &
2008-02-11 21:09:21 +01:00
( from - > home_directory . string ) ) {
old_string = pdb_get_homedir ( to ) ;
2008-02-11 21:09:21 +01:00
new_string = from - > home_directory . string ;
DEBUG ( 10 , ( " INFO_21 UNI_HOME_DIR: %s -> %s \n " , old_string , new_string ) ) ;
if ( STRING_CHANGED )
pdb_set_homedir ( to , new_string , PDB_CHANGED ) ;
}
if ( ( from - > fields_present & ACCT_HOME_DRIVE ) & &
2008-02-11 21:09:21 +01:00
( from - > home_drive . string ) ) {
old_string = pdb_get_dir_drive ( to ) ;
2008-02-11 21:09:21 +01:00
new_string = from - > home_drive . string ;
DEBUG ( 10 , ( " INFO_21 UNI_DIR_DRIVE: %s -> %s \n " , old_string , new_string ) ) ;
if ( STRING_CHANGED )
pdb_set_dir_drive ( to , new_string , PDB_CHANGED ) ;
}
if ( ( from - > fields_present & ACCT_LOGON_SCRIPT ) & &
2008-02-11 21:09:21 +01:00
( from - > logon_script . string ) ) {
old_string = pdb_get_logon_script ( to ) ;
2008-02-11 21:09:21 +01:00
new_string = from - > logon_script . string ;
DEBUG ( 10 , ( " INFO_21 UNI_LOGON_SCRIPT: %s -> %s \n " , old_string , new_string ) ) ;
if ( STRING_CHANGED )
pdb_set_logon_script ( to , new_string , PDB_CHANGED ) ;
}
if ( ( from - > fields_present & ACCT_PROFILE ) & &
2008-02-11 21:09:21 +01:00
( from - > profile_path . string ) ) {
old_string = pdb_get_profile_path ( to ) ;
2008-02-11 21:09:21 +01:00
new_string = from - > profile_path . string ;
DEBUG ( 10 , ( " INFO_21 UNI_PROFILE_PATH: %s -> %s \n " , old_string , new_string ) ) ;
if ( STRING_CHANGED )
pdb_set_profile_path ( to , new_string , PDB_CHANGED ) ;
}
2008-02-07 14:40:39 +01:00
if ( ( from - > fields_present & ACCT_DESCRIPTION ) & &
2008-02-11 21:09:21 +01:00
( from - > description . string ) ) {
old_string = pdb_get_acct_desc ( to ) ;
2008-02-11 21:09:21 +01:00
new_string = from - > description . string ;
DEBUG ( 10 , ( " INFO_21 UNI_ACCT_DESC: %s -> %s \n " , old_string , new_string ) ) ;
if ( STRING_CHANGED )
pdb_set_acct_desc ( to , new_string , PDB_CHANGED ) ;
}
2008-02-07 14:40:39 +01:00
if ( ( from - > fields_present & ACCT_WORKSTATIONS ) & &
2008-02-11 21:09:21 +01:00
( from - > workstations . string ) ) {
old_string = pdb_get_workstations ( to ) ;
2008-02-11 21:09:21 +01:00
new_string = from - > workstations . string ;
DEBUG ( 10 , ( " INFO_21 UNI_WORKSTATIONS: %s -> %s \n " , old_string , new_string ) ) ;
if ( STRING_CHANGED )
pdb_set_workstations ( to , new_string , PDB_CHANGED ) ;
}
2006-07-11 18:01:26 +00:00
if ( ( from - > fields_present & ACCT_COMMENT ) & &
2008-02-11 21:09:21 +01:00
( from - > comment . string ) ) {
2006-07-11 18:01:26 +00:00
old_string = pdb_get_comment ( to ) ;
2008-02-11 21:09:21 +01:00
new_string = from - > comment . string ;
2006-07-11 18:01:26 +00:00
DEBUG ( 10 , ( " INFO_21 UNI_COMMENT: %s -> %s \n " , old_string , new_string ) ) ;
if ( STRING_CHANGED )
2006-07-11 18:01:26 +00:00
pdb_set_comment ( to , new_string , PDB_CHANGED ) ;
}
2008-02-11 21:09:21 +01:00
#if 0
/* FIXME GD */
if ( ( from - > fields_present & ACCT_CALLBACK ) & &
( from - > hdr_munged_dial . buffer ) ) {
char * newstr ;
old_string = pdb_get_munged_dial ( to ) ;
mung . length = from - > hdr_munged_dial . uni_str_len ;
mung . data = ( uint8 * ) from - > uni_munged_dial . buffer ;
2007-01-05 14:52:10 +00:00
mung . free = NULL ;
2004-05-07 08:42:13 +00:00
newstr = ( mung . length = = 0 ) ?
2008-01-19 02:12:35 +01:00
NULL : base64_encode_data_blob ( talloc_tos ( ) , mung ) ;
DEBUG ( 10 , ( " INFO_21 UNI_MUNGED_DIAL: %s -> %s \n " , old_string , newstr ) ) ;
if ( STRING_CHANGED_NC ( old_string , newstr ) )
pdb_set_munged_dial ( to , newstr , PDB_CHANGED ) ;
2007-10-28 19:15:08 +01:00
TALLOC_FREE ( newstr ) ;
}
2008-02-11 21:09:21 +01:00
# endif
if ( from - > fields_present & ACCT_RID ) {
2008-02-11 21:09:21 +01:00
if ( from - > rid = = 0 ) {
DEBUG ( 10 , ( " INFO_21: Asked to set User RID to 0 !? Skipping change! \n " ) ) ;
2008-02-11 21:09:21 +01:00
} else if ( from - > rid ! = pdb_get_user_rid ( to ) ) {
DEBUG ( 10 , ( " INFO_21 USER_RID: %u -> %u NOT UPDATED! \n " , pdb_get_user_rid ( to ) , from - > rid ) ) ;
}
}
2008-02-07 14:40:39 +01:00
if ( from - > fields_present & ACCT_PRIMARY_GID ) {
2008-02-11 21:09:21 +01:00
if ( from - > primary_gid = = 0 ) {
DEBUG ( 10 , ( " INFO_21: Asked to set Group RID to 0 !? Skipping change! \n " ) ) ;
2008-02-11 21:09:21 +01:00
} else if ( from - > primary_gid ! = pdb_get_group_rid ( to ) ) {
DEBUG ( 10 , ( " INFO_21 GROUP_RID: %u -> %u \n " , pdb_get_group_rid ( to ) , from - > primary_gid ) ) ;
pdb_set_group_sid_from_rid ( to , from - > primary_gid , PDB_CHANGED ) ;
}
}
2008-02-07 14:40:39 +01:00
if ( from - > fields_present & ACCT_FLAGS ) {
2008-02-11 21:09:21 +01:00
DEBUG ( 10 , ( " INFO_21 ACCT_CTRL: %08X -> %08X \n " , pdb_get_acct_ctrl ( to ) , from - > acct_flags ) ) ;
if ( from - > acct_flags ! = pdb_get_acct_ctrl ( to ) ) {
if ( ! ( from - > acct_flags & ACB_AUTOLOCK ) & & ( pdb_get_acct_ctrl ( to ) & ACB_AUTOLOCK ) ) {
2004-06-16 18:05:47 +00:00
/* We're unlocking a previously locked user. Reset bad password counts.
Patch from Jianliang Lu . < Jianliang . Lu @ getronics . com > */
pdb_set_bad_password_count ( to , 0 , PDB_CHANGED ) ;
pdb_set_bad_password_time ( to , 0 , PDB_CHANGED ) ;
}
2008-02-11 21:09:21 +01:00
pdb_set_acct_ctrl ( to , from - > acct_flags , PDB_CHANGED ) ;
}
}
2008-02-11 21:09:21 +01:00
#if 0
if ( from - > fields_present & ACCT_LOGON_HOURS ) {
2007-11-27 11:22:58 -08:00
char oldstr [ 44 ] ; /* hours strings are 42 bytes. */
char newstr [ 44 ] ;
DEBUG ( 15 , ( " INFO_21 LOGON_DIVS: %08X -> %08X \n " , pdb_get_logon_divs ( to ) , from - > logon_divs ) ) ;
if ( from - > logon_divs ! = pdb_get_logon_divs ( to ) ) {
pdb_set_logon_divs ( to , from - > logon_divs , PDB_CHANGED ) ;
}
DEBUG ( 15 , ( " INFO_21 LOGON_HRS.LEN: %08X -> %08X \n " , pdb_get_hours_len ( to ) , from - > logon_hrs . len ) ) ;
if ( from - > logon_hrs . len ! = pdb_get_hours_len ( to ) ) {
pdb_set_hours_len ( to , from - > logon_hrs . len , PDB_CHANGED ) ;
}
DEBUG ( 15 , ( " INFO_21 LOGON_HRS.HOURS: %s -> %s \n " , pdb_get_hours ( to ) , from - > logon_hrs . hours ) ) ;
2005-06-24 20:25:18 +00:00
pdb_sethexhours ( oldstr , pdb_get_hours ( to ) ) ;
pdb_sethexhours ( newstr , from - > logon_hrs . hours ) ;
if ( ! strequal ( oldstr , newstr ) ) {
2004-12-24 00:08:15 +00:00
pdb_set_hours ( to , from - > logon_hrs . hours , PDB_CHANGED ) ;
}
}
2008-02-11 21:09:21 +01:00
# endif
if ( from - > fields_present & ACCT_BAD_PWD_COUNT ) {
DEBUG ( 10 , ( " INFO_21 BAD_PASSWORD_COUNT: %08X -> %08X \n " , pdb_get_bad_password_count ( to ) , from - > bad_password_count ) ) ;
if ( from - > bad_password_count ! = pdb_get_bad_password_count ( to ) ) {
pdb_set_bad_password_count ( to , from - > bad_password_count , PDB_CHANGED ) ;
}
}
if ( from - > fields_present & ACCT_NUM_LOGONS ) {
2008-02-11 21:09:21 +01:00
DEBUG ( 10 , ( " INFO_21 LOGON_COUNT: %08X -> %08X \n " , pdb_get_logon_count ( to ) , from - > logon_count ) ) ;
if ( from - > logon_count ! = pdb_get_logon_count ( to ) ) {
pdb_set_logon_count ( to , from - > logon_count , PDB_CHANGED ) ;
}
}
2006-09-20 17:25:46 +00:00
/* If the must change flag is set, the last set time goes to zero.
2008-02-07 14:40:39 +01:00
the must change and can change fields also do , but they are
2006-09-20 17:25:46 +00:00
calculated from policy , not set from the wire */
if ( from - > fields_present & ACCT_EXPIRED_FLAG ) {
2008-02-11 21:09:21 +01:00
DEBUG ( 10 , ( " INFO_21 PASS_MUST_CHANGE_AT_NEXT_LOGON: %02X \n " , from - > password_expired ) ) ;
if ( from - > password_expired = = PASS_MUST_CHANGE_AT_NEXT_LOGON ) {
2008-02-07 14:40:39 +01:00
pdb_set_pass_last_set_time ( to , 0 , PDB_CHANGED ) ;
2006-09-20 17:25:46 +00:00
} else {
2006-09-20 17:37:20 +00:00
pdb_set_pass_last_set_time ( to , time ( NULL ) , PDB_CHANGED ) ;
2005-08-10 16:02:32 +00:00
}
}
}
/*************************************************************
2008-02-11 21:09:21 +01:00
Copies a struct samr_UserInfo23 to a struct samu
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
2008-02-11 21:09:21 +01:00
void copy_id23_to_sam_passwd ( struct samu * to ,
struct samr_UserInfo23 * from )
{
2008-02-07 14:40:39 +01:00
if ( from = = NULL | | to = = NULL )
return ;
2008-02-11 21:09:21 +01:00
copy_id21_to_sam_passwd ( to , & from - > info ) ;
}
2006-06-06 14:18:12 +00:00
/*************************************************************
2008-02-11 21:09:21 +01:00
Copies a struct samr_UserInfo25 to a struct samu
2006-06-06 14:18:12 +00:00
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
2008-02-11 21:09:21 +01:00
void copy_id25_to_sam_passwd ( struct samu * to ,
struct samr_UserInfo25 * from )
2006-06-06 14:18:12 +00:00
{
2008-02-07 14:40:39 +01:00
if ( from = = NULL | | to = = NULL )
2006-06-06 14:18:12 +00:00
return ;
2008-02-11 21:09:21 +01:00
copy_id21_to_sam_passwd ( to , & from - > info ) ;
2006-06-06 14:18:12 +00:00
}