VirtualBox

source: vbox/trunk/src/VBox/Runtime/common/crypto/x509-sanity.cpp@ 51770

Last change on this file since 51770 was 51770, checked in by vboxsync, 10 years ago

Merged in iprt++ dev branch.

  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
File size: 6.9 KB
Line 
1/* $Id: x509-sanity.cpp 51770 2014-07-01 18:14:02Z vboxsync $ */
2/** @file
3 * IPRT - Crypto - X.509, Sanity Checkers.
4 */
5
6/*
7 * Copyright (C) 2006-2014 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
34#include <iprt/err.h>
35#include <iprt/string.h>
36
37#include "x509-internal.h"
38
39
40
41static int rtCrX509Validity_CheckSanityExtra(PCRTCRX509VALIDITY pThis, uint32_t fFlags, PRTERRINFO pErrInfo, const char *pszErrorTag)
42{
43 if (RTAsn1Time_Compare(&pThis->NotBefore, &pThis->NotAfter) > 0)
44 return RTErrInfoSetF(pErrInfo, VERR_CR_X509_VALIDITY_SWAPPED, "%s: NotBefore is after NotAfter", pszErrorTag);
45 /** @todo check tag constraints? */
46 return VINF_SUCCESS;
47}
48
49
50static int rtCrX509Name_CheckSanityExtra(PCRTCRX509NAME pThis, uint32_t fFlags, PRTERRINFO pErrInfo, const char *pszErrorTag)
51{
52 if (pThis->cItems == 0)
53 return RTErrInfoSetF(pErrInfo, VERR_CR_X509_NAME_EMPTY_SET, "%s: Has no components.", pszErrorTag);
54
55 for (uint32_t i = 0; i < pThis->cItems; i++)
56 {
57 if (pThis->cItems == 0)
58 return RTErrInfoSetF(pErrInfo, VERR_CR_X509_NAME_EMPTY_SUB_SET,
59 "%s: Items[%u] has no sub components.", pszErrorTag, i);
60
61 for (uint32_t j = 0; j < pThis->paItems[i].cItems; j++)
62 {
63 if (pThis->paItems[i].paItems[j].Value.enmType != RTASN1TYPE_STRING)
64 return RTErrInfoSetF(pErrInfo, VERR_CR_X509_NAME_NOT_STRING,
65 "%s: Items[%u].paItems[%u].enmType is %d instead of string (%d).",
66 pszErrorTag, i, j, pThis->paItems[i].paItems[j].Value.enmType, RTASN1TYPE_STRING);
67 if (pThis->paItems[i].paItems[j].Value.u.String.Asn1Core.cb == 0)
68 return RTErrInfoSetF(pErrInfo, VERR_CR_X509_NAME_EMPTY_STRING,
69 "%s: Items[%u].paItems[%u] is an empty string", pszErrorTag, i, j);
70 switch (pThis->paItems[i].paItems[j].Value.u.String.Asn1Core.uTag)
71 {
72 case ASN1_TAG_PRINTABLE_STRING:
73 case ASN1_TAG_UTF8_STRING:
74 break;
75 case ASN1_TAG_T61_STRING:
76 case ASN1_TAG_UNIVERSAL_STRING:
77 case ASN1_TAG_BMP_STRING:
78 break;
79 case ASN1_TAG_IA5_STRING: /* Used by "Microsoft Root Certificate Authority" in the "com" part of the Issuer. */
80 break;
81 default:
82 return RTErrInfoSetF(pErrInfo, VERR_CR_X509_INVALID_NAME_STRING_TAG,
83 "%s: Items[%u].paItems[%u] invalid string type: %u", pszErrorTag, i, j,
84 pThis->paItems[i].paItems[j].Value.u.String.Asn1Core.uTag);
85 }
86 }
87 }
88
89 return VINF_SUCCESS;
90}
91
92
93static int rtCrX509SubjectPublicKeyInfo_CheckSanityExtra(PCRTCRX509SUBJECTPUBLICKEYINFO pThis, uint32_t fFlags,
94 PRTERRINFO pErrInfo, const char *pszErrorTag)
95{
96 if (pThis->SubjectPublicKey.cBits <= 32)
97 return RTErrInfoSetF(pErrInfo, VERR_CR_X509_PUBLIC_KEY_TOO_SMALL,
98 "%s: SubjectPublicKey is too small, only %u bits", pszErrorTag, pThis->SubjectPublicKey.cBits);
99 return VINF_SUCCESS;
100}
101
102
103static int rtCrX509TbsCertificate_CheckSanityExtra(PCRTCRX509TBSCERTIFICATE pThis, uint32_t fFlags,
104 PRTERRINFO pErrInfo, const char *pszErrorTag)
105{
106 if ( RTAsn1Integer_IsPresent(&pThis->T0.Version)
107 && RTAsn1Integer_UnsignedCompareWithU32(&pThis->T0.Version, RTCRX509TBSCERTIFICATE_V1) != 0
108 && RTAsn1Integer_UnsignedCompareWithU32(&pThis->T0.Version, RTCRX509TBSCERTIFICATE_V2) != 0
109 && RTAsn1Integer_UnsignedCompareWithU32(&pThis->T0.Version, RTCRX509TBSCERTIFICATE_V3) != 0)
110 return RTErrInfoSetF(pErrInfo, VERR_CR_X509_TBSCERT_UNSUPPORTED_VERSION,
111 "%s: Unknown Version number: %llu",
112 pszErrorTag, pThis->T0.Version.uValue.u);
113
114 if ( pThis->SerialNumber.Asn1Core.cb < 1
115 || pThis->SerialNumber.Asn1Core.cb > 1024)
116 return RTErrInfoSetF(pErrInfo, VERR_CR_X509_TBSCERT_SERIAL_NUMBER_OUT_OF_BOUNDS,
117 "%s: Bad SerialNumber length: %u", pszErrorTag, pThis->SerialNumber.Asn1Core.cb);
118
119 if ( ( RTAsn1BitString_IsPresent(&pThis->T1.IssuerUniqueId)
120 || RTAsn1BitString_IsPresent(&pThis->T2.SubjectUniqueId))
121 && RTAsn1Integer_UnsignedCompareWithU32(&pThis->T0.Version, RTCRX509TBSCERTIFICATE_V2) < 0)
122 return RTErrInfoSetF(pErrInfo, VERR_CR_X509_TBSCERT_UNIQUE_IDS_REQ_V2,
123 "%s: IssuerUniqueId and SubjectUniqueId requires version 2", pszErrorTag);
124
125 if ( RTCrX509Extensions_IsPresent(&pThis->T3.Extensions)
126 && RTAsn1Integer_UnsignedCompareWithU32(&pThis->T0.Version, RTCRX509TBSCERTIFICATE_V3) < 0)
127 return RTErrInfoSetF(pErrInfo, VERR_CR_X509_TBSCERT_EXTS_REQ_V3, "%s: Extensions requires version 3", pszErrorTag);
128
129 return VINF_SUCCESS;
130}
131
132
133static int rtCrX509Certificate_CheckSanityExtra(PCRTCRX509CERTIFICATE pThis, uint32_t fFlags,
134 PRTERRINFO pErrInfo, const char *pszErrorTag)
135{
136 if (RTCrX509AlgorithmIdentifier_Compare(&pThis->SignatureAlgorithm, &pThis->TbsCertificate.Signature) != 0)
137 return RTErrInfoSetF(pErrInfo, VERR_CR_X509_CERT_TBS_SIGN_ALGO_MISMATCH,
138 "%s: SignatureAlgorithm (%s) does not match TbsCertificate.Signature (%s).", pszErrorTag,
139 pThis->SignatureAlgorithm.Algorithm.szObjId,
140 pThis->TbsCertificate.Signature.Algorithm.szObjId);
141 return VINF_SUCCESS;
142}
143
144
145/*
146 * Generate the code.
147 */
148#include <iprt/asn1-generator-sanity.h>
149
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