#include "FoscamRecorder.h" #include "Util.h" #include #include #include #include #include namespace CameraRecorder { namespace Recorder { FoscamRecorder::FoscamRecorder(Http::HttpClient* pHttpClient, const Settings& settings) : m_pHttpClient(pHttpClient), m_settings(settings) { } FoscamRecorder::~FoscamRecorder() { } std::string FoscamRecorder::Snapshot(ctpl::thread_pool* pThreadPool) { Logging::Log(Logging::Severity::Debug, "FoscamRecorder Snapshot"); std::stringstream url; url << "http://" << m_settings.IpAddress << ":" << m_settings.Port << "/cgi-bin/CGIProxy.fcgi?cmd=snapPicture2&usr=" << m_settings.Username << "&pwd=" << m_settings.Password; std::stringstream fileName; fileName << m_settings.Path << "/" << m_settings.IpAddress << "/" << GetDateTimeString() << ".jpg"; try { std::ofstream file(fileName.str()); file << m_pHttpClient->GetUrlContents(url.str()); file.close(); } catch (const std::exception& e) { std::stringstream ss; ss << "CameraDevice::PerformFoscamAction() - Error: " << e.what() << std::endl; Logging::Log(Logging::Severity::Error, ss.str()); return std::string(); } return fileName.str(); } std::string FoscamRecorder::Video(ctpl::thread_pool* pThreadPool, const std::string& ffmpeg) { Logging::Log(Logging::Severity::Debug, "FoscamRecorder Video"); int port = 65534; std::stringstream url; url << "rtsp://" << m_settings.Username << ":" << m_settings.Password << "@" << m_settings.IpAddress << ":" << port << "/videoSub"; std::stringstream fileName; fileName << m_settings.Path << "/" << m_settings.IpAddress << "/" << GetDateTimeString() << ".mp4"; std::stringstream command; command << ffmpeg << " -i \"" << url.str() << "\" -t 30 -c:v copy -an -strict experimental " << fileName.str() << " > /dev/null 2>&1"; std::string cmd(command.str()); Logging::Log(Logging::Severity::Debug, cmd); pThreadPool->push( [cmd](int) { int retval = std::system(cmd.c_str()); } ); return fileName.str(); } } // namespace Recorder } // namespace CameraRecorder