mirror of
https://github.com/JonasunderscoreJones/turbo-octo-potato.git
synced 2025-10-24 10:39:19 +02:00
added webhook functionality
This commit is contained in:
parent
3ef4f18f92
commit
fb8a94d97c
2 changed files with 76 additions and 7 deletions
63
rpop_webhook.py
Normal file
63
rpop_webhook.py
Normal file
|
@ -0,0 +1,63 @@
|
|||
import os
|
||||
import requests
|
||||
import json
|
||||
import dotenv
|
||||
import datetime
|
||||
|
||||
def send_webhook():
|
||||
# Load the webhook URL from the environment variables
|
||||
dotenv.load_dotenv()
|
||||
|
||||
# Replace with your actual webhook URL
|
||||
webhook_url = os.getenv('DISCORD_WEBHOOK_URL')
|
||||
|
||||
today = datetime.datetime.today().date()
|
||||
|
||||
# Get the date from 7 days ago
|
||||
seven_days_ago = today - datetime.timedelta(days=7)
|
||||
|
||||
# request with the date and http://api.jonasjones.dev/v1/kcomebacks/filter/daterange?start=2023-12-1&end=2023-12-16&limit=50&offset=0
|
||||
response = requests.get(f"http://api.jonasjones.dev/v1/kcomebacks/filter/daterange?start={seven_days_ago}&end={today}&limit=50&offset=0")
|
||||
|
||||
# Check if the request was successful
|
||||
if response.status_code != 200:
|
||||
print(f"Failed to fetch data. Status code: {response.status_code}")
|
||||
exit()
|
||||
|
||||
# Parse the JSON response
|
||||
data = response.json()
|
||||
data = data['results']
|
||||
|
||||
# check if there are 50 or more comebacks
|
||||
if len(data) >= 50:
|
||||
# request with offset 50
|
||||
response = requests.get(f"http://api.jonasjones.dev/v1/kcomebacks/filter/daterange?start={seven_days_ago}&end={today}&limit=50&offset=50")
|
||||
# Check if the request was successful
|
||||
if response.status_code != 200:
|
||||
print(f"Failed to fetch data. Status code: {response.status_code}")
|
||||
exit()
|
||||
|
||||
# Parse the JSON response
|
||||
data2 = response.json()
|
||||
|
||||
# join the lists
|
||||
data += data2['results']
|
||||
|
||||
# Create the message content
|
||||
content = "Here are the comebacks from today:\n"
|
||||
for i in data:
|
||||
content += f"{i['date']} > {i['title']} - {i['artist']}: {i['links'] if i['links'] != [] else '*No Links*'}\n"
|
||||
|
||||
# Message content
|
||||
message = {
|
||||
"content": content,
|
||||
}
|
||||
|
||||
# Make the POST request to the webhook URL
|
||||
response = requests.post(webhook_url, data=json.dumps(message), headers={"Content-Type": "application/json"})
|
||||
|
||||
# Check if the request was successful
|
||||
if response.status_code == 204:
|
||||
print("Webhook sent successfully!")
|
||||
else:
|
||||
print(f"Failed to send webhook. Status code: {response.status_code}")
|
20
rpopfetch.py
20
rpopfetch.py
|
@ -6,6 +6,7 @@ import re
|
|||
import json
|
||||
import time
|
||||
import sys
|
||||
import rpop_webhook
|
||||
|
||||
def fetch_main_reddit_wiki_page(subreddit_name, page_name):
|
||||
|
||||
|
@ -86,10 +87,10 @@ def convert_monthly_content_to_json(content, year, month):
|
|||
parts[3] = parts[3][1:]
|
||||
if (parts[3].startswith("[") and parts[3].endswith(")")):
|
||||
parts[3] = parts[3][1:parts[3].find("](")]
|
||||
|
||||
|
||||
if (parts[3].startswith("*[") and parts[3].endswith(")*")):
|
||||
parts[3] = parts[3][2:parts[3].find("](")]
|
||||
|
||||
|
||||
releasetype = []
|
||||
|
||||
# parse the release type
|
||||
|
@ -172,19 +173,19 @@ def convert_monthly_content_to_json(content, year, month):
|
|||
else:
|
||||
# if the song links are not provided, replace the string with an empty list
|
||||
parts[6] = []
|
||||
|
||||
|
||||
# add the reddit link to the list of links
|
||||
reddit = parts.pop(5)
|
||||
if reddit != "":
|
||||
parts[5].append(reddit)
|
||||
|
||||
|
||||
# remove the "th", "st", "nd", "rd" from the day
|
||||
parts[0] = parts[0].replace('th', '').replace('st', '').replace('nd', '').replace('rd', '')
|
||||
|
||||
# make the links an empty list if it's null
|
||||
if parts[5] == [None]:
|
||||
parts[5] = []
|
||||
|
||||
|
||||
# create a json entry from the parsed data
|
||||
json_entry = {
|
||||
"date": f"{year}-{month}-{parts[0]}",
|
||||
|
@ -195,7 +196,7 @@ def convert_monthly_content_to_json(content, year, month):
|
|||
"links": parts[5]
|
||||
}
|
||||
|
||||
|
||||
|
||||
json_data.append(json_entry)
|
||||
|
||||
except Exception as e:
|
||||
|
@ -247,6 +248,7 @@ def fetch_monthly_page(wiki_link, subreddit_name):
|
|||
return None
|
||||
|
||||
UPLOAD_TO_CDN = True if "--cdn" in sys.argv else False
|
||||
SEND_WEBHOOK = False if "--no-webhook" in sys.argv else False if "-nwh" in sys.argv else True
|
||||
|
||||
# reddit infos
|
||||
subreddit_name = "kpop"
|
||||
|
@ -314,7 +316,7 @@ if content:
|
|||
# save json_data to file
|
||||
with open(f"rkpop_data.json", "w") as f:
|
||||
f.write(json.dumps(json_data, indent=4))
|
||||
|
||||
|
||||
print("Fetched", len(json_data) - 1, "entries.")
|
||||
|
||||
cdn_upload_cmd = "rclone copy rkpop_data.json cdn:cdn/api/kcomebacks/"
|
||||
|
@ -325,3 +327,7 @@ if content:
|
|||
elif input("Upload to cdn? [Y/n]") in ["Y", "y", ""]:
|
||||
print("Uploading...")
|
||||
os.system(cdn_upload_cmd)
|
||||
|
||||
|
||||
if SEND_WEBHOOK:
|
||||
rpop_webhook.send_webhook()
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue