Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
W
wine-cw
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Registry
Registry
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
wine
wine-cw
Commits
9adcf560
Commit
9adcf560
authored
May 09, 2006
by
Juan Lang
Committed by
Alexandre Julliard
May 10, 2006
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
crypt32: Implement CRYPT_VERIFY_CERT_SIGN_ISSUER_CERT in CryptVerifyCertificateSignatureEx.
parent
31f29ffc
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
44 additions
and
39 deletions
+44
-39
cert.c
dlls/crypt32/cert.c
+44
-39
No files found.
dlls/crypt32/cert.c
View file @
9adcf560
...
...
@@ -193,6 +193,41 @@ BOOL WINAPI CryptVerifyCertificateSignature(HCRYPTPROV hCryptProv,
CRYPT_VERIFY_CERT_SIGN_ISSUER_PUBKEY
,
pPublicKey
,
0
,
NULL
);
}
static
BOOL
CRYPT_VerifyCertSignatureFromPublicKeyInfo
(
HCRYPTPROV
hCryptProv
,
DWORD
dwCertEncodingType
,
PCERT_PUBLIC_KEY_INFO
pubKeyInfo
,
PCERT_SIGNED_CONTENT_INFO
signedCert
)
{
BOOL
ret
;
ALG_ID
algID
=
CertOIDToAlgId
(
pubKeyInfo
->
Algorithm
.
pszObjId
);
HCRYPTKEY
key
;
/* Load the default provider if necessary */
if
(
!
hCryptProv
)
hCryptProv
=
CRYPT_GetDefaultProvider
();
ret
=
CryptImportPublicKeyInfoEx
(
hCryptProv
,
dwCertEncodingType
,
pubKeyInfo
,
algID
,
0
,
NULL
,
&
key
);
if
(
ret
)
{
HCRYPTHASH
hash
;
/* Some key algorithms aren't hash algorithms, so map them */
if
(
algID
==
CALG_RSA_SIGN
||
algID
==
CALG_RSA_KEYX
)
algID
=
CALG_SHA1
;
ret
=
CryptCreateHash
(
hCryptProv
,
algID
,
0
,
0
,
&
hash
);
if
(
ret
)
{
ret
=
CryptHashData
(
hash
,
signedCert
->
ToBeSigned
.
pbData
,
signedCert
->
ToBeSigned
.
cbData
,
0
);
if
(
ret
)
ret
=
CryptVerifySignatureW
(
hash
,
signedCert
->
Signature
.
pbData
,
signedCert
->
Signature
.
cbData
,
key
,
NULL
,
0
);
CryptDestroyHash
(
hash
);
}
CryptDestroyKey
(
key
);
}
return
ret
;
}
BOOL
WINAPI
CryptVerifyCertificateSignatureEx
(
HCRYPTPROV
hCryptProv
,
DWORD
dwCertEncodingType
,
DWORD
dwSubjectType
,
void
*
pvSubject
,
DWORD
dwIssuerType
,
void
*
pvIssuer
,
DWORD
dwFlags
,
void
*
pvReserved
)
...
...
@@ -249,48 +284,18 @@ BOOL WINAPI CryptVerifyCertificateSignatureEx(HCRYPTPROV hCryptProv,
switch
(
dwIssuerType
)
{
case
CRYPT_VERIFY_CERT_SIGN_ISSUER_PUBKEY
:
{
PCERT_PUBLIC_KEY_INFO
pubKeyInfo
=
(
PCERT_PUBLIC_KEY_INFO
)
pvIssuer
;
ALG_ID
algID
=
CertOIDToAlgId
(
pubKeyInfo
->
Algorithm
.
pszObjId
);
if
(
algID
)
{
HCRYPTKEY
key
;
ret
=
CryptImportPublicKeyInfoEx
(
hCryptProv
,
dwCertEncodingType
,
pubKeyInfo
,
algID
,
0
,
NULL
,
&
key
);
if
(
ret
)
{
HCRYPTHASH
hash
;
ret
=
CryptCreateHash
(
hCryptProv
,
algID
,
0
,
0
,
&
hash
);
if
(
ret
)
{
ret
=
CryptHashData
(
hash
,
signedCert
->
ToBeSigned
.
pbData
,
signedCert
->
ToBeSigned
.
cbData
,
0
);
if
(
ret
)
{
ret
=
CryptVerifySignatureW
(
hash
,
signedCert
->
Signature
.
pbData
,
signedCert
->
Signature
.
cbData
,
key
,
NULL
,
0
);
}
CryptDestroyHash
(
hash
);
}
CryptDestroyKey
(
key
);
}
}
else
{
SetLastError
(
NTE_BAD_ALGID
);
ret
=
FALSE
;
}
ret
=
CRYPT_VerifyCertSignatureFromPublicKeyInfo
(
hCryptProv
,
dwCertEncodingType
,
(
PCERT_PUBLIC_KEY_INFO
)
pvIssuer
,
signedCert
);
break
;
}
case
CRYPT_VERIFY_CERT_SIGN_ISSUER_CERT
:
ret
=
CRYPT_VerifyCertSignatureFromPublicKeyInfo
(
hCryptProv
,
dwCertEncodingType
,
&
((
PCCERT_CONTEXT
)
pvIssuer
)
->
pCertInfo
->
SubjectPublicKeyInfo
,
signedCert
);
break
;
case
CRYPT_VERIFY_CERT_SIGN_ISSUER_CHAIN
:
FIXME
(
"
issuer type %ld: stub
\n
"
,
dwIssuerType
);
FIXME
(
"
CRYPT_VERIFY_CERT_SIGN_ISSUER_CHAIN: stub
\n
"
);
ret
=
FALSE
;
break
;
case
CRYPT_VERIFY_CERT_SIGN_ISSUER_NULL
:
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment