pkix_expirationchecker.c (3594B)
1 /* This Source Code Form is subject to the terms of the Mozilla Public 2 * License, v. 2.0. If a copy of the MPL was not distributed with this 3 * file, You can obtain one at http://mozilla.org/MPL/2.0/. */ 4 /* 5 * pkix_expirationchecker.c 6 * 7 * Functions for expiration validation 8 * 9 */ 10 11 12 #include "pkix_expirationchecker.h" 13 14 /* --Private-Functions-------------------------------------------- */ 15 16 /* 17 * FUNCTION: pkix_ExpirationChecker_Check 18 * (see comments for PKIX_CertChainChecker_CheckCallback in pkix_checker.h) 19 */ 20 PKIX_Error * 21 pkix_ExpirationChecker_Check( 22 PKIX_CertChainChecker *checker, 23 PKIX_PL_Cert *cert, 24 PKIX_List *unresolvedCriticalExtensions, 25 void **pNBIOContext, 26 void *plContext) 27 { 28 PKIX_PL_Date *testDate = NULL; 29 30 PKIX_ENTER(CERTCHAINCHECKER, "pkix_ExpirationChecker_Check"); 31 PKIX_NULLCHECK_THREE(checker, cert, pNBIOContext); 32 33 *pNBIOContext = NULL; /* we never block on pending I/O */ 34 35 PKIX_CHECK(PKIX_CertChainChecker_GetCertChainCheckerState 36 (checker, (PKIX_PL_Object **)&testDate, plContext), 37 PKIX_CERTCHAINCHECKERGETCERTCHAINCHECKERSTATEFAILED); 38 39 PKIX_CHECK(PKIX_PL_Cert_CheckValidity(cert, testDate, plContext), 40 PKIX_CERTCHECKVALIDITYFAILED); 41 42 cleanup: 43 44 PKIX_DECREF(testDate); 45 46 PKIX_RETURN(CERTCHAINCHECKER); 47 48 } 49 50 /* 51 * FUNCTION: pkix_ExpirationChecker_Initialize 52 * DESCRIPTION: 53 * 54 * Creates a new CertChainChecker and stores it at "pChecker", where it will 55 * used by pkix_ExpirationChecker_Check to check that the certificate has not 56 * expired with respect to the Date pointed to by "testDate." If "testDate" 57 * is NULL, then the CertChainChecker will check that a certificate has not 58 * expired with respect to the current date and time. 59 * 60 * PARAMETERS: 61 * "testDate" 62 * Address of Date representing the point in time at which the cert is to 63 * be validated. If "testDate" is NULL, the current date and time is used. 64 * "pChecker" 65 * Address where object pointer will be stored. Must be non-NULL. 66 * "plContext" 67 * Platform-specific context pointer. 68 * THREAD SAFETY: 69 * Thread Safe (see Thread Safety Definitions in Programmer's Guide) 70 * RETURNS: 71 * Returns NULL if the function succeeds. 72 * Returns a CertChainChecker Error if the function fails in a non-fatal way. 73 * Returns a Fatal Error if the function fails in an unrecoverable way. 74 */ 75 PKIX_Error * 76 pkix_ExpirationChecker_Initialize( 77 PKIX_PL_Date *testDate, 78 PKIX_CertChainChecker **pChecker, 79 void *plContext) 80 { 81 PKIX_PL_Date *myDate = NULL; 82 PKIX_PL_Date *nowDate = NULL; 83 84 PKIX_ENTER(CERTCHAINCHECKER, "pkix_ExpirationChecker_Initialize"); 85 PKIX_NULLCHECK_ONE(pChecker); 86 87 /* if testDate is NULL, we use the current time */ 88 if (!testDate){ 89 PKIX_CHECK(PKIX_PL_Date_Create_UTCTime 90 (NULL, &nowDate, plContext), 91 PKIX_DATECREATEUTCTIMEFAILED); 92 myDate = nowDate; 93 } else { 94 myDate = testDate; 95 } 96 97 PKIX_CHECK(PKIX_CertChainChecker_Create 98 (pkix_ExpirationChecker_Check, 99 PKIX_TRUE, 100 PKIX_FALSE, 101 NULL, 102 (PKIX_PL_Object *)myDate, 103 pChecker, 104 plContext), 105 PKIX_CERTCHAINCHECKERCREATEFAILED); 106 107 cleanup: 108 109 PKIX_DECREF(nowDate); 110 111 PKIX_RETURN(CERTCHAINCHECKER); 112 113 }