Bei der Verwendung der Google Analytics-API (PHP-Client-Bibliothek - als Server-zu-Server-Dienst) wird häufig eine leere Ergebnismenge zurückgegeben. Mein Code sieht wie folgt aus:Google Analytics-API gibt manchmal leere Ergebnisse zurück
public function getLeadDetails($view, $gauid, $lead_id,$refresh_token,$dates = [])
{
Log::info("*****************GA Service - GAUID: ".$gauid." **********************************");
$options['dimensions'] = implode(',',config('analytics.dimensions'));
$options['filters'] = "ga:eventAction==".$gauid;
$metrics = "ga:users";
$view = "ga:".$view;
$yesterday = date('Y-m-d',strtotime('yesterday'));
$tomorrow = date("Y-m-d",strtotime('tomorrow'));
if(count($dates)){
$yesterday = $dates['yesterday'];
$tomorrow = $dates['tomorrow'];
}
Log::info('[email protected](), Request Params: ?ids='.$view.'&start-date='.$yesterday.'&end-date='.$tomorrow.'&metrics='.$metrics.'&dimensions='.$options['dimensions'].'&filters='.$options['filters']);
try{
$this->client->setAccessType('offline');
$this->client->setAccessToken($refresh_token);
$this->client->setClientId(config('analytics.client_id'));
$this->client->setScopes([
\Google_Service_Analytics::ANALYTICS,
\Google_Service_Analytics::ANALYTICS_EDIT,
]);
$analytics = new \Google_Service_Analytics($this->client);
$data = $analytics->data_ga->get($view,$yesterday,$tomorrow,$metrics,$options);
if($data['totalResults'] && $data['totalResults'] > 0){
Log::info('Inside [email protected] has totalResults');
$rtn = [];
$i = 0;
foreach ($data['rows'] as $row) {
$rtn['uacid'] = $gauid;
$rtn['user_type'] = $row[0];
$rtn['device_category'] = $row[1];
$rtn['source'] = $row[2];
$rtn['medium'] = $row[3];
$rtn['campaign'] = $row[4];
$rtn['ad_group'] = $row[5];
$rtn['path'] = $row[6];
$i++;
}
Log::info('Inside [email protected] lead '.$lead_id.' should be update');
return $this->insertLeadDetails($rtn , $lead_id);
}
Log::info('GA_Service::getLeadDetails() returned empty results for lead: '.$lead_id);
if(!count($dates)){
$this->throwException('empty results for lead: '.$lead_id.' in GA_Service::getLeadDetails()',275);
return false;
}
return 'empty results for lead: '.$lead_id.' in GA_Service::getLeadDetails()';
}catch (\Google_Service_Exception $e){
Log::info('Google service exception from GA_Service::getLeadDetails() - '. $e->getErrors()[0]['message']);
$this->throwException($e->getErrors()[0]['message'], 335);
}
return false;
}
diese Funktion Feuer wieder alle 5 Minuten, wenn das Ergebnis leer war (5-mal) und immer noch vermisst einige Ergebnisse.
eine Idee warum und wie es zu lösen?
Danke Kumpel, vermisste diesen Teil wahrscheinlich. – benjah