Kaynağa Gözat

add .gz (#3538)

* Update server_help.cpp

* Add files via upload

* Add files via upload

* Update server_help.cpp
SybexX 11 ay önce
ebeveyn
işleme
dadb004e85

+ 78 - 32
code/components/jomjol_fileserver_ota/server_help.cpp

@@ -16,77 +16,101 @@ extern "C" {
 
 
 #include "esp_err.h"
 #include "esp_err.h"
 #include "esp_log.h"
 #include "esp_log.h"
-
 #include "Helper.h"
 #include "Helper.h"
-
 #include "esp_http_server.h"
 #include "esp_http_server.h"
-
 #include "../../include/defines.h"
 #include "../../include/defines.h"
 
 
-
 static const char *TAG = "SERVER HELP";
 static const char *TAG = "SERVER HELP";
 
 
 char scratch[SERVER_HELPER_SCRATCH_BUFSIZE];
 char scratch[SERVER_HELPER_SCRATCH_BUFSIZE];
 
 
-
-bool endsWith(std::string const &str, std::string const &suffix) {
+bool endsWith(std::string const &str, std::string const &suffix) 
+{
     if (str.length() < suffix.length()) {
     if (str.length() < suffix.length()) {
         return false;
         return false;
     }
     }
     return str.compare(str.length() - suffix.length(), suffix.length(), suffix) == 0;
     return str.compare(str.length() - suffix.length(), suffix.length(), suffix) == 0;
 }
 }
 
 
-
 esp_err_t send_file(httpd_req_t *req, std::string filename)
 esp_err_t send_file(httpd_req_t *req, std::string filename)
 {
 {
+    std::string _filename_old = filename;
+    struct stat file_stat;
+    bool _gz_file_exists = false;
+
+    ESP_LOGD(TAG, "old filename: %s", filename.c_str());
+    std::string _filename_temp = std::string(filename) + ".gz";
+
+    // Checks whether the file is available as .gz
+    if (stat(_filename_temp.c_str(), &file_stat) == 0) {
+        filename = _filename_temp;
+
+        ESP_LOGD(TAG, "new filename: %s", filename.c_str());
+        _gz_file_exists = true;
+    }
+
     FILE *fd = fopen(filename.c_str(), "r");
     FILE *fd = fopen(filename.c_str(), "r");
-    if (!fd) {
+    if (!fd)  {
         ESP_LOGE(TAG, "Failed to read file: %s", filename.c_str());
         ESP_LOGE(TAG, "Failed to read file: %s", filename.c_str());
+		
         /* Respond with 404 Error */
         /* Respond with 404 Error */
         httpd_resp_send_err(req, HTTPD_404_NOT_FOUND, get404());
         httpd_resp_send_err(req, HTTPD_404_NOT_FOUND, get404());
         return ESP_FAIL;
         return ESP_FAIL;
     }
     }
 
 
     ESP_LOGD(TAG, "Sending file: %s ...", filename.c_str());
     ESP_LOGD(TAG, "Sending file: %s ...", filename.c_str());
-//    httpd_resp_set_hdr(req, "Access-Control-Allow-Origin", "*");
 
 
-    /* For all files with the following file extention tell
-       the webbrowser to cache them for 24h */
+    /* For all files with the following file extention tell the webbrowser to cache them for 12h */
     if (endsWith(filename, ".html") ||
     if (endsWith(filename, ".html") ||
         endsWith(filename, ".htm") ||
         endsWith(filename, ".htm") ||
+        endsWith(filename, ".xml") ||
         endsWith(filename, ".css") ||
         endsWith(filename, ".css") ||
         endsWith(filename, ".js") ||
         endsWith(filename, ".js") ||
         endsWith(filename, ".map") ||
         endsWith(filename, ".map") ||
         endsWith(filename, ".jpg") ||
         endsWith(filename, ".jpg") ||
         endsWith(filename, ".jpeg") ||
         endsWith(filename, ".jpeg") ||
         endsWith(filename, ".ico") ||
         endsWith(filename, ".ico") ||
-        endsWith(filename, ".png")) {
-
-    	if (filename == "/sdcard/html/setup.html") {    
+        endsWith(filename, ".png") ||
+        endsWith(filename, ".gif") ||
+        // endsWith(filename, ".zip") ||
+        endsWith(filename, ".gz"))	{
+        if (filename == "/sdcard/html/setup.html") {
             httpd_resp_set_hdr(req, "Clear-Site-Data", "\"*\"");
             httpd_resp_set_hdr(req, "Clear-Site-Data", "\"*\"");
+            set_content_type_from_file(req, filename.c_str());
+        }
+        else if (_gz_file_exists) {
+            httpd_resp_set_hdr(req, "Cache-Control", "max-age=43200");
+            httpd_resp_set_hdr(req, "Content-Encoding", "gzip");
+            set_content_type_from_file(req, _filename_old.c_str());
         }
         }
         else {
         else {
-            httpd_resp_set_hdr(req, "Cache-Control", "max-age=86400");
+            httpd_resp_set_hdr(req, "Cache-Control", "max-age=43200");
+            set_content_type_from_file(req, filename.c_str());
         }
         }
     }
     }
-
-    set_content_type_from_file(req, filename.c_str());
+    else {
+        set_content_type_from_file(req, filename.c_str());
+    }
 
 
     /* Retrieve the pointer to scratch buffer for temporary storage */
     /* Retrieve the pointer to scratch buffer for temporary storage */
     char *chunk = scratch;
     char *chunk = scratch;
     size_t chunksize;
     size_t chunksize;
-    do {
+	
+    do  {
         /* Read file in chunks into the scratch buffer */
         /* Read file in chunks into the scratch buffer */
         chunksize = fread(chunk, 1, SERVER_HELPER_SCRATCH_BUFSIZE, fd);
         chunksize = fread(chunk, 1, SERVER_HELPER_SCRATCH_BUFSIZE, fd);
 
 
         /* Send the buffer contents as HTTP response chunk */
         /* Send the buffer contents as HTTP response chunk */
-        if (httpd_resp_send_chunk(req, chunk, chunksize) != ESP_OK) {
+        if (httpd_resp_send_chunk(req, chunk, chunksize) != ESP_OK)  {
             fclose(fd);
             fclose(fd);
             ESP_LOGE(TAG, "File sending failed!");
             ESP_LOGE(TAG, "File sending failed!");
+			
             /* Abort sending file */
             /* Abort sending file */
             httpd_resp_sendstr_chunk(req, NULL);
             httpd_resp_sendstr_chunk(req, NULL);
+			
             /* Respond with 500 Internal Server Error */
             /* Respond with 500 Internal Server Error */
             httpd_resp_send_err(req, HTTPD_500_INTERNAL_SERVER_ERROR, "Failed to send file");
             httpd_resp_send_err(req, HTTPD_500_INTERNAL_SERVER_ERROR, "Failed to send file");
+			
             return ESP_FAIL;
             return ESP_FAIL;
         }
         }
 
 
@@ -95,13 +119,11 @@ esp_err_t send_file(httpd_req_t *req, std::string filename)
 
 
     /* Close file after sending complete */
     /* Close file after sending complete */
     fclose(fd);
     fclose(fd);
-    ESP_LOGD(TAG, "File sending complete");    
+    ESP_LOGD(TAG, "File sending complete");
+	
     return ESP_OK;    
     return ESP_OK;    
 }
 }
 
 
-
-
-
 /* Copies the full path into destination buffer and returns
 /* Copies the full path into destination buffer and returns
  * pointer to path (skipping the preceding base path) */
  * pointer to path (skipping the preceding base path) */
 const char* get_path_from_uri(char *dest, const char *base_path, const char *uri, size_t destsize)
 const char* get_path_from_uri(char *dest, const char *base_path, const char *uri, size_t destsize)
@@ -131,25 +153,49 @@ const char* get_path_from_uri(char *dest, const char *base_path, const char *uri
     return dest + base_pathlen;
     return dest + base_pathlen;
 }
 }
 
 
-
 /* Set HTTP response content type according to file extension */
 /* Set HTTP response content type according to file extension */
 esp_err_t set_content_type_from_file(httpd_req_t *req, const char *filename)
 esp_err_t set_content_type_from_file(httpd_req_t *req, const char *filename)
 {
 {
     if (IS_FILE_EXT(filename, ".pdf")) {
     if (IS_FILE_EXT(filename, ".pdf")) {
-        return httpd_resp_set_type(req, "application/pdf");
-    } else if (IS_FILE_EXT(filename, ".html")) {
+        return httpd_resp_set_type(req, "application/x-pdf");
+    }
+    else if (IS_FILE_EXT(filename, ".htm")) {
         return httpd_resp_set_type(req, "text/html");
         return httpd_resp_set_type(req, "text/html");
-    } else if (IS_FILE_EXT(filename, ".jpeg")) {
+    }
+    else if (IS_FILE_EXT(filename, ".html")) {
+        return httpd_resp_set_type(req, "text/html");
+    }
+    else if (IS_FILE_EXT(filename, ".jpeg")) {
         return httpd_resp_set_type(req, "image/jpeg");
         return httpd_resp_set_type(req, "image/jpeg");
-    } else if (IS_FILE_EXT(filename, ".jpg")) {
+    }
+    else if (IS_FILE_EXT(filename, ".jpg")) {
         return httpd_resp_set_type(req, "image/jpeg");
         return httpd_resp_set_type(req, "image/jpeg");
-    } else if (IS_FILE_EXT(filename, ".ico")) {
+    }
+    else if (IS_FILE_EXT(filename, ".gif")) {
+        return httpd_resp_set_type(req, "image/gif");
+    }
+    else if (IS_FILE_EXT(filename, ".png")) {
+        return httpd_resp_set_type(req, "image/png");
+    }
+    else if (IS_FILE_EXT(filename, ".ico")) {
         return httpd_resp_set_type(req, "image/x-icon");
         return httpd_resp_set_type(req, "image/x-icon");
-    } else if (IS_FILE_EXT(filename, ".js")) {
-        return httpd_resp_set_type(req, "text/javascript");
-    } else if (IS_FILE_EXT(filename, ".css")) {
+    }
+    else if (IS_FILE_EXT(filename, ".js")) {
+        return httpd_resp_set_type(req, "application/javascript");
+    }
+    else if (IS_FILE_EXT(filename, ".css")) {
         return httpd_resp_set_type(req, "text/css");
         return httpd_resp_set_type(req, "text/css");
     }
     }
+    else if (IS_FILE_EXT(filename, ".xml")) {
+        return httpd_resp_set_type(req, "text/xml");
+    }
+    else if (IS_FILE_EXT(filename, ".zip")) {
+        return httpd_resp_set_type(req, "application/x-zip");
+    }
+    else if (IS_FILE_EXT(filename, ".gz")) {
+        return httpd_resp_set_type(req, "application/x-gzip");
+    }
+
     /* This is a limited set only */
     /* This is a limited set only */
     /* For any other type always set as plain text */
     /* For any other type always set as plain text */
     return httpd_resp_set_type(req, "text/plain");
     return httpd_resp_set_type(req, "text/plain");

BIN
sd-card/html/FileSaver.min.js.gz


BIN
sd-card/html/FileSaver.min.js.map.gz


BIN
sd-card/html/Flowstate_initialization.jpg.gz


BIN
sd-card/html/Flowstate_initialization_delayed.jpg.gz


BIN
sd-card/html/Flowstate_take_image.jpg.gz


BIN
sd-card/html/close.png.gz


BIN
sd-card/html/cnn_images.jpg.gz


BIN
sd-card/html/favicon.ico.gz


BIN
sd-card/html/flow_overview.jpg.gz


BIN
sd-card/html/github.min.css.gz


BIN
sd-card/html/help.png.gz


BIN
sd-card/html/img/ChangeRateThreshold.png.gz


BIN
sd-card/html/img/flipImageSize.png.gz


+ 26 - 0
sd-card/html/ipInput.min.css

@@ -0,0 +1,26 @@
+.ip-input-container {
+	display:inline-block;
+	font-size:0;
+	border:1px solid #ccc;
+	padding:1px 0;
+}
+	
+.ip-input-container .ip-input-item {
+	border:none;
+	outline:0;
+	margin:0;
+	width:40px;
+	text-align:center;
+	vertical-align:bottom;
+	font-size:16px;
+}
+
+.ip-input-container .ip-input-dot {
+	display:inline-block;
+	width:2px;
+	height:2px;
+	margin-bottom:1px;
+	background-color:#333;
+	border-radius:50%;
+	vertical-align:bottom;
+}

BIN
sd-card/html/ipInput.min.css.gz


Dosya farkı çok büyük olduğundan ihmal edildi
+ 0 - 0
sd-card/html/ipInput.min.js


BIN
sd-card/html/ipInput.min.js.gz


BIN
sd-card/html/jquery-3.6.0.min.js.gz


BIN
sd-card/html/jszip.min.js.gz


BIN
sd-card/html/mkdocs_theme.css.gz


BIN
sd-card/html/mkdocs_theme_extra.css.gz


BIN
sd-card/html/plotly-basic-2.18.2.min.js.gz


BIN
sd-card/html/timezones.html.gz


BIN
sd-card/html/watermeter.svg.gz


Bu fark içinde çok fazla dosya değişikliği olduğu için bazı dosyalar gösterilmiyor