mirror of
https://github.com/samba-team/samba.git
synced 2025-01-12 09:18:10 +03:00
This commit is number 1 of 4.
In particular this commit focusses on:
Adding the new 'pass changed now' helper function.
While these changes have been mildly tested, and are pretty small, any
assistance in this is appreciated.
(This used to be commit a8971a5448
)
This commit is contained in:
parent
879ecfae58
commit
ab5d5cfbe0
@ -1624,29 +1624,6 @@ BOOL pdb_set_lanman_passwd (SAM_ACCOUNT *sampass, uint8 *pwd)
|
||||
return True;
|
||||
}
|
||||
|
||||
/*********************************************************************
|
||||
Set the user's PLAINTEXT password. Used as an interface to the above.
|
||||
********************************************************************/
|
||||
|
||||
BOOL pdb_set_plaintext_passwd (SAM_ACCOUNT *sampass, char *plaintext)
|
||||
{
|
||||
uchar new_lanman_p16[16];
|
||||
uchar new_nt_p16[16];
|
||||
|
||||
if (!sampass || !plaintext)
|
||||
return False;
|
||||
|
||||
nt_lm_owf_gen (plaintext, new_nt_p16, new_lanman_p16);
|
||||
|
||||
if (!pdb_set_nt_passwd (sampass, new_nt_p16))
|
||||
return False;
|
||||
|
||||
if (!pdb_set_lanman_passwd (sampass, new_lanman_p16))
|
||||
return False;
|
||||
|
||||
return True;
|
||||
}
|
||||
|
||||
BOOL pdb_set_unknown_3 (SAM_ACCOUNT *sampass, uint32 unkn)
|
||||
{
|
||||
if (!sampass)
|
||||
@ -1688,3 +1665,57 @@ BOOL pdb_set_hours (SAM_ACCOUNT *sampass, uint8 *hours)
|
||||
|
||||
return True;
|
||||
}
|
||||
|
||||
|
||||
/* Helpful interfaces to the above */
|
||||
|
||||
/*********************************************************************
|
||||
Sets the last changed times and must change times for a normal
|
||||
password change.
|
||||
********************************************************************/
|
||||
|
||||
BOOL pdb_set_pass_changed_now (SAM_ACCOUNT *sampass)
|
||||
{
|
||||
|
||||
if (!sampass)
|
||||
return False;
|
||||
|
||||
if (!pdb_set_pass_last_set_time (sampass, time(NULL)))
|
||||
return False;
|
||||
|
||||
if (!pdb_set_pass_must_change_time (sampass,
|
||||
pdb_get_pass_last_set_time(sampass)
|
||||
+ MAX_PASSWORD_AGE))
|
||||
return False;
|
||||
|
||||
return True;
|
||||
}
|
||||
|
||||
/*********************************************************************
|
||||
Set the user's PLAINTEXT password. Used as an interface to the above.
|
||||
Also sets the last change time to NOW.
|
||||
********************************************************************/
|
||||
|
||||
BOOL pdb_set_plaintext_passwd (SAM_ACCOUNT *sampass, const char *plaintext)
|
||||
{
|
||||
uchar new_lanman_p16[16];
|
||||
uchar new_nt_p16[16];
|
||||
|
||||
if (!sampass || !plaintext)
|
||||
return False;
|
||||
|
||||
nt_lm_owf_gen (plaintext, new_nt_p16, new_lanman_p16);
|
||||
|
||||
if (!pdb_set_nt_passwd (sampass, new_nt_p16))
|
||||
return False;
|
||||
|
||||
if (!pdb_set_lanman_passwd (sampass, new_lanman_p16))
|
||||
return False;
|
||||
|
||||
if (!pdb_set_pass_changed_now (sampass))
|
||||
return False;
|
||||
|
||||
return True;
|
||||
}
|
||||
|
||||
|
||||
|
@ -436,6 +436,12 @@ NTSTATUS _net_srv_pwset(pipes_struct *p, NET_Q_SRV_PWSET *q_u, NET_R_SRV_PWSET *
|
||||
return NT_STATUS_NO_MEMORY;
|
||||
}
|
||||
|
||||
if (!pdb_set_pass_changed_now (sampass)) {
|
||||
pdb_free_sam(&sampass);
|
||||
/* Not quite sure what this one qualifies as, but this will do */
|
||||
return NT_STATUS_NO_MEMORY;
|
||||
}
|
||||
|
||||
become_root();
|
||||
ret = pdb_update_sam_account (sampass,False);
|
||||
unbecome_root();
|
||||
|
@ -2288,6 +2288,10 @@ static BOOL set_user_info_12(SAM_USER_INFO_12 *id12, uint32 rid)
|
||||
pdb_free_sam(&pwd);
|
||||
return False;
|
||||
}
|
||||
if (!pdb_set_pass_changed_now (pwd)) {
|
||||
pdb_free_sam(&pwd);
|
||||
return False;
|
||||
}
|
||||
|
||||
if(!pdb_update_sam_account(pwd, True)) {
|
||||
pdb_free_sam(&pwd);
|
||||
|
@ -682,6 +682,12 @@ BOOL change_lanman_password(SAM_ACCOUNT *sampass, uchar * pass1,
|
||||
return False; /* We lose the NT hash. Sorry. */
|
||||
}
|
||||
|
||||
if (!pdb_set_pass_changed_now (sampass)) {
|
||||
pdb_free_sam(&sampass);
|
||||
/* Not quite sure what this one qualifies as, but this will do */
|
||||
return False;
|
||||
}
|
||||
|
||||
/* Now flush the sam_passwd struct to persistent storage */
|
||||
become_root();
|
||||
ret = pdb_update_sam_account (sampass, False);
|
||||
|
Loading…
Reference in New Issue
Block a user