VirtualBox

source: vbox/trunk/src/VBox/Runtime/testcase/tstRTHttp.cpp@ 51635

Last change on this file since 51635 was 51635, checked in by vboxsync, 11 years ago

introduced RTHttpGetBinary(), renamed RTHttpGet() to RTHttpGetText()

  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
File size: 8.7 KB
Line 
1/* $Id: tstRTHttp.cpp 51635 2014-06-17 15:58:40Z vboxsync $ */
2/** @file
3 * IPRT Testcase - Simple cURL testcase.
4 */
5
6/*
7 * Copyright (C) 2012-2013 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* Header Files *
29*******************************************************************************/
30#include <iprt/err.h>
31#include <iprt/http.h>
32#include <iprt/mem.h>
33#include <iprt/file.h>
34#include <iprt/stream.h>
35#include <iprt/string.h>
36#include <iprt/initterm.h>
37
38#define CAFILE_NAME "tstHttp-tempcafile.crt"
39
40int main(int argc, char **argv)
41{
42 unsigned cErrors = 0;
43
44 RTR3InitExe(argc, &argv, 0);
45
46 if (argc <= 1)
47 {
48 RTPrintf("usage: %s default\n", argv[0]);
49 return 1;
50 }
51
52 for (int i = 1; i < argc; i++)
53 {
54 if (!strcmp(argv[i], "default"))
55 ;
56 else
57 {
58 RTPrintf("Unknown parameter '%s'\n", argv[i]);
59 return 1;
60 }
61 }
62
63 RTHTTP hHttp;
64 char *pszBuf = NULL;
65 PRTSTREAM CAFile = NULL;
66
67 int rc = RTHttpCreate(&hHttp);
68
69 // create certificate file
70 if (RT_SUCCESS(rc))
71 rc = RTStrmOpen(CAFILE_NAME, "w+b", &CAFile);
72
73 // fetch root CA certificate (new one, often avoided in cert chains by
74 // using an intermediate cert which is signed by old root)
75 if (RT_SUCCESS(rc))
76 rc = RTHttpGetText(hHttp,
77 "http://www.verisign.com/repository/roots/root-certificates/PCA-3G5.pem",
78 &pszBuf);
79 if (RT_SUCCESS(rc) && pszBuf)
80 {
81 uint8_t *abSha1;
82 size_t cbSha1;
83 uint8_t *abSha512;
84 size_t cbSha512;
85 size_t cbBuf = strlen(pszBuf);
86 const uint8_t abSha1PCA3G5[] =
87 {
88 0x4e, 0xb6, 0xd5, 0x78, 0x49, 0x9b, 0x1c, 0xcf, 0x5f, 0x58,
89 0x1e, 0xad, 0x56, 0xbe, 0x3d, 0x9b, 0x67, 0x44, 0xa5, 0xe5
90 };
91 const uint8_t abSha512PCA3G5[] =
92 {
93 0xd4, 0xf8, 0x10, 0x54, 0x72, 0x77, 0x0a, 0x2d,
94 0xe3, 0x17, 0xb3, 0xcf, 0xed, 0x61, 0xae, 0x5c,
95 0x5d, 0x3e, 0xde, 0xa1, 0x41, 0x35, 0xb2, 0xdf,
96 0x60, 0xe2, 0x61, 0xfe, 0x3a, 0xc1, 0x66, 0xa3,
97 0x3c, 0x88, 0x54, 0x04, 0x4f, 0x1d, 0x13, 0x46,
98 0xe3, 0x8c, 0x06, 0x92, 0x9d, 0x70, 0x54, 0xc3,
99 0x44, 0xeb, 0x2c, 0x74, 0x25, 0x9e, 0x5d, 0xfb,
100 0xd2, 0x6b, 0xa8, 0x9a, 0xf0, 0xb3, 0x6a, 0x01
101 };
102 rc = RTHttpCertDigest(hHttp, pszBuf, cbBuf,
103 &abSha1, &cbSha1, &abSha512, &cbSha512);
104 if (RT_SUCCESS(rc))
105 {
106 if (cbSha1 != sizeof(abSha1PCA3G5))
107 {
108 RTPrintf("Wrong SHA1 digest size of PCA-3G5\n");
109 rc = VERR_INTERNAL_ERROR;
110 }
111 else if (memcmp(abSha1PCA3G5, abSha1, cbSha1))
112 {
113 RTPrintf("Wrong SHA1 digest for PCA-3G5:\n"
114 "Got: %.*Rhxs\n"
115 "Expected: %.*Rhxs\n",
116 cbSha1, abSha1, sizeof(abSha1PCA3G5), abSha1PCA3G5);
117 rc = VERR_INTERNAL_ERROR;
118 }
119 if (cbSha512 != sizeof(abSha512PCA3G5))
120 {
121 RTPrintf("Wrong SHA512 digest size of PCA-3G5\n");
122 rc = VERR_INTERNAL_ERROR;
123 }
124 else if (memcmp(abSha512PCA3G5, abSha512, cbSha512))
125 {
126 RTPrintf("Wrong SHA512 digest for PCA-3G5:\n"
127 "Got: %.*Rhxs\n"
128 "Expected: %.*Rhxs\n",
129 cbSha512, abSha512, sizeof(abSha512PCA3G5), abSha512PCA3G5);
130 rc = VERR_INTERNAL_ERROR;
131 }
132 RTMemFree(abSha1);
133 RTMemFree(abSha512);
134 if (RT_SUCCESS(rc))
135 rc = RTStrmWrite(CAFile, pszBuf, cbBuf);
136 if (RT_SUCCESS(rc))
137 rc = RTStrmWrite(CAFile, RTFILE_LINEFEED, strlen(RTFILE_LINEFEED));
138 }
139 }
140 if (pszBuf)
141 {
142 RTMemFree(pszBuf);
143 pszBuf = NULL;
144 }
145
146 // fetch root CA certificate (old one, but still very widely used)
147 if (RT_SUCCESS(rc))
148 rc = RTHttpGetText(hHttp,
149 "http://www.verisign.com/repository/roots/root-certificates/PCA-3.pem",
150 &pszBuf);
151 if (RT_SUCCESS(rc) && pszBuf)
152 {
153 uint8_t *abSha1;
154 size_t cbSha1;
155 uint8_t *abSha512;
156 size_t cbSha512;
157 size_t cbBuf = strlen(pszBuf);
158 const uint8_t abSha1PCA3[] =
159 {
160 0xa1, 0xdb, 0x63, 0x93, 0x91, 0x6f, 0x17, 0xe4, 0x18, 0x55,
161 0x09, 0x40, 0x04, 0x15, 0xc7, 0x02, 0x40, 0xb0, 0xae, 0x6b
162 };
163 const uint8_t abSha512PCA3[] =
164 {
165 0xbb, 0xf7, 0x8a, 0x19, 0x9f, 0x37, 0xee, 0xa2,
166 0xce, 0xc8, 0xaf, 0xe3, 0xd6, 0x22, 0x54, 0x20,
167 0x74, 0x67, 0x6e, 0xa5, 0x19, 0xb7, 0x62, 0x1e,
168 0xc1, 0x2f, 0xd5, 0x08, 0xf4, 0x64, 0xc4, 0xc6,
169 0xbb, 0xc2, 0xf2, 0x35, 0xe7, 0xbe, 0x32, 0x0b,
170 0xde, 0xb2, 0xfc, 0x44, 0x92, 0x5b, 0x8b, 0x9b,
171 0x77, 0xa5, 0x40, 0x22, 0x18, 0x12, 0xcb, 0x3d,
172 0x0a, 0x67, 0x83, 0x87, 0xc5, 0x45, 0xc4, 0x99
173 };
174 rc = RTHttpCertDigest(hHttp, pszBuf, cbBuf,
175 &abSha1, &cbSha1, &abSha512, &cbSha512);
176 if (RT_SUCCESS(rc))
177 {
178 if (cbSha1 != sizeof(abSha1PCA3))
179 {
180 RTPrintf("Wrong SHA1 digest size of PCA-3\n");
181 rc = VERR_INTERNAL_ERROR;
182 }
183 else if (memcmp(abSha1PCA3, abSha1, cbSha1))
184 {
185 RTPrintf("Wrong SHA1 digest for PCA-3:\n"
186 "Got: %.*Rhxs\n"
187 "Expected: %.*Rhxs\n",
188 cbSha1, abSha1, sizeof(abSha1PCA3), abSha1PCA3);
189 rc = VERR_INTERNAL_ERROR;
190 }
191 if (cbSha512 != sizeof(abSha512PCA3))
192 {
193 RTPrintf("Wrong SHA512 digest size of PCA-3\n");
194 rc = VERR_INTERNAL_ERROR;
195 }
196 else if (memcmp(abSha512PCA3, abSha512, cbSha512))
197 {
198 RTPrintf("Wrong SHA512 digest for PCA-3:\n"
199 "Got: %.*Rhxs\n"
200 "Expected: %.*Rhxs\n",
201 cbSha512, abSha512, sizeof(abSha512PCA3), abSha512PCA3);
202 rc = VERR_INTERNAL_ERROR;
203 }
204 RTMemFree(abSha1);
205 RTMemFree(abSha512);
206 if (RT_SUCCESS(rc))
207 rc = RTStrmWrite(CAFile, pszBuf, cbBuf);
208 if (RT_SUCCESS(rc))
209 rc = RTStrmWrite(CAFile, RTFILE_LINEFEED, strlen(RTFILE_LINEFEED));
210 }
211 }
212 if (pszBuf)
213 {
214 RTMemFree(pszBuf);
215 pszBuf = NULL;
216 }
217
218 // close certificate file
219 if (CAFile)
220 {
221 RTStrmClose(CAFile);
222 CAFile = NULL;
223 }
224
225 if (RT_SUCCESS(rc))
226 rc = RTHttpSetCAFile(hHttp, CAFILE_NAME);
227
228 if (RT_SUCCESS(rc))
229 rc = RTHttpGetText(hHttp,
230 "https://update.virtualbox.org/query.php?platform=LINUX_32BITS_UBUNTU_12_04&version=4.1.18",
231 &pszBuf);
232
233 if ( RT_FAILURE(rc)
234 && rc != VERR_HTTP_COULDNT_CONNECT)
235 cErrors++;
236
237 if (RT_FAILURE(rc))
238 RTPrintf("Error code: %Rrc\n", rc);
239 else
240 RTPrintf("Success!\n");
241 RTPrintf("Got: %s\n", pszBuf);
242 if (pszBuf)
243 {
244 RTMemFree(pszBuf);
245 pszBuf = NULL;
246 }
247
248 void *u8Buf;
249 size_t cb;
250 rc = RTHttpGetBinary(hHttp,
251 "http://www.verisign.com/support/roots.zip",
252 &u8Buf, &cb);
253 if (RT_SUCCESS(rc) && u8Buf)
254 {
255 RTPrintf("Got file length %zd\n", cb);
256 }
257 else
258 RTPrintf("Error code %Rrc\n", rc);
259
260 RTHttpDestroy(hHttp);
261
262// RTFileDelete(CAFILE_NAME);
263
264 return !!cErrors;
265}
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