From 0fac1cc64027106ae316482d386121633c7bcfb2 Mon Sep 17 00:00:00 2001
From: karl <karl@suma-ev.de>
Date: Thu, 28 Jul 2016 09:17:52 +0200
Subject: [PATCH] =?UTF-8?q?Der=20Suchfokus=20wird=20jetzt=20automatisch=20?=
 =?UTF-8?q?angepasst,=20falls=20ein=20Nutzer=20mit=20angepassten=20Einstel?=
 =?UTF-8?q?lungen=20aber=20allen=20Suchmaschinen=20eines=20Suchfokus=20aus?=
 =?UTF-8?q?gew=C3=A4hlt=20sucht.?=
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit

---
 app/MetaGer.php | 64 ++++++++++++++++++++++++++++++++++++++++++++-----
 1 file changed, 58 insertions(+), 6 deletions(-)

diff --git a/app/MetaGer.php b/app/MetaGer.php
index e209e2991..28f031b39 100644
--- a/app/MetaGer.php
+++ b/app/MetaGer.php
@@ -297,10 +297,9 @@ class MetaGer
         $enabledSearchengines = [];
         $overtureEnabled = FALSE;
         $countSumas = 0;
+        $sumas = $xml->xpath("suma");
         if($this->fokus === "angepasst")
         {
-            $sumas = $xml->xpath("suma");
-
             foreach($sumas as $suma)
             {
                 if($request->has($suma["name"]) 
@@ -325,7 +324,6 @@ class MetaGer
                 }
             }
         }else{
-            $sumas = $xml->xpath("suma");
             foreach($sumas as $suma){
                 $types = explode(",",$suma["type"]);
                 if(in_array($this->fokus, $types) 
@@ -429,18 +427,20 @@ class MetaGer
                 $this->sockets[$tmp->name] = $tmp->fp;
             }
 
+            # Alternativ
             # Hier wird direkt eine Liste der Fokustypen erstellt, die bei der Suche verwendet werden: [0] => [web, nachrichten]
-            if($engine["name"] !== "overtureAds") {
+            /*if($engine["name"] !== "overtureAds") {
                 $type = explode(",", $engine["type"]);
                 if(!$type[0] == "") {
                     $typeslist[$counter++] = $type;
                 }
-            }
+            }*/
 
 		}
 
+        # Alternativ
         # Jetzt wird geguckt, ob diese Liste überhaupt Typen enthält und für jeden Typen des ersten Eintrags (oder späteren falls dieser "" ist) wird geguckt, ob sich dieser Typ in allen folgenden Einträgen finden lässt. Diese Einträge sind nie "web", da diese Suche meist eh auch möglich ist und ohnehin wie die angepasste Suche funktioniert. Am Ende wird geguckt ob es einen Typen gab, der in allen Elementen enthalten ist. Dieser wird als Fokus gesetzt.
-        if(!empty($typeslist)) {
+        /*if(!empty($typeslist)) {
             foreach($typeslist as $matchTypeSearch) {
                 if(!empty($matchTypeSearch) && $matchTypeSearch[0] !== "") {
                     $toMatch = $matchTypeSearch;
@@ -467,6 +467,58 @@ class MetaGer
             if($matchedType !== "") {
                 $this->fokus = $matchedType;
             }
+        }*/
+
+        # Jetzt werden noch alle Kategorien der Settings durchgegangen und die jeweils enthaltenen namen der Suchmaschinen gespeichert.
+        $foki = [];
+        foreach($sumas as $suma)
+        {
+            if( (!isset($suma['disabled']) || $suma['disabled'] === "") && ( !isset($suma['userSelectable']) || $suma['userSelectable']->__toString() === "1") )
+            {
+                if( isset($suma['type']) )
+                {
+                    $f = explode(",", $suma['type']->__toString());
+                    foreach($f as $tmp)
+                    {
+                        $name = $suma['name']->__toString();
+                        $foki[$tmp][$suma['name']->__toString()] = $name;
+                    }
+                }else
+                {
+                    $name = $suma['name']->__toString();
+                    $foki["andere"][$suma['name']->__toString()] = $name;
+                }
+            }
+        }
+
+        # Es werden auch die Namen der aktuell aktiven Suchmaschinen abgespeichert.
+        $realEngNames = [];
+        foreach($enabledSearchengines as $realEng) {
+            $nam = $realEng["name"]->__toString();
+            if($nam !== "qualigo" && $nam !== "overtureAds") {
+                $realEngNames[] = $nam;
+            }
+        }
+        # Anschließend werden diese beiden Listen verglichen (jeweils eine der Fokuslisten für jeden Fokus), um herauszufinden ob sie vielleicht identisch sind. Ist dies der Fall, so hat der Nutzer anscheinend Suchmaschinen eines kompletten Fokus eingestellt. Der Fokus wird dementsprechend angepasst.
+        foreach($foki as $fok => $engs) {
+            $isFokus = true;
+            $fokiEngNames = [];
+            foreach($engs as $eng) {
+                $fokiEngNames[] = $eng;
+            }
+            foreach($fokiEngNames as $fen) {
+                if(!in_array($fen, $realEngNames)) {
+                    $isFokus = false;
+                }
+            }
+            foreach($realEngNames as $ren) {
+                if(!in_array($ren, $fokiEngNames)) {
+                    $isFokus = false;
+                }
+            }
+            if($isFokus) {
+                $this->fokus = $fok;
+            }
         }
 
         # Nun passiert ein elementarer Schritt.
-- 
GitLab