b38ef228
Alex Savenko
generate GaResource
|
1
2
3
4
5
6
7
8
9
10
11
|
<?php
/**
* Created by PhpStorm.
* User: Alex Savenko
* Date: 09.02.2017
* Time: 18:12
*/
namespace App\Controllers;
|
a941da22
Alex Savenko
ga output
|
12
|
use App\Model\Project;
|
897d06c3
Alex Savenko
generate GaResource
|
13
14
15
|
use Google_Client;
use Google_Service_AnalyticsReporting;
use Google_Service_AnalyticsReporting_DateRange;
|
f51dd710
Alex Savenko
dimensions +dynam...
|
16
|
use Google_Service_AnalyticsReporting_Dimension;
|
897d06c3
Alex Savenko
generate GaResource
|
17
18
19
|
use Google_Service_AnalyticsReporting_GetReportsRequest;
use Google_Service_AnalyticsReporting_Metric;
use Google_Service_AnalyticsReporting_ReportRequest;
|
b38ef228
Alex Savenko
generate GaResource
|
20
|
use PhalconRest\Mvc\Controllers\CrudResourceController;
|
b38ef228
Alex Savenko
generate GaResource
|
21
22
23
|
class GaController extends CrudResourceController {
|
897d06c3
Alex Savenko
generate GaResource
|
24
25
|
const SECRET_JSON = 'ca4a1bd8aa14.json';
const VIEW_ID = '119240817';
|
c9087298
Alex Savenko
ga output
|
26
|
const SCOPE = 'https://www.googleapis.com/auth/analytics.readonly';
|
b38ef228
Alex Savenko
generate GaResource
|
27
|
|
897d06c3
Alex Savenko
generate GaResource
|
28
29
|
public function getAction() {
|
c9087298
Alex Savenko
ga output
|
30
|
/** user params **/
|
0c1a07f0
Alex Savenko
add filter param ...
|
31
32
33
|
$user_id = $this->request->get('user_id')?? '1';
$view_id = $this->request->get('view_id');
$chart = $this->request->get('chart') ?? false;
|
c9087298
Alex Savenko
ga output
|
34
35
|
/** google params **/
|
0c1a07f0
Alex Savenko
add filter param ...
|
36
37
38
39
40
|
$get_metrics = $this->request->get('metric') ?? 'users';
$get_dimensions = $this->request->get('dimension');
$get_start_date = $this->request->get('start') ?? '30daysAgo';
$get_end_date = $this->request->get('end') ?? 'today';
$filter_expression = $this->request->get('filter');
|
c9087298
Alex Savenko
ga output
|
41
|
|
180e10be
Alex Savenko
dynamic dateRange
|
42
|
|
95c83ce2
Alex Savenko
ga output
|
43
|
if (empty($view_id)) {
|
2cda8b9d
Alex Savenko
ga output
|
44
|
$result = [];
|
de9cf95a
Alex Savenko
ga output
|
45
|
$projects = Project::find(['user_id' => $user_id]);
|
9ba864b0
Alex Savenko
ga output
|
46
|
foreach ($projects as $project) {
|
9791b548
Alex Savenko
ga output
|
47
|
$view_id = (string)$project->ga_view_id;
|
1d97c107
Alex Savenko
ga output
|
48
|
if (!empty($view_id)) {
|
0c1a07f0
Alex Savenko
add filter param ...
|
49
|
$result[] = $this->sendGaRequest($project->name, $view_id, $get_metrics, $get_dimensions, $get_start_date, $get_end_date, $chart, $filter_expression);
|
1d97c107
Alex Savenko
ga output
|
50
|
}
|
9ba864b0
Alex Savenko
ga output
|
51
52
53
|
}
}
else {
|
c0f7b2aa
Alex Savenko
ga output
|
54
|
$project = Project::findFirst(['ga_view_id' => $view_id]);
|
0c1a07f0
Alex Savenko
add filter param ...
|
55
|
$result = $this->sendGaRequest($project->name , $view_id, $get_metrics, $get_dimensions, $get_start_date, $get_end_date, $chart, $filter_expression);
|
9ba864b0
Alex Savenko
ga output
|
56
|
}
|
2a57dd72
Alex Savenko
ga fix
|
57
|
return $result;
|
129bec7c
Alex Savenko
ga output
|
58
59
60
|
}
|
0c1a07f0
Alex Savenko
add filter param ...
|
61
|
public function sendGaRequest($project_name, $view, $get_metrics, $get_dimensions, $start, $end, $chart = false, $filter_expression = null) {
|
129bec7c
Alex Savenko
ga output
|
62
|
|
897d06c3
Alex Savenko
generate GaResource
|
63
64
65
|
putenv('GOOGLE_APPLICATION_CREDENTIALS=/var/www/phalcon/'.self::SECRET_JSON);
$client = new Google_Client();
$client->useApplicationDefaultCredentials();
|
c9087298
Alex Savenko
ga output
|
66
|
$client->setScopes([self::SCOPE]);
|
897d06c3
Alex Savenko
generate GaResource
|
67
68
|
$analytics = new Google_Service_AnalyticsReporting($client);
|
c9087298
Alex Savenko
ga output
|
69
|
/** Create the DateRange object. **/
|
29f4a05f
Alex Savenko
multiple metrics
|
70
|
$dateRange = new Google_Service_AnalyticsReporting_DateRange();
|
129bec7c
Alex Savenko
ga output
|
71
72
|
$dateRange->setStartDate($start);
$dateRange->setEndDate($end);
|
29f4a05f
Alex Savenko
multiple metrics
|
73
|
|
c9087298
Alex Savenko
ga output
|
74
|
/** Create the Metrics object. **/
|
29f4a05f
Alex Savenko
multiple metrics
|
75
|
$metrics = [];
|
180e10be
Alex Savenko
dynamic dateRange
|
76
|
$get_metrics = explode(',', $get_metrics);
|
29f4a05f
Alex Savenko
multiple metrics
|
77
78
79
|
foreach ($get_metrics as $metric) {
$metrics_obj = new Google_Service_AnalyticsReporting_Metric();
$metrics_obj->setExpression('ga:'.$metric);
|
6d167872
Alex Savenko
alias to one temp...
|
80
|
$metrics_obj->setAlias('ga:'.$metric);
|
29f4a05f
Alex Savenko
multiple metrics
|
81
82
|
$metrics[] = $metrics_obj;
}
|
897d06c3
Alex Savenko
generate GaResource
|
83
|
|
c9087298
Alex Savenko
ga output
|
84
|
/** Create the Dimensions object. **/
|
584f7b1c
Alex Savenko
ga output
|
85
|
if (!empty($get_dimensions)) {
|
b22a7c02
Alex Savenko
empty dimension
|
86
87
88
89
90
91
92
|
$dimensions = [];
$get_dimensions = explode(',', $get_dimensions);
foreach ($get_dimensions as $dimension) {
$dimension_obj = new Google_Service_AnalyticsReporting_Dimension();
$dimension_obj->setName("ga:".$dimension);
$dimensions[] = $dimension_obj;
}
|
04026e8b
Alex Savenko
dimensions +dynam...
|
93
|
}
|
f51dd710
Alex Savenko
dimensions +dynam...
|
94
|
|
c9087298
Alex Savenko
ga output
|
95
|
//Create the ReportRequest object.
|
29f4a05f
Alex Savenko
multiple metrics
|
96
|
$request = new Google_Service_AnalyticsReporting_ReportRequest();
|
129bec7c
Alex Savenko
ga output
|
97
|
$request->setViewId($view);
|
29f4a05f
Alex Savenko
multiple metrics
|
98
|
$request->setDateRanges($dateRange);
|
11d0a620
Alex Savenko
ga include empty ...
|
99
|
$request->setIncludeEmptyRows(true);
|
c6d3dfe5
Alex Savenko
registration
|
100
101
102
|
if (!empty($dimensions)) {
$request->setDimensions(array($dimensions));
}
|
c5aa2e2b
Alex Savenko
dimensions +dynam...
|
103
|
$request->setMetrics(array($metrics));
|
0c1a07f0
Alex Savenko
add filter param ...
|
104
105
106
|
if (!empty($filter_expression)) {
$request->setFiltersExpression("ga:".$filter_expression);
}
|
897d06c3
Alex Savenko
generate GaResource
|
107
|
|
29f4a05f
Alex Savenko
multiple metrics
|
108
|
$body = new Google_Service_AnalyticsReporting_GetReportsRequest();
|
c6d3dfe5
Alex Savenko
registration
|
109
|
$body->setReportRequests(array($request));
|
897d06c3
Alex Savenko
generate GaResource
|
110
|
|
c6d3dfe5
Alex Savenko
registration
|
111
|
$response = $analytics->reports->batchGet($body);
|
897d06c3
Alex Savenko
generate GaResource
|
112
|
|
a6a1fb9f
Alex Savenko
ga output
|
113
114
|
//have to rewrite code below (2 rows)
$response = $response->toSimpleObject();
|
a6a1fb9f
Alex Savenko
ga output
|
115
|
$response = $response->reports[0]['data']['rows'];
|
9b8fbac2
Alex Savenko
ga output
|
116
|
|
7e1d4fa3
Alex Savenko
ga output
|
117
118
119
120
121
|
if ($chart) {
$result = self::responseChartTransform($response, $project_name);
} else {
$result = self::responseDataTransform($response, $project_name);
}
|
5937dcc7
Alex Savenko
ga output
|
122
|
|
5285e167
Alex Savenko
ga output
|
123
|
return $result;
|
5937dcc7
Alex Savenko
ga output
|
124
125
126
|
}
|
7e1d4fa3
Alex Savenko
ga output
|
127
|
public static function responseDataTransform(array $response, $project_name) {
|
5937dcc7
Alex Savenko
ga output
|
128
|
|
9cbda58b
Alex Savenko
ga output
|
129
|
$result = [];
|
9cbda58b
Alex Savenko
ga output
|
130
|
|
c04bfb94
Alex Savenko
ga output
|
131
|
foreach ($response as $item) {
|
d29dde0e
Alex Savenko
ga output
|
132
133
134
135
|
$metric_val = $item['metrics'][0]['values'];
$dimension_val = $item['dimensions'][0];
|
889ea43e
Alex Savenko
ga output
|
136
137
|
$result['name'] = $project_name;
|
f842989c
Alex Savenko
ga output
|
138
|
if (count($metric_val) > 1) {
|
65b1cb95
Alex Savenko
ga output
|
139
140
|
for ($i = 0; $i < count($metric_val); $i++) {
$result[$dimension_val][] = $metric_val[$i];
|
d29dde0e
Alex Savenko
ga output
|
141
142
143
144
|
}
} else {
$result[$dimension_val] = $metric_val[0];
}
|
9cbda58b
Alex Savenko
ga output
|
145
146
|
}
|
5937dcc7
Alex Savenko
ga output
|
147
|
return $result;
|
05915c96
Alex Savenko
ga output
|
148
|
|
7fe1d3b2
Alex Savenko
create response
|
149
|
}
|
5937dcc7
Alex Savenko
ga output
|
150
|
|
7e1d4fa3
Alex Savenko
ga output
|
151
152
153
|
public static function responseChartTransform(array $response, $project_name) {
$result = [];
|
a7c416d0
Alex Savenko
ga output
|
154
|
|
7e1d4fa3
Alex Savenko
ga output
|
155
156
157
|
foreach ($response as $item) {
$metric_val = $item['metrics'][0]['values'];
|
92a5b7e0
Alex Savenko
ga fix
|
158
|
$result['name'] = $project_name;
|
7e1d4fa3
Alex Savenko
ga output
|
159
160
161
|
if (count($metric_val) > 1) {
for ($i = 0; $i < count($metric_val); $i++) {
|
cea9b628
Alex Savenko
ga fix
|
162
|
$result['data'][] = (int)$metric_val[$i];
|
7e1d4fa3
Alex Savenko
ga output
|
163
164
|
}
} else {
|
92a5b7e0
Alex Savenko
ga fix
|
165
|
$result['data'][] = (int)$metric_val[0];
|
7e1d4fa3
Alex Savenko
ga output
|
166
167
168
169
170
171
172
|
}
}
return $result;
}
|
5937dcc7
Alex Savenko
ga output
|
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
|
public function printResults($reports) {
$res = '';
for ( $reportIndex = 0; $reportIndex < count( $reports ); $reportIndex++ ) {
$report = $reports[ $reportIndex ];
$header = $report->getColumnHeader();
$dimensionHeaders = $header->getDimensions();
$metricHeaders = $header->getMetricHeader()->getMetricHeaderEntries();
$rows = $report->getData()->getRows();
for ( $rowIndex = 0; $rowIndex < count($rows); $rowIndex++) {
$row = $rows[ $rowIndex ];
$dimensions = $row->getDimensions();
$metrics = $row->getMetrics();
for ($i = 0; $i < count($dimensionHeaders) && $i < count($dimensions); $i++) {
print($dimensionHeaders[$i] . ": " . $dimensions[$i] . "\n");
}
for ($j = 0; $j < count( $metricHeaders ) && $j < count( $metrics ); $j++) {
$entry = $metricHeaders[$j];
$values = $metrics[$j];
//print("Metric type: " . $entry->getType() . "\n" );
for ( $valueIndex = 0; $valueIndex < count( $values->getValues() ); $valueIndex++ ) {
$value = $values->getValues()[ $valueIndex ];
$res .= "<b>" . $entry->getName() . "</b>: " . $value . '<br/>';
}
}
}
}
return $res;
}
|
b38ef228
Alex Savenko
generate GaResource
|
211
|
}
|