Spaces:
Running
on
CPU Upgrade
Running
on
CPU Upgrade
test
Browse files
main.py
CHANGED
|
@@ -2,6 +2,11 @@ from fastapi import FastAPI, Request, Response
|
|
| 2 |
import os
|
| 3 |
import requests
|
| 4 |
import json
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 5 |
|
| 6 |
HF_WEBHOOK_SECRET = os.environ.get("HF_WEBHOOK_SECRET")
|
| 7 |
SLACK_WEBHOOK_URL = os.environ.get("SLACK_WEBHOOK_URL")
|
|
@@ -9,30 +14,41 @@ SLACK_WEBHOOK_URL = os.environ.get("SLACK_WEBHOOK_URL")
|
|
| 9 |
def send_slack_message(message: str):
|
| 10 |
"""Send a message to Slack using webhook URL"""
|
| 11 |
if not SLACK_WEBHOOK_URL:
|
| 12 |
-
|
| 13 |
return
|
| 14 |
|
| 15 |
payload = {"text": message}
|
| 16 |
try:
|
| 17 |
response = requests.post(SLACK_WEBHOOK_URL, json=payload)
|
| 18 |
response.raise_for_status()
|
| 19 |
-
|
| 20 |
except requests.exceptions.RequestException as e:
|
| 21 |
-
|
| 22 |
|
| 23 |
app = FastAPI()
|
| 24 |
|
| 25 |
@app.post("/webhook")
|
| 26 |
async def webhook(request: Request):
|
|
|
|
|
|
|
| 27 |
if request.headers.get("X-Webhook-Secret") != HF_WEBHOOK_SECRET:
|
|
|
|
| 28 |
return Response("Invalid secret", status_code=401)
|
|
|
|
| 29 |
data = await request.json()
|
|
|
|
|
|
|
| 30 |
event = data.get("event", {})
|
| 31 |
repo = data.get("repo", {})
|
|
|
|
| 32 |
# Only process model repo events
|
| 33 |
if repo.get("type") != "model" or event.get("scope") != "repo":
|
|
|
|
| 34 |
return Response("Not a model repo event", status_code=200)
|
|
|
|
| 35 |
action = event.get("action")
|
|
|
|
|
|
|
| 36 |
if action == "move":
|
| 37 |
old_name = data.get("oldRepo", {}).get("name", "unknown") # TODO ernsure good key when name change
|
| 38 |
new_name = repo.get("name", "unknown")
|
|
@@ -42,4 +58,7 @@ async def webhook(request: Request):
|
|
| 42 |
name = repo.get("name", "unknown")
|
| 43 |
message = f"Model deleted: `{name}`"
|
| 44 |
send_slack_message(message)
|
| 45 |
-
|
|
|
|
|
|
|
|
|
|
|
|
| 2 |
import os
|
| 3 |
import requests
|
| 4 |
import json
|
| 5 |
+
import logging
|
| 6 |
+
|
| 7 |
+
# Set up logging
|
| 8 |
+
logging.basicConfig(level=logging.INFO, format='%(asctime)s - %(levelname)s - %(message)s')
|
| 9 |
+
logger = logging.getLogger(__name__)
|
| 10 |
|
| 11 |
HF_WEBHOOK_SECRET = os.environ.get("HF_WEBHOOK_SECRET")
|
| 12 |
SLACK_WEBHOOK_URL = os.environ.get("SLACK_WEBHOOK_URL")
|
|
|
|
| 14 |
def send_slack_message(message: str):
|
| 15 |
"""Send a message to Slack using webhook URL"""
|
| 16 |
if not SLACK_WEBHOOK_URL:
|
| 17 |
+
logger.warning(f"No Slack webhook URL configured. Message: {message}")
|
| 18 |
return
|
| 19 |
|
| 20 |
payload = {"text": message}
|
| 21 |
try:
|
| 22 |
response = requests.post(SLACK_WEBHOOK_URL, json=payload)
|
| 23 |
response.raise_for_status()
|
| 24 |
+
logger.info(f"Slack message sent successfully: {message}")
|
| 25 |
except requests.exceptions.RequestException as e:
|
| 26 |
+
logger.error(f"Failed to send Slack message: {e}")
|
| 27 |
|
| 28 |
app = FastAPI()
|
| 29 |
|
| 30 |
@app.post("/webhook")
|
| 31 |
async def webhook(request: Request):
|
| 32 |
+
logger.info(f"Received webhook request from {request.client.host}")
|
| 33 |
+
|
| 34 |
if request.headers.get("X-Webhook-Secret") != HF_WEBHOOK_SECRET:
|
| 35 |
+
logger.warning("Invalid webhook secret received")
|
| 36 |
return Response("Invalid secret", status_code=401)
|
| 37 |
+
|
| 38 |
data = await request.json()
|
| 39 |
+
logger.info(f"Webhook payload: {json.dumps(data, indent=2)}")
|
| 40 |
+
|
| 41 |
event = data.get("event", {})
|
| 42 |
repo = data.get("repo", {})
|
| 43 |
+
|
| 44 |
# Only process model repo events
|
| 45 |
if repo.get("type") != "model" or event.get("scope") != "repo":
|
| 46 |
+
logger.info(f"Skipping non-model repo event: type={repo.get('type')}, scope={event.get('scope')}")
|
| 47 |
return Response("Not a model repo event", status_code=200)
|
| 48 |
+
|
| 49 |
action = event.get("action")
|
| 50 |
+
logger.info(f"Processing model repo action: {action}")
|
| 51 |
+
|
| 52 |
if action == "move":
|
| 53 |
old_name = data.get("oldRepo", {}).get("name", "unknown") # TODO ernsure good key when name change
|
| 54 |
new_name = repo.get("name", "unknown")
|
|
|
|
| 58 |
name = repo.get("name", "unknown")
|
| 59 |
message = f"Model deleted: `{name}`"
|
| 60 |
send_slack_message(message)
|
| 61 |
+
else:
|
| 62 |
+
logger.info(f"Unhandled action: {action}")
|
| 63 |
+
|
| 64 |
+
return Response("Webhook notification received and processed!", status_code=200)
|