mirror of
https://github.com/esp8266/Arduino.git
synced 2025-10-24 07:13:45 +03:00
* update examples * fix serial<->tcp example, use STASSID instead of SSID (name collision) * fix HTTPSRequest.ino * update AxTLS HTTPS examples, update AxTLS API to deprecated * fixes * fixes + fix astyle (no preproc directives) + restyling script * fix HTTPClient library * fixes * common.sh: do not reload arduino when already present (for locally CI testing) * common.sh: do not reload ArduinoJson when already present (for locally CI testing) * fix * fix * fix deprecated example * fix WiFiHTTPSServer.ino * reduce footprint * wipfix * fix led builtin * fix example * finished updating APSSID on all examples * style * restyle examples * helper to run CI test locally * local CI runner more verbose * +const * deprecation deprecation * deprecation * Update NTPClient.ino const char[] => const char * * Update interactive.ino const char[] => const char *
146 lines
3.6 KiB
C++
146 lines
3.6 KiB
C++
/*
|
|
HTTP over TLS (HTTPS) example sketch
|
|
|
|
This example demonstrates how to use
|
|
WiFiClientSecure class to connect to a TLS server.
|
|
|
|
This example verifies server certificate using the
|
|
root CA certificate.
|
|
|
|
We fetch and display the status of
|
|
esp8266/Arduino project continuous integration
|
|
build.
|
|
|
|
Created by Ivan Grokhotkov, 2017.
|
|
This example is in public domain.
|
|
*/
|
|
|
|
#define USING_AXTLS
|
|
#include <time.h>
|
|
#include <ESP8266WiFi.h>
|
|
|
|
// force use of AxTLS (BearSSL is now default)
|
|
#include <WiFiClientSecureAxTLS.h>
|
|
using namespace axTLS;
|
|
|
|
#ifndef STASSID
|
|
#define STASSID "your-ssid"
|
|
#define STAPSK "your-password"
|
|
#endif
|
|
|
|
const char* ssid = STASSID;
|
|
const char* password = STAPSK;
|
|
|
|
const char* host = "api.github.com";
|
|
const int httpsPort = 443;
|
|
|
|
// Root certificate used by api.github.com.
|
|
// Defined in "CACert" tab.
|
|
extern const unsigned char caCert[] PROGMEM;
|
|
extern const unsigned int caCertLen;
|
|
|
|
#pragma GCC diagnostic push
|
|
#pragma GCC diagnostic ignored "-Wdeprecated-declarations"
|
|
WiFiClientSecure client;
|
|
#pragma GCC diagnostic pop
|
|
|
|
void setup() {
|
|
Serial.begin(115200);
|
|
Serial.println();
|
|
Serial.print("connecting to ");
|
|
Serial.println(ssid);
|
|
WiFi.mode(WIFI_STA);
|
|
WiFi.begin(ssid, password);
|
|
while (WiFi.status() != WL_CONNECTED) {
|
|
delay(500);
|
|
Serial.print(".");
|
|
}
|
|
Serial.println("");
|
|
Serial.println("WiFi connected");
|
|
Serial.println("IP address: ");
|
|
Serial.println(WiFi.localIP());
|
|
|
|
// Synchronize time useing SNTP. This is necessary to verify that
|
|
// the TLS certificates offered by the server are currently valid.
|
|
Serial.print("Setting time using SNTP");
|
|
configTime(8 * 3600, 0, "pool.ntp.org", "time.nist.gov");
|
|
time_t now = time(nullptr);
|
|
while (now < 8 * 3600 * 2) {
|
|
delay(500);
|
|
Serial.print(".");
|
|
now = time(nullptr);
|
|
}
|
|
Serial.println("");
|
|
struct tm timeinfo;
|
|
gmtime_r(&now, &timeinfo);
|
|
Serial.print("Current time: ");
|
|
Serial.print(asctime(&timeinfo));
|
|
|
|
// Load root certificate in DER format into WiFiClientSecure object
|
|
bool res = client.setCACert_P(caCert, caCertLen);
|
|
if (!res) {
|
|
Serial.println("Failed to load root CA certificate!");
|
|
while (true) {
|
|
yield();
|
|
}
|
|
}
|
|
}
|
|
|
|
void loop() {
|
|
// Connect to remote server
|
|
Serial.print("connecting to ");
|
|
Serial.println(host);
|
|
if (!client.connect(host, httpsPort)) {
|
|
Serial.println("connection failed");
|
|
return;
|
|
}
|
|
|
|
// Verify validity of server's certificate
|
|
if (client.verifyCertChain(host)) {
|
|
Serial.println("Server certificate verified");
|
|
} else {
|
|
Serial.println("ERROR: certificate verification failed!");
|
|
return;
|
|
}
|
|
|
|
String url = "/repos/esp8266/Arduino/commits/master/status";
|
|
Serial.print("requesting URL: ");
|
|
Serial.println(url);
|
|
|
|
client.print(String("GET ") + url + " HTTP/1.1\r\n" +
|
|
"Host: " + host + "\r\n" +
|
|
"User-Agent: BuildFailureDetectorESP8266\r\n" +
|
|
"Connection: close\r\n\r\n");
|
|
|
|
Serial.println("request sent");
|
|
while (client.connected()) {
|
|
String line = client.readStringUntil('\n');
|
|
if (line == "\r") {
|
|
Serial.println("headers received");
|
|
break;
|
|
}
|
|
}
|
|
String line = client.readStringUntil('\n');
|
|
if (line.startsWith("{\"state\":\"success\"")) {
|
|
Serial.println("esp8266/Arduino CI successfull!");
|
|
} else {
|
|
Serial.println("esp8266/Arduino CI has failed");
|
|
}
|
|
Serial.println("reply was:");
|
|
Serial.println("==========");
|
|
Serial.println(line);
|
|
Serial.println("==========");
|
|
Serial.println();
|
|
|
|
static int repeat = 0;
|
|
if (++repeat == 3) {
|
|
Serial.println("Done");
|
|
while (true) {
|
|
delay(1000);
|
|
}
|
|
}
|
|
delay(10000);
|
|
}
|
|
|
|
|