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;
        
        
    }
    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=[
            'transactions'=>"ga:transactions",
            'transactionRevenue'=>"ga:transactionRevenue",
            'itemQuantity'=>"ga:itemQuantity",
            'adClicks'=>"ga:adClicks",//点击次数
            'adCost'=>"ga:adCost",//成本
            'CPC'=>"ga:CPC",//每次点击费用
            '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;
    }
    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:year',
                    'week'=>'ga:week',
                ];
            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;
    }
   
    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;
      }
    
}