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-- |
307 | 1 |
<?php |
2 |
||
3 |
namespace CorpusParole\Http\Controllers\Api; |
|
4 |
||
5 |
use Illuminate\Http\Request; |
|
6 |
use Log; |
|
375
145561ff51ff
change datestats to use elasticsearch
ymh <ymh.work@gmail.com>
parents:
307
diff
changeset
|
7 |
use Es; |
307 | 8 |
|
9 |
use CorpusParole\Http\Controllers\Controller; |
|
10 |
||
11 |
||
12 |
class DateStatsController extends Controller |
|
13 |
{ |
|
14 |
/** |
|
15 |
* Display the specified resource. |
|
16 |
* |
|
17 |
* @return \Illuminate\Http\Response |
|
18 |
*/ |
|
19 |
public function index(Request $request) |
|
20 |
{ |
|
21 |
||
375
145561ff51ff
change datestats to use elasticsearch
ymh <ymh.work@gmail.com>
parents:
307
diff
changeset
|
22 |
$query = [ "match_all" => []]; |
307 | 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 | 57 |
|
375
145561ff51ff
change datestats to use elasticsearch
ymh <ymh.work@gmail.com>
parents:
307
diff
changeset
|
58 |
$datestats = []; |
307 | 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 | 62 |
} |
63 |
||
375
145561ff51ff
change datestats to use elasticsearch
ymh <ymh.work@gmail.com>
parents:
307
diff
changeset
|
64 |
return response()->json(['datestats' => $datestats ]); |
307 | 65 |
} |
66 |
||
67 |
} |