ADD: do a cursory validatation of the elasticsearch url
[phorkie.git] / src / phorkie / SetupCheck.php
index ba52d4261313b4fe3b4b972773d6bd306b862318..f1fbc0f519e69d63d773e88db52b4713c8867a6d 100644 (file)
@@ -7,11 +7,14 @@ class SetupCheck
         'pear.php.net/VersionControl_Git'  => 'VersionControl_Git',
         'pear.twig-project.org/Twig'       => 'Twig_Autoloader',
         'pear.php.net/Date_HumanDiff'      => 'Date_HumanDiff',
+        'pear.php.net/HTTP_Request2'       => 'HTTP_Request2',
+        'pear.php.net/Pager'               => 'Pager',
         'pear.php.net/Services_Libravatar' => 'Services_Libravatar',
+        'zustellzentrum.cweiske.de/MIME_Type_PlainDetect' => 'MIME_Type_PlainDetect',
     );
 
     protected $writableDirs;
-
+    protected $elasticsearch;
 
     public function __construct()
     {
@@ -20,6 +23,7 @@ class SetupCheck
             'gitdir' => $cfg['gitdir'],
             'workdir' => $cfg['workdir'],
         );
+        $this->elasticsearch = $cfg['elasticsearch'];
     }
 
     public static function run()
@@ -28,6 +32,9 @@ class SetupCheck
         $sc->checkDeps();
         $sc->checkDirs();
         $sc->checkGit();
+        if ($this->elasticsearch != '') {
+            $sc->checkDatabase();
+        }
     }
 
     public function checkDeps()
@@ -67,6 +74,17 @@ class SetupCheck
         }
     }
 
+    public function checkDatabase()
+    {
+        $es = parse_url($this->elasticsearch);
+        if (!preg_match("#/.+/#", $es['path'], $matches)) {
+            $this->fail('Improper elasticsearch url.  Elasticsearch requires a'
+                       . ' search domain to store your data. (e.g. http://localhost:9200/phorkie/)');
+        }
+        $dbs = new Database();
+        $dbs->getSetup()->setup();
+    }
+
     public function fail($msg)
     {
         throw new Exception($msg);