automatic mapping setup for elasticsearch through setupcheck
authorChristian Weiske <cweiske@cweiske.de>
Wed, 2 May 2012 16:18:17 +0000 (18:18 +0200)
committerChristian Weiske <cweiske@cweiske.de>
Wed, 2 May 2012 16:18:17 +0000 (18:18 +0200)
src/phorkie/Database/Setup/Elasticsearch.php [new file with mode: 0644]
src/phorkie/SetupCheck.php

diff --git a/src/phorkie/Database/Setup/Elasticsearch.php b/src/phorkie/Database/Setup/Elasticsearch.php
new file mode 100644 (file)
index 0000000..acf4bfc
--- /dev/null
@@ -0,0 +1,73 @@
+<?php
+namespace phorkie;
+
+class Database_Setup_Elasticsearch
+{
+    public function __construct()
+    {
+        $this->searchInstance = $GLOBALS['phorkie']['cfg']['elasticsearch'];
+    }
+
+    public function setup()
+    {
+        //create mapping
+        //mapping for repositories
+        $r = new \HTTP_Request2(
+            $this->searchInstance . 'repo/_mapping',
+            \HTTP_Request2::METHOD_PUT
+        );
+        $r->setBody(
+            json_encode(
+                (object)array(
+                    'repo' => (object)array(
+                        'properties' => (object)array(
+                            'id' => (object)array(
+                                'type' => 'long'
+                            ),
+                            'description' => (object)array(
+                                'type'  => 'string',
+                                'boost' => 2.0
+                            )
+                        )
+                    )
+                )
+            )
+        );
+        $r->send();
+
+        //mapping for files
+        $r = new \HTTP_Request2(
+            $this->searchInstance . 'file/_mapping',
+            \HTTP_Request2::METHOD_PUT
+        );
+        $r->setBody(
+            json_encode(
+                (object)array(
+                    'file' => (object)array(
+                        '_parent' => (object)array(
+                            'type' => 'repo'
+                        ),
+                        'properties' => (object)array(
+                            'name' => (object)array(
+                                'type'  => 'string',
+                                'boost' => 1.5
+                            ),
+                            'extension' => (object)array(
+                                'type'  => 'string',
+                                'boost' => 1.0
+                            ),
+                            'content' => (object)array(
+                                'type'  => 'string',
+                                'boost' => 0.8
+                            )
+                        )
+                    )
+                )
+            )
+        );
+        $r->send();
+    }
+
+}
+
+?>
index ba52d4261313b4fe3b4b972773d6bd306b862318..0bb632fce6ddc8b702443b02e93ef667251080e3 100644 (file)
@@ -28,6 +28,7 @@ class SetupCheck
         $sc->checkDeps();
         $sc->checkDirs();
         $sc->checkGit();
+        $sc->checkDatabase();
     }
 
     public function checkDeps()
@@ -67,6 +68,12 @@ class SetupCheck
         }
     }
 
+    public function checkDatabase()
+    {
+        $dbs = new Database_Setup_Elasticsearch();
+        $dbs->setup();
+    }
+
     public function fail($msg)
     {
         throw new Exception($msg);