crypt32: Implement CryptVerifyDetachedMessageHash.
This commit is contained in:
parent
1097513697
commit
4e6515e027
|
@ -269,8 +269,52 @@ BOOL WINAPI CryptVerifyDetachedMessageHash(PCRYPT_HASH_MESSAGE_PARA pHashPara,
|
||||||
const BYTE *rgpbToBeHashed[], DWORD rgcbToBeHashed[], BYTE *pbComputedHash,
|
const BYTE *rgpbToBeHashed[], DWORD rgcbToBeHashed[], BYTE *pbComputedHash,
|
||||||
DWORD *pcbComputedHash)
|
DWORD *pcbComputedHash)
|
||||||
{
|
{
|
||||||
FIXME("(%p, %p, %d, %d, %p, %p, %p, %p): stub\n", pHashPara,
|
HCRYPTMSG msg;
|
||||||
pbDetachedHashBlob, cbDetachedHashBlob, cToBeHashed, rgpbToBeHashed,
|
BOOL ret = FALSE;
|
||||||
rgcbToBeHashed, pbComputedHash, pcbComputedHash);
|
|
||||||
return FALSE;
|
TRACE("(%p, %p, %d, %d, %p, %p, %p, %p)\n", pHashPara, pbDetachedHashBlob,
|
||||||
|
cbDetachedHashBlob, cToBeHashed, rgpbToBeHashed, rgcbToBeHashed,
|
||||||
|
pbComputedHash, pcbComputedHash);
|
||||||
|
|
||||||
|
if (pHashPara->cbSize != sizeof(CRYPT_HASH_MESSAGE_PARA))
|
||||||
|
{
|
||||||
|
SetLastError(E_INVALIDARG);
|
||||||
|
return FALSE;
|
||||||
|
}
|
||||||
|
if (GET_CMSG_ENCODING_TYPE(pHashPara->dwMsgEncodingType) !=
|
||||||
|
PKCS_7_ASN_ENCODING)
|
||||||
|
{
|
||||||
|
SetLastError(E_INVALIDARG);
|
||||||
|
return FALSE;
|
||||||
|
}
|
||||||
|
msg = CryptMsgOpenToDecode(pHashPara->dwMsgEncodingType, CMSG_DETACHED_FLAG,
|
||||||
|
0, pHashPara->hCryptProv, NULL, NULL);
|
||||||
|
if (msg)
|
||||||
|
{
|
||||||
|
DWORD i;
|
||||||
|
|
||||||
|
ret = CryptMsgUpdate(msg, pbDetachedHashBlob, cbDetachedHashBlob, TRUE);
|
||||||
|
if (ret)
|
||||||
|
{
|
||||||
|
if (cToBeHashed)
|
||||||
|
{
|
||||||
|
for (i = 0; ret && i < cToBeHashed; i++)
|
||||||
|
{
|
||||||
|
ret = CryptMsgUpdate(msg, rgpbToBeHashed[i],
|
||||||
|
rgcbToBeHashed[i], i == cToBeHashed - 1 ? TRUE : FALSE);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
ret = CryptMsgUpdate(msg, NULL, 0, TRUE);
|
||||||
|
}
|
||||||
|
if (ret)
|
||||||
|
{
|
||||||
|
ret = CryptMsgControl(msg, 0, CMSG_CTRL_VERIFY_HASH, NULL);
|
||||||
|
if (ret && pcbComputedHash)
|
||||||
|
ret = CryptMsgGetParam(msg, CMSG_COMPUTED_HASH_PARAM, 0,
|
||||||
|
pbComputedHash, pcbComputedHash);
|
||||||
|
}
|
||||||
|
CryptMsgClose(msg);
|
||||||
|
}
|
||||||
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
|
@ -109,35 +109,30 @@ static void test_verify_detached_message_hash(void)
|
||||||
SetLastError(0xdeadbeef);
|
SetLastError(0xdeadbeef);
|
||||||
ret = CryptVerifyDetachedMessageHash(¶, NULL, 0, 0, NULL, NULL, NULL,
|
ret = CryptVerifyDetachedMessageHash(¶, NULL, 0, 0, NULL, NULL, NULL,
|
||||||
NULL);
|
NULL);
|
||||||
todo_wine
|
|
||||||
ok(!ret && GetLastError() == E_INVALIDARG,
|
ok(!ret && GetLastError() == E_INVALIDARG,
|
||||||
"expected E_INVALIDARG, got %08x\n", GetLastError());
|
"expected E_INVALIDARG, got %08x\n", GetLastError());
|
||||||
para.cbSize = sizeof(para);
|
para.cbSize = sizeof(para);
|
||||||
SetLastError(0xdeadbeef);
|
SetLastError(0xdeadbeef);
|
||||||
ret = CryptVerifyDetachedMessageHash(¶, NULL, 0, 0, NULL, NULL, NULL,
|
ret = CryptVerifyDetachedMessageHash(¶, NULL, 0, 0, NULL, NULL, NULL,
|
||||||
NULL);
|
NULL);
|
||||||
todo_wine
|
|
||||||
ok(!ret && GetLastError() == E_INVALIDARG,
|
ok(!ret && GetLastError() == E_INVALIDARG,
|
||||||
"expected E_INVALIDARG, got %08x\n", GetLastError());
|
"expected E_INVALIDARG, got %08x\n", GetLastError());
|
||||||
para.dwMsgEncodingType = PKCS_7_ASN_ENCODING;
|
para.dwMsgEncodingType = PKCS_7_ASN_ENCODING;
|
||||||
SetLastError(0xdeadbeef);
|
SetLastError(0xdeadbeef);
|
||||||
ret = CryptVerifyDetachedMessageHash(¶, NULL, 0, 0, NULL, NULL, NULL,
|
ret = CryptVerifyDetachedMessageHash(¶, NULL, 0, 0, NULL, NULL, NULL,
|
||||||
NULL);
|
NULL);
|
||||||
todo_wine
|
|
||||||
ok(!ret && GetLastError() == CRYPT_E_ASN1_EOD,
|
ok(!ret && GetLastError() == CRYPT_E_ASN1_EOD,
|
||||||
"expected CRYPT_E_ASN1_EOD, got %08x\n", GetLastError());
|
"expected CRYPT_E_ASN1_EOD, got %08x\n", GetLastError());
|
||||||
para.dwMsgEncodingType = X509_ASN_ENCODING;
|
para.dwMsgEncodingType = X509_ASN_ENCODING;
|
||||||
SetLastError(0xdeadbeef);
|
SetLastError(0xdeadbeef);
|
||||||
ret = CryptVerifyDetachedMessageHash(¶, NULL, 0, 0, NULL, NULL, NULL,
|
ret = CryptVerifyDetachedMessageHash(¶, NULL, 0, 0, NULL, NULL, NULL,
|
||||||
NULL);
|
NULL);
|
||||||
todo_wine
|
|
||||||
ok(!ret && GetLastError() == E_INVALIDARG,
|
ok(!ret && GetLastError() == E_INVALIDARG,
|
||||||
"expected E_INVALIDARG, got %08x\n", GetLastError());
|
"expected E_INVALIDARG, got %08x\n", GetLastError());
|
||||||
para.dwMsgEncodingType = X509_ASN_ENCODING | PKCS_7_ASN_ENCODING;
|
para.dwMsgEncodingType = X509_ASN_ENCODING | PKCS_7_ASN_ENCODING;
|
||||||
SetLastError(0xdeadbeef);
|
SetLastError(0xdeadbeef);
|
||||||
ret = CryptVerifyDetachedMessageHash(¶, NULL, 0, 0, NULL, NULL, NULL,
|
ret = CryptVerifyDetachedMessageHash(¶, NULL, 0, 0, NULL, NULL, NULL,
|
||||||
NULL);
|
NULL);
|
||||||
todo_wine
|
|
||||||
ok(!ret && GetLastError() == CRYPT_E_ASN1_EOD,
|
ok(!ret && GetLastError() == CRYPT_E_ASN1_EOD,
|
||||||
"expected CRYPT_E_ASN1_EOD, got %08x\n", GetLastError());
|
"expected CRYPT_E_ASN1_EOD, got %08x\n", GetLastError());
|
||||||
/* Curiously, passing no data to hash succeeds.. */
|
/* Curiously, passing no data to hash succeeds.. */
|
||||||
|
@ -150,7 +145,6 @@ static void test_verify_detached_message_hash(void)
|
||||||
pMsgData = msgData;
|
pMsgData = msgData;
|
||||||
ret = CryptVerifyDetachedMessageHash(¶, detachedHashContent,
|
ret = CryptVerifyDetachedMessageHash(¶, detachedHashContent,
|
||||||
sizeof(detachedHashContent), 1, &pMsgData, &size, NULL, NULL);
|
sizeof(detachedHashContent), 1, &pMsgData, &size, NULL, NULL);
|
||||||
todo_wine
|
|
||||||
ok(ret, "CryptVerifyDetachedMessageHash failed: %08x\n", GetLastError());
|
ok(ret, "CryptVerifyDetachedMessageHash failed: %08x\n", GetLastError());
|
||||||
/* while passing data to hash that isn't the content of the message fails.
|
/* while passing data to hash that isn't the content of the message fails.
|
||||||
*/
|
*/
|
||||||
|
@ -159,7 +153,6 @@ static void test_verify_detached_message_hash(void)
|
||||||
SetLastError(0xdeadbeef);
|
SetLastError(0xdeadbeef);
|
||||||
ret = CryptVerifyDetachedMessageHash(¶, detachedHashContent,
|
ret = CryptVerifyDetachedMessageHash(¶, detachedHashContent,
|
||||||
sizeof(detachedHashContent), 1, &pMsgData, &size, NULL, NULL);
|
sizeof(detachedHashContent), 1, &pMsgData, &size, NULL, NULL);
|
||||||
todo_wine
|
|
||||||
ok(!ret && GetLastError() == CRYPT_E_HASH_VALUE,
|
ok(!ret && GetLastError() == CRYPT_E_HASH_VALUE,
|
||||||
"expected CRYPT_E_HASH_VALUE, got %08x\n", GetLastError());
|
"expected CRYPT_E_HASH_VALUE, got %08x\n", GetLastError());
|
||||||
/* Getting the size of the hash while passing no hash data causes the
|
/* Getting the size of the hash while passing no hash data causes the
|
||||||
|
@ -168,28 +161,23 @@ static void test_verify_detached_message_hash(void)
|
||||||
SetLastError(0xdeadbeef);
|
SetLastError(0xdeadbeef);
|
||||||
ret = CryptVerifyDetachedMessageHash(¶, detachedHashContent,
|
ret = CryptVerifyDetachedMessageHash(¶, detachedHashContent,
|
||||||
sizeof(detachedHashContent), 0, NULL, NULL, NULL, &hashSize);
|
sizeof(detachedHashContent), 0, NULL, NULL, NULL, &hashSize);
|
||||||
todo_wine
|
|
||||||
ok(!ret && GetLastError() == CRYPT_E_HASH_VALUE,
|
ok(!ret && GetLastError() == CRYPT_E_HASH_VALUE,
|
||||||
"expected CRYPT_E_HASH_VALUE, got %08x\n", GetLastError());
|
"expected CRYPT_E_HASH_VALUE, got %08x\n", GetLastError());
|
||||||
size = sizeof(msgData);
|
size = sizeof(msgData);
|
||||||
pMsgData = msgData;
|
pMsgData = msgData;
|
||||||
ret = CryptVerifyDetachedMessageHash(¶, detachedHashContent,
|
ret = CryptVerifyDetachedMessageHash(¶, detachedHashContent,
|
||||||
sizeof(detachedHashContent), 1, &pMsgData, &size, NULL, &hashSize);
|
sizeof(detachedHashContent), 1, &pMsgData, &size, NULL, &hashSize);
|
||||||
todo_wine {
|
|
||||||
ok(ret, "CryptVerifyDetachedMessageHash failed: %08x\n", GetLastError());
|
ok(ret, "CryptVerifyDetachedMessageHash failed: %08x\n", GetLastError());
|
||||||
ok(hashSize == sizeof(hash), "unexpected size %d\n", hashSize);
|
ok(hashSize == sizeof(hash), "unexpected size %d\n", hashSize);
|
||||||
}
|
|
||||||
hashSize = 1;
|
hashSize = 1;
|
||||||
SetLastError(0xdeadbeef);
|
SetLastError(0xdeadbeef);
|
||||||
ret = CryptVerifyDetachedMessageHash(¶, detachedHashContent,
|
ret = CryptVerifyDetachedMessageHash(¶, detachedHashContent,
|
||||||
sizeof(detachedHashContent), 1, &pMsgData, &size, hash, &hashSize);
|
sizeof(detachedHashContent), 1, &pMsgData, &size, hash, &hashSize);
|
||||||
todo_wine
|
|
||||||
ok(!ret && GetLastError() == ERROR_MORE_DATA,
|
ok(!ret && GetLastError() == ERROR_MORE_DATA,
|
||||||
"expected ERROR_MORE_DATA, got %08x\n", GetLastError());
|
"expected ERROR_MORE_DATA, got %08x\n", GetLastError());
|
||||||
hashSize = sizeof(hash);
|
hashSize = sizeof(hash);
|
||||||
ret = CryptVerifyDetachedMessageHash(¶, detachedHashContent,
|
ret = CryptVerifyDetachedMessageHash(¶, detachedHashContent,
|
||||||
sizeof(detachedHashContent), 1, &pMsgData, &size, hash, &hashSize);
|
sizeof(detachedHashContent), 1, &pMsgData, &size, hash, &hashSize);
|
||||||
todo_wine
|
|
||||||
ok(ret, "CryptVerifyDetachedMessageHash failed: %08x\n", GetLastError());
|
ok(ret, "CryptVerifyDetachedMessageHash failed: %08x\n", GetLastError());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue