summaryrefslogtreecommitdiff
path: root/source3/rpc_server/samr
diff options
context:
space:
mode:
Diffstat (limited to 'source3/rpc_server/samr')
-rw-r--r--source3/rpc_server/samr/srv_samr_nt.c4
-rw-r--r--source3/rpc_server/samr/srv_samr_util.c9
2 files changed, 11 insertions, 2 deletions
diff --git a/source3/rpc_server/samr/srv_samr_nt.c b/source3/rpc_server/samr/srv_samr_nt.c
index 7432e01601..7a07643597 100644
--- a/source3/rpc_server/samr/srv_samr_nt.c
+++ b/source3/rpc_server/samr/srv_samr_nt.c
@@ -2489,7 +2489,7 @@ static NTSTATUS get_user_info_2(TALLOC_CTX *mem_ctx,
r->comment.string = talloc_strdup(mem_ctx, pdb_get_comment(pw));
r->reserved.string = NULL;
r->country_code = pdb_get_country_code(pw);
- r->code_page = 0;
+ r->code_page = pdb_get_code_page(pw);
return NT_STATUS_OK;
}
@@ -2975,7 +2975,7 @@ static NTSTATUS get_user_info_21(TALLOC_CTX *mem_ctx,
r->password_expired = (pdb_get_pass_must_change_time(pw) == 0) ?
PASS_MUST_CHANGE_AT_NEXT_LOGON : 0;
r->country_code = pdb_get_country_code(pw);
- r->code_page = 0;
+ r->code_page = pdb_get_code_page(pw);
r->lm_password_set = 0;
r->nt_password_set = 0;
diff --git a/source3/rpc_server/samr/srv_samr_util.c b/source3/rpc_server/samr/srv_samr_util.c
index 77d40e0251..0bab1271f2 100644
--- a/source3/rpc_server/samr/srv_samr_util.c
+++ b/source3/rpc_server/samr/srv_samr_util.c
@@ -649,6 +649,15 @@ void copy_id21_to_sam_passwd(const char *log_prefix,
from->country_code, PDB_CHANGED);
}
}
+
+ if (from->fields_present & SAMR_FIELD_CODE_PAGE) {
+ DEBUG(10,("%s SAMR_FIELD_CODE_PAGE: %08X -> %08X\n", l,
+ pdb_get_code_page(to), from->code_page));
+ if (from->code_page != pdb_get_code_page(to)) {
+ pdb_set_code_page(to,
+ from->code_page, PDB_CHANGED);
+ }
+ }
}