SetupCheck::run();
}
-//delete all repos
-$r = new \HTTP_Request2(
- $GLOBALS['phorkie']['cfg']['elasticsearch'] . 'repo/_query',
- \HTTP_Request2::METHOD_DELETE
-);
-$r->setBody(
- json_encode(
- (object)array(
- 'match_all' => (object)array()
- )
- )
-);
-$r->send();
-$r = new \HTTP_Request2(
- $GLOBALS['phorkie']['cfg']['elasticsearch'] . 'file/_query',
- \HTTP_Request2::METHOD_DELETE
-);
-$r->setBody(
- json_encode(
- (object)array(
- 'match_all' => (object)array()
- )
- )
-);
-$r->send();
-//create mapping
-$r = new \HTTP_Request2(
- $GLOBALS['phorkie']['cfg']['elasticsearch'] . 'file/_mapping',
- \HTTP_Request2::METHOD_PUT
-);
-$r->setBody(
- json_encode(
- (object)array(
- 'file' => (object)array(
- '_parent' => (object)array(
- 'type' => 'repo'
- )
- )
- )
- )
-);
-$r->send();
+$db = new Database();
+$idx = $db->getIndexer();
+
+//cleanup
+echo "Deleting all index data\n";
+$idx->deleteAllRepos();
+//create mapping
+echo "Index setup\n";
+$db->getSetup()->setup();
-//FIXME: define schema
$rs = new Repositories();
-foreach ($rs->getList(0, 10000) as $repo) {
+list($repos, $count) = $rs->getList(0, 10000);
+$idx = new Indexer_Elasticsearch();
+foreach ($repos as $repo) {
echo 'Indexing ' . $repo->id . "\n";
- $r = new \HTTP_Request2(
- $GLOBALS['phorkie']['cfg']['elasticsearch'] . 'repo/' . $repo->id,
- \HTTP_Request2::METHOD_PUT
- );
- $r->setBody(
- json_encode(
- (object)array(
- 'id' => $repo->id,
- 'description' => $repo->getDescription(),
- )
- )
- );
- $res = $r->send();
-
- foreach ($repo->getFiles() as $file) {
- $r = new \HTTP_Request2(
- $GLOBALS['phorkie']['cfg']['elasticsearch'] . 'file/?parent=' . $repo->id,
- \HTTP_Request2::METHOD_POST
- );
- $r->setBody(
- json_encode(
- (object)array(
- 'name' => $file->getFilename(),
- 'extension' => $file->getExt(),
- 'content' => $file->isText() ? $file->getContent() : '',
- )
- )
- );
- $r->send();
- }
+ $idx->addRepo($repo, filectime($repo->gitDir));
}
?>
SetupCheck::run();
}
-$r = new \HTTP_Request2(
+$r = new Database_Adapter_Elasticsearch_HTTPRequest(
$GLOBALS['phorkie']['cfg']['elasticsearch'] . 'repo/_search',
\HTTP_Request2::METHOD_GET
);
return new Indexer_Elasticsearch();
}
+ public function getSetup()
+ {
+ return new Database_Setup_Elasticsearch();
+ }
}
?>
--- /dev/null
+<?php
+namespace phorkie;
+
+class Database_Adapter_Elasticsearch_HTTPRequest extends \HTTP_Request2
+{
+ public function send()
+ {
+ $res = parent::send();
+ $mainCode = intval($res->getStatus() / 100);
+ if ($mainCode != 2) {
+ $js = json_decode($res->getBody());
+ if (isset($js->error)) {
+ $error = $js->error;
+ } else {
+ $error = $res->getBody();
+ }
+ throw new Exception(
+ 'Error in elasticsearch communication: ' . $error
+ );
+ }
+ return $res;
+ }
+}
+
+?>
public function setup()
{
+ $r = new Database_Adapter_Elasticsearch_HTTPRequest(
+ $this->searchInstance . 'repo/_mapping',
+ \HTTP_Request2::METHOD_DELETE
+ );
+ $r->send();
+
//create mapping
//mapping for repositories
- $r = new \HTTP_Request2(
+ $r = new Database_Adapter_Elasticsearch_HTTPRequest(
$this->searchInstance . 'repo/_mapping',
\HTTP_Request2::METHOD_PUT
);
json_encode(
(object)array(
'repo' => (object)array(
+ '_timestamp' => (object)array(
+ 'enabled' => true,
+ 'path' => 'tstamp',
+ ),
'properties' => (object)array(
'id' => (object)array(
'type' => 'long'
'description' => (object)array(
'type' => 'string',
'boost' => 2.0
+ ),
+ 'crdate' => (object)array(
+ //creation date
+ 'type' => 'date',
+ ),
+ 'tstamp' => (object)array(
+ //modification date
+ 'type' => 'date',
)
)
)
$r->send();
//mapping for files
- $r = new \HTTP_Request2(
+ $r = new Database_Adapter_Elasticsearch_HTTPRequest(
$this->searchInstance . 'file/_mapping',
\HTTP_Request2::METHOD_PUT
);
}
- public function addRepo(Repository $repo)
+ public function addRepo(Repository $repo, $crdate = null)
{
- $this->updateRepo($repo);
+ if ($crdate == null) {
+ $crdate = time();
+ }
+ $this->updateRepo($repo, $crdate);
}
- public function updateRepo(Repository $repo)
+ public function updateRepo(Repository $repo, $crdate = null)
{
//add repository
- $r = new \HTTP_Request2(
+ $r = new Database_Adapter_Elasticsearch_HTTPRequest(
$this->searchInstance . 'repo/' . $repo->id,
\HTTP_Request2::METHOD_PUT
);
- $r->setBody(
- json_encode(
- (object)array(
- 'id' => $repo->id,
- 'description' => $repo->getDescription(),
- )
- )
+ $repoData = array(
+ 'id' => $repo->id,
+ 'description' => $repo->getDescription(),
+ 'tstamp' => gmdate('c', time()),
);
+ if ($crdate !== null) {
+ $repoData['crdate'] = gmdate('c', $crdate);
+ }
+ $r->setBody(json_encode((object)$repoData));
$r->send();
//add files
$this->deleteRepoFiles($repo);
foreach ($repo->getFiles() as $file) {
- $r = new \HTTP_Request2(
+ $r = new Database_Adapter_Elasticsearch_HTTPRequest(
$this->searchInstance . 'file/?parent=' . $repo->id,
\HTTP_Request2::METHOD_POST
);
}
}
+ public function deleteAllRepos()
+ {
+ $r = new Database_Adapter_Elasticsearch_HTTPRequest(
+ $this->searchInstance . 'repo/_query',
+ \HTTP_Request2::METHOD_DELETE
+ );
+ $r->setBody(
+ json_encode(
+ (object)array(
+ 'match_all' => (object)array()
+ )
+ )
+ );
+ $r->send();
+ $r = new Database_Adapter_Elasticsearch_HTTPRequest(
+ $this->searchInstance . 'file/_query',
+ \HTTP_Request2::METHOD_DELETE
+ );
+ $r->setBody(
+ json_encode(
+ (object)array(
+ 'match_all' => (object)array()
+ )
+ )
+ );
+ $r->send();
+ }
+
public function deleteRepo(Repository $repo)
{
//delete repository from index
- $r = new \HTTP_Request2(
+ $r = new Database_Adapter_Elasticsearch_HTTPRequest(
$this->searchInstance . 'repo/' . $repo->id,
\HTTP_Request2::METHOD_DELETE
);
protected function deleteRepoFiles(Repository $repo)
{
//delete files of that repository
- $r = new \HTTP_Request2(
+ $r = new Database_Adapter_Elasticsearch_HTTPRequest(
$this->searchInstance . 'file/_query',
\HTTP_Request2::METHOD_DELETE
);
*/
public function search($term, $page = 0, $perPage = 10)
{
- $r = new \HTTP_Request2(
+ $r = new Database_Adapter_Elasticsearch_HTTPRequest(
$this->searchInstance . 'repo/_search',
\HTTP_Request2::METHOD_GET
);