mirror of
https://github.com/samba-team/samba.git
synced 2024-12-25 23:21:54 +03:00
r3529: fixed signing support for SMBntcancel requests (no reply means seq
number rises by 1, not 2)
This commit is contained in:
parent
3423e2f414
commit
201ff734d4
@ -2320,6 +2320,7 @@ void reply_ntcreate_and_X(struct smbsrv_request *req)
|
||||
void reply_ntcancel(struct smbsrv_request *req)
|
||||
{
|
||||
/* NOTE: this request does not generate a reply */
|
||||
req_signing_no_reply(req);
|
||||
ntvfs_cancel(req);
|
||||
req_destroy(req);
|
||||
}
|
||||
|
@ -130,13 +130,21 @@ static void req_signing_alloc_seq_num(struct smbsrv_request *req)
|
||||
{
|
||||
req->seq_num = req->smb_conn->signing.next_seq_num;
|
||||
|
||||
/* TODO: we need to handle one-way requests like NTcancel, which
|
||||
only increment the sequence number by 1 */
|
||||
if (req->smb_conn->signing.signing_state != SMB_SIGNING_OFF) {
|
||||
req->smb_conn->signing.next_seq_num += 2;
|
||||
}
|
||||
}
|
||||
|
||||
/*
|
||||
called for requests that do not produce a reply of their own
|
||||
*/
|
||||
void req_signing_no_reply(struct smbsrv_request *req)
|
||||
{
|
||||
if (req->smb_conn->signing.signing_state != SMB_SIGNING_OFF) {
|
||||
req->smb_conn->signing.next_seq_num--;
|
||||
}
|
||||
}
|
||||
|
||||
/***********************************************************
|
||||
SMB signing - Simple implementation - check a MAC sent by client
|
||||
************************************************************/
|
||||
|
Loading…
Reference in New Issue
Block a user