1+ /**
2+ * Copyright (c) 2023 Raspberry Pi (Trading) Ltd.
3+ *
4+ * SPDX-License-Identifier: BSD-3-Clause
5+ */
6+
7+ #include <stdio.h>
8+ #include "pico/stdio.h"
9+ #include "pico/cyw43_arch.h"
10+ #include "pico/async_context.h"
11+
12+ // Using this url as we know the root cert won't change for a long time
13+ #define HOST "fw-download-alias1.raspberrypi.com"
14+ #define URL_REQUEST "/net_install/boot.sig"
15+
16+ // This is the PUBLIC root certificate exported from a browser
17+ // Note that the newlines are needed
18+ #define TLS_ROOT_CERT_OK "-----BEGIN CERTIFICATE-----\n\
19+ MIIC+jCCAn+gAwIBAgICEAAwCgYIKoZIzj0EAwIwgbcxCzAJBgNVBAYTAkdCMRAw\n\
20+ DgYDVQQIDAdFbmdsYW5kMRIwEAYDVQQHDAlDYW1icmlkZ2UxHTAbBgNVBAoMFFJh\n\
21+ c3BiZXJyeSBQSSBMaW1pdGVkMRwwGgYDVQQLDBNSYXNwYmVycnkgUEkgRUNDIENB\n\
22+ MR0wGwYDVQQDDBRSYXNwYmVycnkgUEkgUm9vdCBDQTEmMCQGCSqGSIb3DQEJARYX\n\
23+ c3VwcG9ydEByYXNwYmVycnlwaS5jb20wIBcNMjExMjA5MTEzMjU1WhgPMjA3MTEx\n\
24+ MjcxMTMyNTVaMIGrMQswCQYDVQQGEwJHQjEQMA4GA1UECAwHRW5nbGFuZDEdMBsG\n\
25+ A1UECgwUUmFzcGJlcnJ5IFBJIExpbWl0ZWQxHDAaBgNVBAsME1Jhc3BiZXJyeSBQ\n\
26+ SSBFQ0MgQ0ExJTAjBgNVBAMMHFJhc3BiZXJyeSBQSSBJbnRlcm1lZGlhdGUgQ0Ex\n\
27+ JjAkBgkqhkiG9w0BCQEWF3N1cHBvcnRAcmFzcGJlcnJ5cGkuY29tMHYwEAYHKoZI\n\
28+ zj0CAQYFK4EEACIDYgAEcN9K6Cpv+od3w6yKOnec4EbyHCBzF+X2ldjorc0b2Pq0\n\
29+ N+ZvyFHkhFZSgk2qvemsVEWIoPz+K4JSCpgPstz1fEV6WzgjYKfYI71ghELl5TeC\n\
30+ byoPY+ee3VZwF1PTy0cco2YwZDAdBgNVHQ4EFgQUJ6YzIqFh4rhQEbmCnEbWmHEo\n\
31+ XAUwHwYDVR0jBBgwFoAUIIAVCSiDPXut23NK39LGIyAA7NAwEgYDVR0TAQH/BAgw\n\
32+ BgEB/wIBADAOBgNVHQ8BAf8EBAMCAYYwCgYIKoZIzj0EAwIDaQAwZgIxAJYM+wIM\n\
33+ PC3wSPqJ1byJKA6D+ZyjKR1aORbiDQVEpDNWRKiQ5QapLg8wbcED0MrRKQIxAKUT\n\
34+ v8TJkb/8jC/oBVTmczKlPMkciN+uiaZSXahgYKyYhvKTatCTZb+geSIhc0w/2w==\n\
35+ -----END CERTIFICATE-----\n"
36+
37+ // This is a test certificate
38+ #define TLS_ROOT_CERT_BAD "-----BEGIN CERTIFICATE-----\n\
39+ MIIDezCCAwGgAwIBAgICEAEwCgYIKoZIzj0EAwIwgasxCzAJBgNVBAYTAkdCMRAw\n\
40+ DgYDVQQIDAdFbmdsYW5kMR0wGwYDVQQKDBRSYXNwYmVycnkgUEkgTGltaXRlZDEc\n\
41+ MBoGA1UECwwTUmFzcGJlcnJ5IFBJIEVDQyBDQTElMCMGA1UEAwwcUmFzcGJlcnJ5\n\
42+ IFBJIEludGVybWVkaWF0ZSBDQTEmMCQGCSqGSIb3DQEJARYXc3VwcG9ydEByYXNw\n\
43+ YmVycnlwaS5jb20wHhcNMjExMjA5MTMwMjIyWhcNNDYxMjAzMTMwMjIyWjA6MQsw\n\
44+ CQYDVQQGEwJHQjErMCkGA1UEAwwiZnctZG93bmxvYWQtYWxpYXMxLnJhc3BiZXJy\n\
45+ eXBpLmNvbTBZMBMGByqGSM49AgEGCCqGSM49AwEHA0IABJ6BQv8YtNiNv7ibLtt4\n\
46+ lwpgEr2XD4sOl9wu/l8GnGD5p39YK8jZV0j6HaTNkqi86Nly1H7YklzbxhFy5orM\n\
47+ 356jggGDMIIBfzAJBgNVHRMEAjAAMBEGCWCGSAGG+EIBAQQEAwIGQDAzBglghkgB\n\
48+ hvhCAQ0EJhYkT3BlblNTTCBHZW5lcmF0ZWQgU2VydmVyIENlcnRpZmljYXRlMB0G\n\
49+ A1UdDgQWBBRlONP3G2wTERZA9D+VxJABfiaCVTCB5QYDVR0jBIHdMIHagBQnpjMi\n\
50+ oWHiuFARuYKcRtaYcShcBaGBvaSBujCBtzELMAkGA1UEBhMCR0IxEDAOBgNVBAgM\n\
51+ B0VuZ2xhbmQxEjAQBgNVBAcMCUNhbWJyaWRnZTEdMBsGA1UECgwUUmFzcGJlcnJ5\n\
52+ IFBJIExpbWl0ZWQxHDAaBgNVBAsME1Jhc3BiZXJyeSBQSSBFQ0MgQ0ExHTAbBgNV\n\
53+ BAMMFFJhc3BiZXJyeSBQSSBSb290IENBMSYwJAYJKoZIhvcNAQkBFhdzdXBwb3J0\n\
54+ QHJhc3BiZXJyeXBpLmNvbYICEAAwDgYDVR0PAQH/BAQDAgWgMBMGA1UdJQQMMAoG\n\
55+ CCsGAQUFBwMBMAoGCCqGSM49BAMCA2gAMGUCMEHerJRT0WmG5tz4oVLSIxLbCizd\n\
56+ //SdJBCP+072zRUKs0mfl5EcO7dXWvBAb386PwIxAL7LrgpJroJYrYJtqeufJ3a9\n\
57+ zVi56JFnA3cNTcDYfIzyzy5wUskPAykdrRrCS534ig==\n\
58+ -----END CERTIFICATE-----\n"
59+
60+ extern bool run_http_client_test (async_context_t * context , bool use_https , const uint8_t * cert , size_t cert_len , const char * hostname , const char * url );
61+
62+ int main () {
63+ stdio_init_all ();
64+ if (cyw43_arch_init ()) {
65+ printf ("failed to initialise\n" );
66+ return 1 ;
67+ }
68+ cyw43_arch_enable_sta_mode ();
69+ if (cyw43_arch_wifi_connect_timeout_ms (WIFI_SSID , WIFI_PASSWORD , CYW43_AUTH_WPA2_AES_PSK , 10000 )) {
70+ printf ("failed to connect\n" );
71+ return 1 ;
72+ }
73+ // This should work
74+ const uint8_t cert_ok [] = TLS_ROOT_CERT_OK ;
75+ bool pass1 = run_http_client_test (cyw43_arch_async_context (), true, cert_ok , sizeof (cert_ok ), HOST , URL_REQUEST );
76+ // Repeat the test with the wrong certificate. It should fail
77+ const uint8_t cert_bad [] = TLS_ROOT_CERT_BAD ;
78+ bool pass2 = !run_http_client_test (cyw43_arch_async_context (), true, cert_bad , sizeof (cert_bad ), HOST , URL_REQUEST );
79+ if (!pass1 || !pass2 ) {
80+ panic ("test failed" );
81+ }
82+ cyw43_arch_deinit ();
83+ printf ("Test passed\n" );
84+ sleep_ms (100 );
85+ return 0 ;
86+ }
0 commit comments