VirtualBox

source: vbox/trunk/include/iprt/crypto/spc.h@ 95630

Last change on this file since 95630 was 95630, checked in by vboxsync, 3 years ago

IPRT/RTAsn1,RTCrPkcs7,RTCrSpc: Generate setters for dynamic members. bugref:8691

  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
File size: 19.0 KB
Line 
1/** @file
2 * IPRT - Crypto - Microsoft SPC / Authenticode.
3 */
4
5/*
6 * Copyright (C) 2006-2022 Oracle Corporation
7 *
8 * This file is part of VirtualBox Open Source Edition (OSE), as
9 * available from http://www.virtualbox.org. This file is free software;
10 * you can redistribute it and/or modify it under the terms of the GNU
11 * General Public License (GPL) as published by the Free Software
12 * Foundation, in version 2 as it comes in the "COPYING" file of the
13 * VirtualBox OSE distribution. VirtualBox OSE is distributed in the
14 * hope that it will be useful, but WITHOUT ANY WARRANTY of any kind.
15 *
16 * The contents of this file may alternatively be used under the terms
17 * of the Common Development and Distribution License Version 1.0
18 * (CDDL) only, as it comes in the "COPYING.CDDL" file of the
19 * VirtualBox OSE distribution, in which case the provisions of the
20 * CDDL are applicable instead of those of the GPL.
21 *
22 * You may elect to license modified versions of this file under the
23 * terms and conditions of either the GPL or the CDDL or both.
24 */
25
26#ifndef IPRT_INCLUDED_crypto_spc_h
27#define IPRT_INCLUDED_crypto_spc_h
28#ifndef RT_WITHOUT_PRAGMA_ONCE
29# pragma once
30#endif
31
32#include <iprt/asn1.h>
33#include <iprt/crypto/x509.h>
34#include <iprt/crypto/pkcs7.h>
35#include <iprt/md5.h>
36#include <iprt/sha.h>
37
38
39RT_C_DECLS_BEGIN
40
41/** @defgroup grp_rt_cr_spc RTCrSpc - Microsoft Authenticode
42 * @ingroup grp_rt_crypto
43 * @{
44 */
45
46/** Value for RTCR_PKCS9_ID_MS_STATEMENT_TYPE. */
47#define RTCRSPC_STMT_TYPE_INDIVIDUAL_CODE_SIGNING "1.3.6.1.4.1.311.2.1.21"
48
49/**
50 * PE Image page hash table, generic union.
51 *
52 * @remarks This table isn't used by ldrPE.cpp, it walks the table in a generic
53 * fashion using the hash size. So, we can ditch it if we feel like it.
54 */
55typedef union RTCRSPCPEIMAGEPAGEHASHES
56{
57 /** MD5 page hashes. */
58 struct
59 {
60 /** The file offset. */
61 uint32_t offFile;
62 /** The hash. */
63 uint8_t abHash[RTSHA1_HASH_SIZE];
64 } aMd5[1];
65
66 /** SHA-1 page hashes. */
67 struct
68 {
69 /** The file offset. */
70 uint32_t offFile;
71 /** The hash. */
72 uint8_t abHash[RTSHA1_HASH_SIZE];
73 } aSha1[1];
74
75 /** SHA-256 page hashes. */
76 struct
77 {
78 /** The file offset. */
79 uint32_t offFile;
80 /** The hash. */
81 uint8_t abHash[RTSHA256_HASH_SIZE];
82 } aSha256[1];
83
84 /** SHA-512 page hashes. */
85 struct
86 {
87 /** The file offset. */
88 uint32_t offFile;
89 /** The hash. */
90 uint8_t abHash[RTSHA512_HASH_SIZE];
91 } aSha512[1];
92
93 /** Generic view of ONE hash. */
94 struct
95 {
96 /** The file offset. */
97 uint32_t offFile;
98 /** Variable length hash field. */
99 uint8_t abHash[1];
100 } Generic;
101} RTCRSPCPEIMAGEPAGEHASHES;
102/** Pointer to a PE image page hash table union. */
103typedef RTCRSPCPEIMAGEPAGEHASHES *PRTCRSPCPEIMAGEPAGEHASHES;
104/** Pointer to a const PE image page hash table union. */
105typedef RTCRSPCPEIMAGEPAGEHASHES const *PCRTCRSPCPEIMAGEPAGEHASHES;
106
107
108/**
109 * Serialization wrapper for raw RTCRSPCPEIMAGEPAGEHASHES data.
110 */
111typedef struct RTCRSPCSERIALIZEDPAGEHASHES
112{
113 /** The page hashes are within a set. Dunno if there could be multiple
114 * entries in this set, never seen it yet, so I doubt it. */
115 RTASN1SETCORE SetCore;
116 /** Octet string containing the raw data. */
117 RTASN1OCTETSTRING RawData;
118
119 /** Pointer to the hash data within that string.
120 * The hash algorithm is given by the object attribute type in
121 * RTCRSPCSERIALIZEDOBJECTATTRIBUTE. It is generally the same as for the
122 * whole image hash. */
123 PCRTCRSPCPEIMAGEPAGEHASHES pData;
124 /** Field the user can use to store the number of pages in pData. */
125 uint32_t cPages;
126} RTCRSPCSERIALIZEDPAGEHASHES;
127/** Pointer to a serialized wrapper for page hashes. */
128typedef RTCRSPCSERIALIZEDPAGEHASHES *PRTCRSPCSERIALIZEDPAGEHASHES;
129/** Pointer to a const serialized wrapper for page hashes. */
130typedef RTCRSPCSERIALIZEDPAGEHASHES const *PCRTCRSPCSERIALIZEDPAGEHASHES;
131RTASN1TYPE_STANDARD_PROTOTYPES(RTCRSPCSERIALIZEDPAGEHASHES, RTDECL, RTCrSpcSerializedPageHashes, SetCore.Asn1Core);
132
133RTDECL(int) RTCrSpcSerializedPageHashes_UpdateDerivedData(PRTCRSPCSERIALIZEDPAGEHASHES pThis);
134
135
136/**
137 * Data type selection for RTCRSPCSERIALIZEDOBJECTATTRIBUTE.
138 */
139typedef enum RTCRSPCSERIALIZEDOBJECTATTRIBUTETYPE
140{
141 /** Invalid zero entry. */
142 RTCRSPCSERIALIZEDOBJECTATTRIBUTETYPE_INVALID = 0,
143 /** Not present pro forma. */
144 RTCRSPCSERIALIZEDOBJECTATTRIBUTETYPE_NOT_PRESENT,
145 /** Unknown object. */
146 RTCRSPCSERIALIZEDOBJECTATTRIBUTETYPE_UNKNOWN,
147 /** SHA-1 page hashes (pPageHashes). */
148 RTCRSPCSERIALIZEDOBJECTATTRIBUTETYPE_PAGE_HASHES_V1,
149 /** SHA-256 page hashes (pPageHashes). */
150 RTCRSPCSERIALIZEDOBJECTATTRIBUTETYPE_PAGE_HASHES_V2,
151 /** End of valid values. */
152 RTCRSPCSERIALIZEDOBJECTATTRIBUTETYPE_END,
153 /** Blow up the type to at least 32-bits. */
154 RTCRSPCSERIALIZEDOBJECTATTRIBUTETYPE_32BIT_HACK
155} RTCRSPCSERIALIZEDOBJECTATTRIBUTETYPE;
156
157/**
158 * One serialized object attribute (PE image data).
159 */
160typedef struct RTCRSPCSERIALIZEDOBJECTATTRIBUTE
161{
162 /** Sequence core. */
163 RTASN1SEQUENCECORE SeqCore;
164 /** The attribute type. */
165 RTASN1OBJID Type;
166 /** The allocation of the data type. */
167 RTASN1ALLOCATION Allocation;
168 /** Indicates the valid value in the union. */
169 RTCRSPCSERIALIZEDOBJECTATTRIBUTETYPE enmType;
170 /** Union with data format depending on the Type. */
171 union
172 {
173 /** The unknown value (RTCRSPCSERIALIZEDOBJECTATTRIBUTETYPE_UNKNOWN). */
174 PRTASN1CORE pCore;
175 /** Page hashes (RTCRSPCSERIALIZEDOBJECTATTRIBUTETYPE_PAGE_HASHES_V1 or
176 * RTCRSPCSERIALIZEDOBJECTATTRIBUTETYPE_PAGE_HASHES_V2). */
177 PRTCRSPCSERIALIZEDPAGEHASHES pPageHashes;
178 } u;
179} RTCRSPCSERIALIZEDOBJECTATTRIBUTE;
180/** Pointer to a serialized object attribute. */
181typedef RTCRSPCSERIALIZEDOBJECTATTRIBUTE *PRTCRSPCSERIALIZEDOBJECTATTRIBUTE;
182/** Pointer to a const serialized object attribute. */
183typedef RTCRSPCSERIALIZEDOBJECTATTRIBUTE const *PCRTCRSPCSERIALIZEDOBJECTATTRIBUTE;
184RTASN1TYPE_STANDARD_PROTOTYPES(RTCRSPCSERIALIZEDOBJECTATTRIBUTE, RTDECL, RTCrSpcSerializedObjectAttribute, SeqCore.Asn1Core);
185
186RTDECL(int) RTCrSpcSerializedObjectAttribute_SetV1Hashes(PRTCRSPCSERIALIZEDOBJECTATTRIBUTE pThis,
187 PCRTCRSPCSERIALIZEDPAGEHASHES, PCRTASN1ALLOCATORVTABLE pAllocator);
188RTDECL(int) RTCrSpcSerializedObjectAttribute_SetV2Hashes(PRTCRSPCSERIALIZEDOBJECTATTRIBUTE pThis,
189 PCRTCRSPCSERIALIZEDPAGEHASHES, PCRTASN1ALLOCATORVTABLE pAllocator);
190
191/** @name RTCRSPCSERIALIZEDOBJECTATTRIBUTE::Type values
192 * @{ */
193/** Serialized object attribute type for page hashes version 1. */
194#define RTCRSPC_PE_IMAGE_HASHES_V1_OID "1.3.6.1.4.1.311.2.3.1"
195/** Serialized object attribute type for page hashes version 2. */
196#define RTCRSPC_PE_IMAGE_HASHES_V2_OID "1.3.6.1.4.1.311.2.3.2"
197/** @} */
198
199
200/*
201 * Set of serialized object attributes (PE image data).
202 */
203RTASN1_IMPL_GEN_SET_OF_TYPEDEFS_AND_PROTOS(RTCRSPCSERIALIZEDOBJECTATTRIBUTES, RTCRSPCSERIALIZEDOBJECTATTRIBUTE, RTDECL,
204 RTCrSpcSerializedObjectAttributes);
205
206/** The UUID found in RTCRSPCSERIALIZEDOBJECT::Uuid for
207 * RTCRSPCSERIALIZEDOBJECTATTRIBUTES. */
208#define RTCRSPCSERIALIZEDOBJECT_UUID_STR "d586b5a6-a1b4-6624-ae05-a217da8e60d6"
209
210
211/**
212 * Decoded encapsulated data type selection in RTCRSPCSERIALIZEDOBJECT.
213 */
214typedef enum RTCRSPCSERIALIZEDOBJECTTYPE
215{
216 /** Invalid zero value. */
217 RTCRSPCSERIALIZEDOBJECTTYPE_INVALID = 0,
218 /** Serialized object attributes (RTCRSPCSERIALIZEDOBJECT_UUID_STR / pAttribs). */
219 RTCRSPCSERIALIZEDOBJECTTYPE_ATTRIBUTES,
220 /** End of valid values. */
221 RTCRSPCSERIALIZEDOBJECTTYPE_END,
222 /** MAke sure the type is at least 32-bit wide. */
223 RTCRSPCSERIALIZEDOBJECTTYPE_32BIT_HACK = 0x7fffffff
224} RTCRSPCSERIALIZEDOBJECTTYPE;
225
226/**
227 * A serialized object (PE image data).
228 */
229typedef struct RTCRSPCSERIALIZEDOBJECT
230{
231 /** Sequence core. */
232 RTASN1SEQUENCECORE SeqCore;
233 /** The UUID of the data object. */
234 RTASN1OCTETSTRING Uuid;
235 /** Serialized data object. */
236 RTASN1OCTETSTRING SerializedData;
237
238 /** Indicates the valid pointer in the union. */
239 RTCRSPCSERIALIZEDOBJECTTYPE enmType;
240 /** Union of pointers shadowing SerializedData.pEncapsulated. */
241 union
242 {
243 /** Generic core pointer. */
244 PRTASN1CORE pCore;
245 /** Pointer to decoded data if Uuid is RTCRSPCSERIALIZEDOBJECT_UUID_STR. */
246 PRTCRSPCSERIALIZEDOBJECTATTRIBUTES pData;
247 } u;
248} RTCRSPCSERIALIZEDOBJECT;
249/** Pointer to a serialized object (PE image data). */
250typedef RTCRSPCSERIALIZEDOBJECT *PRTCRSPCSERIALIZEDOBJECT;
251/** Pointer to a const serialized object (PE image data). */
252typedef RTCRSPCSERIALIZEDOBJECT const *PCRTCRSPCSERIALIZEDOBJECT;
253RTASN1TYPE_STANDARD_PROTOTYPES(RTCRSPCSERIALIZEDOBJECT, RTDECL, RTCrSpcSerializedObject, SeqCore.Asn1Core);
254
255
256/**
257 * RTCRSPCSTRING choices.
258 */
259typedef enum RTCRSPCSTRINGCHOICE
260{
261 /** Invalid zero value. */
262 RTCRSPCSTRINGCHOICE_INVALID = 0,
263 /** Not present. */
264 RTCRSPCSTRINGCHOICE_NOT_PRESENT,
265 /** UCS-2 string (pUcs2). */
266 RTCRSPCSTRINGCHOICE_UCS2,
267 /** ASCII string (pAscii). */
268 RTCRSPCSTRINGCHOICE_ASCII,
269 /** End of valid values. */
270 RTCRSPCSTRINGCHOICE_END,
271 /** Blow the type up to 32-bit. */
272 RTCRSPCSTRINGCHOICE_32BIT_HACK = 0x7fffffff
273} RTCRSPCSTRINGCHOICE;
274
275/**
276 * Stupid microsoft choosy string type.
277 */
278typedef struct RTCRSPCSTRING
279{
280 /** Dummy core. */
281 RTASN1DUMMY Dummy;
282 /** Allocation of what the pointer below points to. */
283 RTASN1ALLOCATION Allocation;
284 /** Pointer choice.*/
285 RTCRSPCSTRINGCHOICE enmChoice;
286 /** Pointer union. */
287 union
288 {
289 /** Tag 0, implicit: UCS-2 (BMP) string. */
290 PRTASN1STRING pUcs2;
291 /** Tag 1, implicit: ASCII (IA5) string. */
292 PRTASN1STRING pAscii;
293 } u;
294} RTCRSPCSTRING;
295/** Pointer to a stupid microsoft string choice. */
296typedef RTCRSPCSTRING *PRTCRSPCSTRING;
297/** Pointer to a const stupid microsoft string choice. */
298typedef RTCRSPCSTRING const *PCRTCRSPCSTRING;
299RTASN1TYPE_STANDARD_PROTOTYPES(RTCRSPCSTRING, RTDECL, RTCrSpcString, Dummy.Asn1Core);
300
301RTDECL(int) RTCrSpcString_SetUcs2(PRTCRSPCSTRING pThis, PCRTASN1STRING pToClone, PCRTASN1ALLOCATORVTABLE pAllocator);
302RTDECL(int) RTCrSpcString_SetAscii(PRTCRSPCSTRING pThis, PCRTASN1STRING pToClone, PCRTASN1ALLOCATORVTABLE pAllocator);
303
304
305/**
306 * RTCRSPCSTRING choices.
307 */
308typedef enum RTCRSPCLINKCHOICE
309{
310 /** Invalid zero value. */
311 RTCRSPCLINKCHOICE_INVALID = 0,
312 /** Not present. */
313 RTCRSPCLINKCHOICE_NOT_PRESENT,
314 /** URL (ASCII) string (pUrl). */
315 RTCRSPCLINKCHOICE_URL,
316 /** Serialized object (pMoniker). */
317 RTCRSPCLINKCHOICE_MONIKER,
318 /** Filename (pT2). */
319 RTCRSPCLINKCHOICE_FILE,
320 /** End of valid values. */
321 RTCRSPCLINKCHOICE_END,
322 /** Blow the type up to 32-bit. */
323 RTCRSPCLINKCHOICE_32BIT_HACK = 0x7fffffff
324} RTCRSPCLINKCHOICE;
325
326/**
327 * PE image data link.
328 */
329typedef struct RTCRSPCLINK
330{
331 /** Dummy core. */
332 RTASN1DUMMY Dummy;
333 /** Allocation of what the pointer below points to. */
334 RTASN1ALLOCATION Allocation;
335 /** Pointer choice.*/
336 RTCRSPCLINKCHOICE enmChoice;
337 /** Pointer union. */
338 union
339 {
340 /** Tag 0, implicit: An URL encoded as an IA5 STRING. */
341 PRTASN1STRING pUrl;
342 /** Tag 1, implicit: A serialized object. */
343 PRTCRSPCSERIALIZEDOBJECT pMoniker;
344 /** Tag 2, explicit: The default, a file name.
345 * Documented to be set to "<<<Obsolete>>>" when used. */
346 struct
347 {
348 /** Context tag 2. */
349 RTASN1CONTEXTTAG2 CtxTag2;
350 /** The file name string. */
351 RTCRSPCSTRING File;
352 } *pT2;
353 } u;
354} RTCRSPCLINK;
355/** Poitner to a PE image data link. */
356typedef RTCRSPCLINK *PRTCRSPCLINK;
357/** Poitner to a const PE image data link. */
358typedef RTCRSPCLINK const *PCRTCRSPCLINK;
359RTASN1TYPE_STANDARD_PROTOTYPES(RTCRSPCLINK, RTDECL, RTCrSpcLink, Dummy.Asn1Core);
360
361RTDECL(int) RTCrSpcLink_SetUrl(PRTCRSPCLINK pThis, PCRTASN1STRING pToClone, PCRTASN1ALLOCATORVTABLE pAllocator);
362RTDECL(int) RTCrSpcLink_SetMoniker(PRTCRSPCLINK pThis, PCRTCRSPCSERIALIZEDOBJECT pToClone, PCRTASN1ALLOCATORVTABLE pAllocator);
363RTDECL(int) RTCrSpcLink_SetFile(PRTCRSPCLINK pThis, PCRTCRSPCSTRING pToClone, PCRTASN1ALLOCATORVTABLE pAllocator);
364
365
366#if 0 /** @todo Might not be the correct bit order. */
367/**
368 * Flag values for RTCRSPCPEIMAGEDATA::Flags and RTCRSPCPEIMAGEDATA::fFlags.
369 */
370typedef enum RTCRSPCPEIMAGEFLAGS
371{
372 RTCRSPCPEIMAGEFLAGS_INCLUDE_RESOURCES = 0,
373 RTCRSPCPEIMAGEFLAGS_INCLUDE_DEBUG_INFO = 1,
374 RTCRSPCPEIMAGEFLAGS_IMPORT_ADDRESS_TABLE = 2
375} RTCRSPCPEIMAGEFLAGS;
376#endif
377
378
379/**
380 * Authenticode PE Image data.
381 */
382typedef struct RTCRSPCPEIMAGEDATA
383{
384 /** Sequence core. */
385 RTASN1SEQUENCECORE SeqCore;
386 /** One of the RTCRSPCPEIMAGEFLAGS value, default is
387 * RTCRSPCPEIMAGEFLAGS_INCLUDE_RESOURCES. Obsolete with v2 page hashes? */
388 RTASN1BITSTRING Flags;
389 /** Tag 0, explicit: Link to the data. */
390 struct
391 {
392 /** Context tag 0. */
393 RTASN1CONTEXTTAG0 CtxTag0;
394 /** Link to the data. */
395 RTCRSPCLINK File;
396 } T0;
397} RTCRSPCPEIMAGEDATA;
398/** Pointer to a authenticode PE image data representation. */
399typedef RTCRSPCPEIMAGEDATA *PRTCRSPCPEIMAGEDATA;
400/** Pointer to a const authenticode PE image data representation. */
401typedef RTCRSPCPEIMAGEDATA const *PCRTCRSPCPEIMAGEDATA;
402RTASN1TYPE_STANDARD_PROTOTYPES(RTCRSPCPEIMAGEDATA, RTDECL, RTCrSpcPeImageData, SeqCore.Asn1Core);
403
404RTDECL(int) RTCrSpcPeImageData_SetFlags(PRTCRSPCPEIMAGEDATA pThis, PCRTASN1BITSTRING pToClone, PCRTASN1ALLOCATORVTABLE pAllocator);
405RTDECL(int) RTCrSpcPeImageData_SetFile(PRTCRSPCPEIMAGEDATA pThis, PCRTCRSPCLINK pToClone, PCRTASN1ALLOCATORVTABLE pAllocator);
406
407/** The object ID for SpcPeImageData. */
408#define RTCRSPCPEIMAGEDATA_OID "1.3.6.1.4.1.311.2.1.15"
409
410
411/**
412 * Data type selection for RTCRSPCATTRIBUTETYPEANDOPTIONALVALUE.
413 */
414typedef enum RTCRSPCAAOVTYPE
415{
416 /** Invalid zero entry. */
417 RTCRSPCAAOVTYPE_INVALID = 0,
418 /** Not present (pro forma). */
419 RTCRSPCAAOVTYPE_NOT_PRESENT,
420 /** Unknown object. */
421 RTCRSPCAAOVTYPE_UNKNOWN,
422 /** PE image data (pPeImage). */
423 RTCRSPCAAOVTYPE_PE_IMAGE_DATA,
424 /** End of valid values. */
425 RTCRSPCAAOVTYPE_END,
426 /** Blow up the type to at least 32-bits. */
427 RTCRSPCAAOVTYPE_32BIT_HACK
428} RTCRSPCAAOVTYPE;
429
430/**
431 * Authenticode attribute type and optional value.
432 *
433 * Note! Spec says the value should be explicitly tagged, but in real life
434 * it isn't. So, not very optional?
435 */
436typedef struct RTCRSPCATTRIBUTETYPEANDOPTIONALVALUE
437{
438 /** Sequence core. */
439 RTASN1SEQUENCECORE SeqCore;
440 /** An object ID indicating the type of the value. */
441 RTASN1OBJID Type;
442 /** Allocation of the optional data value. */
443 RTASN1ALLOCATION Allocation;
444 /** The valid pointer. */
445 RTCRSPCAAOVTYPE enmType;
446 /** The value part depends on the Type. */
447 union
448 {
449 /** RTCRSPCAAOVTYPE_UNKNOWN / Generic. */
450 PRTASN1CORE pCore;
451 /** RTCRSPCAAOVTYPE_PE_IMAGE_DATA / RTCRSPCPEIMAGEDATA_OID. */
452 PRTCRSPCPEIMAGEDATA pPeImage;
453 } uValue;
454} RTCRSPCATTRIBUTETYPEANDOPTIONALVALUE;
455/** Pointer to a authentication attribute type and optional value
456 * representation. */
457typedef RTCRSPCATTRIBUTETYPEANDOPTIONALVALUE *PRTCRSPCATTRIBUTETYPEANDOPTIONALVALUE;
458/** Pointer to a const authentication attribute type and optional value
459 * representation. */
460typedef RTCRSPCATTRIBUTETYPEANDOPTIONALVALUE const *PCRTCRSPCATTRIBUTETYPEANDOPTIONALVALUE;
461RTASN1TYPE_STANDARD_PROTOTYPES(RTCRSPCATTRIBUTETYPEANDOPTIONALVALUE, RTDECL, RTCrSpcAttributeTypeAndOptionalValue, SeqCore.Asn1Core);
462
463RTDECL(int) RTCrSpcAttributeTypeAndOptionalValue_SetPeImage(PRTCRSPCATTRIBUTETYPEANDOPTIONALVALUE pThis,
464 PCRTCRSPCPEIMAGEDATA pToClone, PCRTASN1ALLOCATORVTABLE pAllocator);
465
466/**
467 * Authenticode indirect data content.
468 */
469typedef struct RTCRSPCINDIRECTDATACONTENT
470{
471 /** Sequence core. */
472 RTASN1SEQUENCECORE SeqCore;
473 /** Additional data. */
474 RTCRSPCATTRIBUTETYPEANDOPTIONALVALUE Data;
475 /** The whole image digest. */
476 RTCRPKCS7DIGESTINFO DigestInfo;
477} RTCRSPCINDIRECTDATACONTENT;
478/** Pointer to a authenticode indirect data content representation. */
479typedef RTCRSPCINDIRECTDATACONTENT *PRTCRSPCINDIRECTDATACONTENT;
480/** Pointer to a const authenticode indirect data content representation. */
481typedef RTCRSPCINDIRECTDATACONTENT const *PCRTCRSPCINDIRECTDATACONTENT;
482RTASN1TYPE_STANDARD_PROTOTYPES(RTCRSPCINDIRECTDATACONTENT, RTDECL, RTCrSpcIndirectDataContent, SeqCore.Asn1Core);
483
484/** The object ID for SpcIndirectDataContent. */
485#define RTCRSPCINDIRECTDATACONTENT_OID "1.3.6.1.4.1.311.2.1.4"
486
487/**
488 * Check the sanity of an Authenticode SPCIndirectDataContent object.
489 *
490 * @returns IPRT status code
491 * @param pIndData The Authenticode SPCIndirectDataContent to
492 * check.
493 * @param pSignedData The related signed data object.
494 * @param fFlags RTCRSPCINDIRECTDATACONTENT_SANITY_F_XXX.
495 * @param pErrInfo Optional error info.
496 */
497RTDECL(int) RTCrSpcIndirectDataContent_CheckSanityEx(PCRTCRSPCINDIRECTDATACONTENT pIndData, PCRTCRPKCS7SIGNEDDATA pSignedData,
498 uint32_t fFlags, PRTERRINFO pErrInfo);
499/** @name RTCRSPCINDIRECTDATACONTENT_SANITY_F_XXX for RTCrSpcIndirectDataContent_CheckSanityEx.
500 * @{ */
501/** The digest hash algorithm must be known to IPRT. */
502#define RTCRSPCINDIRECTDATACONTENT_SANITY_F_ONLY_KNOWN_HASH RT_BIT_32(0)
503/** PE image signing, check expectations of the spec. */
504#define RTCRSPCINDIRECTDATACONTENT_SANITY_F_PE_IMAGE RT_BIT_32(1)
505/** @} */
506
507/**
508 * Gets the first SPC serialized object attribute in a SPC PE image.
509 *
510 * @returns Pointer to the attribute with the given type, NULL if not found.
511 * @param pThis The Authenticode SpcIndirectDataContent.
512 * @param enmType The type of attribute to get.
513 */
514RTDECL(PCRTCRSPCSERIALIZEDOBJECTATTRIBUTE)
515RTCrSpcIndirectDataContent_GetPeImageObjAttrib(PCRTCRSPCINDIRECTDATACONTENT pThis,
516 RTCRSPCSERIALIZEDOBJECTATTRIBUTETYPE enmType);
517
518/** @} */
519
520RT_C_DECLS_END
521
522#endif /* !IPRT_INCLUDED_crypto_spc_h */
523
Note: See TracBrowser for help on using the repository browser.

© 2024 Oracle Support Privacy / Do Not Sell My Info Terms of Use Trademark Policy Automated Access Etiquette