Blame nss/cmd/libpkix/sample_apps/validate_chain.c

Packit 40b132
/* This Source Code Form is subject to the terms of the Mozilla Public
Packit 40b132
 * License, v. 2.0. If a copy of the MPL was not distributed with this
Packit 40b132
 * file, You can obtain one at http://mozilla.org/MPL/2.0/. */
Packit 40b132
/*
Packit 40b132
 * validateChain.c
Packit 40b132
 *
Packit 40b132
 * Tests Cert Chain Validation
Packit 40b132
 *
Packit 40b132
 */
Packit 40b132
Packit 40b132
#include <stdio.h>
Packit 40b132
#include <string.h>
Packit 40b132
#include <stddef.h>
Packit 40b132
Packit 40b132
#include "pkix_pl_generalname.h"
Packit 40b132
#include "pkix_pl_cert.h"
Packit 40b132
#include "pkix.h"
Packit 40b132
#include "testutil.h"
Packit 40b132
#include "prlong.h"
Packit 40b132
#include "plstr.h"
Packit 40b132
#include "prthread.h"
Packit 40b132
#include "nspr.h"
Packit 40b132
#include "prtypes.h"
Packit 40b132
#include "prtime.h"
Packit 40b132
#include "pk11func.h"
Packit 40b132
#include "secasn1.h"
Packit 40b132
#include "cert.h"
Packit 40b132
#include "cryptohi.h"
Packit 40b132
#include "secoid.h"
Packit 40b132
#include "certdb.h"
Packit 40b132
#include "secitem.h"
Packit 40b132
#include "keythi.h"
Packit 40b132
#include "nss.h"
Packit 40b132
Packit 40b132
static void *plContext = NULL;
Packit 40b132
Packit 40b132
static 
Packit 40b132
void printUsage(void){
Packit 40b132
        (void) printf("\nUSAGE:\tvalidateChain <trustedCert> "
Packit 40b132
                "<cert_1> <cert_2> ... <cert_n>\n");
Packit 40b132
        (void) printf("\tValidates a chain of n certificates "
Packit 40b132
                "using the given trust anchor.\n");
Packit 40b132
Packit 40b132
}
Packit 40b132
Packit 40b132
static PKIX_PL_Cert *
Packit 40b132
createCert(char *inFileName)
Packit 40b132
{
Packit 40b132
        PKIX_PL_ByteArray *byteArray = NULL;
Packit 40b132
        void *buf = NULL;
Packit 40b132
        PRFileDesc *inFile = NULL;
Packit 40b132
        PKIX_UInt32 len;
Packit 40b132
        SECItem certDER;
Packit 40b132
        SECStatus rv;
Packit 40b132
        /* default: NULL cert (failure case) */
Packit 40b132
        PKIX_PL_Cert *cert = NULL;
Packit 40b132
Packit 40b132
        PKIX_TEST_STD_VARS();
Packit 40b132
Packit 40b132
        certDER.data = NULL;
Packit 40b132
Packit 40b132
        inFile = PR_Open(inFileName, PR_RDONLY, 0);
Packit 40b132
Packit 40b132
        if (!inFile){
Packit 40b132
                pkixTestErrorMsg = "Unable to open cert file";
Packit 40b132
                goto cleanup;
Packit 40b132
        } else {
Packit 40b132
                rv = SECU_ReadDERFromFile(&certDER, inFile, PR_FALSE, PR_FALSE);
Packit 40b132
                if (!rv){
Packit 40b132
                        buf = (void *)certDER.data;
Packit 40b132
                        len = certDER.len;
Packit 40b132
Packit 40b132
                        PKIX_TEST_EXPECT_NO_ERROR
Packit 40b132
                                (PKIX_PL_ByteArray_Create
Packit 40b132
                                (buf, len, &byteArray, plContext));
Packit 40b132
Packit 40b132
                        PKIX_TEST_EXPECT_NO_ERROR(PKIX_PL_Cert_Create
Packit 40b132
                                                (byteArray, &cert, plContext));
Packit 40b132
Packit 40b132
                        SECITEM_FreeItem(&certDER, PR_FALSE);
Packit 40b132
                } else {
Packit 40b132
                        pkixTestErrorMsg = "Unable to read DER from cert file";
Packit 40b132
                        goto cleanup;
Packit 40b132
                }
Packit 40b132
        }
Packit 40b132
Packit 40b132
cleanup:
Packit 40b132
Packit 40b132
        if (inFile){
Packit 40b132
                PR_Close(inFile);
Packit 40b132
        }
Packit 40b132
Packit 40b132
        if (PKIX_TEST_ERROR_RECEIVED){
Packit 40b132
                SECITEM_FreeItem(&certDER, PR_FALSE);
Packit 40b132
        }
Packit 40b132
Packit 40b132
        PKIX_TEST_DECREF_AC(byteArray);
Packit 40b132
Packit 40b132
        PKIX_TEST_RETURN();
Packit 40b132
Packit 40b132
        return (cert);
Packit 40b132
}
Packit 40b132
Packit 40b132
int validate_chain(int argc, char *argv[])
Packit 40b132
{
Packit 40b132
        PKIX_TrustAnchor *anchor = NULL;
Packit 40b132
        PKIX_List *anchors = NULL;
Packit 40b132
        PKIX_List *certs = NULL;
Packit 40b132
        PKIX_ProcessingParams *procParams = NULL;
Packit 40b132
        PKIX_ValidateParams *valParams = NULL;
Packit 40b132
        PKIX_ValidateResult *valResult = NULL;
Packit 40b132
        PKIX_PL_X500Name *subject = NULL;
Packit 40b132
        PKIX_ComCertSelParams *certSelParams = NULL;
Packit 40b132
        PKIX_CertSelector *certSelector = NULL;
Packit 40b132
	PKIX_VerifyNode *verifyTree = NULL;
Packit 40b132
	PKIX_PL_String *verifyString = NULL;
Packit 40b132
Packit 40b132
        char *trustedCertFile = NULL;
Packit 40b132
        char *chainCertFile = NULL;
Packit 40b132
        PKIX_PL_Cert *trustedCert = NULL;
Packit 40b132
        PKIX_PL_Cert *chainCert = NULL;
Packit 40b132
        PKIX_UInt32 chainLength = 0;
Packit 40b132
        PKIX_UInt32 i = 0;
Packit 40b132
        PKIX_UInt32 j = 0;
Packit 40b132
        PKIX_UInt32 actualMinorVersion;
Packit 40b132
Packit 40b132
        PKIX_TEST_STD_VARS();
Packit 40b132
Packit 40b132
        if (argc < 3){
Packit 40b132
                printUsage();
Packit 40b132
                return (0);
Packit 40b132
        }
Packit 40b132
Packit 40b132
        PKIX_TEST_EXPECT_NO_ERROR(
Packit 40b132
            PKIX_PL_NssContext_Create(0, PKIX_FALSE, NULL, &plContext));
Packit 40b132
Packit 40b132
        chainLength = (argc - j) - 2;
Packit 40b132
Packit 40b132
        /* create processing params with list of trust anchors */
Packit 40b132
        trustedCertFile = argv[1+j];
Packit 40b132
        trustedCert = createCert(trustedCertFile);
Packit 40b132
Packit 40b132
        PKIX_TEST_EXPECT_NO_ERROR
Packit 40b132
                (PKIX_PL_Cert_GetSubject(trustedCert, &subject, plContext));
Packit 40b132
Packit 40b132
        PKIX_TEST_EXPECT_NO_ERROR
Packit 40b132
                (PKIX_ComCertSelParams_Create(&certSelParams, plContext));
Packit 40b132
Packit 40b132
#if 0
Packit 40b132
        PKIX_TEST_EXPECT_NO_ERROR(PKIX_ComCertSelParams_SetSubject
Packit 40b132
                                    (certSelParams, subject, plContext));
Packit 40b132
#endif
Packit 40b132
Packit 40b132
        PKIX_TEST_EXPECT_NO_ERROR
Packit 40b132
                (PKIX_CertSelector_Create
Packit 40b132
                (NULL, NULL, &certSelector, plContext));
Packit 40b132
Packit 40b132
        PKIX_TEST_EXPECT_NO_ERROR(PKIX_CertSelector_SetCommonCertSelectorParams
Packit 40b132
                                (certSelector, certSelParams, plContext));
Packit 40b132
Packit 40b132
        PKIX_TEST_DECREF_BC(subject);
Packit 40b132
        PKIX_TEST_DECREF_BC(certSelParams);
Packit 40b132
Packit 40b132
        PKIX_TEST_EXPECT_NO_ERROR(PKIX_TrustAnchor_CreateWithCert
Packit 40b132
                                    (trustedCert, &anchor, plContext));
Packit 40b132
Packit 40b132
        PKIX_TEST_EXPECT_NO_ERROR(PKIX_List_Create(&anchors, plContext));
Packit 40b132
        PKIX_TEST_EXPECT_NO_ERROR
Packit 40b132
                (PKIX_List_AppendItem
Packit 40b132
                (anchors, (PKIX_PL_Object *)anchor, plContext));
Packit 40b132
        PKIX_TEST_EXPECT_NO_ERROR(PKIX_ProcessingParams_Create
Packit 40b132
                                    (anchors, &procParams, plContext));
Packit 40b132
Packit 40b132
        PKIX_TEST_EXPECT_NO_ERROR
Packit 40b132
                (PKIX_ProcessingParams_SetTargetCertConstraints
Packit 40b132
                (procParams, certSelector, plContext));
Packit 40b132
Packit 40b132
        PKIX_TEST_DECREF_BC(certSelector);
Packit 40b132
Packit 40b132
        /* create cert chain */
Packit 40b132
        PKIX_TEST_EXPECT_NO_ERROR(PKIX_List_Create(&certs, plContext));
Packit 40b132
        for (i = 0; i < chainLength; i++){
Packit 40b132
                chainCertFile = argv[(i + j) + 2];
Packit 40b132
                chainCert = createCert(chainCertFile);
Packit 40b132
Packit 40b132
                PKIX_TEST_EXPECT_NO_ERROR(PKIX_List_AppendItem
Packit 40b132
                                            (certs,
Packit 40b132
                                            (PKIX_PL_Object *)chainCert,
Packit 40b132
                                            plContext));
Packit 40b132
Packit 40b132
                PKIX_TEST_DECREF_BC(chainCert);
Packit 40b132
                chainCert = NULL;
Packit 40b132
        }
Packit 40b132
        /* create validate params with processing params and cert chain */
Packit 40b132
        PKIX_TEST_EXPECT_NO_ERROR(PKIX_ValidateParams_Create
Packit 40b132
                                    (procParams, certs, &valParams, plContext));
Packit 40b132
Packit 40b132
        PKIX_TEST_DECREF_BC(trustedCert); trustedCert = NULL;
Packit 40b132
        PKIX_TEST_DECREF_BC(anchor); anchor = NULL;
Packit 40b132
        PKIX_TEST_DECREF_BC(anchors); anchors = NULL;
Packit 40b132
        PKIX_TEST_DECREF_BC(certs); certs = NULL;
Packit 40b132
        PKIX_TEST_DECREF_BC(procParams); procParams = NULL;
Packit 40b132
Packit 40b132
        /* validate cert chain using processing params and return valResult */
Packit 40b132
Packit 40b132
        PKIX_TEST_EXPECT_NO_ERROR
Packit 40b132
                (PKIX_ValidateChain(valParams, &valResult, &verifyTree, plContext));
Packit 40b132
Packit 40b132
        if (valResult != NULL){
Packit 40b132
                (void) printf("SUCCESSFULLY VALIDATED\n");
Packit 40b132
        }
Packit 40b132
Packit 40b132
cleanup:
Packit 40b132
Packit 40b132
        if (PKIX_TEST_ERROR_RECEIVED){
Packit 40b132
                (void) printf("FAILED TO VALIDATE\n");
Packit 40b132
	        (void) PKIX_PL_Object_ToString
Packit 40b132
        	        ((PKIX_PL_Object*)verifyTree, &verifyString, plContext);
Packit 40b132
	        (void) printf("verifyTree is\n%s\n", verifyString->escAsciiString);
Packit 40b132
	        PKIX_TEST_DECREF_AC(verifyString);
Packit 40b132
Packit 40b132
        }
Packit 40b132
Packit 40b132
        PKIX_TEST_DECREF_AC(verifyTree);
Packit 40b132
        PKIX_TEST_DECREF_AC(valResult);
Packit 40b132
        PKIX_TEST_DECREF_AC(valParams);
Packit 40b132
Packit 40b132
        PKIX_TEST_RETURN();
Packit 40b132
Packit 40b132
        PKIX_Shutdown(plContext);
Packit 40b132
Packit 40b132
        return (0);
Packit 40b132
Packit 40b132
}