VirtualBox

source: vbox/trunk/include/iprt/crypto/pem.h@ 73798

Last change on this file since 73798 was 73749, checked in by vboxsync, 6 years ago

IPRT/crypto: Implemented reading of PEM encrypted RSA keys. bugref:9152

  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
File size: 7.3 KB
Line 
1/** @file
2 * IPRT - Crypto - PEM-file Reader & Writer.
3 */
4
5/*
6 * Copyright (C) 2006-2017 Oracle Corporation
7 *
8 * This file is part of VirtualBox Open Source Edition (OSE), as
9 * available from http://www.virtualbox.org. This file is free software;
10 * you can redistribute it and/or modify it under the terms of the GNU
11 * General Public License (GPL) as published by the Free Software
12 * Foundation, in version 2 as it comes in the "COPYING" file of the
13 * VirtualBox OSE distribution. VirtualBox OSE is distributed in the
14 * hope that it will be useful, but WITHOUT ANY WARRANTY of any kind.
15 *
16 * The contents of this file may alternatively be used under the terms
17 * of the Common Development and Distribution License Version 1.0
18 * (CDDL) only, as it comes in the "COPYING.CDDL" file of the
19 * VirtualBox OSE distribution, in which case the provisions of the
20 * CDDL are applicable instead of those of the GPL.
21 *
22 * You may elect to license modified versions of this file under the
23 * terms and conditions of either the GPL or the CDDL or both.
24 */
25
26#ifndef ___iprt_crypto_pem_h
27#define ___iprt_crypto_pem_h
28
29#include <iprt/types.h>
30
31
32RT_C_DECLS_BEGIN
33
34/** @defgroup grp_rt_spc RTCrPem - PEM-file Reader & Writer
35 * @ingroup grp_rt_crypto
36 * @{
37 */
38
39
40/**
41 * One PEM marker word (use RT_STR_TUPLE to initialize).
42 */
43typedef struct RTCRPEMMARKERWORD
44{
45 /** The word string. */
46 const char *pszWord;
47 /** The length. */
48 uint32_t cchWord;
49} RTCRPEMMARKERWORD;
50/** Pointer to a const marker word. */
51typedef RTCRPEMMARKERWORD const *PCRTCRPEMMARKERWORD;
52
53
54/**
55 * A PEM marker.
56 *
57 * This is an array of words with lengths, optimized for avoid unnecessary
58 * strlen() while searching the file content. It is ASSUMED that all PEM
59 * section markers starts with either 'BEGIN' or 'END', followed by the words
60 * in the this structure.
61 */
62typedef struct RTCRPEMMARKER
63{
64 /** Pointer to an array of marker words. */
65 PCRTCRPEMMARKERWORD paWords;
66 /** Number of works in the array papszWords points to. */
67 uint32_t cWords;
68} RTCRPEMMARKER;
69/** Pointer to a const PEM marker. */
70typedef RTCRPEMMARKER const *PCRTCRPEMMARKER;
71
72
73/**
74 * A PEM field.
75 */
76typedef struct RTCRPEMFIELD
77{
78 /** Pointer to the next field. */
79 struct RTCRPEMFIELD const *pNext;
80 /** The field value. */
81 char const *pszValue;
82 /** The field value length. */
83 size_t cchValue;
84 /** The field name length. */
85 size_t cchName;
86 /** The field name. */
87 char szName[RT_FLEXIBLE_ARRAY];
88} RTCRPEMFIELD;
89/** Pointer to a PEM field. */
90typedef RTCRPEMFIELD *PRTCRPEMFIELD;
91/** Pointer to a const PEM field. */
92typedef RTCRPEMFIELD const *PCRTCRPEMFIELD;
93
94
95/**
96 * A PEM section.
97 *
98 * The API works on linked lists of these.
99 */
100typedef struct RTCRPEMSECTION
101{
102 /** Pointer to the next file section. */
103 struct RTCRPEMSECTION const *pNext;
104 /** The marker for this section. NULL if binary file. */
105 PCRTCRPEMMARKER pMarker;
106 /** Pointer to the binary data. */
107 uint8_t *pbData;
108 /** The size of the binary data. */
109 size_t cbData;
110 /** List of fields, NULL if none. */
111 PCRTCRPEMFIELD pFieldHead;
112 /** Set if RTCRPEMREADFILE_F_SENSITIVE was specified. */
113 bool fSensitive;
114} RTCRPEMSECTION;
115/** Pointer to a PEM section. */
116typedef RTCRPEMSECTION *PRTCRPEMSECTION;
117/** Pointer to a const PEM section. */
118typedef RTCRPEMSECTION const *PCRTCRPEMSECTION;
119
120
121/**
122 * Frees sections returned by RTCrPemReadFile and RTCrPemParseContent.
123 * @returns IPRT status code.
124 * @param pSectionHead The first section.
125 */
126RTDECL(int) RTCrPemFreeSections(PCRTCRPEMSECTION pSectionHead);
127
128/**
129 * Parses the given data and returns a list of binary sections.
130 *
131 * If the file isn't an ASCII file or if no markers were found, the entire file
132 * content is returned as one single section (with pMarker = NULL).
133 *
134 * @returns IPRT status code.
135 * @retval VINF_EOF if the file is empty. The @a ppSectionHead value will be
136 * NULL.
137 * @retval VWRN_NOT_FOUND no section was found and RTCRPEMREADFILE_F_ONLY_PEM
138 * is specified. The @a ppSectionHead value will be NULL.
139 *
140 * @param pvContent The content bytes to parse.
141 * @param cbContent The number of content bytes.
142 * @param fFlags RTCRPEMREADFILE_F_XXX.
143 * @param paMarkers Array of one or more section markers to look for.
144 * @param cMarkers Number of markers in the array.
145 * @param ppSectionHead Where to return the head of the section list. Call
146 * RTCrPemFreeSections to free.
147 * @param pErrInfo Where to return extend error info. Optional.
148 */
149RTDECL(int) RTCrPemParseContent(void const *pvContent, size_t cbContent, uint32_t fFlags,
150 PCRTCRPEMMARKER paMarkers, size_t cMarkers, PCRTCRPEMSECTION *ppSectionHead, PRTERRINFO pErrInfo);
151
152/**
153 * Reads the content of the given file and returns a list of binary sections
154 * found in the file.
155 *
156 * If the file isn't an ASCII file or if no markers were found, the entire file
157 * content is returned as one single section (with pMarker = NULL).
158 *
159 * @returns IPRT status code.
160 * @retval VINF_EOF if the file is empty. The @a ppSectionHead value will be
161 * NULL.
162 * @retval VWRN_NOT_FOUND no section was found and RTCRPEMREADFILE_F_ONLY_PEM
163 * is specified. The @a ppSectionHead value will be NULL.
164 *
165 * @param pszFilename The path to the file to read.
166 * @param fFlags RTCRPEMREADFILE_F_XXX.
167 * @param paMarkers Array of one or more section markers to look for.
168 * @param cMarkers Number of markers in the array.
169 * @param ppSectionHead Where to return the head of the section list. Call
170 * RTCrPemFreeSections to free.
171 * @param pErrInfo Where to return extend error info. Optional.
172 */
173RTDECL(int) RTCrPemReadFile(const char *pszFilename, uint32_t fFlags, PCRTCRPEMMARKER paMarkers, size_t cMarkers,
174 PCRTCRPEMSECTION *ppSectionHead, PRTERRINFO pErrInfo);
175/** @name RTCRPEMREADFILE_F_XXX - Flags for RTCrPemReadFile and
176 * RTCrPemParseContent.
177 * @{ */
178/** Continue on encoding error. */
179#define RTCRPEMREADFILE_F_CONTINUE_ON_ENCODING_ERROR RT_BIT(0)
180/** Only PEM sections, no binary fallback. */
181#define RTCRPEMREADFILE_F_ONLY_PEM RT_BIT(1)
182/** Sensitive data, use the safer allocator. */
183#define RTCRPEMREADFILE_F_SENSITIVE RT_BIT(2)
184/** Valid flags. */
185#define RTCRPEMREADFILE_F_VALID_MASK UINT32_C(0x00000007)
186/** @} */
187
188/**
189 * Finds the beginning of first PEM section using the specified markers.
190 *
191 * This will not look any further than the first section. Nor will it check for
192 * binaries.
193 *
194 * @returns Pointer to the "-----BEGIN XXXX" sequence on success.
195 * NULL if not found.
196 * @param pvContent The content bytes to parse.
197 * @param cbContent The number of content bytes.
198 * @param paMarkers Array of one or more section markers to look for.
199 * @param cMarkers Number of markers in the array.
200 */
201RTDECL(const char *) RTCrPemFindFirstSectionInContent(void const *pvContent, size_t cbContent,
202 PCRTCRPEMMARKER paMarkers, size_t cMarkers);
203
204/** @} */
205
206RT_C_DECLS_END
207
208#endif
209
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