]> git.saurik.com Git - apple/security.git/blob - OSX/libsecurity_apple_x509_tp/lib/TPDatabase.h
Security-57337.40.85.tar.gz
[apple/security.git] / OSX / libsecurity_apple_x509_tp / lib / TPDatabase.h
1 /*
2 * Copyright (c) 2002,2011,2014 Apple Inc. All Rights Reserved.
3 *
4 * The contents of this file constitute Original Code as defined in and are
5 * subject to the Apple Public Source License Version 1.2 (the 'License').
6 * You may not use this file except in compliance with the License. Please obtain
7 * a copy of the License at http://www.apple.com/publicsource and read it before
8 * using this file.
9 *
10 * This Original Code and all software distributed under the License are
11 * distributed on an 'AS IS' basis, WITHOUT WARRANTY OF ANY KIND, EITHER EXPRESS
12 * OR IMPLIED, AND APPLE HEREBY DISCLAIMS ALL SUCH WARRANTIES, INCLUDING WITHOUT
13 * LIMITATION, ANY WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR
14 * PURPOSE, QUIET ENJOYMENT OR NON-INFRINGEMENT. Please see the License for the
15 * specific language governing rights and limitations under the License.
16 */
17
18
19 /*
20 * TPDatabase.h - TP's DL/DB access functions.
21 *
22 */
23
24 #ifndef _TP_DATABASE_H_
25 #define _TP_DATABASE_H_
26
27 #include <Security/cssmtype.h>
28 #include <security_utilities/alloc.h>
29 #include "TPCertInfo.h"
30
31 #ifdef __cplusplus
32 extern "C" {
33 #endif
34
35 TPCertInfo *tpDbFindIssuerCert(
36 Allocator &alloc,
37 CSSM_CL_HANDLE clHand,
38 CSSM_CSP_HANDLE cspHand,
39 const TPClItemInfo *subjectItem,
40 const CSSM_DL_DB_LIST *dbList,
41 const char *verifyTime, // may be NULL
42 bool &partialIssuerKey, // RETURNED
43 TPCertInfo *oldRoot);
44
45 /*
46 * Search a list of DBs for a CRL from the specified issuer and (optional)
47 * TPVerifyContext.verifyTime.
48 * Just a boolean return - we found it, or not. If we did, we return a
49 * TPCrlInfo which has been verified with the specified TPVerifyContext.
50 */
51 class TPCrlInfo;
52 class TPVerifyContext;
53
54 TPCrlInfo *tpDbFindIssuerCrl(
55 TPVerifyContext &vfyCtx,
56 const CSSM_DATA &issuer,
57 TPCertInfo &forCert);
58
59 #if WRITE_FETCHED_CRLS_TO_DB
60 /*
61 * Store a CRL in a DLDB.
62 */
63 CSSM_RETURN tpDbStoreCrl(
64 TPCrlInfo &crl,
65 CSSM_DL_DB_HANDLE &dlDb);
66
67 #endif /* WRITE_FETCHED_CRLS_TO_DB */
68
69 #ifdef __cplusplus
70 }
71 #endif
72
73 #endif /* _TP_DATABASE_H_ */