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
e763923b
Commit
e763923b
authored
Aug 08, 2008
by
Juan Lang
Committed by
Alexandre Julliard
Aug 19, 2008
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
crypt32: Implement CERT_SIGNATURE_HASH_PROP_ID.
parent
d8da3e83
Show whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
57 additions
and
27 deletions
+57
-27
cert.c
dlls/crypt32/cert.c
+9
-2
cert.c
dlls/crypt32/tests/cert.c
+48
-25
No files found.
dlls/crypt32/cert.c
View file @
e763923b
...
@@ -239,8 +239,15 @@ static BOOL WINAPI CertContext_GetProperty(void *context, DWORD dwPropId,
...
@@ -239,8 +239,15 @@ static BOOL WINAPI CertContext_GetProperty(void *context, DWORD dwPropId,
pvData
,
pcbData
);
pvData
,
pcbData
);
break
;
break
;
case
CERT_SIGNATURE_HASH_PROP_ID
:
case
CERT_SIGNATURE_HASH_PROP_ID
:
FIXME
(
"CERT_SIGNATURE_HASH_PROP_ID unimplemented
\n
"
);
ret
=
CryptHashToBeSigned
(
0
,
pCertContext
->
dwCertEncodingType
,
SetLastError
(
CRYPT_E_NOT_FOUND
);
pCertContext
->
pbCertEncoded
,
pCertContext
->
cbCertEncoded
,
pvData
,
pcbData
);
if
(
ret
&&
pvData
)
{
CRYPT_DATA_BLOB
blob
=
{
*
pcbData
,
pvData
};
ret
=
CertContext_SetProperty
(
context
,
dwPropId
,
0
,
&
blob
);
}
break
;
break
;
case
CERT_KEY_IDENTIFIER_PROP_ID
:
case
CERT_KEY_IDENTIFIER_PROP_ID
:
{
{
...
...
dlls/crypt32/tests/cert.c
View file @
e763923b
...
@@ -372,6 +372,32 @@ static const BYTE v1CertWithSubjectKeyId[] = {
...
@@ -372,6 +372,32 @@ static const BYTE v1CertWithSubjectKeyId[] = {
0x4c
,
0x61
,
0x6e
,
0x67
,
0x00
};
0x4c
,
0x61
,
0x6e
,
0x67
,
0x00
};
static
const
BYTE
subjectKeyId
[]
=
{
static
const
BYTE
subjectKeyId
[]
=
{
0x4a
,
0x75
,
0x61
,
0x6e
,
0x20
,
0x4c
,
0x61
,
0x6e
,
0x67
,
0x00
};
0x4a
,
0x75
,
0x61
,
0x6e
,
0x20
,
0x4c
,
0x61
,
0x6e
,
0x67
,
0x00
};
static
const
BYTE
selfSignedCert
[]
=
{
0x30
,
0x82
,
0x01
,
0x1f
,
0x30
,
0x81
,
0xce
,
0xa0
,
0x03
,
0x02
,
0x01
,
0x02
,
0x02
,
0x10
,
0xeb
,
0x0d
,
0x57
,
0x2a
,
0x9c
,
0x09
,
0xba
,
0xa4
,
0x4a
,
0xb7
,
0x25
,
0x49
,
0xd9
,
0x3e
,
0xb5
,
0x73
,
0x30
,
0x09
,
0x06
,
0x05
,
0x2b
,
0x0e
,
0x03
,
0x02
,
0x1d
,
0x05
,
0x00
,
0x30
,
0x15
,
0x31
,
0x13
,
0x30
,
0x11
,
0x06
,
0x03
,
0x55
,
0x04
,
0x03
,
0x13
,
0x0a
,
0x4a
,
0x75
,
0x61
,
0x6e
,
0x20
,
0x4c
,
0x61
,
0x6e
,
0x67
,
0x00
,
0x30
,
0x1e
,
0x17
,
0x0d
,
0x30
,
0x36
,
0x30
,
0x36
,
0x32
,
0x39
,
0x30
,
0x35
,
0x30
,
0x30
,
0x34
,
0x36
,
0x5a
,
0x17
,
0x0d
,
0x30
,
0x37
,
0x30
,
0x36
,
0x32
,
0x39
,
0x31
,
0x31
,
0x30
,
0x30
,
0x34
,
0x36
,
0x5a
,
0x30
,
0x15
,
0x31
,
0x13
,
0x30
,
0x11
,
0x06
,
0x03
,
0x55
,
0x04
,
0x03
,
0x13
,
0x0a
,
0x4a
,
0x75
,
0x61
,
0x6e
,
0x20
,
0x4c
,
0x61
,
0x6e
,
0x67
,
0x00
,
0x30
,
0x5c
,
0x30
,
0x0d
,
0x06
,
0x09
,
0x2a
,
0x86
,
0x48
,
0x86
,
0xf7
,
0x0d
,
0x01
,
0x01
,
0x01
,
0x05
,
0x00
,
0x03
,
0x4b
,
0x00
,
0x30
,
0x48
,
0x02
,
0x41
,
0x00
,
0xe2
,
0x54
,
0x3a
,
0xa7
,
0x83
,
0xb1
,
0x27
,
0x14
,
0x3e
,
0x59
,
0xbb
,
0xb4
,
0x53
,
0xe6
,
0x1f
,
0xe7
,
0x5d
,
0xf1
,
0x21
,
0x68
,
0xad
,
0x85
,
0x53
,
0xdb
,
0x6b
,
0x1e
,
0xeb
,
0x65
,
0x97
,
0x03
,
0x86
,
0x60
,
0xde
,
0xf3
,
0x6c
,
0x38
,
0x75
,
0xe0
,
0x4c
,
0x61
,
0xbb
,
0xbc
,
0x62
,
0x17
,
0xa9
,
0xcd
,
0x79
,
0x3f
,
0x21
,
0x4e
,
0x96
,
0xcb
,
0x0e
,
0xdc
,
0x61
,
0x94
,
0x30
,
0x18
,
0x10
,
0x6b
,
0xd0
,
0x1c
,
0x10
,
0x79
,
0x02
,
0x03
,
0x01
,
0x00
,
0x01
,
0x30
,
0x09
,
0x06
,
0x05
,
0x2b
,
0x0e
,
0x03
,
0x02
,
0x1d
,
0x05
,
0x00
,
0x03
,
0x41
,
0x00
,
0x25
,
0x90
,
0x53
,
0x34
,
0xd9
,
0x56
,
0x41
,
0x5e
,
0xdb
,
0x7e
,
0x01
,
0x36
,
0xec
,
0x27
,
0x61
,
0x5e
,
0xb7
,
0x4d
,
0x90
,
0x66
,
0xa2
,
0xe1
,
0x9d
,
0x58
,
0x76
,
0xd4
,
0x9c
,
0xba
,
0x2c
,
0x84
,
0xc6
,
0x83
,
0x7a
,
0x22
,
0x0d
,
0x03
,
0x69
,
0x32
,
0x1a
,
0x6d
,
0xcb
,
0x0c
,
0x15
,
0xb3
,
0x6b
,
0xc7
,
0x0a
,
0x8c
,
0xb4
,
0x5c
,
0x34
,
0x78
,
0xe0
,
0x3c
,
0x9c
,
0xe9
,
0xf3
,
0x30
,
0x9f
,
0xa8
,
0x76
,
0x57
,
0x92
,
0x36
};
static
const
BYTE
selfSignedSignatureHash
[]
=
{
0x07
,
0x5a
,
0x3e
,
0xfd
,
0x0d
,
0xf6
,
0x88
,
0xeb
,
0x00
,
0x64
,
0xbd
,
0xc9
,
0xd6
,
0xea
,
0x0a
,
0x7c
,
0xcc
,
0x24
,
0xdb
,
0x5d
};
static
void
testCertProperties
(
void
)
static
void
testCertProperties
(
void
)
{
{
...
@@ -481,6 +507,13 @@ static void testCertProperties(void)
...
@@ -481,6 +507,13 @@ static void testCertProperties(void)
checkHash
(
bigCert
,
sizeof
(
bigCert
),
CALG_MD5
,
context
,
checkHash
(
bigCert
,
sizeof
(
bigCert
),
CALG_MD5
,
context
,
CERT_MD5_HASH_PROP_ID
);
CERT_MD5_HASH_PROP_ID
);
/* Getting the signature hash fails with this bogus certificate */
size
=
0
;
ret
=
CertGetCertificateContextProperty
(
context
,
CERT_SIGNATURE_HASH_PROP_ID
,
NULL
,
&
size
);
ok
(
!
ret
&&
GetLastError
()
==
CRYPT_E_ASN1_BADTAG
,
"Expected CRYPT_E_ASN1_BADTAG, got %08x
\n
"
,
GetLastError
());
/* Test key contexts and handles and such */
/* Test key contexts and handles and such */
size
=
0
;
size
=
0
;
ret
=
CertGetCertificateContextProperty
(
context
,
CERT_KEY_CONTEXT_PROP_ID
,
ret
=
CertGetCertificateContextProperty
(
context
,
CERT_KEY_CONTEXT_PROP_ID
,
...
@@ -574,6 +607,21 @@ static void testCertProperties(void)
...
@@ -574,6 +607,21 @@ static void testCertProperties(void)
}
}
}
}
CertFreeCertificateContext
(
context
);
CertFreeCertificateContext
(
context
);
context
=
CertCreateCertificateContext
(
X509_ASN_ENCODING
,
selfSignedCert
,
sizeof
(
selfSignedCert
));
/* Getting the signature hash of a valid (self-signed) cert succeeds */
size
=
0
;
ret
=
CertGetCertificateContextProperty
(
context
,
CERT_SIGNATURE_HASH_PROP_ID
,
NULL
,
&
size
);
ok
(
ret
,
"CertGetCertificateContextProperty failed: %08x
\n
"
,
GetLastError
());
ok
(
size
==
sizeof
(
selfSignedSignatureHash
),
"unexpected size %d
\n
"
,
size
);
ret
=
CertGetCertificateContextProperty
(
context
,
CERT_SIGNATURE_HASH_PROP_ID
,
hashProperty
,
&
size
);
if
(
ret
)
ok
(
!
memcmp
(
hashProperty
,
selfSignedSignatureHash
,
size
),
"unexpected value
\n
"
);
CertFreeCertificateContext
(
context
);
}
}
static
void
testDupCert
(
void
)
static
void
testDupCert
(
void
)
...
@@ -2746,31 +2794,6 @@ static BYTE privKey[] = {
...
@@ -2746,31 +2794,6 @@ static BYTE privKey[] = {
0x93
,
0x32
,
0x16
,
0xec
,
0x69
,
0x51
,
0x1a
,
0x4e
,
0xc3
,
0xf1
,
0x72
,
0x80
,
0x78
,
0x93
,
0x32
,
0x16
,
0xec
,
0x69
,
0x51
,
0x1a
,
0x4e
,
0xc3
,
0xf1
,
0x72
,
0x80
,
0x78
,
0x5e
,
0x66
,
0x4a
,
0x8d
,
0x85
,
0x2f
,
0x3f
,
0xb2
,
0xa7
};
0x5e
,
0x66
,
0x4a
,
0x8d
,
0x85
,
0x2f
,
0x3f
,
0xb2
,
0xa7
};
static
const
BYTE
selfSignedCert
[]
=
{
0x30
,
0x82
,
0x01
,
0x1f
,
0x30
,
0x81
,
0xce
,
0xa0
,
0x03
,
0x02
,
0x01
,
0x02
,
0x02
,
0x10
,
0xeb
,
0x0d
,
0x57
,
0x2a
,
0x9c
,
0x09
,
0xba
,
0xa4
,
0x4a
,
0xb7
,
0x25
,
0x49
,
0xd9
,
0x3e
,
0xb5
,
0x73
,
0x30
,
0x09
,
0x06
,
0x05
,
0x2b
,
0x0e
,
0x03
,
0x02
,
0x1d
,
0x05
,
0x00
,
0x30
,
0x15
,
0x31
,
0x13
,
0x30
,
0x11
,
0x06
,
0x03
,
0x55
,
0x04
,
0x03
,
0x13
,
0x0a
,
0x4a
,
0x75
,
0x61
,
0x6e
,
0x20
,
0x4c
,
0x61
,
0x6e
,
0x67
,
0x00
,
0x30
,
0x1e
,
0x17
,
0x0d
,
0x30
,
0x36
,
0x30
,
0x36
,
0x32
,
0x39
,
0x30
,
0x35
,
0x30
,
0x30
,
0x34
,
0x36
,
0x5a
,
0x17
,
0x0d
,
0x30
,
0x37
,
0x30
,
0x36
,
0x32
,
0x39
,
0x31
,
0x31
,
0x30
,
0x30
,
0x34
,
0x36
,
0x5a
,
0x30
,
0x15
,
0x31
,
0x13
,
0x30
,
0x11
,
0x06
,
0x03
,
0x55
,
0x04
,
0x03
,
0x13
,
0x0a
,
0x4a
,
0x75
,
0x61
,
0x6e
,
0x20
,
0x4c
,
0x61
,
0x6e
,
0x67
,
0x00
,
0x30
,
0x5c
,
0x30
,
0x0d
,
0x06
,
0x09
,
0x2a
,
0x86
,
0x48
,
0x86
,
0xf7
,
0x0d
,
0x01
,
0x01
,
0x01
,
0x05
,
0x00
,
0x03
,
0x4b
,
0x00
,
0x30
,
0x48
,
0x02
,
0x41
,
0x00
,
0xe2
,
0x54
,
0x3a
,
0xa7
,
0x83
,
0xb1
,
0x27
,
0x14
,
0x3e
,
0x59
,
0xbb
,
0xb4
,
0x53
,
0xe6
,
0x1f
,
0xe7
,
0x5d
,
0xf1
,
0x21
,
0x68
,
0xad
,
0x85
,
0x53
,
0xdb
,
0x6b
,
0x1e
,
0xeb
,
0x65
,
0x97
,
0x03
,
0x86
,
0x60
,
0xde
,
0xf3
,
0x6c
,
0x38
,
0x75
,
0xe0
,
0x4c
,
0x61
,
0xbb
,
0xbc
,
0x62
,
0x17
,
0xa9
,
0xcd
,
0x79
,
0x3f
,
0x21
,
0x4e
,
0x96
,
0xcb
,
0x0e
,
0xdc
,
0x61
,
0x94
,
0x30
,
0x18
,
0x10
,
0x6b
,
0xd0
,
0x1c
,
0x10
,
0x79
,
0x02
,
0x03
,
0x01
,
0x00
,
0x01
,
0x30
,
0x09
,
0x06
,
0x05
,
0x2b
,
0x0e
,
0x03
,
0x02
,
0x1d
,
0x05
,
0x00
,
0x03
,
0x41
,
0x00
,
0x25
,
0x90
,
0x53
,
0x34
,
0xd9
,
0x56
,
0x41
,
0x5e
,
0xdb
,
0x7e
,
0x01
,
0x36
,
0xec
,
0x27
,
0x61
,
0x5e
,
0xb7
,
0x4d
,
0x90
,
0x66
,
0xa2
,
0xe1
,
0x9d
,
0x58
,
0x76
,
0xd4
,
0x9c
,
0xba
,
0x2c
,
0x84
,
0xc6
,
0x83
,
0x7a
,
0x22
,
0x0d
,
0x03
,
0x69
,
0x32
,
0x1a
,
0x6d
,
0xcb
,
0x0c
,
0x15
,
0xb3
,
0x6b
,
0xc7
,
0x0a
,
0x8c
,
0xb4
,
0x5c
,
0x34
,
0x78
,
0xe0
,
0x3c
,
0x9c
,
0xe9
,
0xf3
,
0x30
,
0x9f
,
0xa8
,
0x76
,
0x57
,
0x92
,
0x36
};
static
const
BYTE
exportedPublicKeyBlob
[]
=
{
static
const
BYTE
exportedPublicKeyBlob
[]
=
{
0x06
,
0x02
,
0x00
,
0x00
,
0x00
,
0xa4
,
0x00
,
0x00
,
0x52
,
0x53
,
0x41
,
0x31
,
0x00
,
0x02
,
0x00
,
0x00
,
0x06
,
0x02
,
0x00
,
0x00
,
0x00
,
0xa4
,
0x00
,
0x00
,
0x52
,
0x53
,
0x41
,
0x31
,
0x00
,
0x02
,
0x00
,
0x00
,
0x01
,
0x00
,
0x01
,
0x00
,
0x79
,
0x10
,
0x1c
,
0xd0
,
0x6b
,
0x10
,
0x18
,
0x30
,
0x94
,
0x61
,
0xdc
,
0x0e
,
0x01
,
0x00
,
0x01
,
0x00
,
0x79
,
0x10
,
0x1c
,
0xd0
,
0x6b
,
0x10
,
0x18
,
0x30
,
0x94
,
0x61
,
0xdc
,
0x0e
,
...
...
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