mirror of
https://github.com/esp8266/Arduino.git
synced 2025-04-19 23:22:16 +03:00
generate UUID automatically based on chip ID and MAC address
This commit is contained in:
parent
9cb80528c7
commit
3c54cb0a26
@ -41,6 +41,16 @@ extern "C" {
|
|||||||
#define SSDP_URI_SIZE 2
|
#define SSDP_URI_SIZE 2
|
||||||
#define SSDP_BUFFER_SIZE 64
|
#define SSDP_BUFFER_SIZE 64
|
||||||
|
|
||||||
|
#define SSDP_UUID_SIZE 37
|
||||||
|
#define SSDP_FRIENDLY_NAME_SIZE 64
|
||||||
|
#define SSDP_SERIAL_NUMBER_SIZE 32
|
||||||
|
#define SSDP_PRESENTATION_URL_SIZE 128
|
||||||
|
#define SSDP_MODEL_NAME_SIZE 64
|
||||||
|
#define SSDP_MODEL_URL_SIZE 128
|
||||||
|
#define SSDP_MODEL_VERSION_SIZE 32
|
||||||
|
#define SSDP_MANUFACTURER_SIZE 64
|
||||||
|
#define SSDP_MANUFACTURER_URL_SIZE 128
|
||||||
|
|
||||||
static const IPAddress SSDP_MULTICAST_ADDR(239, 255, 255, 250);
|
static const IPAddress SSDP_MULTICAST_ADDR(239, 255, 255, 250);
|
||||||
|
|
||||||
const char* _ssdp_response_template =
|
const char* _ssdp_response_template =
|
||||||
@ -58,7 +68,7 @@ const char* _ssdp_packet_template =
|
|||||||
"%s" // _ssdp_response_template / _ssdp_notify_template
|
"%s" // _ssdp_response_template / _ssdp_notify_template
|
||||||
"CACHE-CONTROL: max-age=%u\r\n" // SSDP_INTERVAL
|
"CACHE-CONTROL: max-age=%u\r\n" // SSDP_INTERVAL
|
||||||
"SERVER: Arduino/1.0 UPNP/1.1 %s/%s\r\n" // _modelName, _modelNumber
|
"SERVER: Arduino/1.0 UPNP/1.1 %s/%s\r\n" // _modelName, _modelNumber
|
||||||
"USN: uuid:%s-%02X%02X%02X%02X%02X%02X\r\n" // _base, _mac[0], _mac[1], _mac[2], _mac[3], _mac[4], _mac[5]
|
"USN: uuid:%s\r\n" // _uuid
|
||||||
"LOCATION: http://%u.%u.%u.%u/ssdp/schema.xml\r\n" // WiFi.localIP()
|
"LOCATION: http://%u.%u.%u.%u/ssdp/schema.xml\r\n" // WiFi.localIP()
|
||||||
"\r\n";
|
"\r\n";
|
||||||
|
|
||||||
@ -84,14 +94,13 @@ const char* _ssdp_schema_template =
|
|||||||
"<modelURL>%s</modelURL>"
|
"<modelURL>%s</modelURL>"
|
||||||
"<manufacturer>%s</manufacturer>"
|
"<manufacturer>%s</manufacturer>"
|
||||||
"<manufacturerURL>%s</manufacturerURL>"
|
"<manufacturerURL>%s</manufacturerURL>"
|
||||||
"<UDN>%s-%02X%02X%02X%02X%02X%02X</UDN>" //uuid:UUID
|
"<UDN>%s</UDN>"
|
||||||
"</device>"
|
"</device>"
|
||||||
"</root>\r\n"
|
"</root>\r\n"
|
||||||
"\r\n";
|
"\r\n";
|
||||||
|
|
||||||
SSDPClass::SSDPClass(){
|
SSDPClass::SSDPClass(){
|
||||||
_base = (char*)os_malloc(SSDP_BASE_SIZE);
|
_uuid = (char*)os_malloc(SSDP_UUID_SIZE);
|
||||||
_mac = (byte*)os_malloc(6);
|
|
||||||
_friendlyName = (char*)os_malloc(SSDP_FRIENDLY_NAME_SIZE);
|
_friendlyName = (char*)os_malloc(SSDP_FRIENDLY_NAME_SIZE);
|
||||||
_presentationURL = (char*)os_malloc(SSDP_PRESENTATION_URL_SIZE);
|
_presentationURL = (char*)os_malloc(SSDP_PRESENTATION_URL_SIZE);
|
||||||
_serialNumber = (char*)os_malloc(SSDP_SERIAL_NUMBER_SIZE);
|
_serialNumber = (char*)os_malloc(SSDP_SERIAL_NUMBER_SIZE);
|
||||||
@ -101,6 +110,7 @@ SSDPClass::SSDPClass(){
|
|||||||
_manufacturer = (char*)os_malloc(SSDP_MANUFACTURER_SIZE);
|
_manufacturer = (char*)os_malloc(SSDP_MANUFACTURER_SIZE);
|
||||||
_manufacturerURL = (char*)os_malloc(SSDP_MANUFACTURER_URL_SIZE);
|
_manufacturerURL = (char*)os_malloc(SSDP_MANUFACTURER_URL_SIZE);
|
||||||
|
|
||||||
|
_uuid[0] = '\0';
|
||||||
_modelNumber[0] = '\0';
|
_modelNumber[0] = '\0';
|
||||||
_friendlyName[0] = '\0';
|
_friendlyName[0] = '\0';
|
||||||
_presentationURL[0] = '\0';
|
_presentationURL[0] = '\0';
|
||||||
@ -113,8 +123,7 @@ SSDPClass::SSDPClass(){
|
|||||||
}
|
}
|
||||||
|
|
||||||
SSDPClass::~SSDPClass(){
|
SSDPClass::~SSDPClass(){
|
||||||
os_free(_base);
|
os_free(_uuid);
|
||||||
os_free(_mac);
|
|
||||||
os_free(_friendlyName);
|
os_free(_friendlyName);
|
||||||
os_free(_presentationURL);
|
os_free(_presentationURL);
|
||||||
os_free(_serialNumber);
|
os_free(_serialNumber);
|
||||||
@ -126,18 +135,26 @@ SSDPClass::~SSDPClass(){
|
|||||||
_pending = false;
|
_pending = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
void SSDPClass::begin(char *base){
|
void SSDPClass::begin(){
|
||||||
ip_addr_t ifaddr;
|
ip_addr_t ifaddr;
|
||||||
ip_addr_t multicast_addr;
|
ip_addr_t multicast_addr;
|
||||||
|
|
||||||
_pending = false;
|
_pending = false;
|
||||||
strcpy(_base, base);
|
|
||||||
|
|
||||||
WiFi.macAddress(_mac);
|
|
||||||
ifaddr.addr = WiFi.localIP();
|
ifaddr.addr = WiFi.localIP();
|
||||||
multicast_addr.addr = (uint32_t) SSDP_MULTICAST_ADDR;
|
multicast_addr.addr = (uint32_t) SSDP_MULTICAST_ADDR;
|
||||||
igmp_joingroup(&ifaddr, &multicast_addr);
|
igmp_joingroup(&ifaddr, &multicast_addr);
|
||||||
|
|
||||||
|
uint8_t mac[6];
|
||||||
|
WiFi.macAddress(mac);
|
||||||
|
uint32_t chipId = ESP.getChipId();
|
||||||
|
sprintf(_uuid, "38323636-4558-%04X-%04X-%02X%02X%02X%02X%02X%02X",
|
||||||
|
(chipId >> 16) & 0xFFFF, chipId & 0xFFFF,
|
||||||
|
mac[0], mac[1], mac[2], mac[3], mac[4], mac[5]
|
||||||
|
);
|
||||||
|
#ifdef DEBUG_SSDP
|
||||||
|
DEBUG_SSDP.printf("SSDP UUID: %s\n", (char *)_uuid);
|
||||||
|
#endif
|
||||||
_server.begin(SSDP_PORT);
|
_server.begin(SSDP_PORT);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -165,7 +182,7 @@ void SSDPClass::send(ssdp_method_t method){
|
|||||||
(method == NONE)?_ssdp_response_template:_ssdp_notify_template,
|
(method == NONE)?_ssdp_response_template:_ssdp_notify_template,
|
||||||
SSDP_INTERVAL,
|
SSDP_INTERVAL,
|
||||||
_modelName, _modelNumber,
|
_modelName, _modelNumber,
|
||||||
_base, _mac[0], _mac[1], _mac[2], _mac[3], _mac[4], _mac[5],
|
_uuid,
|
||||||
(uint8_t)(ip & 0xFF), (uint8_t)((ip >> 8) & 0xFF), (uint8_t)((ip >> 16) & 0xFF), (uint8_t)((ip >> 24) & 0xFF)
|
(uint8_t)(ip & 0xFF), (uint8_t)((ip >> 8) & 0xFF), (uint8_t)((ip >> 16) & 0xFF), (uint8_t)((ip >> 24) & 0xFF)
|
||||||
);
|
);
|
||||||
|
|
||||||
@ -182,7 +199,7 @@ void SSDPClass::schema(WiFiClient client){
|
|||||||
_modelURL,
|
_modelURL,
|
||||||
_manufacturer,
|
_manufacturer,
|
||||||
_manufacturerURL,
|
_manufacturerURL,
|
||||||
_base, _mac[0], _mac[1], _mac[2], _mac[3], _mac[4], _mac[5]
|
_uuid
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -35,16 +35,6 @@ License (MIT license):
|
|||||||
|
|
||||||
#define DEBUG_SSDP Serial
|
#define DEBUG_SSDP Serial
|
||||||
|
|
||||||
#define SSDP_BASE_SIZE 24
|
|
||||||
#define SSDP_FRIENDLY_NAME_SIZE 32
|
|
||||||
#define SSDP_SERIAL_NUMBER_SIZE 32
|
|
||||||
#define SSDP_PRESENTATION_URL_SIZE 32
|
|
||||||
#define SSDP_MODEL_NAME_SIZE 32
|
|
||||||
#define SSDP_MODEL_URL_SIZE 32
|
|
||||||
#define SSDP_MODEL_VERSION_SIZE 32
|
|
||||||
#define SSDP_MANUFACTURER_SIZE 32
|
|
||||||
#define SSDP_MANUFACTURER_URL_SIZE 32
|
|
||||||
|
|
||||||
typedef enum {
|
typedef enum {
|
||||||
NONE,
|
NONE,
|
||||||
SEARCH,
|
SEARCH,
|
||||||
@ -56,7 +46,7 @@ class SSDPClass{
|
|||||||
SSDPClass();
|
SSDPClass();
|
||||||
~SSDPClass();
|
~SSDPClass();
|
||||||
|
|
||||||
void begin(char *base);
|
void begin();
|
||||||
uint8_t update();
|
uint8_t update();
|
||||||
void send(ssdp_method_t method);
|
void send(ssdp_method_t method);
|
||||||
void schema(WiFiClient client);
|
void schema(WiFiClient client);
|
||||||
@ -78,7 +68,7 @@ class SSDPClass{
|
|||||||
unsigned long _notify_time;
|
unsigned long _notify_time;
|
||||||
|
|
||||||
uint8_t *_mac;
|
uint8_t *_mac;
|
||||||
char *_base;
|
char *_uuid;
|
||||||
char *_friendlyName;
|
char *_friendlyName;
|
||||||
char *_serialNumber;
|
char *_serialNumber;
|
||||||
char *_presentationURL;
|
char *_presentationURL;
|
||||||
|
@ -11,29 +11,23 @@ ESP8266WebServer HTTP(80);
|
|||||||
void setup() {
|
void setup() {
|
||||||
Serial.begin(115200);
|
Serial.begin(115200);
|
||||||
Serial.println();
|
Serial.println();
|
||||||
Serial.println("Booting Sketch...");
|
Serial.println("Starting WiFi...");
|
||||||
|
|
||||||
WiFi.mode(WIFI_STA);
|
WiFi.mode(WIFI_STA);
|
||||||
WiFi.begin(ssid, password);
|
WiFi.begin(ssid, password);
|
||||||
if(WiFi.waitForConnectResult() == WL_CONNECTED){
|
if(WiFi.waitForConnectResult() == WL_CONNECTED){
|
||||||
|
|
||||||
|
Serial.printf("Starting HTTP...\n");
|
||||||
HTTP.on("/", HTTP_GET, [](){
|
HTTP.on("/", HTTP_GET, [](){
|
||||||
HTTP.sendHeader("Connection", "close");
|
|
||||||
HTTP.sendHeader("Access-Control-Allow-Origin", "*");
|
|
||||||
HTTP.send(200, "text/plain", "Hello World!");
|
HTTP.send(200, "text/plain", "Hello World!");
|
||||||
});
|
});
|
||||||
HTTP.on("/ssdp/schema.xml", HTTP_GET, [](){
|
HTTP.on("/ssdp/schema.xml", HTTP_GET, [](){
|
||||||
SSDP.schema(HTTP.client());
|
SSDP.schema(HTTP.client());
|
||||||
});
|
});
|
||||||
HTTP.begin();
|
HTTP.begin();
|
||||||
|
|
||||||
byte mac[6];
|
|
||||||
char base[24];
|
|
||||||
WiFi.macAddress(mac);
|
|
||||||
sprintf(base, "esp8266x-%02x%02x-%02x%02x-%02x%02x", mac[0], mac[1], mac[2], mac[3], mac[4], mac[5]);
|
|
||||||
|
|
||||||
Serial.printf("Starting SSDP: %s\n", base);
|
Serial.printf("Starting SSDP...\n");
|
||||||
|
SSDP.begin();
|
||||||
SSDP.begin((char*)base);
|
|
||||||
SSDP.setName((char*)"ESP8266");
|
SSDP.setName((char*)"ESP8266");
|
||||||
SSDP.setSerialNumber((char*)"A0123456789");
|
SSDP.setSerialNumber((char*)"A0123456789");
|
||||||
SSDP.setURL((char*)"/");
|
SSDP.setURL((char*)"/");
|
||||||
|
Loading…
x
Reference in New Issue
Block a user