diff options
author | Günther Deschner <gd@samba.org> | 2012-12-11 23:52:59 +0100 |
---|---|---|
committer | Günther Deschner <gd@samba.org> | 2012-12-15 21:50:36 +0100 |
commit | be43456c94d0ed3786020223aac31e1908028caf (patch) | |
tree | 844285dcb3599dc14be26416e153cc6d1da407cb /source3 | |
parent | 301f69b0ca72e55556ac2c7b5fbf940821b41766 (diff) | |
download | samba-be43456c94d0ed3786020223aac31e1908028caf.tar.gz samba-be43456c94d0ed3786020223aac31e1908028caf.tar.bz2 samba-be43456c94d0ed3786020223aac31e1908028caf.zip |
s3-rpc_server: use netlogon_creds_encrypt_samlogon().
Guenther
Signed-off-by: Günther Deschner <gd@samba.org>
Reviewed-by: Andrew Bartlett <abartlet@samba.org>
Diffstat (limited to 'source3')
-rw-r--r-- | source3/rpc_server/netlogon/srv_netlog_nt.c | 23 |
1 files changed, 3 insertions, 20 deletions
diff --git a/source3/rpc_server/netlogon/srv_netlog_nt.c b/source3/rpc_server/netlogon/srv_netlog_nt.c index 9b506552fb..cfd91c263f 100644 --- a/source3/rpc_server/netlogon/srv_netlog_nt.c +++ b/source3/rpc_server/netlogon/srv_netlog_nt.c @@ -1466,7 +1466,6 @@ static NTSTATUS _netr_LogonSamLogon_base(struct pipes_struct *p, struct auth_serversupplied_info *server_info = NULL; struct auth_context *auth_context = NULL; const char *fn; - struct netr_SamBaseInfo *base; switch (p->opnum) { case NDR_NETR_LOGONSAMLOGON: @@ -1693,17 +1692,14 @@ static NTSTATUS _netr_LogonSamLogon_base(struct pipes_struct *p, case 2: status = serverinfo_to_SamInfo2(server_info, r->out.validation->sam2); - base = &r->out.validation->sam2->base; break; case 3: status = serverinfo_to_SamInfo3(server_info, r->out.validation->sam3); - base = &r->out.validation->sam3->base; break; case 6: status = serverinfo_to_SamInfo6(server_info, r->out.validation->sam6); - base = &r->out.validation->sam6->base; break; } @@ -1713,22 +1709,9 @@ static NTSTATUS _netr_LogonSamLogon_base(struct pipes_struct *p, return status; } - if (r->in.validation_level == 6) { - /* no further crypto to be applied - gd */ - return NT_STATUS_OK; - } - - if (creds->negotiate_flags & NETLOGON_NEG_SUPPORTS_AES) { - netlogon_creds_aes_encrypt(creds, base->key.key, 16); - netlogon_creds_aes_encrypt(creds, base->LMSessKey.key, 8); - } else if (creds->negotiate_flags & NETLOGON_NEG_ARCFOUR) { - netlogon_creds_arcfour_crypt(creds, base->key.key, 16); - netlogon_creds_arcfour_crypt(creds, base->LMSessKey.key, 8); - } else { - /* key is unencrypted when neither AES nor RC4 bits are set */ - netlogon_creds_des_encrypt_LMKey(creds, &base->LMSessKey); - } - + netlogon_creds_encrypt_samlogon_validation(creds, + r->in.validation_level, + r->out.validation); return NT_STATUS_OK; } |