Commit 0c1a07f0d6b1b3303f59d01921df46e45887b649
1 parent
365177f8
add filter param to Ga Collections
Showing
2 changed files
with
20 additions
and
15 deletions
Show diff stats
app/library/App/Controllers/GaController.php
... | ... | @@ -28,15 +28,16 @@ class GaController extends CrudResourceController { |
28 | 28 | public function getAction() { |
29 | 29 | |
30 | 30 | /** user params **/ |
31 | - $user_id = $this->request->get('user_id')?? '1'; | |
32 | - $view_id= $this->request->get('view_id'); | |
33 | - $chart = $this->request->get('chart') ?? false; | |
31 | + $user_id = $this->request->get('user_id')?? '1'; | |
32 | + $view_id = $this->request->get('view_id'); | |
33 | + $chart = $this->request->get('chart') ?? false; | |
34 | 34 | |
35 | 35 | /** google params **/ |
36 | - $get_metrics = $this->request->get('metric') ?? 'users'; | |
37 | - $get_dimensions = $this->request->get('dimension'); | |
38 | - $get_start_date = $this->request->get('start') ?? '30daysAgo'; | |
39 | - $get_end_date = $this->request->get('end') ?? 'today'; | |
36 | + $get_metrics = $this->request->get('metric') ?? 'users'; | |
37 | + $get_dimensions = $this->request->get('dimension'); | |
38 | + $get_start_date = $this->request->get('start') ?? '30daysAgo'; | |
39 | + $get_end_date = $this->request->get('end') ?? 'today'; | |
40 | + $filter_expression = $this->request->get('filter'); | |
40 | 41 | |
41 | 42 | |
42 | 43 | if (empty($view_id)) { |
... | ... | @@ -45,19 +46,19 @@ class GaController extends CrudResourceController { |
45 | 46 | foreach ($projects as $project) { |
46 | 47 | $view_id = (string)$project->ga_view_id; |
47 | 48 | if (!empty($view_id)) { |
48 | - $result[] = $this->sendGaRequest($project->name, $view_id, $get_metrics, $get_dimensions, $get_start_date, $get_end_date, $chart); | |
49 | + $result[] = $this->sendGaRequest($project->name, $view_id, $get_metrics, $get_dimensions, $get_start_date, $get_end_date, $chart, $filter_expression); | |
49 | 50 | } |
50 | 51 | } |
51 | 52 | } |
52 | 53 | else { |
53 | 54 | $project = Project::findFirst(['ga_view_id' => $view_id]); |
54 | - $result = $this->sendGaRequest($project->name , $view_id, $get_metrics, $get_dimensions, $get_start_date, $get_end_date, $chart); | |
55 | + $result = $this->sendGaRequest($project->name , $view_id, $get_metrics, $get_dimensions, $get_start_date, $get_end_date, $chart, $filter_expression); | |
55 | 56 | } |
56 | 57 | return $result; |
57 | 58 | |
58 | 59 | } |
59 | 60 | |
60 | - public function sendGaRequest($project_name, $view, $get_metrics, $get_dimensions, $start, $end, $chart = false) { | |
61 | + public function sendGaRequest($project_name, $view, $get_metrics, $get_dimensions, $start, $end, $chart = false, $filter_expression = null) { | |
61 | 62 | |
62 | 63 | putenv('GOOGLE_APPLICATION_CREDENTIALS=/var/www/phalcon/'.self::SECRET_JSON); |
63 | 64 | $client = new Google_Client(); |
... | ... | @@ -100,6 +101,9 @@ class GaController extends CrudResourceController { |
100 | 101 | $request->setDimensions(array($dimensions)); |
101 | 102 | } |
102 | 103 | $request->setMetrics(array($metrics)); |
104 | + if (!empty($filter_expression)) { | |
105 | + $request->setFiltersExpression("ga:".$filter_expression); | |
106 | + } | |
103 | 107 | |
104 | 108 | $body = new Google_Service_AnalyticsReporting_GetReportsRequest(); |
105 | 109 | $body->setReportRequests(array($request)); | ... | ... |
app/library/App/Resources/GaResource.php
... | ... | @@ -43,18 +43,19 @@ class GaResource extends ApiResource { |
43 | 43 | ->paramsDescription([ |
44 | 44 | 'get params' => [ |
45 | 45 | 'required params' => [ |
46 | - 'metric' => 'string(метрика Google, линк в описании запроса)', | |
46 | + 'metric' => 'string(метрика Google, линк в описании запроса)', | |
47 | 47 | 'dimension' => 'string(размерность Google, линк в описании запроса)', |
48 | - 'start' => 'ГГГГ-ММ-ДД/NdaysAgo, где N – целое положительное число(дата начала загрузки данных)', | |
49 | - 'end' => 'ГГГГ-ММ-ДД/NdaysAgo, где N – целое положительное число(дата конца загрузки данных)' | |
48 | + 'start' => 'ГГГГ-ММ-ДД/NdaysAgo, где N – целое положительное число(дата начала загрузки данных)', | |
49 | + 'end' => 'ГГГГ-ММ-ДД/NdaysAgo, где N – целое положительное число(дата конца загрузки данных)' | |
50 | 50 | ], |
51 | 51 | 'optional params' => [ |
52 | 52 | 'user_id' => 'integer(id пользователя в системе)', |
53 | 53 | 'view_id' => 'integer(id представления проэкта с гугл аналитики)', |
54 | - 'chart' => 'boolean(Задает структуру возвращаемых данных(true для графиков))', | |
54 | + 'chart' => 'boolean(Задает структуру возвращаемых данных(true для графиков))', | |
55 | + 'filter' => 'expression(https://developers.google.com/analytics/devguides/reporting/core/v3/reference#filters)', | |
55 | 56 | ] |
56 | 57 | ], |
57 | - 'summary' => 'http://test-30.artweb.com.ua/ga?view_id=119240817&metric=users,sessions&dimension=source,browser' | |
58 | + 'summary' => '/ga?view_id=119240817&metric=users,sessions&dimension=source,browser&filter=browser=~^Firef' | |
58 | 59 | ]) |
59 | 60 | ) |
60 | 61 | ; | ... | ... |