Untitled
unknown
plain_text
a year ago
4.7 kB
2
Indexable
Never
import re import json import requests from requests.adapters import HTTPAdapter, Retry from datetime import datetime # ===================================== # SETTING # ===================================== webhook_urls = [ r"https://tradingview.to/binance/valXwdbFptVeGvv993yw", #r"https://yourwebhook2.com", #r"https://yourwebhook3.com", ] # vv for logging (fill in the webhook URL if you need) discord_webhook_url = r"" # 4 = info, ok, warning, error # 3 = ok, warning, error # 2 = warning, error # 1 = error only # 0 = OFF log_level = 4 # ===================================== # CODE # ===================================== show_welcome_msg = False url_regex = "https?://([A-Za-z_0-9.-]+).*" dc_embeds_sample = [{ "type":"rich", "title": "", "description": "", "color": 5533306, "footer": { "text": "Developed by Freeman(soranoo)", "icon_url": "" }, }] class log: def info(payload): if (log_level < 4 or log_level < 0): return embeds = dc_embeds_sample.copy() embeds[0]["title"] = "INFO" embeds[0]["description"] = payload embeds[0]["color"] = 5533306 send_msg_to_dc("", embeds) def ok(payload:str): if (log_level < 3 or log_level < 0): return embeds = dc_embeds_sample.copy() embeds[0]["title"] = "OK" embeds[0]["description"] = payload embeds[0]["color"] = 5763719 send_msg_to_dc("", embeds) def warning(payload:str): if (log_level < 2 or log_level < 0): return embeds = dc_embeds_sample.copy() embeds[0]["title"] = "WARNING" embeds[0]["description"] = payload embeds[0]["color"] = 16776960 send_msg_to_dc("", embeds) def error(payload:str): if (log_level < 1 or log_level < 0): return embeds = dc_embeds_sample.copy() embeds[0]["title"] = "ERROR" embeds[0]["description"] = payload embeds[0]["color"] = 15548997 send_msg_to_dc("", embeds) def extract_domain_name(url:str): m = re.search(url_regex, url) if m: return m.group(1) return None def post_request(webhook_url:str, payload:str or json, auto_json_dumps:bool = True): headers = { "Content-Type": "text/plain", "User-Agent": "Mozilla/5.0 (X11; Linux x86_64) AppleWebKit/537.11 (KHTML, like Gecko) Chrome/23.0.1271.64 Safari/537.11" } data = payload # start a session session = requests.Session() # set retry policy retry = Retry(connect=3, backoff_factor=0.5) adapter = HTTPAdapter(max_retries=retry) # add adapter to session session.mount('http://', adapter) session.mount('https://', adapter) # send request response = session.post(webhook_url, data=data, headers=headers) return response def send_msg_to_dc(message, embeds=None): if (len(discord_webhook_url.strip()) == 0): return # empty URL if extract_domain_name(discord_webhook_url) is None: print("Invalid Discord Webhook URL") return payload = json.dumps({'content': f"{message}", "embeds":embeds} ) post_request(discord_webhook_url, payload, False) def send_webhook(payload:str): # load json try: payload = json.loads(payload) except ValueError as err: pass # loop for webhook_url in webhook_urls: domain = extract_domain_name(webhook_url) if domain is None: log.warning(f"Send webhook failed.\nReason: invalid URL <{webhook_url}>\nContent: {payload}") continue currentTime = datetime.now() response = post_request(webhook_url, payload) time_used = (datetime.now()-currentTime).total_seconds() * 1000 if (response.status_code == 200): log.ok(f"Webhook Sent!\n\nProcess Time: {time_used}ms\nDomain: {domain}\nFull URL: {webhook_url}\nContent: {payload}") else: log.error(f"Send webhook failed.\nReason: {response.text}\nStatus: {response.status_code}\n\nDomain: {domain}\nFull URL: {webhook_url}\nContent: {payload}") def handler(pd: "pipedream"): global show_welcome_msg if not show_welcome_msg: log.info("You are GOOD to go!\n\n") show_welcome_msg = True # extract data from previous steps content = pd.steps["trigger"]["event"]["body"]["text"] from_email = pd.steps["trigger"]["event"]["headers"]["from"]["value"][0]["address"] if from_email in ["noreply@tradingview.com"]: send_webhook(content)