-
-
Notifications
You must be signed in to change notification settings - Fork 2
Expand file tree
/
Copy pathmain.py
More file actions
75 lines (59 loc) · 2.16 KB
/
main.py
File metadata and controls
75 lines (59 loc) · 2.16 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
from datetime import datetime, timedelta, timezone
from app import models
from app.database import get_session, init_db
from fastapi import Depends, FastAPI, HTTPException
from sqlmodel import Session, desc
from timescaledb import list_hypertables
from timescaledb.queries import time_bucket_gapfill_query
app = FastAPI(title="FastAPI SQLModel Demo")
@app.on_event("startup")
def on_startup():
init_db()
@app.get("/")
def root(session: Session = Depends(get_session)):
hypertables = list_hypertables(session)
return {
"message": "Hello World",
"hypertables": [hypertable.model_dump() for hypertable in hypertables],
}
@app.post("/metrics/", response_model=models.MetricRead)
def create_metric(metric: models.MetricCreate, session: Session = Depends(get_session)):
db_metric = models.Metric.from_orm(metric)
session.add(db_metric)
session.commit()
session.refresh(db_metric)
return db_metric
@app.get("/metrics/{metric_id}", response_model=models.MetricRead)
def read_metric(metric_id: int, session: Session = Depends(get_session)):
metric = session.get(models.Metric, metric_id)
if not metric:
raise HTTPException(status_code=404, message="Metric not found")
return metric
@app.get("/metrics/", response_model=list[models.MetricRead])
def list_metrics(session: Session = Depends(get_session)):
metrics = session.query(models.Metric).all()
return metrics
@app.get("/metrics/buckets/", response_model=list[dict])
def get_metric_buckets(
interval: str = "1 hour", session: Session = Depends(get_session)
):
"""Get metrics aggregated into time buckets"""
latest_metric = (
session.query(models.Metric).order_by(desc(models.Metric.time)).first()
)
if not latest_metric:
return []
end_time = datetime.now(timezone.utc)
start_time = end_time - timedelta(hours=24)
raw_results = time_bucket_gapfill_query(
session=session,
model=models.Metric,
time_field="time",
metric_field="temp",
interval=interval,
use_interpolate=True,
use_locf=False,
start=start_time,
finish=end_time,
)
return raw_results