forked from SmingHub/Sming
-
Notifications
You must be signed in to change notification settings - Fork 0
/
application.cpp
170 lines (135 loc) · 6.33 KB
/
application.cpp
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
#include <SmingCore.h>
#include <Network/HttpClient.h>
// If you want, you can define WiFi settings globally in Eclipse Environment Variables
#ifndef WIFI_SSID
#define WIFI_SSID "PleaseEnterSSID" // Put your SSID and Password here
#define WIFI_PWD "PleaseEnterPass"
#endif
namespace
{
HttpClient httpClient;
int onDownload(HttpConnection& connection, bool success)
{
auto& request = *connection.getRequest();
auto& response = *connection.getResponse();
Serial << endl << _F("=========[ URL: ") << request.uri << _F(" ]============") << endl;
Serial << _F("RemoteIP: ") << connection.getRemoteIp() << endl;
Serial << _F("Got response code: ") << response.code << " " << toString(response.code) << endl;
Serial << _F("Success: ") << success << " " << (success ? "OK" : "FAIL") << endl;
if(request.method != HTTP_HEAD) {
Serial.print(_F("Got content: "));
auto stream = response.stream;
if(stream == nullptr || stream->available() == 0) {
Serial.println(_F("EMPTY!"));
} else {
Serial.copyFrom(stream);
Serial.println();
}
}
auto ssl = connection.getSsl();
if(ssl != nullptr) {
ssl->printTo(Serial);
}
return 0; // return 0 on success in your callbacks
}
void sslRequestInit(Ssl::Session& session, HttpRequest& request)
{
// Go with maximum buffer sizes
session.maxBufferSize = Ssl::MaxBufferSize::K16;
/**
* If there is not enough RAM and the response from the server is not a big one
* you may prefer to set the size to a lower value. One useful value would be 4K
*
* session.maxBufferSize = Ssl::MaxBufferSize::K4;
*
* Unfortunately most of the servers may ignore this plea from
* our HTTP client and send big SSL packet.
*/
/*
* SSL validation: We check the remote server certificate against a fingerprint
* Note that fingerprints _may_ change, in which case these need to be updated.
*
* Note: SSL is not compiled by default. In our example we set the ENABLE_SSL directive to 1
* (See: ../component.mk)
*/
session.options.verifyLater = true;
// These are the fingerprints for httpbin.org
static const Ssl::Fingerprint::Cert::Sha1 sha1Fingerprint PROGMEM{
0xBF, 0x5C, 0x1E, 0x24, 0xA1, 0xB7, 0x73, 0xCF, 0xE6, 0xBF,
0xBC, 0xF5, 0x8A, 0x58, 0xF3, 0xC2, 0xE4, 0xB6, 0x98, 0xE1,
};
static const Ssl::Fingerprint::Pki::Sha256 publicKeyFingerprint PROGMEM{
0x83, 0x7E, 0x88, 0xA9, 0x13, 0x02, 0xDC, 0xA9, 0x44, 0xEE, 0xEC, 0x3A, 0x92, 0xC3, 0x94, 0x3A,
0x01, 0x0B, 0x98, 0x97, 0x26, 0xE3, 0xB0, 0xC3, 0xC1, 0xA0, 0x5C, 0x7B, 0x60, 0xB7, 0x47, 0xDB,
};
// Trust only a certificate in which the public key matches the SHA256 fingerprint...
session.validators.pin(publicKeyFingerprint);
// ... or a certificate that matches the SHA1 fingerprint.
session.validators.pin(sha1Fingerprint);
}
void connectOk(IpAddress ip, IpAddress mask, IpAddress gateway)
{
Serial << _F("Connected. Got IP: ") << ip << endl;
// [ GET request: The example below shows how to make HTTP requests ]
// First: The HttpRequest object contains all the data that needs to be sent
// to the remote server.
HttpRequest* getRequest = new HttpRequest(F("https://httpbin.org/get"));
getRequest->setMethod(HTTP_GET); // << you may set the method. If not set the default HTTP_GET method will be used
// Headers: if you need to set custom headers then you can do something like ...
HttpHeaders headers;
headers[HTTP_HEADER_USER_AGENT] = _F("HttpClient/Sming"); // Prefer use of enumerated type for standard field names
headers[F("X-Powered-By")] = _F("Sming"); // Use text for non-standard field names
getRequest->setHeaders(headers);
// ... or like
getRequest->setHeader(F("X-Powered-By"), F("Sming"));
/*
* Notice: If we use SSL we need to set the SSL settings only for the first request
* and all consecutive requests to the same host:port will try to reuse those settings
*/
getRequest->onSslInit(sslRequestInit);
// If we want to process the response we can do it by setting a onRequestCallback
getRequest->onRequestComplete(onDownload);
// Second: We have to send that request using our httpClient
httpClient.send(getRequest);
// [ POST request: the example below shows how to set a POST request with form data and files. ]
FileStream* fileStream = new FileStream("5K.txt");
HttpRequest* postRequest = new HttpRequest(F("https://httpbin.org/post"));
// For this request we will use a slightly improved syntax
postRequest
->setMethod(HTTP_POST) // << we set the method to POST
->setHeaders(headers) // << we add extra headers
->setPostParameter("text", "Test upload") // << we set one form element called "text"
->setFile("file1", fileStream) // << we set one file upload that should upload the data.txt
// ... under the form element name "file1"
->onRequestComplete(onDownload);
httpClient.send(postRequest); // << don't forget to `send` the request
// [PUT request with raw data: We will send the data.txt content without any additional content encoding ]
FileStream* fileStream1 = new FileStream("20K.txt");
HttpRequest* putRequest = new HttpRequest(F("https://httpbin.org/put"));
putRequest->setMethod(HTTP_PUT)
->setBody(fileStream1) // << we set the complete HTTP body
->onRequestComplete(onDownload);
// Remark: Response body handling.
// The remote server will "echo" the data meaning that the body will be bigger than 20K.
// By default the http client will store in memory up to 1024 bytes.
// If you want to store in memory larger body you can do something like this
// putRequest->setResponseStream(new LimitedMemoryStream(4096)); // << stores max 4K in memory
// Or if you want to directly save the response body to a file then the following can be done
// FileStream* responseBodyFile = new FileStream();
// responseBodyFile->open("file.name", File::CreateNewAlways | File::WriteOnly);
// putRequest->setResponseStream(responseBodyFile); // << the complete body will be stored on your file system
// see the implementation of `bool HttpClient::downloadFile(const String& url, const String& saveFileName, ...` for details.
httpClient.send(putRequest);
}
} // namespace
void init()
{
Serial.begin(SERIAL_BAUD_RATE);
Serial.systemDebugOutput(true);
// This sample is using files and we need to mount beforehand the file system
spiffs_mount();
// Setup the WIFI connection
WifiStation.enable(true);
WifiStation.config(WIFI_SSID, WIFI_PWD);
WifiEvents.onStationGotIP(connectOk);
}