VirtualBox

source: vbox/trunk/src/VBox/Runtime/common/crypto/x509-verify.cpp@ 57444

Last change on this file since 57444 was 57358, checked in by vboxsync, 9 years ago

*: scm cleanup run.

  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
File size: 3.8 KB
Line 
1/* $Id: x509-verify.cpp 57358 2015-08-14 15:16:38Z vboxsync $ */
2/** @file
3 * IPRT - Crypto - X.509, Signature verficiation.
4 */
5
6/*
7 * Copyright (C) 2006-2015 Oracle Corporation
8 *
9 * This file is part of VirtualBox Open Source Edition (OSE), as
10 * available from http://www.virtualbox.org. This file is free software;
11 * you can redistribute it and/or modify it under the terms of the GNU
12 * General Public License (GPL) as published by the Free Software
13 * Foundation, in version 2 as it comes in the "COPYING" file of the
14 * VirtualBox OSE distribution. VirtualBox OSE is distributed in the
15 * hope that it will be useful, but WITHOUT ANY WARRANTY of any kind.
16 *
17 * The contents of this file may alternatively be used under the terms
18 * of the Common Development and Distribution License Version 1.0
19 * (CDDL) only, as it comes in the "COPYING.CDDL" file of the
20 * VirtualBox OSE distribution, in which case the provisions of the
21 * CDDL are applicable instead of those of the GPL.
22 *
23 * You may elect to license modified versions of this file under the
24 * terms and conditions of either the GPL or the CDDL or both.
25 */
26
27
28/*********************************************************************************************************************************
29* Header Files *
30*********************************************************************************************************************************/
31#include "internal/iprt.h"
32#include <iprt/crypto/x509.h>
33#include <iprt/crypto/pkix.h>
34
35#include <iprt/err.h>
36#include <iprt/string.h>
37
38
39RTDECL(int) RTCrX509Certificate_VerifySignature(PCRTCRX509CERTIFICATE pThis, PCRTASN1OBJID pAlgorithm,
40 PCRTASN1DYNTYPE pParameters, PCRTASN1BITSTRING pPublicKey,
41 PRTERRINFO pErrInfo)
42{
43 /*
44 * Validate the input a little.
45 */
46 AssertPtrReturn(pThis, VERR_INVALID_POINTER);
47 AssertReturn(RTCrX509Certificate_IsPresent(pThis), VERR_INVALID_PARAMETER);
48
49 AssertPtrReturn(pAlgorithm, VERR_INVALID_POINTER);
50 AssertReturn(RTAsn1ObjId_IsPresent(pAlgorithm), VERR_INVALID_POINTER);
51
52 if (pParameters)
53 {
54 AssertPtrReturn(pParameters, VERR_INVALID_POINTER);
55 if (pParameters->enmType == RTASN1TYPE_NULL)
56 pParameters = NULL;
57 }
58
59 AssertPtrReturn(pPublicKey, VERR_INVALID_POINTER);
60 AssertReturn(RTAsn1BitString_IsPresent(pPublicKey), VERR_INVALID_POINTER);
61
62 /*
63 * Check if the algorithm matches.
64 */
65 const char *pszCipherOid = RTCrPkixGetCiperOidFromSignatureAlgorithm(&pThis->SignatureAlgorithm.Algorithm);
66 if (!pszCipherOid)
67 return RTErrInfoSetF(pErrInfo, VERR_CR_X509_UNKNOWN_CERT_SIGN_ALGO,
68 "Certificate signature algorithm not known: %s",
69 pThis->SignatureAlgorithm.Algorithm.szObjId);
70
71 if (RTAsn1ObjId_CompareWithString(pAlgorithm, pszCipherOid) != 0)
72 return RTErrInfoSetF(pErrInfo, VERR_CR_X509_CERT_SIGN_ALGO_MISMATCH,
73 "Certificate signature cipher algorithm mismatch: cert uses %s (%s) while key uses %s",
74 pszCipherOid, pThis->SignatureAlgorithm.Algorithm.szObjId, pAlgorithm->szObjId);
75
76 /*
77 * Here we should recode the to-be-signed part as DER, but we'll ASSUME
78 * that it's already in DER encoding. This is safe.
79 */
80 return RTCrPkixPubKeyVerifySignature(&pThis->SignatureAlgorithm.Algorithm, pParameters, pPublicKey, &pThis->SignatureValue,
81 RTASN1CORE_GET_RAW_ASN1_PTR(&pThis->TbsCertificate.SeqCore.Asn1Core),
82 RTASN1CORE_GET_RAW_ASN1_SIZE(&pThis->TbsCertificate.SeqCore.Asn1Core),
83 pErrInfo);
84}
85
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