#include "ClassFlowImage.h" #include #include #include #ifdef __cplusplus extern "C" { #endif #include #ifdef __cplusplus } #endif #include "time_sntp.h" #include "ClassLogFile.h" #include "CImageBasis.h" #include "esp_log.h" static const char* TAG = "FLOW IMG"; ClassFlowImage::ClassFlowImage(const char* logTag) { this->logTag = logTag; isLogImage = false; disabled = false; this->logfileRetentionInDays = 5; } ClassFlowImage::ClassFlowImage(std::vector * lfc, const char* logTag) : ClassFlow(lfc) { this->logTag = logTag; isLogImage = false; disabled = false; this->logfileRetentionInDays = 5; } ClassFlowImage::ClassFlowImage(std::vector * lfc, ClassFlow *_prev, const char* logTag) : ClassFlow(lfc, _prev) { this->logTag = logTag; isLogImage = false; disabled = false; this->logfileRetentionInDays = 5; } string ClassFlowImage::CreateLogFolder(string time) { if (!isLogImage) return ""; string logPath = LogImageLocation + "/" + time.LOGFILE_TIME_FORMAT_DATE_EXTR + "/" + time.LOGFILE_TIME_FORMAT_HOUR_EXTR; isLogImage = mkdir_r(logPath.c_str(), S_IRWXU) == 0; if (!isLogImage) { LogFile.WriteToFile(ESP_LOG_ERROR, TAG, "Can't create log folder for analog images. Path " + logPath); } return logPath; } void ClassFlowImage::LogImage(string logPath, string name, float *resultFloat, int *resultInt, string time, CImageBasis *_img) { if (!isLogImage) return; char buf[10]; if (resultFloat != NULL) { if (*resultFloat < 0) sprintf(buf, "N.N_"); else { sprintf(buf, "%.1f_", *resultFloat); if (strcmp(buf, "10.0_") == 0) sprintf(buf, "0.0_"); } } else if (resultInt != NULL) { sprintf(buf, "%d_", *resultInt); } else { buf[0] = '\0'; } string nm = logPath + "/" + buf + name + "_" + time + ".jpg"; nm = FormatFileName(nm); string output = "/sdcard/img_tmp/" + name + ".jpg"; output = FormatFileName(output); ESP_LOGD(logTag, "save to file: %s", nm.c_str()); _img->SaveToFile(nm); // CopyFile(output, nm); } void ClassFlowImage::RemoveOldLogs() { if (!isLogImage) return; ESP_LOGI(TAG, "remove old images"); if (logfileRetentionInDays == 0) { return; } time_t rawtime; struct tm* timeinfo; char cmpfilename[30]; time(&rawtime); rawtime = addDays(rawtime, -logfileRetentionInDays + 1); timeinfo = localtime(&rawtime); //ESP_LOGD(TAG, "ImagefileRetentionInDays: %d", logfileRetentionInDays); strftime(cmpfilename, 30, LOGFILE_TIME_FORMAT, timeinfo); //ESP_LOGD(TAG, "file name to compare: %s", cmpfilename); string folderName = string(cmpfilename).LOGFILE_TIME_FORMAT_DATE_EXTR; DIR *dir = opendir(LogImageLocation.c_str()); if (!dir) { ESP_LOGE(TAG, "Failed to stat dir: %s", LogImageLocation.c_str()); return; } struct dirent *entry; int deleted = 0; int notDeleted = 0; while ((entry = readdir(dir)) != NULL) { string folderPath = LogImageLocation + "/" + entry->d_name; if (entry->d_type == DT_DIR) { //ESP_LOGD(TAG, "Compare %s to %s", entry->d_name, folderName.c_str()); if ((strlen(entry->d_name) == folderName.length()) && (strcmp(entry->d_name, folderName.c_str()) < 0)) { removeFolder(folderPath.c_str(), logTag); deleted++; } else { notDeleted ++; } } } ESP_LOGI(TAG, "Image folder deleted: %d | Image folder not deleted: %d", deleted, notDeleted); closedir(dir); }