diff options
-rwxr-xr-x | responsememblk.c | 25 |
1 files changed, 12 insertions, 13 deletions
diff --git a/responsememblk.c b/responsememblk.c index c83b57b..26dd7fa 100755 --- a/responsememblk.c +++ b/responsememblk.c @@ -2349,7 +2349,6 @@ int cResponseMemBlk::sendRecordingsXml(struct stat *statbuf) { mResponseMessage = new string(); *mResponseMessage = ""; mResponseMessagePos = 0; - // mRequest->mContentType = MEMBLOCK; mRequest->mConnState = SERVING; @@ -2367,13 +2366,16 @@ int cResponseMemBlk::sendRecordingsXml(struct stat *statbuf) { bool add_desc = true; string guid = ""; bool single_item = false; - + + // allows creating a TV Model specific recordings.xml, i.e. HLS or HAS only for ts recordings with fps < 30 + // see type field evaluation for defails if (mRequest->getQueryAttributeValue(&avps, "model", model) == OKAY){ *(mLog->log())<< DEBUGPREFIX << " Found a Model Parameter: " << model << endl; } + // allows requesting the recordings information for a single file only if (mRequest->getQueryAttributeValue(&avps, "guid", guid) == OKAY){ guid = cUrlEncode::doUrlSaveDecode(guid); *(mLog->log())<< DEBUGPREFIX @@ -2383,6 +2385,7 @@ int cResponseMemBlk::sendRecordingsXml(struct stat *statbuf) { single_item = true; } + // allows requesting Urls with HLS or HAS type of manifest if (mRequest->getQueryAttributeValue(&avps, "type", type) == OKAY){ *(mLog->log())<< DEBUGPREFIX << " Found a Type Parameter: " << type @@ -2401,6 +2404,7 @@ int cResponseMemBlk::sendRecordingsXml(struct stat *statbuf) { } } + // allows tuning the recordings file, e.g. without any descriptions (size reduction) if (mRequest->getQueryAttributeValue(&avps, "mode", mode) == OKAY){ if (mode == "nodesc") { add_desc = false; @@ -2410,6 +2414,7 @@ int cResponseMemBlk::sendRecordingsXml(struct stat *statbuf) { } } + // when set to false, the type=hls or type=has fields are ignored for content with fps>=30 if (mRequest->getQueryAttributeValue(&avps, "has4hd", has_4_hd_str) == OKAY){ *(mLog->log())<< DEBUGPREFIX << " Found a Has4Hd Parameter: " << has_4_hd_str @@ -2418,14 +2423,12 @@ int cResponseMemBlk::sendRecordingsXml(struct stat *statbuf) { has_4_hd = false; } - #ifndef DEBUG *(mLog->log())<< DEBUGPREFIX << " generating /recordings.xml" << endl; #endif - //-------------------- char f[600]; #ifndef DEBUG @@ -2438,11 +2441,13 @@ int cResponseMemBlk::sendRecordingsXml(struct stat *statbuf) { time_t now = time(NULL); vector<sTimerEntry> act_rec; - /*#ifndef DEBUG*/ +#ifndef DEBUG *(mLog->log())<< DEBUGPREFIX << " checking active timer" << endl; - /*#endif*/ +#endif + // looking for recordings with active timer in order to determine, whether the recording is currently running + // the recording length needs to be determined from the EPG data in that case. for (cTimer * ti = Timers.First(); ti; ti = Timers.Next(ti)){ ti->Matches(); @@ -2464,7 +2469,6 @@ int cResponseMemBlk::sendRecordingsXml(struct stat *statbuf) { << endl; #endif - string hdr = ""; hdr += "<?xml version=\"1.0\" encoding=\"UTF-8\"?>\n"; hdr += "<rss version=\"2.0\">\n"; @@ -2488,7 +2492,6 @@ int cResponseMemBlk::sendRecordingsXml(struct stat *statbuf) { else { recording = Recordings.First(); } - // for (cRecording *recording = Recordings.First(); recording; recording = Recordings.Next(recording)) { while (recording != NULL) { hdr = ""; @@ -2496,7 +2499,6 @@ int cResponseMemBlk::sendRecordingsXml(struct stat *statbuf) { snprintf(f, sizeof(f), "http://%s:%d%s", own_ip.c_str(), mRequest->mServerPort, cUrlEncode::doUrlSaveEncode(recording->FileName()).c_str()); else - // snprintf(f, sizeof(f), "http://%s:%d%s%s", mServerAddr.c_str(), mServerPort, snprintf(f, sizeof(f), "http://%s:%d%s%s", own_ip.c_str(), mRequest->mServerPort, cUrlEncode::doUrlSaveEncode(recording->FileName()).c_str(), link_ext.c_str()); @@ -2508,8 +2510,7 @@ int cResponseMemBlk::sendRecordingsXml(struct stat *statbuf) { for (uint x = 0; x < act_rec.size(); x++) { if (act_rec[x].name == name) { - - // *(mLog->log())<< DEBUGPREFIX << " !!!!! Found active Recording !!! " << endl; + // Active Recording, correct recording duration with EPG info rec_dur += (act_rec[x].startTime + act_rec[x].duration - now); } } // for @@ -2530,8 +2531,6 @@ int cResponseMemBlk::sendRecordingsXml(struct stat *statbuf) { return OKAY; } item_count ++; - // if (!single_item) - // recording = Recordings.Next(recording); recording = (!single_item) ? Recordings.Next(recording) : NULL; } |