Compare commits
6 Commits
2590c9021c
...
fdd7e26e54
Author | SHA1 | Date | |
---|---|---|---|
|
fdd7e26e54 | ||
|
87fb00bd26 | ||
90c8d9b1d6 | |||
327b1eb33f | |||
|
3d07fbd213 | ||
|
d8cf5d8534 |
1
.gitignore
vendored
1
.gitignore
vendored
@ -3,3 +3,4 @@
|
|||||||
.vscode/c_cpp_properties.json
|
.vscode/c_cpp_properties.json
|
||||||
.vscode/launch.json
|
.vscode/launch.json
|
||||||
.vscode/ipch
|
.vscode/ipch
|
||||||
|
.vscode/*
|
10
.vscode/extensions.json
vendored
Normal file
10
.vscode/extensions.json
vendored
Normal file
@ -0,0 +1,10 @@
|
|||||||
|
{
|
||||||
|
// See http://go.microsoft.com/fwlink/?LinkId=827846
|
||||||
|
// for the documentation about the extensions.json format
|
||||||
|
"recommendations": [
|
||||||
|
"platformio.platformio-ide"
|
||||||
|
],
|
||||||
|
"unwantedRecommendations": [
|
||||||
|
"ms-vscode.cpptools-extension-pack"
|
||||||
|
]
|
||||||
|
}
|
39
include/README
Normal file
39
include/README
Normal file
@ -0,0 +1,39 @@
|
|||||||
|
|
||||||
|
This directory is intended for project header files.
|
||||||
|
|
||||||
|
A header file is a file containing C declarations and macro definitions
|
||||||
|
to be shared between several project source files. You request the use of a
|
||||||
|
header file in your project source file (C, C++, etc) located in `src` folder
|
||||||
|
by including it, with the C preprocessing directive `#include'.
|
||||||
|
|
||||||
|
```src/main.c
|
||||||
|
|
||||||
|
#include "header.h"
|
||||||
|
|
||||||
|
int main (void)
|
||||||
|
{
|
||||||
|
...
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
Including a header file produces the same results as copying the header file
|
||||||
|
into each source file that needs it. Such copying would be time-consuming
|
||||||
|
and error-prone. With a header file, the related declarations appear
|
||||||
|
in only one place. If they need to be changed, they can be changed in one
|
||||||
|
place, and programs that include the header file will automatically use the
|
||||||
|
new version when next recompiled. The header file eliminates the labor of
|
||||||
|
finding and changing all the copies as well as the risk that a failure to
|
||||||
|
find one copy will result in inconsistencies within a program.
|
||||||
|
|
||||||
|
In C, the usual convention is to give header files names that end with `.h'.
|
||||||
|
It is most portable to use only letters, digits, dashes, and underscores in
|
||||||
|
header file names, and at most one dot.
|
||||||
|
|
||||||
|
Read more about using header files in official GCC documentation:
|
||||||
|
|
||||||
|
* Include Syntax
|
||||||
|
* Include Operation
|
||||||
|
* Once-Only Headers
|
||||||
|
* Computed Includes
|
||||||
|
|
||||||
|
https://gcc.gnu.org/onlinedocs/cpp/Header-Files.html
|
46
lib/README
Normal file
46
lib/README
Normal file
@ -0,0 +1,46 @@
|
|||||||
|
|
||||||
|
This directory is intended for project specific (private) libraries.
|
||||||
|
PlatformIO will compile them to static libraries and link into executable file.
|
||||||
|
|
||||||
|
The source code of each library should be placed in a an own separate directory
|
||||||
|
("lib/your_library_name/[here are source files]").
|
||||||
|
|
||||||
|
For example, see a structure of the following two libraries `Foo` and `Bar`:
|
||||||
|
|
||||||
|
|--lib
|
||||||
|
| |
|
||||||
|
| |--Bar
|
||||||
|
| | |--docs
|
||||||
|
| | |--examples
|
||||||
|
| | |--src
|
||||||
|
| | |- Bar.c
|
||||||
|
| | |- Bar.h
|
||||||
|
| | |- library.json (optional, custom build options, etc) https://docs.platformio.org/page/librarymanager/config.html
|
||||||
|
| |
|
||||||
|
| |--Foo
|
||||||
|
| | |- Foo.c
|
||||||
|
| | |- Foo.h
|
||||||
|
| |
|
||||||
|
| |- README --> THIS FILE
|
||||||
|
|
|
||||||
|
|- platformio.ini
|
||||||
|
|--src
|
||||||
|
|- main.c
|
||||||
|
|
||||||
|
and a contents of `src/main.c`:
|
||||||
|
```
|
||||||
|
#include <Foo.h>
|
||||||
|
#include <Bar.h>
|
||||||
|
|
||||||
|
int main (void)
|
||||||
|
{
|
||||||
|
...
|
||||||
|
}
|
||||||
|
|
||||||
|
```
|
||||||
|
|
||||||
|
PlatformIO Library Dependency Finder will find automatically dependent
|
||||||
|
libraries scanning project source files.
|
||||||
|
|
||||||
|
More information about PlatformIO Library Dependency Finder
|
||||||
|
- https://docs.platformio.org/page/librarymanager/ldf.html
|
133
src/main.cpp
133
src/main.cpp
@ -1,4 +1,3 @@
|
|||||||
|
|
||||||
#include <ESP8266WiFi.h>
|
#include <ESP8266WiFi.h>
|
||||||
#include <WiFiClient.h>
|
#include <WiFiClient.h>
|
||||||
#include <ESP8266WebServer.h>
|
#include <ESP8266WebServer.h>
|
||||||
@ -7,59 +6,147 @@
|
|||||||
|
|
||||||
#ifndef APSSID
|
#ifndef APSSID
|
||||||
#define APSSID "ESPap"
|
#define APSSID "ESPap"
|
||||||
#define APPSK "thereisnospoon"
|
#define APPSK "thereisnospoon"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#define BUTTON D2
|
||||||
|
|
||||||
/* Set these to your desired credentials. */
|
/* Set these to your desired credentials. */
|
||||||
const char *APssid = APSSID;
|
const char *APssid = APSSID;
|
||||||
const char *APpassword = APPSK;
|
const char *APpassword = APPSK;
|
||||||
|
|
||||||
const char *ssid = "yourssid";
|
const char *ssid = "QueirozX";
|
||||||
const char *password = "yourspassword";
|
const char *password = "queirozlindo";
|
||||||
|
|
||||||
|
bool is_discovering_tuya_ip = true;
|
||||||
|
|
||||||
|
|
||||||
ESP8266WebServer web_server(80);
|
ESP8266WebServer web_server(80);
|
||||||
WiFiClient wifiClient;
|
WiFiClient wifiClient;
|
||||||
|
|
||||||
|
String HOST_ADDRESS = "192.168.0.47";
|
||||||
|
|
||||||
void make_request(){
|
String make_toggle_request()
|
||||||
HTTPClient http; //Declare object of class HTTPClient
|
{
|
||||||
|
HTTPClient http;
|
||||||
|
String ADCData, station, getData, request;
|
||||||
|
|
||||||
String ADCData, station, getData, link;
|
request = "http://" + HOST_ADDRESS + "/cm?cmnd=Power24%20Toggle";
|
||||||
|
Serial.println("Sent request to:" + request);
|
||||||
|
http.begin(wifiClient, request);
|
||||||
|
|
||||||
link = "http://hostname/?m=1&o=1";
|
auto httpCode = http.GET();
|
||||||
Serial.println("Sent request to:" + link);
|
String response = http.getString();
|
||||||
http.begin(wifiClient, link); //Specify request destination
|
http.end();
|
||||||
|
|
||||||
int httpCode = http.GET(); //Send the request
|
return response;
|
||||||
String payload = http.getString(); //Get the response payload
|
|
||||||
|
|
||||||
http.end(); //Close connection
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void handleRoot() {
|
void handleRoot()
|
||||||
make_request();
|
{
|
||||||
web_server.send(200, "text/html", "<h1>Soy yo</h1>");
|
String response = make_toggle_request();
|
||||||
|
web_server.send(200, "text/html", response);
|
||||||
}
|
}
|
||||||
|
|
||||||
void setup() {
|
void handleSetHost()
|
||||||
|
{
|
||||||
|
String host = web_server.arg("host");
|
||||||
|
Serial.println("Setting host to: " + host);
|
||||||
|
HOST_ADDRESS = host;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void try_to_connect_to_wifi_network_if_not_connected()
|
||||||
|
{
|
||||||
|
WiFi.begin(ssid, password);
|
||||||
|
while(WiFi.status() != WL_CONNECTED)
|
||||||
|
{
|
||||||
|
Serial.print(".");
|
||||||
|
delay(500);
|
||||||
|
}
|
||||||
|
Serial.println("");
|
||||||
|
}
|
||||||
|
|
||||||
|
String return_first_client_ip()
|
||||||
|
{
|
||||||
|
unsigned char softap_stations_cnt;
|
||||||
|
struct station_info *stat_info;
|
||||||
|
uint32 uintaddress;
|
||||||
|
|
||||||
|
softap_stations_cnt = wifi_softap_get_station_num();
|
||||||
|
stat_info = wifi_softap_get_station_info();
|
||||||
|
String string_ip;
|
||||||
|
|
||||||
|
if (stat_info != NULL) {
|
||||||
|
auto IPaddress = &stat_info->ip;
|
||||||
|
uintaddress = IPaddress->addr;
|
||||||
|
IPAddress myIp(uintaddress);
|
||||||
|
string_ip = myIp.toString();
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
return String("👎");
|
||||||
|
}
|
||||||
|
return string_ip;
|
||||||
|
}
|
||||||
|
|
||||||
|
void setup()
|
||||||
|
{
|
||||||
|
pinMode(BUTTON, INPUT_PULLUP);
|
||||||
delay(1000);
|
delay(1000);
|
||||||
Serial.begin(9600);
|
Serial.begin(9600);
|
||||||
Serial.println();
|
Serial.println("Init");
|
||||||
Serial.print("Configuring access point...");
|
Serial.print("Configuring access point...");
|
||||||
/* You can remove the password parameter if you want the AP to be open. */
|
/* You can remove the password parameter if you want the AP to be open. */
|
||||||
|
|
||||||
WiFi.mode(WIFI_AP_STA);
|
WiFi.mode(WIFI_AP_STA);
|
||||||
WiFi.softAP(APssid, APpassword);
|
WiFi.softAP(APssid, APpassword);
|
||||||
WiFi.begin(ssid, password);
|
|
||||||
Serial.println(WiFi.localIP());
|
Serial.print("Server AP ip: ");
|
||||||
Serial.println(WiFi.softAPIP());
|
Serial.println(WiFi.softAPIP());
|
||||||
Serial.println("AP IP address: ");
|
|
||||||
|
Serial.print("AP IP address: ");
|
||||||
web_server.on("/", handleRoot);
|
web_server.on("/", handleRoot);
|
||||||
|
web_server.on("/sethost", handleSetHost);
|
||||||
web_server.begin();
|
web_server.begin();
|
||||||
Serial.println("HTTP server started");
|
Serial.println("HTTP server started");
|
||||||
|
|
||||||
|
|
||||||
|
while (is_discovering_tuya_ip)
|
||||||
|
{
|
||||||
|
Serial.println('Collecting ip');
|
||||||
|
String client_ip = return_first_client_ip();
|
||||||
|
if (client_ip != String("👎"))
|
||||||
|
{
|
||||||
|
is_discovering_tuya_ip = false;
|
||||||
|
HOST_ADDRESS = client_ip;
|
||||||
|
Serial.println("New host address: " + HOST_ADDRESS);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
Serial.println("Leaving setup");
|
||||||
|
|
||||||
|
try_to_connect_to_wifi_network_if_not_connected();
|
||||||
|
|
||||||
|
Serial.print("Server AP ip: ");
|
||||||
|
Serial.println(WiFi.localIP());
|
||||||
|
|
||||||
|
Serial.print("Server external ip: ");
|
||||||
|
Serial.println(WiFi.softAPIP());
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
void loop() {
|
void handle_button_click()
|
||||||
|
{
|
||||||
|
if(digitalRead(BUTTON) == LOW) {
|
||||||
|
make_toggle_request();
|
||||||
|
delay(500);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void loop()
|
||||||
|
{
|
||||||
|
handle_button_click();
|
||||||
web_server.handleClient();
|
web_server.handleClient();
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user