Telegram version of schneiderbot
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

137 lines
3.6 KiB

5 years ago
5 years ago
5 years ago
  1. import datetime
  2. from telegram import ParseMode
  3. import requests
  4. DISABLED_GROUPS = [-1001301570558]
  5. DIETS = {
  6. "veggy": ["Vegetarisch", "Vegan"],
  7. "vegan": ["Vegan"]
  8. }
  9. WEEKDAYS = {
  10. "montag": 1,
  11. "dienstag": 2,
  12. "mittwoch": 3,
  13. "donnerstag": 4,
  14. "freitag": 5,
  15. "samstag": 6,
  16. "sonntag": 7
  17. }
  18. MENSA_URL = {
  19. "zentral": "goe1",
  20. "turm": "goe2",
  21. "linux": "goe2",
  22. "nord": "goe3",
  23. "italia": "goe4",
  24. "fasthochschule": "goe5"
  25. }
  26. MENSA_NAME = {
  27. "zentral": "Zentralmensa",
  28. "nord": "Nordmensa",
  29. "turm": "Turmmensa",
  30. "linux": "Linuxmensa",
  31. "italia": "Mensa Italia",
  32. "fasthochschule": "Bistro Fasthochschule"
  33. }
  34. HIDE_CATEGORIES_LIGHT = {
  35. "CampusCurry",
  36. "natürlich fit",
  37. "Fitnesscenter",
  38. "Salatbuffet",
  39. "Studentenfutter",
  40. "Süße Versuchung",
  41. "Süße Spezial Tagesangebot",
  42. "Vollwert & Co. Stärke",
  43. "Vollwert & Co. Gemüse",
  44. "Bio-Beilagen",
  45. "Dessertbuffet",
  46. "Last Minute ab 14:30 Uhr",
  47. ## Nordmensa:
  48. "Salatbuffet/Pastapoint",
  49. "Last Minute ab 13:30 Uhr",
  50. ## Turmmensa:
  51. "Beilagen",
  52. "Last Minute ab 14:00Uhr"
  53. }
  54. HIDE_CATEGORIES_FULL = {
  55. "Last Minute ab 14:30 Uhr",
  56. "Last Minute ab 13:30 Uhr",
  57. "Last Minute ab 14:00Uhr"
  58. }
  59. MODES = {
  60. "light": HIDE_CATEGORIES_LIGHT,
  61. "full": HIDE_CATEGORIES_FULL
  62. }
  63. def linux_mensa(bot, update):
  64. mensa(bot, update, ["linux"])
  65. def mensa(bot, update, args):
  66. if update.message.chat_id in DISABLED_GROUPS:
  67. return
  68. which = "zentral"
  69. filter_categories = MODES["light"]
  70. diet = [""]
  71. auto_next_day = True
  72. today = datetime.datetime.now().date()
  73. for arg in args:
  74. arg = arg.lower()
  75. if arg in MENSA_NAME:
  76. which = arg
  77. elif arg in MODES:
  78. filter_categories = MODES[arg]
  79. elif arg in WEEKDAYS:
  80. date_offset = (6 - today.weekday() + WEEKDAYS[arg])
  81. today += datetime.timedelta(days=date_offset)
  82. auto_next_day = False
  83. elif arg in DIETS:
  84. diet = DIETS[arg]
  85. else:
  86. update.message.reply_text("Falscher Aufruf! RTFM und versuchs nochmal.")
  87. return
  88. if auto_next_day and datetime.datetime.now().time() > datetime.time(hour=16):
  89. today += datetime.timedelta(days=1)
  90. if today.weekday() == 6:
  91. update.message.reply_text("Sonntags hat die Mensa zu")
  92. return
  93. url = "https://app.mensaplan.de/api/11102/de.mensaplan.app.android.goettingen/%s.json" % MENSA_URL[which]
  94. request = requests.get(url)
  95. request.encoding = 'utf-8'
  96. data = request.json()
  97. today_data = get_data_for_day(today, data)
  98. if not today_data:
  99. message = today.strftime("Kein Speiseplan für den %d.%m.%Y vorhanden")
  100. else:
  101. message = "Das Essen für %s in der %s \n\n" % (today_data["date"], MENSA_NAME[which])
  102. for cat in today_data['categories']:
  103. label = cat['name']
  104. meals = cat['meals']
  105. if label not in filter_categories and (
  106. any(filtered in label for filtered in diet) or
  107. [item['name'].replace('\xad', '') for item in meals if
  108. any(filtered in item['name'].replace('\xad', '') for filtered in diet)]): # TODO: simplify
  109. meal_line = "*%s*\n" % label
  110. for meal in meals:
  111. meal_line += meal['name'].strip() + "\n"
  112. message += meal_line + '\n'
  113. update.message.reply_text(message, ParseMode.MARKDOWN)
  114. def get_data_for_day(day, complete_data):
  115. for data in complete_data['days']:
  116. if day.isoformat() == data['iso-date']:
  117. return data