#include "comboaddress.hh" #include "sclasses.hh" #include #include #include "navmon.pb.h" #include "fmt/format.h" #include "fmt/printf.h" #include #include #include #include #include #include #include #include "storage.hh" #include #include #include "navmon.hh" #include "CLI/CLI.hpp" #include "version.hh" static char program[]="navcat"; using namespace std; extern const char* g_gitHash; void unixDie(const std::string& str) { throw std::runtime_error(str+string(": ")+string(strerror(errno))); } time_t parseTime(std::string_view in) { time_t now=time(0); vector formats({"%Y-%m-%d %H:%M", "%Y%m%d %H%M", "%H:%M", "%H%M"}); for(const auto& f : formats) { struct tm tm; memset(&tm, 0, sizeof(tm)); localtime_r(&now, &tm); tm.tm_isdst = -1; tm.tm_sec = 0; char* res = strptime(&in[0], f.c_str(), &tm); if(res && !*res) { cerr<<"Matched on "< getSources(string_view dirname) { DIR *dir = opendir(&dirname[0]); if(!dir) unixDie("Listing metrics from statistics storage "+(string)dirname); struct dirent *result=0; vector ret; for(;;) { errno=0; if(!(result = readdir(dir))) { closedir(dir); if(errno) unixDie("Reading directory entry "+(string)dirname); else break; } if(result->d_name[0] != '.') { uint64_t src; if(sscanf(result->d_name, "%08" PRIx64, &src)==1) ret.push_back(src); } } sort(ret.begin(), ret.end()); return ret; } static size_t writen2(int fd, const void *buf, size_t count) { const char *ptr = (char*)buf; const char *eptr = ptr + count; ssize_t res; while(ptr != eptr) { res = ::write(fd, ptr, eptr - ptr); if(res < 0) { throw runtime_error("failed in writen2: "+string(strerror(errno))); } else if (res == 0) throw EofException(); ptr += (size_t) res; } return count; } void sendProtobuf(string_view dir, time_t startTime, time_t stopTime=0) { timespec start; start.tv_sec = startTime; start.tv_nsec = 0; // so we have a ton of files, and internally these are not ordered map fpos; vector > rnmms; for(;;) { auto srcs = getSources(dir); rnmms.clear(); for(const auto& src: srcs) { string fname = getPath(dir, start.tv_sec, src); FILE* fp = fopen(fname.c_str(), "r"); if(!fp) continue; uint32_t offset= fpos[fname]; if(fseek(fp, offset, SEEK_SET) < 0) { cerr<<"Error seeking: "<= make_pair(start.tv_sec, start.tv_nsec)) { rnmms.push_back({ts, msg}); } ++looked; } cerr<<"Harvested "< stopTime) break; std::string buf="bert"; uint16_t len = htons(nmm.second.size()); buf.append((char*)(&len), 2); buf += nmm.second; //fwrite(buf.c_str(), 1, buf.size(), stdout); writen2(1, buf.c_str(), buf.size()); } if(3600 + start.tv_sec - (start.tv_sec%3600) < stopTime) start.tv_sec = 3600 + start.tv_sec - (start.tv_sec%3600); else { break; } } } int main(int argc, char** argv) { bool doVERSION{false}; /* CLI::App app(program); app.add_flag("--version", doVERSION, "show program version and copyright"); app.allow_extras(true); // allow bare positional parameters try { app.parse(argc, argv); } catch(const CLI::Error &e) { return app.exit(e); } if(doVERSION) { showVersion(program, g_gitHash); exit(0); } */ signal(SIGPIPE, SIG_IGN); if(argc < 3) { cout<<"Syntax: navcat storage start stop"<