1
0
mirror of https://github.com/samba-team/samba.git synced 2025-01-26 10:04:02 +03:00

Merge branch 'master' of ssh://git.samba.org/data/git/samba

This commit is contained in:
Jelmer Vernooij 2008-12-23 19:30:16 +01:00
commit 5dce4148a3
2 changed files with 67 additions and 25 deletions

View File

@ -586,7 +586,7 @@ static NTSTATUS fetch_account_info_to_ldif(TALLOC_CTX *mem_ctx,
uchar zero_buf[16]; uchar zero_buf[16];
uint32 rid = 0, group_rid = 0, gidNumber = 0; uint32 rid = 0, group_rid = 0, gidNumber = 0;
time_t unix_time; time_t unix_time;
int i; int i, ret;
memset(zero_buf, '\0', sizeof(zero_buf)); memset(zero_buf, '\0', sizeof(zero_buf));
@ -660,7 +660,10 @@ static NTSTATUS fetch_account_info_to_ldif(TALLOC_CTX *mem_ctx,
return NT_STATUS_UNSUCCESSFUL; return NT_STATUS_UNSUCCESSFUL;
} }
gidNumber = groupmap[i].gidNumber; gidNumber = groupmap[i].gidNumber;
snprintf(sambaSID, sizeof(sambaSID), groupmap[i].sambaSID); ret = snprintf(sambaSID, sizeof(sambaSID), "%s", groupmap[i].sambaSID);
if (ret < 0 || ret == sizeof(sambaSID)) {
return NT_STATUS_UNSUCCESSFUL;
}
/* Set up sambaAcctFlags */ /* Set up sambaAcctFlags */
flags = pdb_encode_acct_ctrl(r->acct_flags, flags = pdb_encode_acct_ctrl(r->acct_flags,

View File

@ -686,12 +686,16 @@ NTSTATUS local_password_change(const char *user_name,
} }
if (!NT_STATUS_IS_OK(result)) { if (!NT_STATUS_IS_OK(result)) {
asprintf(pp_err_str, "Failed to " "initialize account for user %s: %s\n", if (asprintf(pp_err_str, "Failed to " "initialize account for user %s: %s\n",
user_name, nt_errstr(result)); user_name, nt_errstr(result)) < 0) {
*pp_err_str = NULL;
}
return result; return result;
} }
} else { } else {
asprintf(pp_err_str, "Failed to find entry for user %s.\n", user_name); if (asprintf(pp_err_str, "Failed to find entry for user %s.\n", user_name) < 0) {
*pp_err_str = NULL;
}
return NT_STATUS_NO_SUCH_USER; return NT_STATUS_NO_SUCH_USER;
} }
} else { } else {
@ -704,19 +708,25 @@ NTSTATUS local_password_change(const char *user_name,
other_acb = (pdb_get_acct_ctrl(sam_pass) & (~(ACB_WSTRUST|ACB_DOMTRUST|ACB_SVRTRUST|ACB_NORMAL))); other_acb = (pdb_get_acct_ctrl(sam_pass) & (~(ACB_WSTRUST|ACB_DOMTRUST|ACB_SVRTRUST|ACB_NORMAL)));
if (local_flags & LOCAL_TRUST_ACCOUNT) { if (local_flags & LOCAL_TRUST_ACCOUNT) {
if (!pdb_set_acct_ctrl(sam_pass, ACB_WSTRUST | other_acb, PDB_CHANGED) ) { if (!pdb_set_acct_ctrl(sam_pass, ACB_WSTRUST | other_acb, PDB_CHANGED) ) {
asprintf(pp_err_str, "Failed to set 'trusted workstation account' flags for user %s.\n", user_name); if (asprintf(pp_err_str, "Failed to set 'trusted workstation account' flags for user %s.\n", user_name) < 0) {
*pp_err_str = NULL;
}
TALLOC_FREE(sam_pass); TALLOC_FREE(sam_pass);
return NT_STATUS_UNSUCCESSFUL; return NT_STATUS_UNSUCCESSFUL;
} }
} else if (local_flags & LOCAL_INTERDOM_ACCOUNT) { } else if (local_flags & LOCAL_INTERDOM_ACCOUNT) {
if (!pdb_set_acct_ctrl(sam_pass, ACB_DOMTRUST | other_acb, PDB_CHANGED)) { if (!pdb_set_acct_ctrl(sam_pass, ACB_DOMTRUST | other_acb, PDB_CHANGED)) {
asprintf(pp_err_str, "Failed to set 'domain trust account' flags for user %s.\n", user_name); if (asprintf(pp_err_str, "Failed to set 'domain trust account' flags for user %s.\n", user_name) < 0) {
*pp_err_str = NULL;
}
TALLOC_FREE(sam_pass); TALLOC_FREE(sam_pass);
return NT_STATUS_UNSUCCESSFUL; return NT_STATUS_UNSUCCESSFUL;
} }
} else { } else {
if (!pdb_set_acct_ctrl(sam_pass, ACB_NORMAL | other_acb, PDB_CHANGED)) { if (!pdb_set_acct_ctrl(sam_pass, ACB_NORMAL | other_acb, PDB_CHANGED)) {
asprintf(pp_err_str, "Failed to set 'normal account' flags for user %s.\n", user_name); if (asprintf(pp_err_str, "Failed to set 'normal account' flags for user %s.\n", user_name) < 0) {
*pp_err_str = NULL;
}
TALLOC_FREE(sam_pass); TALLOC_FREE(sam_pass);
return NT_STATUS_UNSUCCESSFUL; return NT_STATUS_UNSUCCESSFUL;
} }
@ -729,13 +739,17 @@ NTSTATUS local_password_change(const char *user_name,
if (local_flags & LOCAL_DISABLE_USER) { if (local_flags & LOCAL_DISABLE_USER) {
if (!pdb_set_acct_ctrl (sam_pass, pdb_get_acct_ctrl(sam_pass)|ACB_DISABLED, PDB_CHANGED)) { if (!pdb_set_acct_ctrl (sam_pass, pdb_get_acct_ctrl(sam_pass)|ACB_DISABLED, PDB_CHANGED)) {
asprintf(pp_err_str, "Failed to set 'disabled' flag for user %s.\n", user_name); if (asprintf(pp_err_str, "Failed to set 'disabled' flag for user %s.\n", user_name) < 0) {
*pp_err_str = NULL;
}
TALLOC_FREE(sam_pass); TALLOC_FREE(sam_pass);
return NT_STATUS_UNSUCCESSFUL; return NT_STATUS_UNSUCCESSFUL;
} }
} else if (local_flags & LOCAL_ENABLE_USER) { } else if (local_flags & LOCAL_ENABLE_USER) {
if (!pdb_set_acct_ctrl (sam_pass, pdb_get_acct_ctrl(sam_pass)&(~ACB_DISABLED), PDB_CHANGED)) { if (!pdb_set_acct_ctrl (sam_pass, pdb_get_acct_ctrl(sam_pass)&(~ACB_DISABLED), PDB_CHANGED)) {
asprintf(pp_err_str, "Failed to unset 'disabled' flag for user %s.\n", user_name); if (asprintf(pp_err_str, "Failed to unset 'disabled' flag for user %s.\n", user_name) < 0) {
*pp_err_str = NULL;
}
TALLOC_FREE(sam_pass); TALLOC_FREE(sam_pass);
return NT_STATUS_UNSUCCESSFUL; return NT_STATUS_UNSUCCESSFUL;
} }
@ -743,7 +757,9 @@ NTSTATUS local_password_change(const char *user_name,
if (local_flags & LOCAL_SET_NO_PASSWORD) { if (local_flags & LOCAL_SET_NO_PASSWORD) {
if (!pdb_set_acct_ctrl (sam_pass, pdb_get_acct_ctrl(sam_pass)|ACB_PWNOTREQ, PDB_CHANGED)) { if (!pdb_set_acct_ctrl (sam_pass, pdb_get_acct_ctrl(sam_pass)|ACB_PWNOTREQ, PDB_CHANGED)) {
asprintf(pp_err_str, "Failed to set 'no password required' flag for user %s.\n", user_name); if (asprintf(pp_err_str, "Failed to set 'no password required' flag for user %s.\n", user_name) < 0) {
*pp_err_str = NULL;
}
TALLOC_FREE(sam_pass); TALLOC_FREE(sam_pass);
return NT_STATUS_UNSUCCESSFUL; return NT_STATUS_UNSUCCESSFUL;
} }
@ -759,19 +775,25 @@ NTSTATUS local_password_change(const char *user_name,
*/ */
if ((pdb_get_lanman_passwd(sam_pass)==NULL) && (pdb_get_acct_ctrl(sam_pass)&ACB_DISABLED)) { if ((pdb_get_lanman_passwd(sam_pass)==NULL) && (pdb_get_acct_ctrl(sam_pass)&ACB_DISABLED)) {
if (!pdb_set_acct_ctrl (sam_pass, pdb_get_acct_ctrl(sam_pass)&(~ACB_DISABLED), PDB_CHANGED)) { if (!pdb_set_acct_ctrl (sam_pass, pdb_get_acct_ctrl(sam_pass)&(~ACB_DISABLED), PDB_CHANGED)) {
asprintf(pp_err_str, "Failed to unset 'disabled' flag for user %s.\n", user_name); if (asprintf(pp_err_str, "Failed to unset 'disabled' flag for user %s.\n", user_name) < 0) {
*pp_err_str = NULL;
}
TALLOC_FREE(sam_pass); TALLOC_FREE(sam_pass);
return NT_STATUS_UNSUCCESSFUL; return NT_STATUS_UNSUCCESSFUL;
} }
} }
if (!pdb_set_acct_ctrl (sam_pass, pdb_get_acct_ctrl(sam_pass)&(~ACB_PWNOTREQ), PDB_CHANGED)) { if (!pdb_set_acct_ctrl (sam_pass, pdb_get_acct_ctrl(sam_pass)&(~ACB_PWNOTREQ), PDB_CHANGED)) {
asprintf(pp_err_str, "Failed to unset 'no password required' flag for user %s.\n", user_name); if (asprintf(pp_err_str, "Failed to unset 'no password required' flag for user %s.\n", user_name) < 0) {
*pp_err_str = NULL;
}
TALLOC_FREE(sam_pass); TALLOC_FREE(sam_pass);
return NT_STATUS_UNSUCCESSFUL; return NT_STATUS_UNSUCCESSFUL;
} }
if (!pdb_set_plaintext_passwd (sam_pass, new_passwd)) { if (!pdb_set_plaintext_passwd (sam_pass, new_passwd)) {
asprintf(pp_err_str, "Failed to set password for user %s.\n", user_name); if (asprintf(pp_err_str, "Failed to set password for user %s.\n", user_name) < 0) {
*pp_err_str = NULL;
}
TALLOC_FREE(sam_pass); TALLOC_FREE(sam_pass);
return NT_STATUS_UNSUCCESSFUL; return NT_STATUS_UNSUCCESSFUL;
} }
@ -779,34 +801,51 @@ NTSTATUS local_password_change(const char *user_name,
if (local_flags & LOCAL_ADD_USER) { if (local_flags & LOCAL_ADD_USER) {
if (NT_STATUS_IS_OK(pdb_add_sam_account(sam_pass))) { if (NT_STATUS_IS_OK(pdb_add_sam_account(sam_pass))) {
asprintf(pp_msg_str, "Added user %s.\n", user_name); if (asprintf(pp_msg_str, "Added user %s.\n", user_name) < 0) {
*pp_msg_str = NULL;
}
TALLOC_FREE(sam_pass); TALLOC_FREE(sam_pass);
return NT_STATUS_OK; return NT_STATUS_OK;
} else { } else {
asprintf(pp_err_str, "Failed to add entry for user %s.\n", user_name); if (asprintf(pp_err_str, "Failed to add entry for user %s.\n", user_name) < 0) {
*pp_err_str = NULL;
}
TALLOC_FREE(sam_pass); TALLOC_FREE(sam_pass);
return NT_STATUS_UNSUCCESSFUL; return NT_STATUS_UNSUCCESSFUL;
} }
} else if (local_flags & LOCAL_DELETE_USER) { } else if (local_flags & LOCAL_DELETE_USER) {
if (!NT_STATUS_IS_OK(pdb_delete_sam_account(sam_pass))) { if (!NT_STATUS_IS_OK(pdb_delete_sam_account(sam_pass))) {
asprintf(pp_err_str, "Failed to delete entry for user %s.\n", user_name); if (asprintf(pp_err_str, "Failed to delete entry for user %s.\n", user_name) < 0) {
*pp_err_str = NULL;
}
TALLOC_FREE(sam_pass); TALLOC_FREE(sam_pass);
return NT_STATUS_UNSUCCESSFUL; return NT_STATUS_UNSUCCESSFUL;
} }
asprintf(pp_msg_str, "Deleted user %s.\n", user_name); if (asprintf(pp_msg_str, "Deleted user %s.\n", user_name) < 0) {
*pp_msg_str = NULL;
}
} else { } else {
result = pdb_update_sam_account(sam_pass); result = pdb_update_sam_account(sam_pass);
if(!NT_STATUS_IS_OK(result)) { if(!NT_STATUS_IS_OK(result)) {
asprintf(pp_err_str, "Failed to modify entry for user %s.\n", user_name); if (asprintf(pp_err_str, "Failed to modify entry for user %s.\n", user_name) < 0) {
*pp_err_str = NULL;
}
TALLOC_FREE(sam_pass); TALLOC_FREE(sam_pass);
return result; return result;
} }
if(local_flags & LOCAL_DISABLE_USER) if(local_flags & LOCAL_DISABLE_USER) {
asprintf(pp_msg_str, "Disabled user %s.\n", user_name); if (asprintf(pp_msg_str, "Disabled user %s.\n", user_name) < 0) {
else if (local_flags & LOCAL_ENABLE_USER) *pp_msg_str = NULL;
asprintf(pp_msg_str, "Enabled user %s.\n", user_name); }
else if (local_flags & LOCAL_SET_NO_PASSWORD) } else if (local_flags & LOCAL_ENABLE_USER) {
asprintf(pp_msg_str, "User %s password set to none.\n", user_name); if (asprintf(pp_msg_str, "Enabled user %s.\n", user_name) < 0) {
*pp_msg_str = NULL;
}
} else if (local_flags & LOCAL_SET_NO_PASSWORD) {
if (asprintf(pp_msg_str, "User %s password set to none.\n", user_name) < 0) {
*pp_msg_str = NULL;
}
}
} }
TALLOC_FREE(sam_pass); TALLOC_FREE(sam_pass);