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
bbcd95a7
Commit
bbcd95a7
authored
Jun 12, 2007
by
Juan Lang
Committed by
Alexandre Julliard
Jun 13, 2007
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
crypt32: Separate set encoding into a separate function.
parent
1cd9510b
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
70 additions
and
57 deletions
+70
-57
encode.c
dlls/crypt32/encode.c
+70
-57
No files found.
dlls/crypt32/encode.c
View file @
bbcd95a7
...
@@ -1165,92 +1165,105 @@ static int BLOBComp(const void *l, const void *r)
...
@@ -1165,92 +1165,105 @@ static int BLOBComp(const void *l, const void *r)
return
ret
;
return
ret
;
}
}
/* This encodes as a SET OF, which in DER must be lexicographically sorted.
typedef
struct
_CRYPT_SET_OF
{
DWORD
cValue
;
PCRYPT_DER_BLOB
rgValue
;
}
CRYPT_SET_OF
;
/* This encodes a SET OF, which in DER must be lexicographically sorted.
*/
*/
static
BOOL
WINAPI
CRYPT_DEREncodeSet
(
DWORD
dwCertEncodingType
,
LPCSTR
lpszStructType
,
const
void
*
pvStructInfo
,
DWORD
dwFlags
,
PCRYPT_ENCODE_PARA
pEncodePara
,
BYTE
*
pbEncoded
,
DWORD
*
pcbEncoded
)
{
CRYPT_SET_OF
*
set
=
(
CRYPT_SET_OF
*
)
pvStructInfo
;
DWORD
bytesNeeded
=
0
,
lenBytes
,
i
;
BOOL
ret
=
FALSE
;
for
(
i
=
0
;
i
<
set
->
cValue
;
i
++
)
bytesNeeded
+=
set
->
rgValue
[
i
].
cbData
;
CRYPT_EncodeLen
(
bytesNeeded
,
NULL
,
&
lenBytes
);
bytesNeeded
+=
1
+
lenBytes
;
if
(
pbEncoded
)
{
if
(
*
pcbEncoded
<
bytesNeeded
)
{
*
pcbEncoded
=
bytesNeeded
;
SetLastError
(
ERROR_MORE_DATA
);
}
else
{
ret
=
TRUE
;
*
pcbEncoded
=
bytesNeeded
;
qsort
(
set
->
rgValue
,
set
->
cValue
,
sizeof
(
CRYPT_DER_BLOB
),
BLOBComp
);
*
pbEncoded
++
=
ASN_CONSTRUCTOR
|
ASN_SETOF
;
CRYPT_EncodeLen
(
bytesNeeded
-
lenBytes
-
1
,
pbEncoded
,
&
lenBytes
);
pbEncoded
+=
lenBytes
;
for
(
i
=
0
;
ret
&&
i
<
set
->
cValue
;
i
++
)
{
memcpy
(
pbEncoded
,
set
->
rgValue
[
i
].
pbData
,
set
->
rgValue
[
i
].
cbData
);
pbEncoded
+=
set
->
rgValue
[
i
].
cbData
;
}
}
}
else
{
*
pcbEncoded
=
bytesNeeded
;
ret
=
TRUE
;
}
return
ret
;
}
static
BOOL
WINAPI
CRYPT_AsnEncodeRdn
(
DWORD
dwCertEncodingType
,
CERT_RDN
*
rdn
,
static
BOOL
WINAPI
CRYPT_AsnEncodeRdn
(
DWORD
dwCertEncodingType
,
CERT_RDN
*
rdn
,
CryptEncodeObjectExFunc
nameValueEncodeFunc
,
BYTE
*
pbEncoded
,
CryptEncodeObjectExFunc
nameValueEncodeFunc
,
BYTE
*
pbEncoded
,
DWORD
*
pcbEncoded
)
DWORD
*
pcbEncoded
)
{
{
BOOL
ret
;
BOOL
ret
;
CRYPT_
DER_BLOB
*
blobs
=
NULL
;
CRYPT_
SET_OF
setOf
=
{
0
,
NULL
}
;
__TRY
__TRY
{
{
DWORD
bytesNeeded
=
0
,
lenBytes
,
i
;
DWORD
i
;
blobs
=
NULL
;
ret
=
TRUE
;
ret
=
TRUE
;
if
(
rdn
->
cRDNAttr
)
if
(
rdn
->
cRDNAttr
)
{
{
blobs
=
CryptMemAlloc
(
rdn
->
cRDNAttr
*
sizeof
(
CRYPT_DER_BLOB
));
setOf
.
cValue
=
rdn
->
cRDNAttr
;
if
(
!
blobs
)
setOf
.
rgValue
=
CryptMemAlloc
(
rdn
->
cRDNAttr
*
sizeof
(
CRYPT_DER_BLOB
));
if
(
!
setOf
.
rgValue
)
ret
=
FALSE
;
ret
=
FALSE
;
else
else
memset
(
blobs
,
0
,
rdn
->
cRDNAttr
*
sizeof
(
CRYPT_DER_BLOB
));
memset
(
setOf
.
rgValue
,
0
,
setOf
.
cValue
*
sizeof
(
CRYPT_DER_BLOB
));
}
}
for
(
i
=
0
;
ret
&&
i
<
rdn
->
cRDNAttr
;
i
++
)
for
(
i
=
0
;
ret
&&
i
<
rdn
->
cRDNAttr
;
i
++
)
{
{
setOf
.
rgValue
[
i
].
cbData
=
0
;
ret
=
CRYPT_AsnEncodeRdnAttr
(
dwCertEncodingType
,
&
rdn
->
rgRDNAttr
[
i
],
ret
=
CRYPT_AsnEncodeRdnAttr
(
dwCertEncodingType
,
&
rdn
->
rgRDNAttr
[
i
],
nameValueEncodeFunc
,
NULL
,
&
blobs
[
i
].
cbData
);
nameValueEncodeFunc
,
NULL
,
&
setOf
.
rgValue
[
i
].
cbData
);
if
(
ret
)
bytesNeeded
+=
blobs
[
i
].
cbData
;
else
{
/* Have to propagate index of failing character */
*
pcbEncoded
=
blobs
[
i
].
cbData
;
}
}
if
(
ret
)
if
(
ret
)
{
{
CRYPT_EncodeLen
(
bytesNeeded
,
NULL
,
&
lenBytes
);
setOf
.
rgValue
[
i
].
pbData
=
bytesNeeded
+=
1
+
lenBytes
;
CryptMemAlloc
(
setOf
.
rgValue
[
i
].
cbData
);
if
(
pbEncoded
)
if
(
!
setOf
.
rgValue
[
i
].
pbData
)
{
if
(
*
pcbEncoded
<
bytesNeeded
)
{
SetLastError
(
ERROR_MORE_DATA
);
ret
=
FALSE
;
ret
=
FALSE
;
}
else
else
{
for
(
i
=
0
;
ret
&&
i
<
rdn
->
cRDNAttr
;
i
++
)
{
blobs
[
i
].
pbData
=
CryptMemAlloc
(
blobs
[
i
].
cbData
);
if
(
!
blobs
[
i
].
pbData
)
ret
=
FALSE
;
else
{
ret
=
CRYPT_AsnEncodeRdnAttr
(
dwCertEncodingType
,
ret
=
CRYPT_AsnEncodeRdnAttr
(
dwCertEncodingType
,
&
rdn
->
rgRDNAttr
[
i
],
nameValueEncodeFunc
,
&
rdn
->
rgRDNAttr
[
i
],
nameValueEncodeFunc
,
blobs
[
i
].
pbData
,
&
blobs
[
i
].
cbData
);
setOf
.
rgValue
[
i
].
pbData
,
&
setOf
.
rgValue
[
i
].
cbData
);
if
(
!
ret
)
*
pcbEncoded
=
blobs
[
i
].
cbData
;
}
}
}
if
(
ret
)
if
(
!
ret
)
{
qsort
(
blobs
,
rdn
->
cRDNAttr
,
sizeof
(
CRYPT_DER_BLOB
),
BLOBComp
);
*
pbEncoded
++
=
ASN_CONSTRUCTOR
|
ASN_SETOF
;
CRYPT_EncodeLen
(
bytesNeeded
-
lenBytes
-
1
,
pbEncoded
,
&
lenBytes
);
pbEncoded
+=
lenBytes
;
for
(
i
=
0
;
ret
&&
i
<
rdn
->
cRDNAttr
;
i
++
)
{
{
memcpy
(
pbEncoded
,
blobs
[
i
].
pbData
,
blobs
[
i
].
cbData
);
/* Have to propagate index of failing character */
pbEncoded
+=
blobs
[
i
].
cbData
;
*
pcbEncoded
=
setOf
.
rgValue
[
i
].
cbData
;
}
}
}
}
}
}
if
(
ret
)
if
(
ret
)
*
pcbEncoded
=
bytesNeeded
;
ret
=
CRYPT_DEREncodeSet
(
X509_ASN_ENCODING
,
NULL
,
&
setOf
,
0
,
NULL
,
}
pbEncoded
,
pcbEncoded
);
if
(
blobs
)
for
(
i
=
0
;
i
<
setOf
.
cValue
;
i
++
)
{
CryptMemFree
(
setOf
.
rgValue
[
i
].
pbData
);
for
(
i
=
0
;
i
<
rdn
->
cRDNAttr
;
i
++
)
CryptMemFree
(
blobs
[
i
].
pbData
);
}
}
}
__EXCEPT_PAGE_FAULT
__EXCEPT_PAGE_FAULT
{
{
...
@@ -1258,7 +1271,7 @@ static BOOL WINAPI CRYPT_AsnEncodeRdn(DWORD dwCertEncodingType, CERT_RDN *rdn,
...
@@ -1258,7 +1271,7 @@ static BOOL WINAPI CRYPT_AsnEncodeRdn(DWORD dwCertEncodingType, CERT_RDN *rdn,
ret
=
FALSE
;
ret
=
FALSE
;
}
}
__ENDTRY
__ENDTRY
CryptMemFree
(
blobs
);
CryptMemFree
(
setOf
.
rgValue
);
return
ret
;
return
ret
;
}
}
...
...
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