VirtualBox

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

Last change on this file since 58813 was 57577, checked in by vboxsync, 9 years ago

IPRT,QtGui: Redid the certificate download code in the GUI and reduced the number of unnecessary wrapper methods. Removed RTHttpCertDigest, adding RTHttpFreeResponse and RTHttpFreeResponseText. Also added RTCrPemParseContent.

  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
File size: 5.5 KB
Line 
1/** @file
2 * IPRT - Crypto - PEM-file Reader & Writer.
3 */
4
5/*
6 * Copyright (C) 2006-2015 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_spc_h
27#define ___iprt_crypto_spc_h
28
29#include <iprt/asn1.h>
30#include <iprt/crypto/x509.h>
31#include <iprt/crypto/pkcs7.h>
32#include <iprt/md5.h>
33#include <iprt/sha.h>
34
35
36RT_C_DECLS_BEGIN
37
38/** @defgroup grp_rt_spc RTCrPem - PEM-file Reader & Writer
39 * @ingroup grp_rt_crypto
40 * @{
41 */
42
43
44/**
45 * One PEM marker word (use RT_STR_TUPLE to initialize).
46 */
47typedef struct RTCRPEMMARKERWORD
48{
49 /** The word string. */
50 const char *pszWord;
51 /** The length. */
52 uint32_t cchWord;
53} RTCRPEMMARKERWORD;
54/** Pointer to a const marker word. */
55typedef RTCRPEMMARKERWORD const *PCRTCRPEMMARKERWORD;
56
57
58/**
59 * A PEM marker.
60 *
61 * This is an array of words with lengths, optimized for avoid unnecessary
62 * strlen() while searching the file content. It is ASSUMED that all PEM
63 * section markers starts with either 'BEGIN' or 'END', followed by the words
64 * in the this structure.
65 */
66typedef struct RTCRPEMMARKER
67{
68 /** Pointer to an array of marker words. */
69 PCRTCRPEMMARKERWORD paWords;
70 /** Number of works in the array papszWords points to. */
71 uint32_t cWords;
72} RTCRPEMMARKER;
73/** Pointer to a const PEM marker. */
74typedef RTCRPEMMARKER const *PCRTCRPEMMARKER;
75
76
77/**
78 * A PEM section.
79 *
80 * The API works on linked lists of these.
81 */
82typedef struct RTCRPEMSECTION
83{
84 /** Pointer to the next file section. */
85 struct RTCRPEMSECTION const *pNext;
86 /** The marker for this section. NULL if binary file. */
87 PCRTCRPEMMARKER pMarker;
88 /** Pointer to the binary data. */
89 uint8_t *pbData;
90 /** The size of the binary data. */
91 size_t cbData;
92 /** Additional text preceeding the binary data. NULL if none. */
93 char *pszPreamble;
94 /** The length of the preamble. */
95 size_t cchPreamble;
96} RTCRPEMSECTION;
97/** Pointer to a PEM section. */
98typedef RTCRPEMSECTION *PRTCRPEMSECTION;
99/** Pointer to a const PEM section. */
100typedef RTCRPEMSECTION const *PCRTCRPEMSECTION;
101
102
103/**
104 * Frees sections returned by RTCrPemReadFile and RTCrPemParseContent.
105 * @returns IPRT status code.
106 * @param pSectionHead The first section.
107 */
108RTDECL(int) RTCrPemFreeSections(PCRTCRPEMSECTION pSectionHead);
109
110/**
111 * Parses the given data and returns a list of binary sections.
112 *
113 * If the file isn't an ASCII file or if no markers were found, the entire file
114 * content is returned as one single section (with pMarker = NULL).
115 *
116 * @returns IPRT status code.
117 * @retval VINF_EOF if the file is empty. The ppSectionHead value will be NULL.
118 *
119 * @param pvContent The content bytes to parse.
120 * @param cbContent The number of content bytes.
121 * @param fFlags RTCRPEMREADFILE_F_XXX.
122 * @param paMarkers Array of one or more section markers to look for.
123 * @param cMarkers Number of markers in the array.
124 * @param ppSectionHead Where to return the head of the section list. Call
125 * RTCrPemFreeSections to free.
126 * @param pErrInfo Where to return extend error info. Optional.
127 */
128RTDECL(int) RTCrPemParseContent(void const *pvContent, size_t cbContent, uint32_t fFlags,
129 PCRTCRPEMMARKER paMarkers, size_t cMarkers, PCRTCRPEMSECTION *ppSectionHead, PRTERRINFO pErrInfo);
130
131/**
132 * Reads the content of the given file and returns a list of binary sections
133 * found in the file.
134 *
135 * If the file isn't an ASCII file or if no markers were found, the entire file
136 * content is returned as one single section (with pMarker = NULL).
137 *
138 * @returns IPRT status code.
139 * @retval VINF_EOF if the file is empty. The ppSectionHead value will be NULL.
140 *
141 * @param pszFilename The path to the file to read.
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) RTCrPemReadFile(const char *pszFilename, uint32_t fFlags, PCRTCRPEMMARKER paMarkers, size_t cMarkers,
150 PCRTCRPEMSECTION *ppSectionHead, PRTERRINFO pErrInfo);
151/** @name RTCRPEMREADFILE_F_XXX - Flags for RTCrPemReadFile and
152 * RTCrPemParseContent.
153 * @{ */
154/** Continue on encoding error. */
155#define RTCRPEMREADFILE_F_CONTINUE_ON_ENCODING_ERROR RT_BIT(0)
156/** @} */
157
158/** @} */
159
160RT_C_DECLS_END
161
162#endif
163
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