Umgebaut auf REST API
This commit is contained in:
@ -1,31 +1,24 @@
|
||||
import requests
|
||||
import time
|
||||
import json
|
||||
from bs4 import BeautifulSoup
|
||||
from datetime import datetime
|
||||
import re
|
||||
|
||||
TI_STATUS_URL = "https://fachportal.gematik.de/ti-status"
|
||||
TI_API_URL = "https://ti-lage.prod.ccs.gematik.solutions/lageapi/v2/tilage"
|
||||
WEBHOOK_URL = "https://mattermost.medisoftware.org/hooks/i67zgcgajifxxxtfwjxcxace7a"
|
||||
STATE_FILE = "ti_status_state.json"
|
||||
|
||||
def fetch_status_messages():
|
||||
resp = requests.get(TI_STATUS_URL)
|
||||
resp = requests.get(TI_API_URL)
|
||||
resp.raise_for_status()
|
||||
soup = BeautifulSoup(resp.text, "html.parser")
|
||||
# Annahme: Meldungen stehen in bestimmten HTML-Elementen (z.B. <div class="c-status-list__item">)
|
||||
# Dies muss ggf. angepasst werden, wenn die Struktur anders ist!
|
||||
data = resp.json()
|
||||
messages = []
|
||||
for item in soup.find_all("div", class_="c-status-list__item"):
|
||||
title = item.get_text(strip=True)
|
||||
if title:
|
||||
messages.append(title)
|
||||
# Fallback: Wenn keine spezielle Klasse, alle sichtbaren Meldungen im Hauptbereich
|
||||
if not messages:
|
||||
for p in soup.find_all("p"):
|
||||
text = p.get_text(strip=True)
|
||||
if text and len(text) > 30:
|
||||
messages.append(text)
|
||||
for meldung in data.get("meldungen", []):
|
||||
zeit = meldung.get("zeitpunkt", "")
|
||||
titel = meldung.get("titel", "")
|
||||
beschreibung = meldung.get("beschreibung", "")
|
||||
link = meldung.get("link", "")
|
||||
msg = f"{zeit}\n- {titel}: {beschreibung}\n{link}".strip()
|
||||
messages.append(msg)
|
||||
return messages
|
||||
|
||||
def load_state():
|
||||
@ -40,7 +33,8 @@ def save_state(state):
|
||||
json.dump(state, f, ensure_ascii=False, indent=2)
|
||||
|
||||
def markdownify_message(message):
|
||||
# Datumsangaben fett hervorheben (z.B. 23.06.2025)
|
||||
# Datumsangaben fett hervorheben (z.B. 2025-06-23 oder 23.06.2025)
|
||||
message = re.sub(r"(\d{4}-\d{2}-\d{2})", r"**\1**", message)
|
||||
message = re.sub(r"(\d{2}\.\d{2}\.\d{4})", r"**\1**", message)
|
||||
# URLs als Links darstellen
|
||||
message = re.sub(r"(https?://\S+)", r"[\1](\1)", message)
|
||||
@ -60,7 +54,7 @@ def markdownify_message(message):
|
||||
def send_to_mattermost(message):
|
||||
md_message = markdownify_message(message)
|
||||
payload = {
|
||||
"text": f"#### Neue TI-Status-Meldung\n\n{md_message}\n\n[Zur Statusseite]({TI_STATUS_URL})\n_Gemeldet am {datetime.now().strftime('%d.%m.%Y %H:%M:%S')}_"
|
||||
"text": f"#### Neue TI-Status-Meldung\n\n{md_message}\n\n[Zur Statusseite](https://fachportal.gematik.de/ti-status)\n_Gemeldet am {datetime.now().strftime('%d.%m.%Y %H:%M:%S')}_"
|
||||
}
|
||||
resp = requests.post(WEBHOOK_URL, json=payload)
|
||||
resp.raise_for_status()
|
||||
@ -68,7 +62,7 @@ def send_to_mattermost(message):
|
||||
def main():
|
||||
state = load_state()
|
||||
known_messages = set(state.get("messages", []))
|
||||
print("Prüfe TI-Status-Seite auf neue Meldungen...")
|
||||
print("Prüfe TI-Status-API auf neue Meldungen...")
|
||||
try:
|
||||
messages = fetch_status_messages()
|
||||
new_messages = [m for m in messages if m not in known_messages]
|
||||
|
Reference in New Issue
Block a user