Blame view

app/library/App/Controllers/GaController.php 6.84 KB
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;
9ba864b0   Alex Savenko   ga output
13
  use App\Model\User;
897d06c3   Alex Savenko   generate GaResource
14
15
16
  use Google_Client;
  use Google_Service_AnalyticsReporting;
  use Google_Service_AnalyticsReporting_DateRange;
f51dd710   Alex Savenko   dimensions +dynam...
17
  use Google_Service_AnalyticsReporting_Dimension;
897d06c3   Alex Savenko   generate GaResource
18
19
20
  use Google_Service_AnalyticsReporting_GetReportsRequest;
  use Google_Service_AnalyticsReporting_Metric;
  use Google_Service_AnalyticsReporting_ReportRequest;
b38ef228   Alex Savenko   generate GaResource
21
  use PhalconRest\Mvc\Controllers\CrudResourceController;
b38ef228   Alex Savenko   generate GaResource
22
23
24
  
  class GaController extends CrudResourceController {
  
897d06c3   Alex Savenko   generate GaResource
25
26
      const SECRET_JSON = 'ca4a1bd8aa14.json';
      const VIEW_ID = '119240817';
b38ef228   Alex Savenko   generate GaResource
27
  
897d06c3   Alex Savenko   generate GaResource
28
29
      public function getAction() {
  
95c83ce2   Alex Savenko   ga output
30
31
32
          $user_id = $this->request->get('user_id')?? '1';
          //$view_id= $this->request->get('view_id') ?? '119240817';
          $view_id= $this->request->get('view_id');
180e10be   Alex Savenko   dynamic dateRange
33
          $get_metrics = $this->request->get('metric') ?? 'users';
129bec7c   Alex Savenko   ga output
34
          $get_dimensions = $this->request->get('dimension');
180e10be   Alex Savenko   dynamic dateRange
35
36
          $get_start_date = $this->request->get('start') ?? '30daysAgo';
          $get_end_date = $this->request->get('end') ?? 'today';
5937dcc7   Alex Savenko   ga output
37
          $chart = $this->request->get('chart') ?? false;
180e10be   Alex Savenko   dynamic dateRange
38
  
95c83ce2   Alex Savenko   ga output
39
          if (empty($view_id)) {
2cda8b9d   Alex Savenko   ga output
40
              $result = [];
de9cf95a   Alex Savenko   ga output
41
              $projects = Project::find(['user_id' => $user_id]);
9ba864b0   Alex Savenko   ga output
42
              foreach ($projects as $project) {
9791b548   Alex Savenko   ga output
43
                  $view_id = (string)$project->ga_view_id;
d1032ef0   Alex Savenko   ga output
44
                  die($view_id);
7e1d4fa3   Alex Savenko   ga output
45
                  $result[] = $this->sendGaRequest($project->name, $view_id, $get_metrics, $get_dimensions, $get_start_date, $get_end_date, $chart);
9ba864b0   Alex Savenko   ga output
46
47
48
              }
          }
          else {
c0f7b2aa   Alex Savenko   ga output
49
              $project = Project::findFirst(['ga_view_id' => $view_id]);
7e1d4fa3   Alex Savenko   ga output
50
              $result = $this->sendGaRequest($project->name , $view_id, $get_metrics, $get_dimensions, $get_start_date, $get_end_date, $chart);
9ba864b0   Alex Savenko   ga output
51
52
          }
          return $result;
129bec7c   Alex Savenko   ga output
53
54
55
  
      }
  
7e1d4fa3   Alex Savenko   ga output
56
      public function sendGaRequest($project_name, $view, $get_metrics, $get_dimensions, $start, $end, $chart = false) {
129bec7c   Alex Savenko   ga output
57
  
897d06c3   Alex Savenko   generate GaResource
58
59
60
61
          putenv('GOOGLE_APPLICATION_CREDENTIALS=/var/www/phalcon/'.self::SECRET_JSON);
          $client = new Google_Client();
          $client->useApplicationDefaultCredentials();
          $client->setScopes(['https://www.googleapis.com/auth/analytics.readonly']);
897d06c3   Alex Savenko   generate GaResource
62
63
          $analytics = new Google_Service_AnalyticsReporting($client);
  
29f4a05f   Alex Savenko   multiple metrics
64
65
          // Создание объекта DateRange.
          $dateRange = new Google_Service_AnalyticsReporting_DateRange();
129bec7c   Alex Savenko   ga output
66
67
          $dateRange->setStartDate($start);
          $dateRange->setEndDate($end);
29f4a05f   Alex Savenko   multiple metrics
68
69
70
  
          // Создание объекта Metrics.
          $metrics = [];
180e10be   Alex Savenko   dynamic dateRange
71
          $get_metrics = explode(',', $get_metrics);
29f4a05f   Alex Savenko   multiple metrics
72
73
74
          foreach ($get_metrics as $metric) {
              $metrics_obj = new Google_Service_AnalyticsReporting_Metric();
              $metrics_obj->setExpression('ga:'.$metric);
6d167872   Alex Savenko   alias to one temp...
75
              $metrics_obj->setAlias('ga:'.$metric);
29f4a05f   Alex Savenko   multiple metrics
76
77
              $metrics[] = $metrics_obj;
          }
897d06c3   Alex Savenko   generate GaResource
78
  
f51dd710   Alex Savenko   dimensions +dynam...
79
          //Create the Dimensions object.
584f7b1c   Alex Savenko   ga output
80
          if (!empty($get_dimensions)) {
b22a7c02   Alex Savenko   empty dimension
81
82
83
84
85
86
87
              $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...
88
          }
f51dd710   Alex Savenko   dimensions +dynam...
89
  
29f4a05f   Alex Savenko   multiple metrics
90
91
          // Создание объекта ReportRequest.
          $request = new Google_Service_AnalyticsReporting_ReportRequest();
129bec7c   Alex Savenko   ga output
92
          $request->setViewId($view);
29f4a05f   Alex Savenko   multiple metrics
93
          $request->setDateRanges($dateRange);
c6d3dfe5   Alex Savenko   registration
94
95
96
          if (!empty($dimensions)) {
              $request->setDimensions(array($dimensions));
          }
c5aa2e2b   Alex Savenko   dimensions +dynam...
97
          $request->setMetrics(array($metrics));
897d06c3   Alex Savenko   generate GaResource
98
  
29f4a05f   Alex Savenko   multiple metrics
99
          $body = new Google_Service_AnalyticsReporting_GetReportsRequest();
c6d3dfe5   Alex Savenko   registration
100
          $body->setReportRequests(array($request));
897d06c3   Alex Savenko   generate GaResource
101
  
c6d3dfe5   Alex Savenko   registration
102
          $response =  $analytics->reports->batchGet($body);
897d06c3   Alex Savenko   generate GaResource
103
  
a6a1fb9f   Alex Savenko   ga output
104
105
          //have to rewrite code below (2 rows)
          $response = $response->toSimpleObject();
a6a1fb9f   Alex Savenko   ga output
106
          $response = $response->reports[0]['data']['rows'];
9b8fbac2   Alex Savenko   ga output
107
  
7e1d4fa3   Alex Savenko   ga output
108
109
110
111
112
          if ($chart) {
              $result = self::responseChartTransform($response, $project_name);
          } else {
              $result = self::responseDataTransform($response, $project_name);
          }
5937dcc7   Alex Savenko   ga output
113
114
115
116
117
  
          return ($result);
  
      }
  
7e1d4fa3   Alex Savenko   ga output
118
      public static function responseDataTransform(array $response, $project_name) {
5937dcc7   Alex Savenko   ga output
119
  
9cbda58b   Alex Savenko   ga output
120
          $result = [];
9cbda58b   Alex Savenko   ga output
121
  
c04bfb94   Alex Savenko   ga output
122
          foreach ($response as $item) {
d29dde0e   Alex Savenko   ga output
123
124
125
126
  
              $metric_val = $item['metrics'][0]['values'];
              $dimension_val = $item['dimensions'][0];
  
889ea43e   Alex Savenko   ga output
127
128
              $result['name'] = $project_name;
  
f842989c   Alex Savenko   ga output
129
              if (count($metric_val) > 1) {
65b1cb95   Alex Savenko   ga output
130
131
                  for ($i = 0; $i < count($metric_val); $i++) {
                      $result[$dimension_val][] = $metric_val[$i];
d29dde0e   Alex Savenko   ga output
132
133
134
135
                  }
              } else {
                  $result[$dimension_val] = $metric_val[0];
              }
9cbda58b   Alex Savenko   ga output
136
137
          }
  
5937dcc7   Alex Savenko   ga output
138
          return $result;
05915c96   Alex Savenko   ga output
139
  
7fe1d3b2   Alex Savenko   create response
140
      }
5937dcc7   Alex Savenko   ga output
141
  
7e1d4fa3   Alex Savenko   ga output
142
143
144
      public static function responseChartTransform(array $response, $project_name) {
  
          $result = [];
a7c416d0   Alex Savenko   ga output
145
  
7e1d4fa3   Alex Savenko   ga output
146
147
148
149
150
151
152
153
154
155
          foreach ($response as $item) {
  
              $metric_val = $item['metrics'][0]['values'];
              $result['name'] = $project_name;
  
              if (count($metric_val) > 1) {
                  for ($i = 0; $i < count($metric_val); $i++) {
                      $result['data'][] = $metric_val[$i];
                  }
              } else {
f98d60e3   Alex Savenko   ga output
156
                  $result['data'][] = $metric_val[0];
7e1d4fa3   Alex Savenko   ga output
157
158
159
160
161
162
163
              }
          }
  
          return $result;
  
      }
  
5937dcc7   Alex Savenko   ga output
164
165
166
167
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
  
  
  
  
  
  
      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
202
  }