From b899579ca8c42c254489ede9cc350a651cedb33e Mon Sep 17 00:00:00 2001 From: dgtlmoon Date: Thu, 30 Nov 2023 12:15:22 +0100 Subject: [PATCH] properly handle user/pass auth and clean URL without token --- changedetectionio/notification.py | 21 ++++++++++++++++++++- 1 file changed, 20 insertions(+), 1 deletion(-) diff --git a/changedetectionio/notification.py b/changedetectionio/notification.py index 12985814..7f08c1b3 100644 --- a/changedetectionio/notification.py +++ b/changedetectionio/notification.py @@ -72,6 +72,9 @@ def apprise_custom_api_call_wrapper(body, title, notify_type, *args, **kwargs): url = url.replace('deletes://', 'https://') headers = {} + params = {} + auth = None + # Convert /foobar?+some-header=hello to proper header dictionary results = apprise_parse_url(url) if results: @@ -80,6 +83,17 @@ def apprise_custom_api_call_wrapper(body, title, notify_type, *args, **kwargs): headers = {URLBase.unquote(x): URLBase.unquote(y) for x, y in results['qsd+'].items()} + # Add our GET paramters in the event the user wants to pass these along + params = {URLBase.unquote(x): URLBase.unquote(y) + for x, y in results['qsd-'].items()} + + # Determine Authentication + auth = '' + if results.get('user') and results.get('password'): + auth = (URLBase.unquote(results.get('user')), URLBase.unquote(results.get('user'))) + elif results.get('user'): + auth = (URLBase.unquote(results.get('user'))) + # Try to auto-guess if it's JSON try: json.loads(body) @@ -87,7 +101,12 @@ def apprise_custom_api_call_wrapper(body, title, notify_type, *args, **kwargs): except ValueError as e: pass - r(url, headers=headers, data=body) + r(results.get('url'), + headers=headers, + data=body, + params=params, + auth=auth + ) def process_notification(n_object, datastore):