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 **/
|
95c83ce2
Alex Savenko
ga output
|
31
|
$user_id = $this->request->get('user_id')?? '1';
|
95c83ce2
Alex Savenko
ga output
|
32
|
$view_id= $this->request->get('view_id');
|
c9087298
Alex Savenko
ga output
|
33
34
35
|
$chart = $this->request->get('chart') ?? false;
/** google params **/
|
180e10be
Alex Savenko
dynamic dateRange
|
36
|
$get_metrics = $this->request->get('metric') ?? 'users';
|
129bec7c
Alex Savenko
ga output
|
37
|
$get_dimensions = $this->request->get('dimension');
|
180e10be
Alex Savenko
dynamic dateRange
|
38
39
|
$get_start_date = $this->request->get('start') ?? '30daysAgo';
$get_end_date = $this->request->get('end') ?? 'today';
|
c9087298
Alex Savenko
ga output
|
40
|
|
180e10be
Alex Savenko
dynamic dateRange
|
41
|
|
95c83ce2
Alex Savenko
ga output
|
42
|
if (empty($view_id)) {
|
2cda8b9d
Alex Savenko
ga output
|
43
|
$result = [];
|
de9cf95a
Alex Savenko
ga output
|
44
|
$projects = Project::find(['user_id' => $user_id]);
|
9ba864b0
Alex Savenko
ga output
|
45
|
foreach ($projects as $project) {
|
9791b548
Alex Savenko
ga output
|
46
|
$view_id = (string)$project->ga_view_id;
|
1d97c107
Alex Savenko
ga output
|
47
48
49
|
if (!empty($view_id)) {
$result[] = $this->sendGaRequest($project->name, $view_id, $get_metrics, $get_dimensions, $get_start_date, $get_end_date, $chart);
}
|
9ba864b0
Alex Savenko
ga output
|
50
51
52
|
}
}
else {
|
c0f7b2aa
Alex Savenko
ga output
|
53
|
$project = Project::findFirst(['ga_view_id' => $view_id]);
|
7e1d4fa3
Alex Savenko
ga output
|
54
|
$result = $this->sendGaRequest($project->name , $view_id, $get_metrics, $get_dimensions, $get_start_date, $get_end_date, $chart);
|
9ba864b0
Alex Savenko
ga output
|
55
56
|
}
return $result;
|
129bec7c
Alex Savenko
ga output
|
57
58
59
|
}
|
7e1d4fa3
Alex Savenko
ga output
|
60
|
public function sendGaRequest($project_name, $view, $get_metrics, $get_dimensions, $start, $end, $chart = false) {
|
129bec7c
Alex Savenko
ga output
|
61
|
|
897d06c3
Alex Savenko
generate GaResource
|
62
63
64
|
putenv('GOOGLE_APPLICATION_CREDENTIALS=/var/www/phalcon/'.self::SECRET_JSON);
$client = new Google_Client();
$client->useApplicationDefaultCredentials();
|
c9087298
Alex Savenko
ga output
|
65
|
$client->setScopes([self::SCOPE]);
|
897d06c3
Alex Savenko
generate GaResource
|
66
67
|
$analytics = new Google_Service_AnalyticsReporting($client);
|
c9087298
Alex Savenko
ga output
|
68
|
/** Create the DateRange object. **/
|
29f4a05f
Alex Savenko
multiple metrics
|
69
|
$dateRange = new Google_Service_AnalyticsReporting_DateRange();
|
129bec7c
Alex Savenko
ga output
|
70
71
|
$dateRange->setStartDate($start);
$dateRange->setEndDate($end);
|
29f4a05f
Alex Savenko
multiple metrics
|
72
|
|
c9087298
Alex Savenko
ga output
|
73
|
/** Create the Metrics object. **/
|
29f4a05f
Alex Savenko
multiple metrics
|
74
|
$metrics = [];
|
180e10be
Alex Savenko
dynamic dateRange
|
75
|
$get_metrics = explode(',', $get_metrics);
|
29f4a05f
Alex Savenko
multiple metrics
|
76
77
78
|
foreach ($get_metrics as $metric) {
$metrics_obj = new Google_Service_AnalyticsReporting_Metric();
$metrics_obj->setExpression('ga:'.$metric);
|
6d167872
Alex Savenko
alias to one temp...
|
79
|
$metrics_obj->setAlias('ga:'.$metric);
|
29f4a05f
Alex Savenko
multiple metrics
|
80
81
|
$metrics[] = $metrics_obj;
}
|
897d06c3
Alex Savenko
generate GaResource
|
82
|
|
c9087298
Alex Savenko
ga output
|
83
|
/** Create the Dimensions object. **/
|
584f7b1c
Alex Savenko
ga output
|
84
|
if (!empty($get_dimensions)) {
|
b22a7c02
Alex Savenko
empty dimension
|
85
86
87
88
89
90
91
|
$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...
|
92
|
}
|
f51dd710
Alex Savenko
dimensions +dynam...
|
93
|
|
c9087298
Alex Savenko
ga output
|
94
|
//Create the ReportRequest object.
|
29f4a05f
Alex Savenko
multiple metrics
|
95
|
$request = new Google_Service_AnalyticsReporting_ReportRequest();
|
129bec7c
Alex Savenko
ga output
|
96
|
$request->setViewId($view);
|
29f4a05f
Alex Savenko
multiple metrics
|
97
|
$request->setDateRanges($dateRange);
|
c6d3dfe5
Alex Savenko
registration
|
98
99
100
|
if (!empty($dimensions)) {
$request->setDimensions(array($dimensions));
}
|
c5aa2e2b
Alex Savenko
dimensions +dynam...
|
101
|
$request->setMetrics(array($metrics));
|
897d06c3
Alex Savenko
generate GaResource
|
102
|
|
29f4a05f
Alex Savenko
multiple metrics
|
103
|
$body = new Google_Service_AnalyticsReporting_GetReportsRequest();
|
c6d3dfe5
Alex Savenko
registration
|
104
|
$body->setReportRequests(array($request));
|
897d06c3
Alex Savenko
generate GaResource
|
105
|
|
c6d3dfe5
Alex Savenko
registration
|
106
|
$response = $analytics->reports->batchGet($body);
|
897d06c3
Alex Savenko
generate GaResource
|
107
|
|
a6a1fb9f
Alex Savenko
ga output
|
108
109
|
//have to rewrite code below (2 rows)
$response = $response->toSimpleObject();
|
a6a1fb9f
Alex Savenko
ga output
|
110
|
$response = $response->reports[0]['data']['rows'];
|
9b8fbac2
Alex Savenko
ga output
|
111
|
|
7e1d4fa3
Alex Savenko
ga output
|
112
113
114
115
116
|
if ($chart) {
$result = self::responseChartTransform($response, $project_name);
} else {
$result = self::responseDataTransform($response, $project_name);
}
|
5937dcc7
Alex Savenko
ga output
|
117
|
|
5285e167
Alex Savenko
ga output
|
118
|
return $result;
|
5937dcc7
Alex Savenko
ga output
|
119
120
121
|
}
|
7e1d4fa3
Alex Savenko
ga output
|
122
|
public static function responseDataTransform(array $response, $project_name) {
|
5937dcc7
Alex Savenko
ga output
|
123
|
|
9cbda58b
Alex Savenko
ga output
|
124
|
$result = [];
|
9cbda58b
Alex Savenko
ga output
|
125
|
|
c04bfb94
Alex Savenko
ga output
|
126
|
foreach ($response as $item) {
|
d29dde0e
Alex Savenko
ga output
|
127
128
129
130
|
$metric_val = $item['metrics'][0]['values'];
$dimension_val = $item['dimensions'][0];
|
889ea43e
Alex Savenko
ga output
|
131
132
|
$result['name'] = $project_name;
|
f842989c
Alex Savenko
ga output
|
133
|
if (count($metric_val) > 1) {
|
65b1cb95
Alex Savenko
ga output
|
134
135
|
for ($i = 0; $i < count($metric_val); $i++) {
$result[$dimension_val][] = $metric_val[$i];
|
d29dde0e
Alex Savenko
ga output
|
136
137
138
139
|
}
} else {
$result[$dimension_val] = $metric_val[0];
}
|
9cbda58b
Alex Savenko
ga output
|
140
141
|
}
|
5937dcc7
Alex Savenko
ga output
|
142
|
return $result;
|
05915c96
Alex Savenko
ga output
|
143
|
|
7fe1d3b2
Alex Savenko
create response
|
144
|
}
|
5937dcc7
Alex Savenko
ga output
|
145
|
|
7e1d4fa3
Alex Savenko
ga output
|
146
147
148
|
public static function responseChartTransform(array $response, $project_name) {
$result = [];
|
a7c416d0
Alex Savenko
ga output
|
149
|
|
7e1d4fa3
Alex Savenko
ga output
|
150
151
152
|
foreach ($response as $item) {
$metric_val = $item['metrics'][0]['values'];
|
0482e3d3
Alex Savenko
ga fix
|
153
|
$result['name'] = $project_name.'!';
|
7e1d4fa3
Alex Savenko
ga output
|
154
155
156
|
if (count($metric_val) > 1) {
for ($i = 0; $i < count($metric_val); $i++) {
|
cea9b628
Alex Savenko
ga fix
|
157
|
$result['data'][] = (int)$metric_val[$i];
|
7e1d4fa3
Alex Savenko
ga output
|
158
159
|
}
} else {
|
0482e3d3
Alex Savenko
ga fix
|
160
|
$result['data'][] = (float)$metric_val[0];
|
7e1d4fa3
Alex Savenko
ga output
|
161
162
163
164
165
166
167
|
}
}
return $result;
}
|
5937dcc7
Alex Savenko
ga output
|
168
169
170
171
172
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
|
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
|
206
|
}
|