"""Hello Analytics Reporting API V4."""
#!/usr/bin/python3
import sys
import codecs
import traceback
import requests
import re
import pandas as pd
import random
import urllib
import dataset
import json
import gspread
import datetime
from gspread_pandas import Spread, Client
from oauth2client.service_account import ServiceAccountCredentials
import os
import threading
from apiclient.discovery import build
from oauth2client.service_account import ServiceAccountCredentials
import dataset

db = dataset.connect('mysql://choozmo:pAssw0rd@db.ptt.cx:3306/hhh?charset=utf8mb4')
db.query('delete from hhh_weekly_report')

table=db['hhh_weekly_report']

SCOPES = ['https://www.googleapis.com/auth/analytics.readonly']
KEY_FILE_LOCATION = 'c:\\keys\\choozmo-ga-beee24b7a4c1.json'
VIEW_ID = '188916214'


def initialize_analyticsreporting():
  """Initializes an Analytics Reporting API V4 service object.

  Returns:
    An authorized Analytics Reporting API V4 service object.
  """
  credentials = ServiceAccountCredentials.from_json_keyfile_name(
      KEY_FILE_LOCATION, SCOPES)

  # Build the service object.
  analytics = build('analyticsreporting', 'v4', credentials=credentials)

  return analytics


def get_report(analytics,body):
  """Queries the Analytics Reporting API V4.

  Args:
    analytics: An authorized Analytics Reporting API V4 service object.
  Returns:
    The Analytics Reporting API V4 response.
  """
  return analytics.reports().batchGet(
      body={
        'reportRequests':body
        # [
        #{
#          'viewId': VIEW_ID,
#          'dateRanges': [{'startDate': '14daysAgo', 'endDate': 'today'}],
#          'dateRanges': [{'startDate': '2021-05-30', 'endDate': '2021-06-05'}],

#          'metrics': [{'expression': 'ga:users'}],
#          'dimensions': [{'name': 'ga:sourceMedium'}]
#          'dimensions': [{'name': 'ga:date'},{'name': 'ga:sourceMedium'}]

#        }]
      }
  ).execute()


def print_response(response):
  """Parses and prints the Analytics Reporting API V4 response.

  Args:
    response: An Analytics Reporting API V4 response.
  """
  result=[]
  for report in response.get('reports', []):
    columnHeader = report.get('columnHeader', {})
    dimensionHeaders = columnHeader.get('dimensions', [])
    metricHeaders = columnHeader.get('metricHeader', {}).get('metricHeaderEntries', [])

    for row in report.get('data', {}).get('rows', []):
      dimensions = row.get('dimensions', [])
      dateRangeValues = row.get('metrics', [])
      ga_dict={}

      for header, dimension in zip(dimensionHeaders, dimensions):
        print(header + ': ', dimension)
        ga_dict[header]=dimension
      
      for i, values in enumerate(dateRangeValues):
        print('Date range:', str(i))
        for metricHeader, value in zip(metricHeaders, values.get('values')):
          ga_dict[metricHeader.get('name')]=value
#          print(metricHeader.get('name') + ':', value)
        result.append(ga_dict)
    return result
#        print(ga_dict)

def main():
  analytics = initialize_analyticsreporting()
#(FB_|facebook|IG_|LINE_|LINEMP_|qsear.ch)

  body=[{ 'viewId': VIEW_ID,
#  'dateRanges': [{'startDate': '2021-05-31', 'endDate': '2021-06-18'}],
  'dateRanges': [{'startDate': '2021-05-31', 'endDate': '2021-06-25'}],

#  'filtersExpression': 'ga:sourceMedium=~(FB_|facebook|IG_|LINE_|LINEMP_|qsear.ch)',
  'filtersExpression': 'ga:sourceMedium=~(FB_|facebook|IG_|LINE_|LINEMP_|qsear.ch)',
  'metrics': [{'expression': 'ga:users'},{'expression': 'ga:newusers'},{'expression': 'ga:sessions'},{'expression': 'ga:pageviews'},{'expression': 'ga:bounceRate'},{'expression': 'ga:pageviewsPerSession'}],
  'dimensions': [{'name': 'ga:date'},{'name': 'ga:isoWeek'}]
  }]

  response = get_report(analytics,body)
  ga_dict=print_response(response)
  for elmt in ga_dict:
      elmt['category']='social'
      table.insert(elmt)

  body=[{ 'viewId': VIEW_ID,
#  'dateRanges': [{'startDate': '2021-05-24', 'endDate': '2021-06-10'}],
#  'dateRanges': [{'startDate': '2021-05-31', 'endDate': '2021-06-18'}],
  'dateRanges': [{'startDate': '2021-05-31', 'endDate': '2021-06-25'}],

#  'filtersExpression': 'ga:sourceMedium=~(FB_|facebook|IG_|LINE_|LINEMP_|qsear.ch)',
  'filtersExpression': 'ga:sourceMedium!~(FB_|facebook|IG_|LINE_|LINEMP_|qsear.ch)',
  'metrics': [{'expression': 'ga:users'},{'expression': 'ga:newusers'},{'expression': 'ga:sessions'},{'expression': 'ga:pageviews'},{'expression': 'ga:bounceRate'},{'expression': 'ga:pageviewsPerSession'}],
  'dimensions': [{'name': 'ga:date'},{'name': 'ga:isoWeek'}]
  }]

  response = get_report(analytics,body)
  ga_dict=print_response(response)
  for elmt in ga_dict:
      elmt['category']='organic'
      table.insert(elmt)


if __name__ == '__main__':
  main()