diff options
author | Alex McGivern <[email protected]> | 2017-04-27 00:21:32 +0100 |
---|---|---|
committer | Alex McGivern <[email protected]> | 2017-04-27 00:21:32 +0100 |
commit | 91e5388daef3f66b546726dcd57e84682df40a8f (patch) | |
tree | 47c42cf81ea6acb56fba26d48c2c42093fff99f1 | |
parent | 973182cda07bc64545523b2ae0940c6f170c6db6 (diff) | |
download | mastodon.py-91e5388daef3f66b546726dcd57e84682df40a8f.tar.gz |
added content-type hint
fixed POST parameters for reports
added handling for PATCH requests
added check for missing Date header to prevent errors when testing against Puma
-rw-r--r-- | mastodon/Mastodon.py | 19 |
1 files changed, 12 insertions, 7 deletions
diff --git a/mastodon/Mastodon.py b/mastodon/Mastodon.py index a32241b..3b00f37 100644 --- a/mastodon/Mastodon.py +++ b/mastodon/Mastodon.py | |||
@@ -643,7 +643,8 @@ class Mastodon: | |||
643 | 643 | ||
644 | 'note' is the user's bio. | 644 | 'note' is the user's bio. |
645 | 645 | ||
646 | 'avatar' and 'header' are PNG images encoded in base64. | 646 | 'avatar' and 'header' are images encoded in base64, prepended by a content-type |
647 | (for example: '[...]') | ||
647 | """ | 648 | """ |
648 | params = self.__generate_params(locals()) | 649 | params = self.__generate_params(locals()) |
649 | return self.__api_request('PATCH', '/api/v1/accounts/update_credentials', params) | 650 | return self.__api_request('PATCH', '/api/v1/accounts/update_credentials', params) |
@@ -651,7 +652,7 @@ class Mastodon: | |||
651 | ### | 652 | ### |
652 | # Writing data: Reports | 653 | # Writing data: Reports |
653 | ### | 654 | ### |
654 | def report(self, id, toots, comment): | 655 | def report(self, account_id, status_ids, comment): |
655 | """ | 656 | """ |
656 | Report a user to the admin. | 657 | Report a user to the admin. |
657 | 658 | ||
@@ -813,6 +814,9 @@ class Mastodon: | |||
813 | if method == 'POST': | 814 | if method == 'POST': |
814 | response_object = requests.post(self.api_base_url + endpoint, data = params, headers = headers, files = files, timeout = self.request_timeout) | 815 | response_object = requests.post(self.api_base_url + endpoint, data = params, headers = headers, files = files, timeout = self.request_timeout) |
815 | 816 | ||
817 | if method == 'PATCH': | ||
818 | response_object = requests.patch(self.api_base_url + endpoint, data = params, headers = headers, files = files, timeout = self.request_timeout) | ||
819 | |||
816 | if method == 'DELETE': | 820 | if method == 'DELETE': |
817 | response_object = requests.delete(self.api_base_url + endpoint, data = params, headers = headers, files = files, timeout = self.request_timeout) | 821 | response_object = requests.delete(self.api_base_url + endpoint, data = params, headers = headers, files = files, timeout = self.request_timeout) |
818 | except Exception as e: | 822 | except Exception as e: |
@@ -848,11 +852,12 @@ class Mastodon: | |||
848 | self.ratelimit_reset = self.__datetime_to_epoch(ratelimit_reset_datetime) | 852 | self.ratelimit_reset = self.__datetime_to_epoch(ratelimit_reset_datetime) |
849 | 853 | ||
850 | # Adjust server time to local clock | 854 | # Adjust server time to local clock |
851 | server_time_datetime = dateutil.parser.parse(response_object.headers['Date']) | 855 | if 'Date' in response_object.headers: |
852 | server_time = self.__datetime_to_epoch(server_time_datetime) | 856 | server_time_datetime = dateutil.parser.parse(response_object.headers['Date']) |
853 | server_time_diff = time.time() - server_time | 857 | server_time = self.__datetime_to_epoch(server_time_datetime) |
854 | self.ratelimit_reset += server_time_diff | 858 | server_time_diff = time.time() - server_time |
855 | self.ratelimit_lastcall = time.time() | 859 | self.ratelimit_reset += server_time_diff |
860 | self.ratelimit_lastcall = time.time() | ||
856 | except Exception as e: | 861 | except Exception as e: |
857 | raise MastodonRatelimitError("Rate limit time calculations failed: %s" % e) | 862 | raise MastodonRatelimitError("Rate limit time calculations failed: %s" % e) |
858 | 863 | ||