server/src/app/Http/Controllers/Api/DateStatsController.php
author ymh <ymh.work@gmail.com>
Thu, 20 Oct 2016 17:27:36 +0200
changeset 377 52169c718513
parent 375 145561ff51ff
child 378 5b47eab083f3
permissions -rw-r--r--
make all stats view use elasticsearch. Make sure that the document discourse types are taken form the predefined list
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;
07b44a378ad8 Add the datestats api
ymh <ymh.work@gmail.com>
parents:
diff changeset
    10
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
class DateStatsController extends Controller
07b44a378ad8 Add the datestats api
ymh <ymh.work@gmail.com>
parents:
diff changeset
    13
{
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
     * Display the specified resource.
07b44a378ad8 Add the datestats api
ymh <ymh.work@gmail.com>
parents:
diff changeset
    16
     *
07b44a378ad8 Add the datestats api
ymh <ymh.work@gmail.com>
parents:
diff changeset
    17
     * @return \Illuminate\Http\Response
07b44a378ad8 Add the datestats api
ymh <ymh.work@gmail.com>
parents:
diff changeset
    18
     */
07b44a378ad8 Add the datestats api
ymh <ymh.work@gmail.com>
parents:
diff changeset
    19
    public function index(Request $request)
07b44a378ad8 Add the datestats api
ymh <ymh.work@gmail.com>
parents:
diff changeset
    20
    {
07b44a378ad8 Add the datestats api
ymh <ymh.work@gmail.com>
parents:
diff changeset
    21
375
145561ff51ff change datestats to use elasticsearch
ymh <ymh.work@gmail.com>
parents: 307
diff changeset
    22
        $query = [ "match_all" => []];
307
07b44a378ad8 Add the datestats api
ymh <ymh.work@gmail.com>
parents:
diff changeset
    23
375
145561ff51ff change datestats to use elasticsearch
ymh <ymh.work@gmail.com>
parents: 307
diff changeset
    24
        $esQuery = [
145561ff51ff change datestats to use elasticsearch
ymh <ymh.work@gmail.com>
parents: 307
diff changeset
    25
            'index' => env('ELASTICSEARCH_INDEX'),
145561ff51ff change datestats to use elasticsearch
ymh <ymh.work@gmail.com>
parents: 307
diff changeset
    26
            'body' => [
145561ff51ff change datestats to use elasticsearch
ymh <ymh.work@gmail.com>
parents: 307
diff changeset
    27
                "size" => 0,
145561ff51ff change datestats to use elasticsearch
ymh <ymh.work@gmail.com>
parents: 307
diff changeset
    28
                "query" => $query,
145561ff51ff change datestats to use elasticsearch
ymh <ymh.work@gmail.com>
parents: 307
diff changeset
    29
                "aggs" => [
145561ff51ff change datestats to use elasticsearch
ymh <ymh.work@gmail.com>
parents: 307
diff changeset
    30
                    "datestats" => [
145561ff51ff change datestats to use elasticsearch
ymh <ymh.work@gmail.com>
parents: 307
diff changeset
    31
                        "nested"=> [
145561ff51ff change datestats to use elasticsearch
ymh <ymh.work@gmail.com>
parents: 307
diff changeset
    32
                            "path" => "creation_years"
145561ff51ff change datestats to use elasticsearch
ymh <ymh.work@gmail.com>
parents: 307
diff changeset
    33
                        ],
145561ff51ff change datestats to use elasticsearch
ymh <ymh.work@gmail.com>
parents: 307
diff changeset
    34
                        "aggs" => [
145561ff51ff change datestats to use elasticsearch
ymh <ymh.work@gmail.com>
parents: 307
diff changeset
    35
                            "years" => [
145561ff51ff change datestats to use elasticsearch
ymh <ymh.work@gmail.com>
parents: 307
diff changeset
    36
                                "terms"=> [
145561ff51ff change datestats to use elasticsearch
ymh <ymh.work@gmail.com>
parents: 307
diff changeset
    37
                                    "field" => "creation_years.year",
145561ff51ff change datestats to use elasticsearch
ymh <ymh.work@gmail.com>
parents: 307
diff changeset
    38
                                    "size" => 0,
145561ff51ff change datestats to use elasticsearch
ymh <ymh.work@gmail.com>
parents: 307
diff changeset
    39
                                    "order" => [
145561ff51ff change datestats to use elasticsearch
ymh <ymh.work@gmail.com>
parents: 307
diff changeset
    40
                                        "_term" => "asc"
145561ff51ff change datestats to use elasticsearch
ymh <ymh.work@gmail.com>
parents: 307
diff changeset
    41
                                    ]
145561ff51ff change datestats to use elasticsearch
ymh <ymh.work@gmail.com>
parents: 307
diff changeset
    42
                                ],
145561ff51ff change datestats to use elasticsearch
ymh <ymh.work@gmail.com>
parents: 307
diff changeset
    43
                                "aggs" => [
145561ff51ff change datestats to use elasticsearch
ymh <ymh.work@gmail.com>
parents: 307
diff changeset
    44
                                    "year_count" => [
145561ff51ff change datestats to use elasticsearch
ymh <ymh.work@gmail.com>
parents: 307
diff changeset
    45
                                        "sum" => [
145561ff51ff change datestats to use elasticsearch
ymh <ymh.work@gmail.com>
parents: 307
diff changeset
    46
                                            "field" => "creation_years.weight"
145561ff51ff change datestats to use elasticsearch
ymh <ymh.work@gmail.com>
parents: 307
diff changeset
    47
                                        ]
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
                            ]
145561ff51ff change datestats to use elasticsearch
ymh <ymh.work@gmail.com>
parents: 307
diff changeset
    51
                        ]
145561ff51ff change datestats to use elasticsearch
ymh <ymh.work@gmail.com>
parents: 307
diff changeset
    52
                    ]
145561ff51ff change datestats to use elasticsearch
ymh <ymh.work@gmail.com>
parents: 307
diff changeset
    53
                ]
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
        $esRes = Es::search($esQuery);
307
07b44a378ad8 Add the datestats api
ymh <ymh.work@gmail.com>
parents:
diff changeset
    57
375
145561ff51ff change datestats to use elasticsearch
ymh <ymh.work@gmail.com>
parents: 307
diff changeset
    58
        $datestats = [];
307
07b44a378ad8 Add the datestats api
ymh <ymh.work@gmail.com>
parents:
diff changeset
    59
375
145561ff51ff change datestats to use elasticsearch
ymh <ymh.work@gmail.com>
parents: 307
diff changeset
    60
        foreach($esRes['aggregations']['datestats']['years']['buckets'] as $bucket) {
145561ff51ff change datestats to use elasticsearch
ymh <ymh.work@gmail.com>
parents: 307
diff changeset
    61
            $datestats[(string)($bucket['key'])] = round($bucket['year_count']['value']);
307
07b44a378ad8 Add the datestats api
ymh <ymh.work@gmail.com>
parents:
diff changeset
    62
        }
07b44a378ad8 Add the datestats api
ymh <ymh.work@gmail.com>
parents:
diff changeset
    63
375
145561ff51ff change datestats to use elasticsearch
ymh <ymh.work@gmail.com>
parents: 307
diff changeset
    64
        return response()->json(['datestats' => $datestats ]);
307
07b44a378ad8 Add the datestats api
ymh <ymh.work@gmail.com>
parents:
diff changeset
    65
    }
07b44a378ad8 Add the datestats api
ymh <ymh.work@gmail.com>
parents:
diff changeset
    66
07b44a378ad8 Add the datestats api
ymh <ymh.work@gmail.com>
parents:
diff changeset
    67
}