1*6236dae4SAndroid Build Coastguard Worker /***************************************************************************
2*6236dae4SAndroid Build Coastguard Worker * _ _ ____ _
3*6236dae4SAndroid Build Coastguard Worker * Project ___| | | | _ \| |
4*6236dae4SAndroid Build Coastguard Worker * / __| | | | |_) | |
5*6236dae4SAndroid Build Coastguard Worker * | (__| |_| | _ <| |___
6*6236dae4SAndroid Build Coastguard Worker * \___|\___/|_| \_\_____|
7*6236dae4SAndroid Build Coastguard Worker *
8*6236dae4SAndroid Build Coastguard Worker * Copyright (C) Daniel Stenberg, <[email protected]>, et al.
9*6236dae4SAndroid Build Coastguard Worker *
10*6236dae4SAndroid Build Coastguard Worker * This software is licensed as described in the file COPYING, which
11*6236dae4SAndroid Build Coastguard Worker * you should have received as part of this distribution. The terms
12*6236dae4SAndroid Build Coastguard Worker * are also available at https://curl.se/docs/copyright.html.
13*6236dae4SAndroid Build Coastguard Worker *
14*6236dae4SAndroid Build Coastguard Worker * You may opt to use, copy, modify, merge, publish, distribute and/or sell
15*6236dae4SAndroid Build Coastguard Worker * copies of the Software, and permit persons to whom the Software is
16*6236dae4SAndroid Build Coastguard Worker * furnished to do so, under the terms of the COPYING file.
17*6236dae4SAndroid Build Coastguard Worker *
18*6236dae4SAndroid Build Coastguard Worker * This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY
19*6236dae4SAndroid Build Coastguard Worker * KIND, either express or implied.
20*6236dae4SAndroid Build Coastguard Worker *
21*6236dae4SAndroid Build Coastguard Worker * SPDX-License-Identifier: curl
22*6236dae4SAndroid Build Coastguard Worker *
23*6236dae4SAndroid Build Coastguard Worker ***************************************************************************/
24*6236dae4SAndroid Build Coastguard Worker #include "test.h"
25*6236dae4SAndroid Build Coastguard Worker
26*6236dae4SAndroid Build Coastguard Worker #include "testutil.h"
27*6236dae4SAndroid Build Coastguard Worker #include "warnless.h"
28*6236dae4SAndroid Build Coastguard Worker #include "memdebug.h"
29*6236dae4SAndroid Build Coastguard Worker
loadfile(const char * filename,void ** filedata,size_t * filesize)30*6236dae4SAndroid Build Coastguard Worker static int loadfile(const char *filename, void **filedata, size_t *filesize)
31*6236dae4SAndroid Build Coastguard Worker {
32*6236dae4SAndroid Build Coastguard Worker size_t datasize = 0;
33*6236dae4SAndroid Build Coastguard Worker void *data = NULL;
34*6236dae4SAndroid Build Coastguard Worker if(filename) {
35*6236dae4SAndroid Build Coastguard Worker FILE *fInCert = fopen(filename, "rb");
36*6236dae4SAndroid Build Coastguard Worker
37*6236dae4SAndroid Build Coastguard Worker if(fInCert) {
38*6236dae4SAndroid Build Coastguard Worker long cert_tell = 0;
39*6236dae4SAndroid Build Coastguard Worker bool continue_reading = fseek(fInCert, 0, SEEK_END) == 0;
40*6236dae4SAndroid Build Coastguard Worker if(continue_reading)
41*6236dae4SAndroid Build Coastguard Worker cert_tell = ftell(fInCert);
42*6236dae4SAndroid Build Coastguard Worker if(cert_tell < 0)
43*6236dae4SAndroid Build Coastguard Worker continue_reading = FALSE;
44*6236dae4SAndroid Build Coastguard Worker else
45*6236dae4SAndroid Build Coastguard Worker datasize = (size_t)cert_tell;
46*6236dae4SAndroid Build Coastguard Worker if(continue_reading)
47*6236dae4SAndroid Build Coastguard Worker continue_reading = fseek(fInCert, 0, SEEK_SET) == 0;
48*6236dae4SAndroid Build Coastguard Worker if(continue_reading)
49*6236dae4SAndroid Build Coastguard Worker data = malloc(datasize + 1);
50*6236dae4SAndroid Build Coastguard Worker if((!data) ||
51*6236dae4SAndroid Build Coastguard Worker ((int)fread(data, datasize, 1, fInCert) != 1))
52*6236dae4SAndroid Build Coastguard Worker continue_reading = FALSE;
53*6236dae4SAndroid Build Coastguard Worker fclose(fInCert);
54*6236dae4SAndroid Build Coastguard Worker if(!continue_reading) {
55*6236dae4SAndroid Build Coastguard Worker free(data);
56*6236dae4SAndroid Build Coastguard Worker datasize = 0;
57*6236dae4SAndroid Build Coastguard Worker data = NULL;
58*6236dae4SAndroid Build Coastguard Worker }
59*6236dae4SAndroid Build Coastguard Worker }
60*6236dae4SAndroid Build Coastguard Worker }
61*6236dae4SAndroid Build Coastguard Worker *filesize = datasize;
62*6236dae4SAndroid Build Coastguard Worker *filedata = data;
63*6236dae4SAndroid Build Coastguard Worker return data ? 1 : 0;
64*6236dae4SAndroid Build Coastguard Worker }
65*6236dae4SAndroid Build Coastguard Worker
test_cert_blob(const char * url,const char * cafile)66*6236dae4SAndroid Build Coastguard Worker static CURLcode test_cert_blob(const char *url, const char *cafile)
67*6236dae4SAndroid Build Coastguard Worker {
68*6236dae4SAndroid Build Coastguard Worker CURLcode code = CURLE_OUT_OF_MEMORY;
69*6236dae4SAndroid Build Coastguard Worker CURL *curl;
70*6236dae4SAndroid Build Coastguard Worker struct curl_blob blob;
71*6236dae4SAndroid Build Coastguard Worker size_t certsize;
72*6236dae4SAndroid Build Coastguard Worker void *certdata;
73*6236dae4SAndroid Build Coastguard Worker
74*6236dae4SAndroid Build Coastguard Worker curl = curl_easy_init();
75*6236dae4SAndroid Build Coastguard Worker if(!curl) {
76*6236dae4SAndroid Build Coastguard Worker fprintf(stderr, "curl_easy_init() failed\n");
77*6236dae4SAndroid Build Coastguard Worker return CURLE_FAILED_INIT;
78*6236dae4SAndroid Build Coastguard Worker }
79*6236dae4SAndroid Build Coastguard Worker
80*6236dae4SAndroid Build Coastguard Worker if(loadfile(cafile, &certdata, &certsize)) {
81*6236dae4SAndroid Build Coastguard Worker curl_easy_setopt(curl, CURLOPT_VERBOSE, 1L);
82*6236dae4SAndroid Build Coastguard Worker curl_easy_setopt(curl, CURLOPT_HEADER, 1L);
83*6236dae4SAndroid Build Coastguard Worker curl_easy_setopt(curl, CURLOPT_URL, url);
84*6236dae4SAndroid Build Coastguard Worker curl_easy_setopt(curl, CURLOPT_USERAGENT, "CURLOPT_CAINFO_BLOB");
85*6236dae4SAndroid Build Coastguard Worker curl_easy_setopt(curl, CURLOPT_SSL_OPTIONS,
86*6236dae4SAndroid Build Coastguard Worker CURLSSLOPT_REVOKE_BEST_EFFORT);
87*6236dae4SAndroid Build Coastguard Worker
88*6236dae4SAndroid Build Coastguard Worker blob.data = certdata;
89*6236dae4SAndroid Build Coastguard Worker blob.len = certsize;
90*6236dae4SAndroid Build Coastguard Worker blob.flags = CURL_BLOB_COPY;
91*6236dae4SAndroid Build Coastguard Worker curl_easy_setopt(curl, CURLOPT_CAINFO_BLOB, &blob);
92*6236dae4SAndroid Build Coastguard Worker free(certdata);
93*6236dae4SAndroid Build Coastguard Worker code = curl_easy_perform(curl);
94*6236dae4SAndroid Build Coastguard Worker }
95*6236dae4SAndroid Build Coastguard Worker curl_easy_cleanup(curl);
96*6236dae4SAndroid Build Coastguard Worker
97*6236dae4SAndroid Build Coastguard Worker return code;
98*6236dae4SAndroid Build Coastguard Worker }
99*6236dae4SAndroid Build Coastguard Worker
test(char * URL)100*6236dae4SAndroid Build Coastguard Worker CURLcode test(char *URL)
101*6236dae4SAndroid Build Coastguard Worker {
102*6236dae4SAndroid Build Coastguard Worker CURLcode res = CURLE_OK;
103*6236dae4SAndroid Build Coastguard Worker curl_global_init(CURL_GLOBAL_DEFAULT);
104*6236dae4SAndroid Build Coastguard Worker if(!strcmp("check", URL)) {
105*6236dae4SAndroid Build Coastguard Worker CURL *e;
106*6236dae4SAndroid Build Coastguard Worker CURLcode w = CURLE_OK;
107*6236dae4SAndroid Build Coastguard Worker struct curl_blob blob = {0};
108*6236dae4SAndroid Build Coastguard Worker e = curl_easy_init();
109*6236dae4SAndroid Build Coastguard Worker if(e) {
110*6236dae4SAndroid Build Coastguard Worker w = curl_easy_setopt(e, CURLOPT_CAINFO_BLOB, &blob);
111*6236dae4SAndroid Build Coastguard Worker if(w)
112*6236dae4SAndroid Build Coastguard Worker printf("CURLOPT_CAINFO_BLOB is not supported\n");
113*6236dae4SAndroid Build Coastguard Worker curl_easy_cleanup(e);
114*6236dae4SAndroid Build Coastguard Worker }
115*6236dae4SAndroid Build Coastguard Worker res = w;
116*6236dae4SAndroid Build Coastguard Worker }
117*6236dae4SAndroid Build Coastguard Worker else
118*6236dae4SAndroid Build Coastguard Worker res = test_cert_blob(URL, libtest_arg2);
119*6236dae4SAndroid Build Coastguard Worker
120*6236dae4SAndroid Build Coastguard Worker curl_global_cleanup();
121*6236dae4SAndroid Build Coastguard Worker return res;
122*6236dae4SAndroid Build Coastguard Worker }
123