| 
									
										
										
										
											2019-11-11 15:45:26 +01:00
										 |  |  | /*|-----------------------------------------------------------|*/ | 
					
						
							|  |  |  | /*|WORKING EXAMPLE FOR HTTPS CONNECTION                       |*/ | 
					
						
							|  |  |  | /*|Author: Bc. Martin Chlebovec                               |*/ | 
					
						
							|  |  |  | /*|Technical University of Košice                             |*/ | 
					
						
							|  |  |  | /*|TESTED BOARDS: Devkit v1 DOIT, Devkitc v4                  |*/ | 
					
						
							|  |  |  | /*|CORE: 0.9x, 1.0.0, 1.0.1 tested, working (newer not tested)|*/ | 
					
						
							|  |  |  | /*|Supported methods: PEAP + MsCHAPv2, EAP-TTLS + MsCHAPv2    |*/ | 
					
						
							|  |  |  | /*|-----------------------------------------------------------|*/ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-11-19 17:02:24 +01:00
										 |  |  | #include <WiFi.h>
 | 
					
						
							|  |  |  | #include <WiFiClientSecure.h>
 | 
					
						
							|  |  |  | #include "esp_wpa2.h"
 | 
					
						
							|  |  |  | #include <Wire.h>
 | 
					
						
							| 
									
										
										
										
											2019-11-11 15:45:26 +01:00
										 |  |  | #define EAP_ANONYMOUS_IDENTITY "anonymous@example.com" //anonymous identity
 | 
					
						
							|  |  |  | #define EAP_IDENTITY "id@example.com"                  //user identity
 | 
					
						
							|  |  |  | #define EAP_PASSWORD "password" //eduroam user password
 | 
					
						
							|  |  |  | const char* ssid = "eduroam"; // eduroam SSID
 | 
					
						
							|  |  |  | const char* host = "arduino.php5.sk"; //external server domain for HTTPS connection
 | 
					
						
							| 
									
										
										
										
											2018-11-19 17:02:24 +01:00
										 |  |  | int counter = 0; | 
					
						
							| 
									
										
										
										
											2019-11-11 15:45:26 +01:00
										 |  |  | const char* test_root_ca = \ | 
					
						
							|  |  |  |                            "-----BEGIN CERTIFICATE-----\n" \ | 
					
						
							|  |  |  |                            "MIIEsTCCA5mgAwIBAgIQCKWiRs1LXIyD1wK0u6tTSTANBgkqhkiG9w0BAQsFADBh\n" \ | 
					
						
							|  |  |  |                            "MQswCQYDVQQGEwJVUzEVMBMGA1UEChMMRGlnaUNlcnQgSW5jMRkwFwYDVQQLExB3\n" \ | 
					
						
							|  |  |  |                            "d3cuZGlnaWNlcnQuY29tMSAwHgYDVQQDExdEaWdpQ2VydCBHbG9iYWwgUm9vdCBD\n" \ | 
					
						
							|  |  |  |                            "QTAeFw0xNzExMDYxMjIzMzNaFw0yNzExMDYxMjIzMzNaMF4xCzAJBgNVBAYTAlVT\n" \ | 
					
						
							|  |  |  |                            "MRUwEwYDVQQKEwxEaWdpQ2VydCBJbmMxGTAXBgNVBAsTEHd3dy5kaWdpY2VydC5j\n" \ | 
					
						
							|  |  |  |                            "b20xHTAbBgNVBAMTFFJhcGlkU1NMIFJTQSBDQSAyMDE4MIIBIjANBgkqhkiG9w0B\n" \ | 
					
						
							|  |  |  |                            "AQEFAAOCAQ8AMIIBCgKCAQEA5S2oihEo9nnpezoziDtx4WWLLCll/e0t1EYemE5n\n" \ | 
					
						
							|  |  |  |                            "+MgP5viaHLy+VpHP+ndX5D18INIuuAV8wFq26KF5U0WNIZiQp6mLtIWjUeWDPA28\n" \ | 
					
						
							|  |  |  |                            "OeyhTlj9TLk2beytbtFU6ypbpWUltmvY5V8ngspC7nFRNCjpfnDED2kRyJzO8yoK\n" \ | 
					
						
							|  |  |  |                            "MFz4J4JE8N7NA1uJwUEFMUvHLs0scLoPZkKcewIRm1RV2AxmFQxJkdf7YN9Pckki\n" \ | 
					
						
							|  |  |  |                            "f2Xgm3b48BZn0zf0qXsSeGu84ua9gwzjzI7tbTBjayTpT+/XpWuBVv6fvarI6bik\n" \ | 
					
						
							|  |  |  |                            "KB859OSGQuw73XXgeuFwEPHTIRoUtkzu3/EQ+LtwznkkdQIDAQABo4IBZjCCAWIw\n" \ | 
					
						
							|  |  |  |                            "HQYDVR0OBBYEFFPKF1n8a8ADIS8aruSqqByCVtp1MB8GA1UdIwQYMBaAFAPeUDVW\n" \ | 
					
						
							|  |  |  |                            "0Uy7ZvCj4hsbw5eyPdFVMA4GA1UdDwEB/wQEAwIBhjAdBgNVHSUEFjAUBggrBgEF\n" \ | 
					
						
							|  |  |  |                            "BQcDAQYIKwYBBQUHAwIwEgYDVR0TAQH/BAgwBgEB/wIBADA0BggrBgEFBQcBAQQo\n" \ | 
					
						
							|  |  |  |                            "MCYwJAYIKwYBBQUHMAGGGGh0dHA6Ly9vY3NwLmRpZ2ljZXJ0LmNvbTBCBgNVHR8E\n" \ | 
					
						
							|  |  |  |                            "OzA5MDegNaAzhjFodHRwOi8vY3JsMy5kaWdpY2VydC5jb20vRGlnaUNlcnRHbG9i\n" \ | 
					
						
							|  |  |  |                            "YWxSb290Q0EuY3JsMGMGA1UdIARcMFowNwYJYIZIAYb9bAECMCowKAYIKwYBBQUH\n" \ | 
					
						
							|  |  |  |                            "AgEWHGh0dHBzOi8vd3d3LmRpZ2ljZXJ0LmNvbS9DUFMwCwYJYIZIAYb9bAEBMAgG\n" \ | 
					
						
							|  |  |  |                            "BmeBDAECATAIBgZngQwBAgIwDQYJKoZIhvcNAQELBQADggEBAH4jx/LKNW5ZklFc\n" \ | 
					
						
							|  |  |  |                            "YWs8Ejbm0nyzKeZC2KOVYR7P8gevKyslWm4Xo4BSzKr235FsJ4aFt6yAiv1eY0tZ\n" \ | 
					
						
							|  |  |  |                            "/ZN18bOGSGStoEc/JE4ocIzr8P5Mg11kRYHbmgYnr1Rxeki5mSeb39DGxTpJD4kG\n" \ | 
					
						
							|  |  |  |                            "hs5lXNoo4conUiiJwKaqH7vh2baryd8pMISag83JUqyVGc2tWPpO0329/CWq2kry\n" \ | 
					
						
							|  |  |  |                            "qv66OSMjwulUz0dXf4OHQasR7CNfIr+4KScc6ABlQ5RDF86PGeE6kdwSQkFiB/cQ\n" \ | 
					
						
							|  |  |  |                            "ysNyq0jEDQTkfa2pjmuWtMCNbBnhFXBYejfubIhaUbEv2FOQB3dCav+FPg5eEveX\n" \ | 
					
						
							|  |  |  |                            "TVyMnGo=\n" \ | 
					
						
							|  |  |  |                            "-----END CERTIFICATE-----\n"; | 
					
						
							| 
									
										
										
										
											2018-11-19 17:02:24 +01:00
										 |  |  | // You can use x.509 client certificates if you want
 | 
					
						
							|  |  |  | //const char* test_client_key = "";   //to verify the client
 | 
					
						
							|  |  |  | //const char* test_client_cert = "";  //to verify the client
 | 
					
						
							|  |  |  | WiFiClientSecure client; | 
					
						
							|  |  |  | void setup() { | 
					
						
							|  |  |  |   Serial.begin(115200); | 
					
						
							|  |  |  |   delay(10); | 
					
						
							|  |  |  |   Serial.println(); | 
					
						
							|  |  |  |   Serial.print("Connecting to network: "); | 
					
						
							|  |  |  |   Serial.println(ssid); | 
					
						
							|  |  |  |   WiFi.disconnect(true);  //disconnect form wifi to set new wifi connection
 | 
					
						
							|  |  |  |   WiFi.mode(WIFI_STA); //init wifi mode
 | 
					
						
							| 
									
										
										
										
											2019-11-11 15:45:26 +01:00
										 |  |  |   esp_wifi_sta_wpa2_ent_set_identity((uint8_t *)EAP_ANONYMOUS_IDENTITY, strlen(EAP_ANONYMOUS_IDENTITY)); //provide identity
 | 
					
						
							|  |  |  |   esp_wifi_sta_wpa2_ent_set_username((uint8_t *)EAP_IDENTITY, strlen(EAP_IDENTITY)); //provide username
 | 
					
						
							| 
									
										
										
										
											2018-11-19 17:02:24 +01:00
										 |  |  |   esp_wifi_sta_wpa2_ent_set_password((uint8_t *)EAP_PASSWORD, strlen(EAP_PASSWORD)); //provide password
 | 
					
						
							| 
									
										
										
										
											2019-11-11 15:45:26 +01:00
										 |  |  |   esp_wpa2_config_t config = WPA2_CONFIG_INIT_DEFAULT(); | 
					
						
							|  |  |  |   esp_wifi_sta_wpa2_ent_enable(&config); | 
					
						
							| 
									
										
										
										
											2018-11-19 17:02:24 +01:00
										 |  |  |   WiFi.begin(ssid); //connect to wifi
 | 
					
						
							|  |  |  |   while (WiFi.status() != WL_CONNECTED) { | 
					
						
							|  |  |  |     delay(500); | 
					
						
							|  |  |  |     Serial.print("."); | 
					
						
							|  |  |  |     counter++; | 
					
						
							| 
									
										
										
										
											2019-11-11 15:45:26 +01:00
										 |  |  |     if (counter >= 60) { //after 30 seconds timeout - reset board (on unsucessful connection)
 | 
					
						
							| 
									
										
										
										
											2018-11-19 17:02:24 +01:00
										 |  |  |       ESP.restart(); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   client.setCACert(test_root_ca); | 
					
						
							| 
									
										
										
										
											2019-11-11 15:45:26 +01:00
										 |  |  |   //client.setCertificate(test_client_key); // for client verification - certificate
 | 
					
						
							|  |  |  |   //client.setPrivateKey(test_client_cert);  // for client verification - private key
 | 
					
						
							| 
									
										
										
										
											2018-11-19 17:02:24 +01:00
										 |  |  |   Serial.println(""); | 
					
						
							|  |  |  |   Serial.println("WiFi connected"); | 
					
						
							| 
									
										
										
										
											2019-11-11 15:45:26 +01:00
										 |  |  |   Serial.println("IP address set: "); | 
					
						
							| 
									
										
										
										
											2018-11-19 17:02:24 +01:00
										 |  |  |   Serial.println(WiFi.localIP()); //print LAN IP
 | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | void loop() { | 
					
						
							| 
									
										
										
										
											2019-11-11 15:45:26 +01:00
										 |  |  |   if (WiFi.status() == WL_CONNECTED) { //if we are connected to eduroam network
 | 
					
						
							| 
									
										
										
										
											2018-11-19 17:02:24 +01:00
										 |  |  |     counter = 0; //reset counter
 | 
					
						
							| 
									
										
										
										
											2019-11-11 15:45:26 +01:00
										 |  |  |     Serial.println("Wifi is still connected with IP: "); | 
					
						
							| 
									
										
										
										
											2018-11-19 17:02:24 +01:00
										 |  |  |     Serial.println(WiFi.localIP());   //inform user about his IP address
 | 
					
						
							| 
									
										
										
										
											2019-11-11 15:45:26 +01:00
										 |  |  |   } else if (WiFi.status() != WL_CONNECTED) { //if we lost connection, retry
 | 
					
						
							|  |  |  |     WiFi.begin(ssid); | 
					
						
							| 
									
										
										
										
											2018-11-19 17:02:24 +01:00
										 |  |  |   } | 
					
						
							|  |  |  |   while (WiFi.status() != WL_CONNECTED) { //during lost connection, print dots
 | 
					
						
							|  |  |  |     delay(500); | 
					
						
							|  |  |  |     Serial.print("."); | 
					
						
							|  |  |  |     counter++; | 
					
						
							| 
									
										
										
										
											2019-11-11 15:45:26 +01:00
										 |  |  |     if (counter >= 60) { //30 seconds timeout - reset board
 | 
					
						
							|  |  |  |       ESP.restart(); | 
					
						
							| 
									
										
										
										
											2018-11-19 17:02:24 +01:00
										 |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   Serial.print("Connecting to website: "); | 
					
						
							|  |  |  |   Serial.println(host); | 
					
						
							|  |  |  |   if (client.connect(host, 443)) { | 
					
						
							|  |  |  |     String url = "/rele/rele1.txt"; | 
					
						
							|  |  |  |     client.print(String("GET ") + url + " HTTP/1.1\r\n" + "Host: " + host + "\r\n" + "User-Agent: ESP32\r\n" + "Connection: close\r\n\r\n"); | 
					
						
							|  |  |  |     while (client.connected()) { | 
					
						
							|  |  |  |       String header = client.readStringUntil('\n'); | 
					
						
							|  |  |  |       Serial.println(header); | 
					
						
							|  |  |  |       if (header == "\r") { | 
					
						
							|  |  |  |         break; | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     String line = client.readStringUntil('\n'); | 
					
						
							| 
									
										
										
										
											2019-11-11 15:45:26 +01:00
										 |  |  |     Serial.println(line); | 
					
						
							|  |  |  |   } else { | 
					
						
							|  |  |  |     Serial.println("Connection unsucessful"); | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2018-11-19 17:02:24 +01:00
										 |  |  |   delay(5000); | 
					
						
							|  |  |  | } |