Skip to content

Commit

Permalink
feat(main.py): Add events endpoint
Browse files Browse the repository at this point in the history
Add initial implementation of events endpoint

Signed-off-by: Denys Fedoryshchenko <[email protected]>
  • Loading branch information
nuclearcat committed Oct 30, 2024
1 parent 7c0b59a commit 40c9bc0
Showing 1 changed file with 50 additions and 1 deletion.
51 changes: 50 additions & 1 deletion api/main.py
Original file line number Diff line number Diff line change
Expand Up @@ -54,6 +54,7 @@
UserUpdate,
UserGroup,
)
import traceback

Check warning on line 57 in api/main.py

View workflow job for this annotation

GitHub Actions / Lint

standard import "import traceback" should be placed before "from fastapi import Depends, FastAPI, HTTPException, status, Request, Form, Header, Query, Body"


@asynccontextmanager
Expand Down Expand Up @@ -166,6 +167,19 @@ async def invalid_id_exception_handler(
)


@app.exception_handler(Exception)
async def server_error(request: Request, error: Exception):
"""
Global exception handler for all exceptions
"""
print(f"Internal server error: {error} \n{traceback.format_exc()}")
return JSONResponse(
status_code=status.HTTP_500_INTERNAL_SERVER_ERROR,
content={"detail": "Internal server error (exception)"},
)



@app.get('/')

Check warning on line 183 in api/main.py

View workflow job for this annotation

GitHub Actions / Lint

too many blank lines (3)
async def root():
"""Root endpoint handler"""
Expand Down Expand Up @@ -498,9 +512,44 @@ def _get_eventhistory(evdict):
return evhist


# TBD: Restrict response by Pydantic model
@app.get('/events')
async def get_events(request: Request):
"""Get all the events if no request parameters have passed.
Format: [{event1}, {event2}, ...] or if recursive is set to true,
then we add to each event the node information.
Get all the matching events otherwise.
Query parameters can be used to filter the events:
- limit: Number of events to return
- from: Start timestamp (unix epoch) to filter events
- kind: Event kind to filter events
- recursive: Retrieve node together with event
This API endpoint is under development and may change in future.
"""
metrics.add('http_requests_total', 1)
query_params = dict(request.query_params)
recursive = query_params.pop('recursive', None)
limit = query_params.pop('limit', None)
kind = query_params.pop('kind', None)
from_ts = query_params.pop('from', None)
if from_ts:
query_params['timestamp'] = {'$gte': int(from_ts)}
if kind:
query_params['data.kind'] = kind
if limit:
query_params['limit'] = int(limit)
print(query_params)
resp = await db.find_by_attributes_nonpaginated(EventHistory, query_params)
print(resp)
if recursive:
for item in resp.items:
node = await db.find_by_id(Node, item['data']['id'])
item['node'] = node

Check warning on line 547 in api/main.py

View workflow job for this annotation

GitHub Actions / Lint

Trailing whitespace

Check warning on line 547 in api/main.py

View workflow job for this annotation

GitHub Actions / Lint

trailing whitespace
return JSONResponse(content=resp.dict())


# -----------------------------------------------------------------------------
# Nodes

def _get_node_event_data(operation, node, is_hierarchy=False):
return {
'op': operation,
Expand Down

0 comments on commit 40c9bc0

Please sign in to comment.