server/src/app/Http/Controllers/Api/DateStatsController.php
author ymh <ymh.work@gmail.com>
Wed, 09 Nov 2016 23:41:15 +0100
changeset 407 2dba812c7ef2
parent 406 cf0f23803a53
child 424 feb0d3e0fef9
permissions -rw-r--r--
add a way to build rpm for puppet files, correct elasticsearch provisioning, correct error on elasticsearch queries + tests
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
307
07b44a378ad8 Add the datestats api
ymh <ymh.work@gmail.com>
parents:
diff changeset
     1
<?php
07b44a378ad8 Add the datestats api
ymh <ymh.work@gmail.com>
parents:
diff changeset
     2
07b44a378ad8 Add the datestats api
ymh <ymh.work@gmail.com>
parents:
diff changeset
     3
namespace CorpusParole\Http\Controllers\Api;
07b44a378ad8 Add the datestats api
ymh <ymh.work@gmail.com>
parents:
diff changeset
     4
07b44a378ad8 Add the datestats api
ymh <ymh.work@gmail.com>
parents:
diff changeset
     5
use Illuminate\Http\Request;
07b44a378ad8 Add the datestats api
ymh <ymh.work@gmail.com>
parents:
diff changeset
     6
use Log;
375
145561ff51ff change datestats to use elasticsearch
ymh <ymh.work@gmail.com>
parents: 307
diff changeset
     7
use Es;
307
07b44a378ad8 Add the datestats api
ymh <ymh.work@gmail.com>
parents:
diff changeset
     8
07b44a378ad8 Add the datestats api
ymh <ymh.work@gmail.com>
parents:
diff changeset
     9
use CorpusParole\Http\Controllers\Controller;
378
5b47eab083f3 implement filters on stats controller, put all filter logic in CorpusFilterManager
ymh <ymh.work@gmail.com>
parents: 377
diff changeset
    10
use CorpusParole\Libraries\Filters\CorpusFilterManager;
307
07b44a378ad8 Add the datestats api
ymh <ymh.work@gmail.com>
parents:
diff changeset
    11
07b44a378ad8 Add the datestats api
ymh <ymh.work@gmail.com>
parents:
diff changeset
    12
07b44a378ad8 Add the datestats api
ymh <ymh.work@gmail.com>
parents:
diff changeset
    13
class DateStatsController extends Controller
07b44a378ad8 Add the datestats api
ymh <ymh.work@gmail.com>
parents:
diff changeset
    14
{
07b44a378ad8 Add the datestats api
ymh <ymh.work@gmail.com>
parents:
diff changeset
    15
    /**
07b44a378ad8 Add the datestats api
ymh <ymh.work@gmail.com>
parents:
diff changeset
    16
     * Display the specified resource.
07b44a378ad8 Add the datestats api
ymh <ymh.work@gmail.com>
parents:
diff changeset
    17
     *
07b44a378ad8 Add the datestats api
ymh <ymh.work@gmail.com>
parents:
diff changeset
    18
     * @return \Illuminate\Http\Response
07b44a378ad8 Add the datestats api
ymh <ymh.work@gmail.com>
parents:
diff changeset
    19
     */
07b44a378ad8 Add the datestats api
ymh <ymh.work@gmail.com>
parents:
diff changeset
    20
    public function index(Request $request)
07b44a378ad8 Add the datestats api
ymh <ymh.work@gmail.com>
parents:
diff changeset
    21
    {
07b44a378ad8 Add the datestats api
ymh <ymh.work@gmail.com>
parents:
diff changeset
    22
378
5b47eab083f3 implement filters on stats controller, put all filter logic in CorpusFilterManager
ymh <ymh.work@gmail.com>
parents: 377
diff changeset
    23
5b47eab083f3 implement filters on stats controller, put all filter logic in CorpusFilterManager
ymh <ymh.work@gmail.com>
parents: 377
diff changeset
    24
        $filterManager = new CorpusFilterManager();
5b47eab083f3 implement filters on stats controller, put all filter logic in CorpusFilterManager
ymh <ymh.work@gmail.com>
parents: 377
diff changeset
    25
        $filters = $filterManager->prepareFilters($request);
5b47eab083f3 implement filters on stats controller, put all filter logic in CorpusFilterManager
ymh <ymh.work@gmail.com>
parents: 377
diff changeset
    26
        unset($filters['dates']);
5b47eab083f3 implement filters on stats controller, put all filter logic in CorpusFilterManager
ymh <ymh.work@gmail.com>
parents: 377
diff changeset
    27
        $qFilterParts = $filterManager->buildESFilters($filters);
5b47eab083f3 implement filters on stats controller, put all filter logic in CorpusFilterManager
ymh <ymh.work@gmail.com>
parents: 377
diff changeset
    28
5b47eab083f3 implement filters on stats controller, put all filter logic in CorpusFilterManager
ymh <ymh.work@gmail.com>
parents: 377
diff changeset
    29
        $query = $filterManager->buildQuery($qFilterParts);
307
07b44a378ad8 Add the datestats api
ymh <ymh.work@gmail.com>
parents:
diff changeset
    30
375
145561ff51ff change datestats to use elasticsearch
ymh <ymh.work@gmail.com>
parents: 307
diff changeset
    31
        $esQuery = [
406
cf0f23803a53 upgrade elasticsearch to 5.0, upgrade ember
ymh <ymh.work@gmail.com>
parents: 378
diff changeset
    32
            'index' => config('elasticsearch.index'),
375
145561ff51ff change datestats to use elasticsearch
ymh <ymh.work@gmail.com>
parents: 307
diff changeset
    33
            'body' => [
145561ff51ff change datestats to use elasticsearch
ymh <ymh.work@gmail.com>
parents: 307
diff changeset
    34
                "size" => 0,
145561ff51ff change datestats to use elasticsearch
ymh <ymh.work@gmail.com>
parents: 307
diff changeset
    35
                "query" => $query,
145561ff51ff change datestats to use elasticsearch
ymh <ymh.work@gmail.com>
parents: 307
diff changeset
    36
                "aggs" => [
145561ff51ff change datestats to use elasticsearch
ymh <ymh.work@gmail.com>
parents: 307
diff changeset
    37
                    "datestats" => [
145561ff51ff change datestats to use elasticsearch
ymh <ymh.work@gmail.com>
parents: 307
diff changeset
    38
                        "nested"=> [
145561ff51ff change datestats to use elasticsearch
ymh <ymh.work@gmail.com>
parents: 307
diff changeset
    39
                            "path" => "creation_years"
145561ff51ff change datestats to use elasticsearch
ymh <ymh.work@gmail.com>
parents: 307
diff changeset
    40
                        ],
145561ff51ff change datestats to use elasticsearch
ymh <ymh.work@gmail.com>
parents: 307
diff changeset
    41
                        "aggs" => [
145561ff51ff change datestats to use elasticsearch
ymh <ymh.work@gmail.com>
parents: 307
diff changeset
    42
                            "years" => [
145561ff51ff change datestats to use elasticsearch
ymh <ymh.work@gmail.com>
parents: 307
diff changeset
    43
                                "terms"=> [
145561ff51ff change datestats to use elasticsearch
ymh <ymh.work@gmail.com>
parents: 307
diff changeset
    44
                                    "field" => "creation_years.year",
407
2dba812c7ef2 add a way to build rpm for puppet files, correct elasticsearch provisioning, correct error on elasticsearch queries + tests
ymh <ymh.work@gmail.com>
parents: 406
diff changeset
    45
                                    "size" => 2147483647,
375
145561ff51ff change datestats to use elasticsearch
ymh <ymh.work@gmail.com>
parents: 307
diff changeset
    46
                                    "order" => [
145561ff51ff change datestats to use elasticsearch
ymh <ymh.work@gmail.com>
parents: 307
diff changeset
    47
                                        "_term" => "asc"
145561ff51ff change datestats to use elasticsearch
ymh <ymh.work@gmail.com>
parents: 307
diff changeset
    48
                                    ]
145561ff51ff change datestats to use elasticsearch
ymh <ymh.work@gmail.com>
parents: 307
diff changeset
    49
                                ],
145561ff51ff change datestats to use elasticsearch
ymh <ymh.work@gmail.com>
parents: 307
diff changeset
    50
                                "aggs" => [
145561ff51ff change datestats to use elasticsearch
ymh <ymh.work@gmail.com>
parents: 307
diff changeset
    51
                                    "year_count" => [
145561ff51ff change datestats to use elasticsearch
ymh <ymh.work@gmail.com>
parents: 307
diff changeset
    52
                                        "sum" => [
145561ff51ff change datestats to use elasticsearch
ymh <ymh.work@gmail.com>
parents: 307
diff changeset
    53
                                            "field" => "creation_years.weight"
145561ff51ff change datestats to use elasticsearch
ymh <ymh.work@gmail.com>
parents: 307
diff changeset
    54
                                        ]
145561ff51ff change datestats to use elasticsearch
ymh <ymh.work@gmail.com>
parents: 307
diff changeset
    55
                                    ]
145561ff51ff change datestats to use elasticsearch
ymh <ymh.work@gmail.com>
parents: 307
diff changeset
    56
                                ]
145561ff51ff change datestats to use elasticsearch
ymh <ymh.work@gmail.com>
parents: 307
diff changeset
    57
                            ]
145561ff51ff change datestats to use elasticsearch
ymh <ymh.work@gmail.com>
parents: 307
diff changeset
    58
                        ]
145561ff51ff change datestats to use elasticsearch
ymh <ymh.work@gmail.com>
parents: 307
diff changeset
    59
                    ]
145561ff51ff change datestats to use elasticsearch
ymh <ymh.work@gmail.com>
parents: 307
diff changeset
    60
                ]
145561ff51ff change datestats to use elasticsearch
ymh <ymh.work@gmail.com>
parents: 307
diff changeset
    61
            ]
145561ff51ff change datestats to use elasticsearch
ymh <ymh.work@gmail.com>
parents: 307
diff changeset
    62
        ];
145561ff51ff change datestats to use elasticsearch
ymh <ymh.work@gmail.com>
parents: 307
diff changeset
    63
        $esRes = Es::search($esQuery);
307
07b44a378ad8 Add the datestats api
ymh <ymh.work@gmail.com>
parents:
diff changeset
    64
375
145561ff51ff change datestats to use elasticsearch
ymh <ymh.work@gmail.com>
parents: 307
diff changeset
    65
        $datestats = [];
307
07b44a378ad8 Add the datestats api
ymh <ymh.work@gmail.com>
parents:
diff changeset
    66
375
145561ff51ff change datestats to use elasticsearch
ymh <ymh.work@gmail.com>
parents: 307
diff changeset
    67
        foreach($esRes['aggregations']['datestats']['years']['buckets'] as $bucket) {
378
5b47eab083f3 implement filters on stats controller, put all filter logic in CorpusFilterManager
ymh <ymh.work@gmail.com>
parents: 377
diff changeset
    68
            $c = round($bucket['year_count']['value']);
5b47eab083f3 implement filters on stats controller, put all filter logic in CorpusFilterManager
ymh <ymh.work@gmail.com>
parents: 377
diff changeset
    69
            if($c > 0) {
5b47eab083f3 implement filters on stats controller, put all filter logic in CorpusFilterManager
ymh <ymh.work@gmail.com>
parents: 377
diff changeset
    70
                $datestats[(string)($bucket['key'])] = $c;
5b47eab083f3 implement filters on stats controller, put all filter logic in CorpusFilterManager
ymh <ymh.work@gmail.com>
parents: 377
diff changeset
    71
            }
307
07b44a378ad8 Add the datestats api
ymh <ymh.work@gmail.com>
parents:
diff changeset
    72
        }
07b44a378ad8 Add the datestats api
ymh <ymh.work@gmail.com>
parents:
diff changeset
    73
375
145561ff51ff change datestats to use elasticsearch
ymh <ymh.work@gmail.com>
parents: 307
diff changeset
    74
        return response()->json(['datestats' => $datestats ]);
307
07b44a378ad8 Add the datestats api
ymh <ymh.work@gmail.com>
parents:
diff changeset
    75
    }
07b44a378ad8 Add the datestats api
ymh <ymh.work@gmail.com>
parents:
diff changeset
    76
07b44a378ad8 Add the datestats api
ymh <ymh.work@gmail.com>
parents:
diff changeset
    77
}