64 lines
2.7 KiB
Python
64 lines
2.7 KiB
Python
#!/bin/python3
|
|
import os
|
|
import re
|
|
import locale
|
|
import html
|
|
from datetime import datetime
|
|
from pytz import timezone
|
|
import requests
|
|
from bs4 import BeautifulSoup
|
|
locale.setlocale(locale.LC_TIME, 'de_DE.UTF-8')
|
|
|
|
BASEURL = os.getenv("BASEURL", default="https://www.feuerwehr-nea.de")
|
|
FWNAME = os.getenv("FWNAME", default="Feuerwehr Nea")
|
|
|
|
session = requests.Session()
|
|
|
|
soup = BeautifulSoup(session.get(BASEURL + "/einsaetze",timeout=20).content, 'html.parser')
|
|
|
|
csrfmiddlewaretoken = soup.find('input', attrs={ "name": "csrfmiddlewaretoken" })['value']
|
|
|
|
soup = BeautifulSoup(session.post(BASEURL + "/einsaetze/load_reports/0/no_group/", data={ "csrfmiddlewaretoken": csrfmiddlewaretoken }, headers={'referer': BASEURL + "/einsaetze"}).content, 'html.parser')
|
|
|
|
print('<?xml version="1.0" encoding="UTF-8" ?>\n'
|
|
'<rss version="2.0">'
|
|
'<channel>'
|
|
'<title>' + FWNAME +' Einsätze</title>'
|
|
'<link>' + BASEURL + '</link>'
|
|
'<description>' + FWNAME + ' Einsätze</description>')
|
|
|
|
for mysoup in soup.find_all('a', class_='einsatz-link text-nowrap'):
|
|
mylink = html.escape(BASEURL + mysoup['href'])
|
|
soup2 = BeautifulSoup(session.get( mylink ,timeout=10).content, 'html.parser')
|
|
mydatetime_str = soup2.find("th",string='Einsatzstart').find_next("td").string
|
|
mydatetime = datetime.strptime(mydatetime_str, '%d. %B %Y %H:%M')
|
|
mydatetime = timezone("CET").localize(mydatetime)
|
|
mykeywords = soup2.find("th",string='Alarmierungsart')
|
|
if mykeywords is None:
|
|
mykeywords = soup2.find("th",string='Einsatzart')
|
|
if mykeywords is not None:
|
|
mykeywords = mykeywords.find_next("td").string.strip()
|
|
else:
|
|
mykeywords = ""
|
|
mykeywords = html.escape(mykeywords)
|
|
myunits = soup2.find("th",string='Alarmierte Einheiten')
|
|
if myunits is None:
|
|
myunits = soup2.find("th",string='Alarmierung')
|
|
if myunits is not None:
|
|
myunits = myunits.find_next("td").string.strip()
|
|
else:
|
|
myunits = ""
|
|
myunits = html.escape(myunits)
|
|
print("<item>")
|
|
locale.setlocale(locale.LC_TIME, 'en_US.UTF-8')
|
|
print("<pubDate>" + mydatetime.strftime('%a, %d %b %Y %H:%M:%S %z') + "</pubDate>")
|
|
locale.setlocale(locale.LC_TIME, 'de_DE.UTF-8')
|
|
print("<title>" + mykeywords + " - " + html.escape((soup2.find('meta', attrs={ "property": "og:title" }))['content']) + " - " + myunits + "</title>")
|
|
print("<link>" + mylink + "</link>")
|
|
try:
|
|
print("<description>" + html.escape((soup2.find('div', class_="description")).string.strip() + '<br>' + (soup2.find('div', class_="description").find_next("p").string.strip()) + '<hr>' + myunits) + "</description>")
|
|
except:
|
|
print("<description></description>")
|
|
print("</item>")
|
|
print("</channel></rss>")
|