setApplicationName("Hello Analytics Reporting");
$client->setAuthConfig($KEY_FILE_LOCATION);
$client->setScopes(['https://www.googleapis.com/auth/analytics.readonly']);
$analytics = new \Google_Service_AnalyticsReporting($client);
return $analytics;
}
public static function getInstance($dp){
if(isset(self::$insances[$dp])){
return self::$insances[$dp];
}else{
self::$insances[$dp]=self::initializeAnalytics($dp);
return self::$insances[$dp];
}
}
private function getViewId($dp){
$VIEW_ID="";
switch($dp){
case "1"://supernovahair
$VIEW_ID="155703065";
break;
case "2"://asteriahair
$VIEW_ID="162723112";
break;
case "3"://alipearlhair
$VIEW_ID="148377136";
break;
case "4"://alipearlhair
$VIEW_ID="152302477";
break;
case "5"://yolissahair
$VIEW_ID="157127813";
break;
case "6"://wiggins
$VIEW_ID="154631720";
break;
}
return $VIEW_ID;
}
public static function getPath($dp){
$path="";
switch($dp){
case "1"://supernovahair
$path=self::SUPERNOVA_KEY_PATH;
break;
case "2"://asteriahair
$path=self::ASTERIA_KEY_PATH;
break;
case "3"://alipearlhair
$path=self::ALIPEARL_KEY_PATH;
break;
case "4"://westkiss
$path=self::WESTKISS_KEY_PATH;
break;
case "5"://yolissahair
$path=self::YOLISSA_KEY_PATH;
break;
case "6"://alipearlhair
$path=self::WIGGINS_KEY_PATH;
break;
}
return $path;
}
/*进一步封装
*$config=[
'dp'=>'',
'metricArr'=[],
'dimensionArr'=[],
'date'=[start_at,end_at]
'SegmentDimensionFilters'=>[[name,operate,expression,not=]]
'oderBy'=>[name,order]
]
*
*
*
*/
public function getData($config){
$dp=$config['dp']??"";
$date=$config['date'];
if(!$dp||!$date||empty($config['metricArr'])){
return false;
}
$metricArr=$config['metricArr'];
$dimensionArr=$config['dimensionArr']??[];
$analytics=self::getInstance($dp);
$VIEW_ID = $this->getViewId($dp);//
$request = new \Google_Service_AnalyticsReporting_ReportRequest();
$request->setViewId($VIEW_ID);
$metrics=[];
$dimensions=[];
foreach($metricArr as $k=>$v){
$Metric = new \Google_Service_AnalyticsReporting_Metric();
$Metric->setExpression($v);
$Metric->setAlias($k);
array_push($metrics,$Metric);
}
foreach($dimensionArr as $k=>$v){
$Dimension = new \Google_Service_AnalyticsReporting_Dimension();
$Dimension->setName($v);
array_push($dimensions,$Dimension);
}
$dateRange = new \Google_Service_AnalyticsReporting_DateRange();
$dateRange->setStartDate($date['start_at']);
$dateRange->setEndDate($date['end_at']);
$request->setDateRanges($dateRange);
$segment=[];
if(isset($config['SegmentDimensionFilters'])&&!empty($config['SegmentDimensionFilters'])){
$segmentDimensions = new \Google_Service_AnalyticsReporting_Dimension();
$segmentDimensions->setName("ga:segment");
array_push($dimensions,$segmentDimensions);
foreach($config['SegmentDimensionFilters'] as $filter){
$segment[]=$this->setSegmentDimensionFilter($filter);
}
}
if(isset($config['SegmentMetricFilters'])&&!empty($config['SegmentMetricFilters'])){
foreach($config['SegmentMetricFilters'] as $filter){
$segment[]=$this->setSegmentMetricFilters($filter);
}
}
$request->setMetrics($metrics);
$request->setDimensions($dimensions);
if(!empty($segment)){
$request->setSegments($segment);
}
if(isset($config['orderBy'])&&!empty($config['orderBy'])){
$orderBy=new \Google_Service_AnalyticsReporting_OrderBy();
$orderBy->setFieldName($config['orderBy']['name']);
$orderBy->setSortOrder($config['orderBy']['order']);
$request->setOrderBys($orderBy);
}
$body = new \Google_Service_AnalyticsReporting_GetReportsRequest();
$body->setReportRequests( array( $request) );
$reports= $analytics->reports->batchGet( $body );
$result=$this->getResults($reports);
return $result;
}
private function setSegmentDimensionFilter($param){
$dimensionFilter = new \Google_Service_AnalyticsReporting_SegmentDimensionFilter();
$dimensionFilter->setDimensionName($param['name']);
$dimensionFilter->setOperator($param['operate']);
$dimensionFilter->setExpressions($param['expression']);
// Create Segment Filter Clause.
$segmentFilterClause = new \Google_Service_AnalyticsReporting_SegmentFilterClause();
$segmentFilterClause->setDimensionFilter($dimensionFilter);
// Create the Or Filters for Segment.
$orFiltersForSegment = new \Google_Service_AnalyticsReporting_OrFiltersForSegment();
$orFiltersForSegment->setSegmentFilterClauses(array($segmentFilterClause));
// Create the Simple Segment.
$simpleSegment = new \Google_Service_AnalyticsReporting_SimpleSegment();
$simpleSegment->setOrFiltersForSegment(array($orFiltersForSegment));
// Create the Segment Filters.
$segmentFilter = new \Google_Service_AnalyticsReporting_SegmentFilter();
$segmentFilter->setSimpleSegment($simpleSegment);
if($param['not']){
$segmentFilter->setNot(True);
}
// Create the Segment Definition.
$segmentDefinition = new \Google_Service_AnalyticsReporting_SegmentDefinition();
$segmentDefinition->setSegmentFilters(array($segmentFilter));
$dynamicSegment = new \Google_Service_AnalyticsReporting_DynamicSegment();
$dynamicSegment->setSessionSegment($segmentDefinition);
$dynamicSegment->setName($param['name']);
$segment = new \Google_Service_AnalyticsReporting_Segment();
$segment->setDynamicSegment($dynamicSegment);
return $segment;
}
private function setSegmentMetricFilters($param){
$metricFilter = new \Google_Service_AnalyticsReporting_SegmentMetricFilter();
$metricFilter->setMetricName($param['name']);
$metricFilter->setOperator($param['operate']);
$metricFilter->setComparisonValue($param['value']);
// Create Segment Filter Clause.
$segmentFilterClause = new \Google_Service_AnalyticsReporting_SegmentFilterClause();
$segmentFilterClause->setMetricFilter($metricFilter);
// Create the Or Filters for Segment.
$orFiltersForSegment = new \Google_Service_AnalyticsReporting_OrFiltersForSegment();
$orFiltersForSegment->setSegmentFilterClauses(array($segmentFilterClause));
// Create the Simple Segment.
$simpleSegment = new \Google_Service_AnalyticsReporting_SimpleSegment();
$simpleSegment->setOrFiltersForSegment(array($orFiltersForSegment));
// Create the Segment Filters.
$segmentFilter = new \Google_Service_AnalyticsReporting_SegmentFilter();
$segmentFilter->setSimpleSegment($simpleSegment);
if($param['not']){
$segmentFilter->setNot(True);
}
// Create the Segment Definition.
$segmentDefinition = new \Google_Service_AnalyticsReporting_SegmentDefinition();
$segmentDefinition->setSegmentFilters(array($segmentFilter));
$dynamicSegment = new \Google_Service_AnalyticsReporting_DynamicSegment();
$dynamicSegment->setSessionSegment($segmentDefinition);
$dynamicSegment->setName($param['name']);
$segment = new \Google_Service_AnalyticsReporting_Segment();
$segment->setDynamicSegment($dynamicSegment);
return $segment;
}
public function contentpages($dp,$start_at,$end_at){
$analytics=self::getInstance($dp);
$metricArr=[
'pageviews'=>"ga:pageviews",
'uniquePageviews'=>"ga:uniquePageviews",
'avgTimeOnPage'=>"ga:avgTimeOnPage",
'entrances'=>"ga:entrances",
'bounceRate'=>"ga:bounceRate",
'exitRate'=>"ga:exitRate",
'pageValue'=>"ga:pageValue",
];
$dimensionArr=[
'pagePath'=>'ga:pagePath',
'date'=>"ga:date",
];
$VIEW_ID = $this->getViewId($dp);//
$dateRange = new \Google_Service_AnalyticsReporting_DateRange();
$dateRange->setStartDate($start_at);
$dateRange->setEndDate($end_at);
$metrics=[];
$dimensions=[];
foreach($metricArr as $k=>$v){
$Metric = new \Google_Service_AnalyticsReporting_Metric();
$Metric->setExpression($v);
$Metric->setAlias($k);
array_push($metrics,$Metric);
}
foreach($dimensionArr as $k=>$v){
$Dimension = new \Google_Service_AnalyticsReporting_Dimension();
$Dimension->setName($v);
array_push($dimensions,$Dimension);
}
$pageviewsFilter = new \Google_Service_AnalyticsReporting_MetricFilter();
$pageviewsFilter->setMetricName("ga:pageviews");
$pageviewsFilter->setOperator("GREATER_THAN");
$pageviewsFilter->setComparisonValue("1");
$MetricFilterClause=new \Google_Service_AnalyticsReporting_MetricFilterClause();
$MetricFilterClause->setFilters(array($pageviewsFilter));
$segmentDimensions = new \Google_Service_AnalyticsReporting_Dimension();
$segmentDimensions->setName("ga:segment");
array_push($dimensions,$segmentDimensions);
// Create Dimension Filter.
$dimensionFilter = new \Google_Service_AnalyticsReporting_SegmentDimensionFilter();
$dimensionFilter->setDimensionName("ga:pagePath");
$dimensionFilter->setOperator("REGEXP");
$dimensionFilter->setExpressions(array("(fbclid|catalogsearch)"));
// Create Segment Filter Clause.
$segmentFilterClause = new \Google_Service_AnalyticsReporting_SegmentFilterClause();
$segmentFilterClause->setDimensionFilter($dimensionFilter);
// Create the Or Filters for Segment.
$orFiltersForSegment = new \Google_Service_AnalyticsReporting_OrFiltersForSegment();
$orFiltersForSegment->setSegmentFilterClauses(array($segmentFilterClause));
// Create the Simple Segment.
$simpleSegment = new \Google_Service_AnalyticsReporting_SimpleSegment();
$simpleSegment->setOrFiltersForSegment(array($orFiltersForSegment));
// Create the Segment Filters.
$segmentFilter = new \Google_Service_AnalyticsReporting_SegmentFilter();
$segmentFilter->setSimpleSegment($simpleSegment);
$segmentFilter->setNot(True);
// Create the Segment Definition.
$segmentDefinition = new \Google_Service_AnalyticsReporting_SegmentDefinition();
$segmentDefinition->setSegmentFilters(array($segmentFilter));
$dynamicSegment = new \Google_Service_AnalyticsReporting_DynamicSegment();
$dynamicSegment->setSessionSegment($segmentDefinition);
$dynamicSegment->setName('pagePath');
$segment = new \Google_Service_AnalyticsReporting_Segment();
$segment->setDynamicSegment($dynamicSegment);
$orderBy=new \Google_Service_AnalyticsReporting_OrderBy();
$orderBy->setFieldName('ga:pageviews');
$orderBy->setSortOrder("DESCENDING");
$request = new \Google_Service_AnalyticsReporting_ReportRequest();
$request->setViewId($VIEW_ID);
$request->setDateRanges($dateRange);
$request->setMetrics($metrics);
$request->setDimensions($dimensions);
$request->setSegments(array($segment));
$request->setOrderBys($orderBy);
$request->setPageSize(5000);
$request->setMetricFilterClauses($MetricFilterClause);
$body = new \Google_Service_AnalyticsReporting_GetReportsRequest();
$body->setReportRequests( array( $request) );
$reports= $analytics->reports->batchGet( $body );
$result=$this->getResults($reports);
return $result;
}
public function trafficsource($dp,$start_at,$end_at){
$analytics=self::getInstance($dp);
$metricArr=[
'users'=>"ga:users",
'newUsers'=>"ga:newUsers",
'sessions'=>"ga:sessions",
'bounceRate'=>"ga:bounceRate",
'pageviewsPerSession'=>"ga:pageviewsPerSession",
'avgSessionDuration'=>"ga:avgSessionDuration",
'transactionsPerVisit'=>"ga:transactionsPerVisit",
'transactions'=>"ga:transactions",
'transactionRevenue'=>"ga:transactionRevenue",
];
$dimensionArr=[
'pagePath'=>'ga:source',
'date'=>"ga:date",
'channelGrouping'=>"ga:channelGrouping",
'landingPagePath'=>"ga:landingPagePath",
'keyword'=>"ga:keyword",
'socialNetwork'=>"ga:socialNetwork",
];
$VIEW_ID = $this->getViewId($dp);//
$dateRange = new \Google_Service_AnalyticsReporting_DateRange();
$dateRange->setStartDate($start_at);
$dateRange->setEndDate($end_at);
$metrics=[];
$dimensions=[];
foreach($metricArr as $k=>$v){
$Metric = new \Google_Service_AnalyticsReporting_Metric();
$Metric->setExpression($v);
$Metric->setAlias($k);
array_push($metrics,$Metric);
}
foreach($dimensionArr as $k=>$v){
$Dimension = new \Google_Service_AnalyticsReporting_Dimension();
$Dimension->setName($v);
array_push($dimensions,$Dimension);
}
$segmentDimensions = new \Google_Service_AnalyticsReporting_Dimension();
$segmentDimensions->setName("ga:segment");
array_push($dimensions,$segmentDimensions);
// Create Dimension Filter.
$dimensionFilter = new \Google_Service_AnalyticsReporting_SegmentDimensionFilter();
$dimensionFilter->setDimensionName("ga:source");
$dimensionFilter->setOperator("REGEXP");
$dimensionFilter->setExpressions(array("(fbclid|catalogsearch)"));
// Create Segment Filter Clause.
$segmentFilterClause = new \Google_Service_AnalyticsReporting_SegmentFilterClause();
$segmentFilterClause->setDimensionFilter($dimensionFilter);
// Create the Or Filters for Segment.
$orFiltersForSegment = new \Google_Service_AnalyticsReporting_OrFiltersForSegment();
$orFiltersForSegment->setSegmentFilterClauses(array($segmentFilterClause));
// Create the Simple Segment.
$simpleSegment = new \Google_Service_AnalyticsReporting_SimpleSegment();
$simpleSegment->setOrFiltersForSegment(array($orFiltersForSegment));
// Create the Segment Filters.
$segmentFilter = new \Google_Service_AnalyticsReporting_SegmentFilter();
$segmentFilter->setSimpleSegment($simpleSegment);
$segmentFilter->setNot(True);
// Create the Segment Definition.
$segmentDefinition = new \Google_Service_AnalyticsReporting_SegmentDefinition();
$segmentDefinition->setSegmentFilters(array($segmentFilter));
$dynamicSegment = new \Google_Service_AnalyticsReporting_DynamicSegment();
$dynamicSegment->setSessionSegment($segmentDefinition);
$dynamicSegment->setName('trafficsources filter');
$segment = new \Google_Service_AnalyticsReporting_Segment();
$segment->setDynamicSegment($dynamicSegment);
$request = new \Google_Service_AnalyticsReporting_ReportRequest();
$request->setViewId($VIEW_ID);
$request->setDateRanges($dateRange);
$request->setMetrics($metrics);
$request->setDimensions($dimensions);
$request->setSegments(array($segment));
$request->setPageSize(5000);
// $request->setOrderBys($orderBy);
// $request->setMetricFilterClauses($MetricFilterClause);
$body = new \Google_Service_AnalyticsReporting_GetReportsRequest();
$body->setReportRequests( array( $request) );
$reports= $analytics->reports->batchGet( $body );
$result=$this->getResults($reports);
return $result;
}
public function visitors_geo($dp,$start_at,$end_at){
$analytics=self::getInstance($dp);
$dimensionArr=[
'country'=>'ga:country',
'region'=>"ga:region",
];
$metricArr=[
'transactions'=>"ga:transactions",
'transactionRevenue'=>"ga:transactionRevenue",
];
$VIEW_ID = $this->getViewId($dp);//
$dateRange = new \Google_Service_AnalyticsReporting_DateRange();
$dateRange->setStartDate($start_at);
$dateRange->setEndDate($end_at);
$metrics=[];
$dimensions=[];
foreach($metricArr as $k=>$v){
$Metric = new \Google_Service_AnalyticsReporting_Metric();
$Metric->setExpression($v);
$Metric->setAlias($k);
array_push($metrics,$Metric);
}
foreach($dimensionArr as $k=>$v){
$Dimension = new \Google_Service_AnalyticsReporting_Dimension();
$Dimension->setName($v);
array_push($dimensions,$Dimension);
}
$orderBy=new \Google_Service_AnalyticsReporting_OrderBy();
$orderBy->setFieldName('ga:transactions');
$orderBy->setSortOrder("DESCENDING");
$request = new \Google_Service_AnalyticsReporting_ReportRequest();
$request->setViewId($VIEW_ID);
$request->setDateRanges($dateRange);
$request->setMetrics($metrics);
$request->setDimensions($dimensions);
$request->setOrderBys($orderBy);
$body = new \Google_Service_AnalyticsReporting_GetReportsRequest();
$body->setReportRequests( array( $request) );
$reports= $analytics->reports->batchGet( $body );
$result=$this->getResults($reports);
return $result;
}
public function product($dp,$start_at,$end_at){
$analytics=self::getInstance($dp);
$dimensionArr=[
'productName'=>'ga:productName',
];
$metricArr=[
'itemRevenue'=>"ga:itemRevenue",
'uniquePurchases'=>"ga:uniquePurchases",
'itemQuantity'=>"ga:itemQuantity",
];
$VIEW_ID = $this->getViewId($dp);//
$dateRange = new \Google_Service_AnalyticsReporting_DateRange();
$dateRange->setStartDate($start_at);
$dateRange->setEndDate($end_at);
$metrics=[];
$dimensions=[];
foreach($metricArr as $k=>$v){
$Metric = new \Google_Service_AnalyticsReporting_Metric();
$Metric->setExpression($v);
$Metric->setAlias($k);
array_push($metrics,$Metric);
}
foreach($dimensionArr as $k=>$v){
$Dimension = new \Google_Service_AnalyticsReporting_Dimension();
$Dimension->setName($v);
array_push($dimensions,$Dimension);
}
$orderBy=new \Google_Service_AnalyticsReporting_OrderBy();
$orderBy->setFieldName('ga:itemQuantity');
$orderBy->setSortOrder("DESCENDING");
$request = new \Google_Service_AnalyticsReporting_ReportRequest();
$request->setViewId($VIEW_ID);
$request->setDateRanges($dateRange);
$request->setMetrics($metrics);
$request->setDimensions($dimensions);
$request->setOrderBys($orderBy);
$body = new \Google_Service_AnalyticsReporting_GetReportsRequest();
$body->setReportRequests( array( $request) );
$reports= $analytics->reports->batchGet( $body );
$result=$this->getResults($reports);
return $result;
}
public function visitors_type($dp,$start_at,$end_at){
$analytics=self::getInstance($dp);
$dimensionArr=[
'userType'=>'ga:userType',
'date'=>'ga:date',
];
$metricArr=[
'users'=>"ga:users",
'newUsers'=>"ga:newUsers",
];
$VIEW_ID = $this->getViewId($dp);//
$dateRange = new \Google_Service_AnalyticsReporting_DateRange();
$dateRange->setStartDate($start_at);
$dateRange->setEndDate($end_at);
$metrics=[];
$dimensions=[];
foreach($metricArr as $k=>$v){
$Metric = new \Google_Service_AnalyticsReporting_Metric();
$Metric->setExpression($v);
$Metric->setAlias($k);
array_push($metrics,$Metric);
}
foreach($dimensionArr as $k=>$v){
$Dimension = new \Google_Service_AnalyticsReporting_Dimension();
$Dimension->setName($v);
array_push($dimensions,$Dimension);
}
// $orderBy=new \Google_Service_AnalyticsReporting_OrderBy();
// $orderBy->setFieldName('ga:itemQuantity');
// $orderBy->setSortOrder("DESCENDING");
$request = new \Google_Service_AnalyticsReporting_ReportRequest();
$request->setViewId($VIEW_ID);
$request->setDateRanges($dateRange);
$request->setMetrics($metrics);
$request->setDimensions($dimensions);
// $request->setOrderBys($orderBy);
$body = new \Google_Service_AnalyticsReporting_GetReportsRequest();
$body->setReportRequests( array( $request) );
$reports= $analytics->reports->batchGet( $body );
$result=$this->getResults($reports);
return $result;
}
public function productInfo($productName,$dp,$start_at,$end_at){
$analytics=self::getInstance($dp);
$dimensionArr=[
'productName'=>'ga:productName',
];
$metricArr=[
'itemRevenue'=>"ga:itemRevenue",
'revenuePerItem'=>"ga:revenuePerItem",
'productRefundAmount'=>"ga:productRefundAmount",
'quantityAddedToCart'=>"ga:quantityAddedToCart",
// 'quantityRemovedFromCart'=>"ga:quantityRemovedFromCart",
'itemQuantity'=>"ga:itemQuantity",
'productListViews'=>"ga:productListViews",
'productDetailViews'=>"ga:productDetailViews",
'productAddsToCart'=>"ga:productAddsToCart",
// 'productRemovesFromCart'=>"ga:productRemovesFromCart",
'productCheckouts'=>"ga:productCheckouts",
'uniquePurchases'=>"ga:uniquePurchases",
];
$VIEW_ID = $this->getViewId($dp);//
$dateRange = new \Google_Service_AnalyticsReporting_DateRange();
$dateRange->setStartDate($start_at);
$dateRange->setEndDate($end_at);
$metrics=[];
$dimensions=[];
foreach($metricArr as $k=>$v){
$Metric = new \Google_Service_AnalyticsReporting_Metric();
$Metric->setExpression($v);
$Metric->setAlias($k);
array_push($metrics,$Metric);
}
foreach($dimensionArr as $k=>$v){
$Dimension = new \Google_Service_AnalyticsReporting_Dimension();
$Dimension->setName($v);
array_push($dimensions,$Dimension);
}
$skuFilter = new \Google_Service_AnalyticsReporting_DimensionFilter();
$skuFilter->setDimensionName("ga:productName");
$skuFilter->setOperator("EXACT");
$skuFilter->setExpressions([$productName]);
$MetricFilterClause=new \Google_Service_AnalyticsReporting_MetricFilterClause();
$MetricFilterClause->setFilters(array($skuFilter));
$request = new \Google_Service_AnalyticsReporting_ReportRequest();
$request->setViewId($VIEW_ID);
$request->setDateRanges($dateRange);
$request->setMetrics($metrics);
$request->setDimensions($dimensions);
$request->setDimensionFilterClauses($MetricFilterClause);
// $request->setOrderBys($orderBy);
$body = new \Google_Service_AnalyticsReporting_GetReportsRequest();
$body->setReportRequests( array( $request) );
$reports= $analytics->reports->batchGet( $body );
$result=$this->getResults($reports);
return $result;
}
public function goals($dp,$metricArr,$start_at,$end_at){
$analytics=self::getInstance($dp);
$dimensionArr=[
// 'date'=>'ga:date',
// 'sessionCount'=>'ga:sessionCount',
];
$VIEW_ID = $this->getViewId($dp);//
$dateRange = new \Google_Service_AnalyticsReporting_DateRange();
$dateRange->setStartDate($start_at);
$dateRange->setEndDate($end_at);
$metrics=[];
$dimensions=[];
foreach($metricArr as $k=>$v){
$Metric = new \Google_Service_AnalyticsReporting_Metric();
$Metric->setExpression($v);
$Metric->setAlias($k);
array_push($metrics,$Metric);
}
foreach($dimensionArr as $k=>$v){
$Dimension = new \Google_Service_AnalyticsReporting_Dimension();
$Dimension->setName($v);
array_push($dimensions,$Dimension);
}
$request = new \Google_Service_AnalyticsReporting_ReportRequest();
$request->setViewId($VIEW_ID);
$request->setDateRanges($dateRange);
$request->setMetrics($metrics);
$request->setDimensions($dimensions);
// $request->setOrderBys($orderBy);
$body = new \Google_Service_AnalyticsReporting_GetReportsRequest();
$body->setReportRequests( array( $request) );
$reports= $analytics->reports->batchGet( $body );
$result=$this->getResults($reports);
return $result;
}
public function regionProduct($region,$dp,$start_at,$end_at){
$analytics=self::getInstance($dp);
$dimensionArr=[
'region'=>'ga:region',
];
$metricArr=[
'itemRevenue'=>"ga:itemRevenue",
'revenuePerItem'=>"ga:revenuePerItem",
'productRefundAmount'=>"ga:productRefundAmount",
'quantityAddedToCart'=>"ga:quantityAddedToCart",
// 'quantityRemovedFromCart'=>"ga:quantityRemovedFromCart",
'itemQuantity'=>"ga:itemQuantity",
'productListViews'=>"ga:productListViews",
'productDetailViews'=>"ga:productDetailViews",
'productAddsToCart'=>"ga:productAddsToCart",
// 'productRemovesFromCart'=>"ga:productRemovesFromCart",
'productCheckouts'=>"ga:productCheckouts",
// 'uniquePurchases'=>"ga:uniquePurchases",
'transactions'=>"ga:transactions",
];
$VIEW_ID = $this->getViewId($dp);//
$dateRange = new \Google_Service_AnalyticsReporting_DateRange();
$dateRange->setStartDate($start_at);
$dateRange->setEndDate($end_at);
$metrics=[];
$dimensions=[];
foreach($metricArr as $k=>$v){
$Metric = new \Google_Service_AnalyticsReporting_Metric();
$Metric->setExpression($v);
$Metric->setAlias($k);
array_push($metrics,$Metric);
}
foreach($dimensionArr as $k=>$v){
$Dimension = new \Google_Service_AnalyticsReporting_Dimension();
$Dimension->setName($v);
array_push($dimensions,$Dimension);
}
$regionFilter = new \Google_Service_AnalyticsReporting_DimensionFilter();
$regionFilter->setDimensionName("ga:region");
$regionFilter->setOperator("EXACT");
$regionFilter->setExpressions([$region]);
$MetricFilterClause=new \Google_Service_AnalyticsReporting_MetricFilterClause();
$MetricFilterClause->setFilters(array($regionFilter));
$request = new \Google_Service_AnalyticsReporting_ReportRequest();
$request->setViewId($VIEW_ID);
$request->setDateRanges($dateRange);
$request->setMetrics($metrics);
$request->setDimensions($dimensions);
$request->setDimensionFilterClauses($MetricFilterClause);
// $request->setOrderBys($orderBy);
$body = new \Google_Service_AnalyticsReporting_GetReportsRequest();
$body->setReportRequests( array( $request) );
$reports= $analytics->reports->batchGet( $body );
$result=$this->getResults($reports);
return $result;
}
public function storeData($dp,$start_at,$end_at){
$analytics=self::getInstance($dp);
$dimensionArr=[
// 'campaign'=>'ga:campaign'
];
$metricArr=[
'销量'=>"ga:itemQuantity",
'订单量'=>"ga:transactions",
'订单金额'=>"ga:transactionRevenue",
'广告点击次数'=>"ga:adClicks",//点击次数
'广告花费'=>"ga:adCost",//成本
'CTR'=>"ga:CTR",//点击率
'ROAS'=>"ga:ROAS",//回报率
];
$VIEW_ID = $this->getViewId($dp);//
$dateRange = new \Google_Service_AnalyticsReporting_DateRange();
$dateRange->setStartDate($start_at);
$dateRange->setEndDate($end_at);
$metrics=[];
$dimensions=[];
foreach($metricArr as $k=>$v){
$Metric = new \Google_Service_AnalyticsReporting_Metric();
$Metric->setExpression($v);
$Metric->setAlias($k);
array_push($metrics,$Metric);
}
foreach($dimensionArr as $k=>$v){
$Dimension = new \Google_Service_AnalyticsReporting_Dimension();
$Dimension->setName($v);
array_push($dimensions,$Dimension);
}
$request = new \Google_Service_AnalyticsReporting_ReportRequest();
$request->setViewId($VIEW_ID);
$request->setDateRanges($dateRange);
$request->setMetrics($metrics);
$request->setDimensions($dimensions);
// $request->setOrderBys($orderBy);
$body = new \Google_Service_AnalyticsReporting_GetReportsRequest();
$body->setReportRequests( array( $request) );
$reports= $analytics->reports->batchGet( $body );
$result=$this->getResults($reports);
return $result[0]??[];
}
public function storeSellData($dp,$start_at,$end_at,$type="day"){
$analytics=self::getInstance($dp);
switch($type){
case "day":
$dimensionArr=[
'date'=>'ga:date',
];
break;
case "hour":
$dimensionArr=[
'date'=>'ga:date',
'hour'=>'ga:hour'
];
break;
case "week":
$dimensionArr=[
'year'=>'ga:isoYear',
'week'=>'ga:isoWeek',
];
break;
case "month":
$dimensionArr=[
'year'=>'ga:year',
'month'=>'ga:month',
];
break;
}
$metricArr=[
'itemQuantity'=>"ga:itemQuantity",
];
$VIEW_ID = $this->getViewId($dp);//
$dateRange = new \Google_Service_AnalyticsReporting_DateRange();
$dateRange->setStartDate($start_at);
$dateRange->setEndDate($end_at);
$metrics=[];
$dimensions=[];
foreach($metricArr as $k=>$v){
$Metric = new \Google_Service_AnalyticsReporting_Metric();
$Metric->setExpression($v);
$Metric->setAlias($k);
array_push($metrics,$Metric);
}
foreach($dimensionArr as $k=>$v){
$Dimension = new \Google_Service_AnalyticsReporting_Dimension();
$Dimension->setName($v);
array_push($dimensions,$Dimension);
}
$request = new \Google_Service_AnalyticsReporting_ReportRequest();
$request->setViewId($VIEW_ID);
$request->setDateRanges($dateRange);
$request->setMetrics($metrics);
$request->setDimensions($dimensions);
// $request->setOrderBys($orderBy);
$body = new \Google_Service_AnalyticsReporting_GetReportsRequest();
$body->setReportRequests( array( $request) );
$reports= $analytics->reports->batchGet( $body );
$result=$this->getResults($reports);
return $result;
}
public function trafficsource_overview($dp,$start_at,$end_at){
$analytics=self::getInstance($dp);
$dimensionArr=[
'channelGrouping'=>'ga:channelGrouping',
];
$metricArr=[
'users'=>"ga:users",
'newUsers'=>"ga:newUsers",
'sessions'=>"ga:sessions",
'bounceRate'=>"ga:bounceRate",
'transactionsPerSession'=>"ga:transactionsPerSession",
'transactionRevenue'=>"ga:transactionRevenue",
'transactions'=>"ga:transactions",
];
$VIEW_ID = $this->getViewId($dp);//
$dateRange = new \Google_Service_AnalyticsReporting_DateRange();
$dateRange->setStartDate($start_at);
$dateRange->setEndDate($end_at);
$metrics=[];
$dimensions=[];
foreach($metricArr as $k=>$v){
$Metric = new \Google_Service_AnalyticsReporting_Metric();
$Metric->setExpression($v);
$Metric->setAlias($k);
array_push($metrics,$Metric);
}
foreach($dimensionArr as $k=>$v){
$Dimension = new \Google_Service_AnalyticsReporting_Dimension();
$Dimension->setName($v);
array_push($dimensions,$Dimension);
}
$request = new \Google_Service_AnalyticsReporting_ReportRequest();
$request->setViewId($VIEW_ID);
$request->setDateRanges($dateRange);
$request->setMetrics($metrics);
$request->setDimensions($dimensions);
// $request->setOrderBys($orderBy);
$body = new \Google_Service_AnalyticsReporting_GetReportsRequest();
$body->setReportRequests( array( $request) );
$reports= $analytics->reports->batchGet( $body );
$result=$this->getResults($reports);
return $result;
}
public function googleAds(){
$analytics=self::getInstance($dp);
$dimensionArr=[
'adwordsCampaignID'=>'ga:adwordsCampaignID',
];
$metricArr=[
'adClicks'=>"ga:adClicks",
'adCost'=>"ga:adCost",
'CPC'=>"ga:CPC",
'users'=>"ga:users",
'sessions'=>"ga:sessions",
'bounceRate'=>"ga:bounceRate",
'transactionsPerSession'=>"ga:transactionsPerSession",
'transactionRevenue'=>"ga:transactionRevenue",
'transactions'=>"ga:transactions",
];
$VIEW_ID = $this->getViewId($dp);//
$dateRange = new \Google_Service_AnalyticsReporting_DateRange();
$dateRange->setStartDate($start_at);
$dateRange->setEndDate($end_at);
$metrics=[];
$dimensions=[];
foreach($metricArr as $k=>$v){
$Metric = new \Google_Service_AnalyticsReporting_Metric();
$Metric->setExpression($v);
$Metric->setAlias($k);
array_push($metrics,$Metric);
}
foreach($dimensionArr as $k=>$v){
$Dimension = new \Google_Service_AnalyticsReporting_Dimension();
$Dimension->setName($v);
array_push($dimensions,$Dimension);
}
$request = new \Google_Service_AnalyticsReporting_ReportRequest();
$request->setViewId($VIEW_ID);
$request->setDateRanges($dateRange);
$request->setMetrics($metrics);
$request->setDimensions($dimensions);
// $request->setOrderBys($orderBy);
$body = new \Google_Service_AnalyticsReporting_GetReportsRequest();
$body->setReportRequests( array( $request) );
$reports= $analytics->reports->batchGet( $body );
$result=$this->getResults($reports);
return $result;
}
function getResults($reports) {
$data=[];
for ( $reportIndex = 0; $reportIndex < count( $reports ); $reportIndex++ ) {
$item=[];
$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();
if($dimensionHeaders&&$dimensions){
for ($i = 0; $i < count($dimensionHeaders) && $i < count($dimensions); $i++) {
$header = $dimensionHeaders[$i];
$header=str_replace('ga:','',$header);
$item[$header]=$dimensions[$i];
// print($dimensionHeaders[$i] . ": " . $dimensions[$i] . "\n\r");
// echo"
";
}
// $date=$dimensions[0];
// $date=date('Y-m-d',strtotime($date));
}
if($metricHeaders&&$metrics){
for ($j = 0; $j < count($metrics); $j++) {
$values = $metrics[$j]->getValues();
for ($k = 0; $k < count($values); $k++) {
$entry = $metricHeaders[$k];
$item[$entry->getName()]=$values[$k];
// print($entry->getName() . ": " . $values[$k] . "\n\r");
// echo"
";
}
}
}
$data[]=$item;
}
}
return $data;
}
}