Blame view

app/library/App/Controllers/GaController.php 5.08 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;
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';
b38ef228   Alex Savenko   generate GaResource
26
  
897d06c3   Alex Savenko   generate GaResource
27
28
      public function getAction() {
  
2617218b   Alex Savenko   dynamic view_id
29
          $view_id = $this->request->get('view_id') ?? '119240817';
180e10be   Alex Savenko   dynamic dateRange
30
31
32
          $get_metrics = $this->request->get('metric') ?? 'users';
          $get_start_date = $this->request->get('start') ?? '30daysAgo';
          $get_end_date = $this->request->get('end') ?? 'today';
b22a7c02   Alex Savenko   empty dimension
33
          $get_dimensions = $this->request->get('dimension');
180e10be   Alex Savenko   dynamic dateRange
34
  
d6c4c133   Alex Savenko   ga response
35
  
897d06c3   Alex Savenko   generate GaResource
36
37
38
39
          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
40
41
          $analytics = new Google_Service_AnalyticsReporting($client);
  
29f4a05f   Alex Savenko   multiple metrics
42
43
          // Создание объекта DateRange.
          $dateRange = new Google_Service_AnalyticsReporting_DateRange();
180e10be   Alex Savenko   dynamic dateRange
44
45
          $dateRange->setStartDate($get_start_date);
          $dateRange->setEndDate($get_end_date);
29f4a05f   Alex Savenko   multiple metrics
46
47
48
  
          // Создание объекта Metrics.
          $metrics = [];
180e10be   Alex Savenko   dynamic dateRange
49
          $get_metrics = explode(',', $get_metrics);
29f4a05f   Alex Savenko   multiple metrics
50
51
52
          foreach ($get_metrics as $metric) {
              $metrics_obj = new Google_Service_AnalyticsReporting_Metric();
              $metrics_obj->setExpression('ga:'.$metric);
6d167872   Alex Savenko   alias to one temp...
53
              $metrics_obj->setAlias('ga:'.$metric);
29f4a05f   Alex Savenko   multiple metrics
54
55
              $metrics[] = $metrics_obj;
          }
897d06c3   Alex Savenko   generate GaResource
56
  
f51dd710   Alex Savenko   dimensions +dynam...
57
          //Create the Dimensions object.
b22a7c02   Alex Savenko   empty dimension
58
59
60
61
62
63
64
65
          if (!empty($get_dimensions)) {
              $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...
66
          }
f51dd710   Alex Savenko   dimensions +dynam...
67
  
29f4a05f   Alex Savenko   multiple metrics
68
69
          // Создание объекта ReportRequest.
          $request = new Google_Service_AnalyticsReporting_ReportRequest();
2617218b   Alex Savenko   dynamic view_id
70
          $request->setViewId($view_id);
29f4a05f   Alex Savenko   multiple metrics
71
          $request->setDateRanges($dateRange);
c6d3dfe5   Alex Savenko   registration
72
73
74
          if (!empty($dimensions)) {
              $request->setDimensions(array($dimensions));
          }
c5aa2e2b   Alex Savenko   dimensions +dynam...
75
          $request->setMetrics(array($metrics));
897d06c3   Alex Savenko   generate GaResource
76
  
29f4a05f   Alex Savenko   multiple metrics
77
          $body = new Google_Service_AnalyticsReporting_GetReportsRequest();
c6d3dfe5   Alex Savenko   registration
78
          $body->setReportRequests(array($request));
897d06c3   Alex Savenko   generate GaResource
79
  
c6d3dfe5   Alex Savenko   registration
80
          $response =  $analytics->reports->batchGet($body);
897d06c3   Alex Savenko   generate GaResource
81
  
a6a1fb9f   Alex Savenko   ga output
82
83
          //have to rewrite code below (2 rows)
          $response = $response->toSimpleObject();
a6a1fb9f   Alex Savenko   ga output
84
          $response = $response->reports[0]['data']['rows'];
9b8fbac2   Alex Savenko   ga output
85
  
9cbda58b   Alex Savenko   ga output
86
          $result = [];
a941da22   Alex Savenko   ga output
87
88
          $project = Project::findFirst(['ga_view_id' => $view_id]);
          $result['name'] = $project->name;
9cbda58b   Alex Savenko   ga output
89
  
c04bfb94   Alex Savenko   ga output
90
          foreach ($response as $item) {
d29dde0e   Alex Savenko   ga output
91
92
93
94
  
              $metric_val = $item['metrics'][0]['values'];
              $dimension_val = $item['dimensions'][0];
  
f842989c   Alex Savenko   ga output
95
              if (count($metric_val) > 1) {
65b1cb95   Alex Savenko   ga output
96
97
                  for ($i = 0; $i < count($metric_val); $i++) {
                      $result[$dimension_val][] = $metric_val[$i];
d29dde0e   Alex Savenko   ga output
98
99
100
101
                  }
              } else {
                  $result[$dimension_val] = $metric_val[0];
              }
9cbda58b   Alex Savenko   ga output
102
103
          }
  
17f81e11   Alex Savenko   ga output
104
          return ($result);
05915c96   Alex Savenko   ga output
105
  
7fe1d3b2   Alex Savenko   create response
106
107
      }
  
ff25157e   Alex Savenko   ga response
108
      public function printResults($reports) {
7fe1d3b2   Alex Savenko   create response
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
          $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/>';
                      }
                  }
              }
          }
b38ef228   Alex Savenko   generate GaResource
136
  
7fe1d3b2   Alex Savenko   create response
137
          return $res;
b38ef228   Alex Savenko   generate GaResource
138
139
      }
  
7fe1d3b2   Alex Savenko   create response
140
  
b38ef228   Alex Savenko   generate GaResource
141
  }