![JAR search and dependency download from the Maven repository](/logo.png)
mServer.search.MserverSearch Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of MServer Show documentation
Show all versions of MServer Show documentation
The crawler for mediathekview/MediathekView
/*
* MediathekView
* Copyright (C) 2008 W. Xaver
* W.Xaver[at]googlemail.com
* http://zdfmediathk.sourceforge.net/
*
* 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 3 of the License, or
* 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, see .
*/
package mServer.search;
import static mServer.crawler.CrawlerTool.loadLongMax;
import java.util.ArrayList;
import java.util.Date;
import java.util.concurrent.TimeUnit;
import org.apache.commons.lang3.time.FastDateFormat;
import de.mediathekview.mlib.Config;
import de.mediathekview.mlib.tool.Log;
import mServer.crawler.Crawler;
import mServer.crawler.CrawlerConfig;
import mServer.daten.MserverSearchTask;
import mServer.tool.MserverDaten;
import mServer.tool.MserverDatumZeit;
import mServer.tool.MserverKonstanten;
import mServer.tool.MserverLog;
public class MserverSearch {
Crawler crawler;
public MserverSearch() {
this.crawler = null;
CrawlerConfig.dirFilme = MserverDaten.getVerzeichnisFilme();
}
@SuppressWarnings("deprecation")
public boolean filmeSuchen(MserverSearchTask aktSearchTask) {
boolean ret = true;
try {
// ===========================================
// den nächsten Suchlauf starten
MserverLog.systemMeldung("");
MserverLog.systemMeldung("-----------------------------------");
MserverLog.systemMeldung("Filmsuche starten");
crawler = new Crawler();
// was und wie
CrawlerConfig.senderLoadHow = aktSearchTask.loadHow();
CrawlerConfig.updateFilmliste = aktSearchTask.updateFilmliste();
CrawlerConfig.nurSenderLaden = arrLesen(aktSearchTask.arr[MserverSearchTask.SUCHEN_SENDER_NR].trim());
CrawlerConfig.orgFilmlisteErstellen = aktSearchTask.orgListeAnlegen();
CrawlerConfig.orgFilmliste = MserverDaten.system[MserverKonstanten.SYSTEM_FILMLISTE_ORG_NR];
// live-steams
CrawlerConfig.importLive = MserverDaten.system[MserverKonstanten.SYSTEM_IMPORT_LIVE_NR];
// und noch evtl. ein paar Imports von Filmlisten anderer Server
CrawlerConfig.importUrl_1__anhaengen = MserverDaten.system[MserverKonstanten.SYSTEM_IMPORT_URL_1_NR];
CrawlerConfig.importUrl_2__anhaengen = MserverDaten.system[MserverKonstanten.SYSTEM_IMPORT_URL_2_NR];
// für die alte Filmliste
CrawlerConfig.importOld = MserverDaten.system[MserverKonstanten.SYSTEM_IMPORT_OLD_NR];
CrawlerConfig.importAkt = MserverDatumZeit.getNameAkt(MserverDaten.system[MserverKonstanten.SYSTEM_IMPORT_AKT_NR]);
// Rest
Config.setUserAgent(MserverDaten.getUserAgent());
CrawlerConfig.proxyUrl = MserverDaten.system[MserverKonstanten.SYSTEM_PROXY_URL_NR];
CrawlerConfig.proxyPort = MserverDaten.getProxyPort();
Config.debug = MserverDaten.debug;
Log.setLogfile(MserverDaten.getLogDatei(MserverKonstanten.LOG_FILE_NAME_MSEARCH));
Thread t = new Thread(crawler);
t.setName("Crawler");
t.start();
MserverLog.systemMeldung("Filme suchen gestartet");
// ===========================================
// warten auf das Ende
//int warten = aktSearchTask.allesLaden() == true ? MvSKonstanten.WARTEZEIT_ALLES_LADEN : MvSKonstanten.WARTEZEIT_UPDATE_LADEN;
int warten = aktSearchTask.getWaitTime()/*Minuten*/;
MserverLog.systemMeldung("Max Laufzeit[Min]: " + warten);
MserverLog.systemMeldung("-----------------------------------");
TimeUnit.MINUTES.timedJoin(t, warten);
// ===========================================
// erst mal schauen ob noch was läuft
if (t != null) {
if (t.isAlive()) {
MserverLog.fehlerMeldung(915147623, MserverSearch.class.getName(), "Der letzte Suchlauf läuft noch");
if (crawler != null) {
MserverLog.systemMeldung("");
MserverLog.systemMeldung("");
MserverLog.systemMeldung("================================");
MserverLog.systemMeldung("================================");
MserverLog.systemMeldung("und wird jetzt gestoppt");
MserverLog.systemMeldung("Zeit: " + FastDateFormat.getInstance("dd.MM.yyyy HH:mm:ss").format(new Date()));
MserverLog.systemMeldung("================================");
MserverLog.systemMeldung("================================");
MserverLog.systemMeldung("");
//und jetzt STOPPEN!!!!!!!!
crawler.stop();
}
int w;
if (loadLongMax())
w = 30; // 30 Minuten bei langen Läufen
else
w = 20;// 20 Minuten warten, das Erstellen/Komprimieren der Liste dauert
TimeUnit.MINUTES.timedJoin(t, w);
if (t.isAlive()) {
MserverLog.systemMeldung("");
MserverLog.systemMeldung("");
MserverLog.systemMeldung("================================");
MserverLog.systemMeldung("================================");
MserverLog.systemMeldung("und noch gekillt");
MserverLog.systemMeldung("Zeit: " + FastDateFormat.getInstance("dd.MM.yyyy HH:mm:ss").format(new Date()));
MserverLog.systemMeldung("================================");
MserverLog.systemMeldung("================================");
MserverLog.systemMeldung("");
ret = false;
}
//jetzt ist Schicht im Schacht
t.stop();
}
}
} catch (Exception ex) {
MserverLog.fehlerMeldung(636987308, MserverSearch.class.getName(), "filmeSuchen", ex);
}
int l = crawler.getListeFilme().size();
MserverLog.systemMeldung("");
MserverLog.systemMeldung("");
MserverLog.systemMeldung("================================");
MserverLog.systemMeldung("Filmliste Anzahl Filme: " + l);
if (l < 10_000) {
//dann hat was nicht gepasst
MserverLog.systemMeldung(" Fehler!!");
MserverLog.systemMeldung("================================");
ret = false;
} else {
MserverLog.systemMeldung(" dann ist alles OK");
MserverLog.systemMeldung("================================");
}
MserverLog.systemMeldung("filmeSuchen beendet");
crawler = null;
return ret;
}
private String[] arrLesen(String s) {
ArrayList arr = new ArrayList<>();
String tmp = "";
s = s.trim();
if (s.equals("")) {
return null;
}
for (int i = 0; i < s.length(); ++i) {
if (s.charAt(i) == ',') {
if (!tmp.equals("")) {
arr.add(tmp);
}
tmp = "";
} else {
tmp += s.charAt(i);
}
}
if (!tmp.equals("")) {
arr.add(tmp);
}
return arr.toArray(new String[]{});
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy