import requests
import pandas as pd
import json
from datetime import datetime as dt
from dateutil.relativedelta import relativedelta

API_URL = "https://api.weather.com/v1/location/KTEB:9:US/observations/historical.json?apiKey=e1f10a1e78da46f5b10a1e78da96f525&units=e"

SRC_FORMAT = "%Y.%m.%d"
TGT_FORMAT = "%Y%m%d"

START_DATE = dt.strptime("2020.01.01", SRC_FORMAT)
END_DATE = dt.strptime("2025.08.01", SRC_FORMAT)


def make_request(start_date: dt, end_date: dt) -> dict:
    start_date = start_date.strftime(TGT_FORMAT)
    end_date = end_date.strftime(TGT_FORMAT)

    url = API_URL + f"&startDate={start_date}&endDate={end_date}"

    response = requests.get(url)
    response.raise_for_status()

    data = json.loads(response.text)

    return data


def download(start_date: dt, end_date: dt) -> pd.DataFrame:
    all_observations = []

    n_months = (
        relativedelta(end_date, start_date).years * 12
        + relativedelta(end_date, start_date).months
    )
    for month in range(n_months):
        cur_start = start_date + relativedelta(months=month)
        cur_end = start_date + relativedelta(months=month + 1) - relativedelta(days=1)
        cur_end = min(cur_end, end_date)

        data = make_request(cur_start, cur_end)
        all_observations.extend(data["observations"])

    df = pd.DataFrame.from_records(all_observations)
    return df


def preprocess(data: pd.DataFrame) -> pd.DataFrame:
    grouped = data.groupby(["date"])
    formatted = pd.DataFrame()
    formatted["precip_avg"] = grouped["precip_hrly"].mean()

    return formatted


def app():
    data = download(START_DATE, END_DATE)
    # data = pd.read_csv('test.csv')
    # data = preprocess(data)

    data.to_csv("formatted.csv")


if __name__ == "__main__":
    app()
