/* * smarttvfactory.h: VDR on Smart TV plugin * * Copyright (C) 2012 - 2016 T. Lohmar * * This program is free software; you can redistribute it and/or * modify it under the terms of the GNU General Public License * as published by the Free Software Foundation; either version 2 * of the License, or (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program; if not, write to the Free Software * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA * Or, point your browser to http://www.gnu.org/licenses/old-licenses/gpl-2.0.html * */ #ifndef __SMARTTVSERVER_H__ #define __SMARTTVSERVER_H__ #include #include #include #include #include #include #include "httpresource_base.h" #include "log.h" #include "stvw_cfg.h" #include "mngurls.h" #ifndef STANDALONE #include #include #include #else class cStatus { }; #endif using namespace std; #define PLG_VERSION "1.0.4" #define SERVER "SmartTvWeb/1.0.4" class cLiveRelay; struct sClientEntry { string mac; string ip; time_t lastKeepAlive; sClientEntry(string m, string i, time_t t ): mac(m), ip(i), lastKeepAlive(t) {}; }; class cCmd { public: cCmd(string t); void trim(string& t); string mTitle; string mCommand; bool mConfirm; }; class cActiveRecording { public: string mName; string mFilename; cActiveRecording(string n, string fn) : mName(n), mFilename(fn) {}; }; class cRecEntryBase { public: cRecEntryBase (string n, int l, bool i, Log* lg) : mLevel(l), mName(n), mIsFolder(i), mLog(lg) {}; virtual ~cRecEntryBase() {}; // virtual void appendEntry(cRecEntryBase*, int ) {}; int mLevel; string mName; bool mIsFolder; virtual void print(string pref); virtual int writeXmlItem(string *, string own_ip, int own_port) { return -1; }; Log *mLog; friend ostream &operator<< (ostream &ofd, cRecEntryBase b) { return ofd; }; }; class cRecEntry; class cRecFolder : public cRecEntryBase { public: list mEntries; // only when folder string mPath; // full path (incl mName) cRecFolder(string n, string p, int l, Log* lg) : cRecEntryBase(n, l, true, lg), mEntries(), mPath(p) {}; virtual ~cRecFolder() { for (list::iterator iter = mEntries.begin(); iter != mEntries.end(); ++iter) delete *iter; }; void appendEntry(cRecEntry*); void appendEntry(cRecFolder*); cRecFolder* GetFolder(list *folder_list); void print(string pref); int writeXmlItem(string *, string own_ip, int own_port); int writeXmlFolder(string*, string own_ip, int own_port); friend ostream &operator<< (ostream &ofd, cRecFolder b) { ofd << "Folder " << b.mName << " l= " << b.mLevel; return ofd; }; }; class cRecEntry : public cRecEntryBase { cRecording* mRec; // bool mIsFolder ; public: vector mSubfolders; bool mError; // int mLevel; string mTitle; // list mEntries; // only when folder cRecEntry(string mName, int l, Log* lg, cRecording*); virtual ~cRecEntry() {}; int writeXmlItem(string *, string own_ip, int own_port); void print(string pref); friend ostream &operator<< (ostream &ofd, cRecEntry b) { ofd << "Entry " << b.mName << " l= " << b.mLevel << " s= " << b.mSubfolders.size() << " E= "; for (uint i = 0; i < b.mSubfolders.size(); i++) ofd << b.mSubfolders[i] << " "; return ofd; }; }; //---------------------------- struct sUsageStatsEntry { string ipAddr; double usage; int count; sUsageStatsEntry() : ipAddr(""), usage(0.0), count (0) {}; sUsageStatsEntry(string ip, double d) : ipAddr(ip), usage(d), count(1) {}; }; class sUsageStatistics { private: // struct tm collectionDay; // once the collectionDay is changed, the stats are written time_t collectionDay; // once the collectionDay is changed, the stats are written vector clientEntry; bool enabled; int collectionWindow; string usageStatLogFilename; Log *mLog; void checkDay(); void writeEntries(); public: sUsageStatistics(string fn, Log* mLog); ~sUsageStatistics(); void addUsageInfo (string ip, double dur); }; class SmartTvServer : public cStatus { public: SmartTvServer(); virtual ~SmartTvServer(); void initServer(string c_dir, cSmartTvConfig* cfg); void loop(); void cleanUp(); int runAsThread(); void threadLoop(); Log mLog; void readRecordings(); int isServing(); int getActiveHttpSessions(); string getConfigDir() { return mConfigDir; }; cSmartTvConfig* getConfig() { return mConfig; }; void updateTvClient(string ip, string mac, time_t upd); void removeTvClient(string ip, string mac, time_t upd); void storeYtVideoId(string guid); bool deleteYtVideoId(string guid); cManageUrls* getUrlsObj(); void pushYtVideoId(string, bool); void pushCfgServerAddressToTv( string tv_addr); string getRecCmdsMsg() { return mRecMsg; }; string getCmdCmdsMsg() { return mCmdMsg; }; vector* getRecCmds() { return &mRecCmds; }; vector* getCmdCmds() { return &mCmdCmds; }; void OsdStatusMessage(const char *Message); void clrWriteFlag(int fd); void setWriteFlag(int fd); int openPipe(); cRecFolder* GetRecDb(); void addToBlackList(string); void removeFromBlackList(string); bool isBlackListed(string); list *getBlackList(); private: void addHttpResource(int fd, cHttpResourceBase* resource); void pushToClients(cHttpResourceBase* resource); int connectToClient(string peer, time_t last_update); void setNonBlocking(int fd); void initRecCmds(); void initCmdCmds(); // status callbacks void Recording(const cDevice *Device, const char *Name, const char *FileName, bool On); void TimerChange(const cTimer *Timer, eTimerChange Change); string processNestedItemList(string, cList *, vector*); list::iterator closeHttpResource(list::iterator); void acceptHttpResource(int &req_id); void logActiveSessionIds() ; pthread_t mThreadId; int mRequestCount; bool isInited; int serverPort; int mServerFd; unsigned int mSegmentDuration; int mHasMinBufferTime; int mLiveChannels; /* vector clientList; */ list clientList; vector mConTvClients; // list mConTvClients; vector mRecCmds; vector mCmdCmds; string mRecMsg; string mCmdMsg; int mActiveSessions; int mHttpClientId; string mConfigDir; cSmartTvConfig *mConfig; int mMaxFd; fd_set mReadState; fd_set mWriteState; cManageUrls* mManagedUrls; string mRecCmdMsg; string mCmdCmdMsg; vector mRecCmdList; vector mCmdCmdList; list mActRecordings; void AddActRecording(string, string); void DelActRecording(string, string); bool IsActRecording(string); cRecFolder* mRecordings; int mRecState; void CreateRecDb(); list mClientBlackList; public: sUsageStatistics *mUsageStatistics; }; #endif