mServer.search.MserverSearch.java Source code

Java tutorial

Introduction

Here is the source code for mServer.search.MserverSearch.java

Source

/*
 * 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 <http://www.gnu.org/licenses/>.
 */
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 nchsten 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];

            // fr 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 luft
            if (t != null) {
                if (t.isAlive()) {
                    MserverLog.fehlerMeldung(915147623, MserverSearch.class.getName(),
                            "Der letzte Suchlauf luft 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 Lufen
                    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<String> 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[] {});
    }
}