libcli:smb: Use gnutls_error_to_ntstatus() in smb2_signing_check_pdu()
authorAndreas Schneider <asn@samba.org>
Tue, 11 Jun 2019 10:10:38 +0000 (12:10 +0200)
committerAndreas Schneider <asn@cryptomilk.org>
Mon, 24 Jun 2019 06:11:16 +0000 (06:11 +0000)
Signed-off-by: Andreas Schneider <asn@samba.org>
Reviewed-by: Stefan Metzmacher <metze@samba.org>
Reviewed-by: Andrew Bartlett <abartlet@samba.org>
libcli/smb/smb2_signing.c

index 2d182485db4744e9fabdc27b5e60a13e1d226cae..cfe89b6ef79b678033b266e2e9292f6b61f22946 100644 (file)
@@ -206,17 +206,17 @@ NTSTATUS smb2_signing_check_pdu(struct smb2_signing_key *signing_key,
                                              signing_key->blob.data,
                                              MIN(signing_key->blob.length, 16));
                        if (rc < 0) {
-                               return NT_STATUS_NO_MEMORY;
+                               return gnutls_error_to_ntstatus(rc, NT_STATUS_HMAC_NOT_SUPPORTED);
                        }
                }
 
                rc = gnutls_hmac(signing_key->hmac_hnd, hdr, SMB2_HDR_SIGNATURE);
                if (rc < 0) {
-                       return NT_STATUS_INTERNAL_ERROR;
+                       return gnutls_error_to_ntstatus(rc, NT_STATUS_HMAC_NOT_SUPPORTED);
                }
                rc = gnutls_hmac(signing_key->hmac_hnd, zero_sig, 16);
                if (rc < 0) {
-                       return NT_STATUS_INTERNAL_ERROR;
+                       return gnutls_error_to_ntstatus(rc, NT_STATUS_HMAC_NOT_SUPPORTED);
                }
 
                for (i = 1; i < count; i++) {
@@ -224,7 +224,7 @@ NTSTATUS smb2_signing_check_pdu(struct smb2_signing_key *signing_key,
                                         vector[i].iov_base,
                                         vector[i].iov_len);
                        if (rc < 0) {
-                               return NT_STATUS_INTERNAL_ERROR;
+                               return gnutls_error_to_ntstatus(rc, NT_STATUS_HMAC_NOT_SUPPORTED);
                        }
                }
                gnutls_hmac_output(signing_key->hmac_hnd, digest);