diff options
-rw-r--r-- | docs/index.rst | 34 | ||||
-rw-r--r-- | mastodon/Mastodon.py | 209 |
2 files changed, 137 insertions, 106 deletions
diff --git a/docs/index.rst b/docs/index.rst index da670b1..0c05321 100644 --- a/docs/index.rst +++ b/docs/index.rst | |||
@@ -156,6 +156,8 @@ and are parsed into python datetime objects. | |||
156 | 156 | ||
157 | User dicts | 157 | User dicts |
158 | ~~~~~~~~~~ | 158 | ~~~~~~~~~~ |
159 | .. _user dict: | ||
160 | |||
159 | .. code-block:: python | 161 | .. code-block:: python |
160 | 162 | ||
161 | mastodon.account(<numerical id>) | 163 | mastodon.account(<numerical id>) |
@@ -189,6 +191,8 @@ User dicts | |||
189 | 191 | ||
190 | Toot dicts | 192 | Toot dicts |
191 | ~~~~~~~~~~ | 193 | ~~~~~~~~~~ |
194 | .. _toot dict: | ||
195 | |||
192 | .. code-block:: python | 196 | .. code-block:: python |
193 | 197 | ||
194 | mastodon.toot("Hello from Python") | 198 | mastodon.toot("Hello from Python") |
@@ -222,6 +226,8 @@ Toot dicts | |||
222 | 226 | ||
223 | Mention dicts | 227 | Mention dicts |
224 | ~~~~~~~~~~~~~ | 228 | ~~~~~~~~~~~~~ |
229 | .. _mention dict: | ||
230 | |||
225 | .. code-block:: python | 231 | .. code-block:: python |
226 | 232 | ||
227 | { | 233 | { |
@@ -233,6 +239,8 @@ Mention dicts | |||
233 | 239 | ||
234 | Hashtag dicts | 240 | Hashtag dicts |
235 | ~~~~~~~~~~~~~ | 241 | ~~~~~~~~~~~~~ |
242 | .. _hashtag dict: | ||
243 | |||
236 | .. code-block:: python | 244 | .. code-block:: python |
237 | 245 | ||
238 | { | 246 | { |
@@ -242,6 +250,8 @@ Hashtag dicts | |||
242 | 250 | ||
243 | Emoji dicts | 251 | Emoji dicts |
244 | ~~~~~~~~~~~ | 252 | ~~~~~~~~~~~ |
253 | .. _emoji dict: | ||
254 | |||
245 | .. code-block:: python | 255 | .. code-block:: python |
246 | 256 | ||
247 | { | 257 | { |
@@ -252,6 +262,8 @@ Emoji dicts | |||
252 | 262 | ||
253 | Relationship dicts | 263 | Relationship dicts |
254 | ~~~~~~~~~~~~~~~~~~ | 264 | ~~~~~~~~~~~~~~~~~~ |
265 | .. _relationship dict: | ||
266 | |||
255 | .. code-block:: python | 267 | .. code-block:: python |
256 | 268 | ||
257 | mastodon.account_follow(<numerical id>) | 269 | mastodon.account_follow(<numerical id>) |
@@ -268,6 +280,8 @@ Relationship dicts | |||
268 | 280 | ||
269 | Notification dicts | 281 | Notification dicts |
270 | ~~~~~~~~~~~~~~~~~~ | 282 | ~~~~~~~~~~~~~~~~~~ |
283 | .. _notification dict: | ||
284 | |||
271 | .. code-block:: python | 285 | .. code-block:: python |
272 | 286 | ||
273 | mastodon.notifications()[0] | 287 | mastodon.notifications()[0] |
@@ -283,6 +297,8 @@ Notification dicts | |||
283 | 297 | ||
284 | Context dicts | 298 | Context dicts |
285 | ~~~~~~~~~~~~~ | 299 | ~~~~~~~~~~~~~ |
300 | .. _context dict: | ||
301 | |||
286 | .. code-block:: python | 302 | .. code-block:: python |
287 | 303 | ||
288 | mastodon.status_context(<numerical id>) | 304 | mastodon.status_context(<numerical id>) |
@@ -294,6 +310,8 @@ Context dicts | |||
294 | 310 | ||
295 | Media dicts | 311 | Media dicts |
296 | ~~~~~~~~~~~ | 312 | ~~~~~~~~~~~ |
313 | .. _media dict: | ||
314 | |||
297 | .. code-block:: python | 315 | .. code-block:: python |
298 | 316 | ||
299 | mastodon.media_post("image.jpg", "image/jpeg") | 317 | mastodon.media_post("image.jpg", "image/jpeg") |
@@ -318,6 +336,8 @@ Media dicts | |||
318 | 336 | ||
319 | Card dicts | 337 | Card dicts |
320 | ~~~~~~~~~~ | 338 | ~~~~~~~~~~ |
339 | .. _card dict: | ||
340 | |||
321 | .. code-block:: python | 341 | .. code-block:: python |
322 | 342 | ||
323 | mastodon.status_card(<numerical id>): | 343 | mastodon.status_card(<numerical id>): |
@@ -342,9 +362,11 @@ Card dicts | |||
342 | 362 | ||
343 | Search result dicts | 363 | Search result dicts |
344 | ~~~~~~~~~~~~~~~~~~~ | 364 | ~~~~~~~~~~~~~~~~~~~ |
365 | .. _search result dict: | ||
366 | |||
345 | .. code-block:: python | 367 | .. code-block:: python |
346 | 368 | ||
347 | mastodon.search(...) | 369 | mastodon.search("<query>") |
348 | # Returns the folowing dictionary | 370 | # Returns the folowing dictionary |
349 | { | 371 | { |
350 | 'accounts': # List of account dicts resulting from the query | 372 | 'accounts': # List of account dicts resulting from the query |
@@ -354,6 +376,8 @@ Search result dicts | |||
354 | 376 | ||
355 | Instance dicts | 377 | Instance dicts |
356 | ~~~~~~~~~~~~~~ | 378 | ~~~~~~~~~~~~~~ |
379 | .. _instance dict: | ||
380 | |||
357 | .. code-block:: python | 381 | .. code-block:: python |
358 | 382 | ||
359 | mastodon.instance() | 383 | mastodon.instance() |
@@ -369,6 +393,8 @@ Instance dicts | |||
369 | 393 | ||
370 | Report dicts | 394 | Report dicts |
371 | ~~~~~~~~~~~~ | 395 | ~~~~~~~~~~~~ |
396 | .. _report dict: | ||
397 | |||
372 | .. code-block:: python | 398 | .. code-block:: python |
373 | 399 | ||
374 | mastodon.reports()[0] | 400 | mastodon.reports()[0] |
@@ -404,6 +430,7 @@ is specified, Mastodon.py defaults to https. | |||
404 | 430 | ||
405 | .. automethod:: Mastodon.create_app | 431 | .. automethod:: Mastodon.create_app |
406 | .. automethod:: Mastodon.__init__ | 432 | .. automethod:: Mastodon.__init__ |
433 | .. _log_in(): | ||
407 | .. automethod:: Mastodon.log_in | 434 | .. automethod:: Mastodon.log_in |
408 | .. automethod:: Mastodon.auth_request_url | 435 | .. automethod:: Mastodon.auth_request_url |
409 | 436 | ||
@@ -434,10 +461,12 @@ Reading data: Timelines | |||
434 | This function allows you to access the timelines a logged in | 461 | This function allows you to access the timelines a logged in |
435 | user could see, as well as hashtag timelines and the public timeline. | 462 | user could see, as well as hashtag timelines and the public timeline. |
436 | 463 | ||
464 | .. _timeline(): | ||
437 | .. automethod:: Mastodon.timeline | 465 | .. automethod:: Mastodon.timeline |
438 | .. automethod:: Mastodon.timeline_home | 466 | .. automethod:: Mastodon.timeline_home |
439 | .. automethod:: Mastodon.timeline_local | 467 | .. automethod:: Mastodon.timeline_local |
440 | .. automethod:: Mastodon.timeline_public | 468 | .. automethod:: Mastodon.timeline_public |
469 | .. _timeline_hashtag(): | ||
441 | .. automethod:: Mastodon.timeline_hashtag | 470 | .. automethod:: Mastodon.timeline_hashtag |
442 | 471 | ||
443 | Reading data: Statuses | 472 | Reading data: Statuses |
@@ -518,6 +547,7 @@ Writing data: Statuses | |||
518 | These functions allow you to post statuses to Mastodon and to | 547 | These functions allow you to post statuses to Mastodon and to |
519 | interact with already posted statuses. | 548 | interact with already posted statuses. |
520 | 549 | ||
550 | .. _status_post(): | ||
521 | .. automethod:: Mastodon.status_post | 551 | .. automethod:: Mastodon.status_post |
522 | .. automethod:: Mastodon.toot | 552 | .. automethod:: Mastodon.toot |
523 | .. automethod:: Mastodon.status_reblog | 553 | .. automethod:: Mastodon.status_reblog |
@@ -562,6 +592,8 @@ This function allows you to upload media to Mastodon. The returned | |||
562 | media IDs (Up to 4 at the same time) can then be used with post_status | 592 | media IDs (Up to 4 at the same time) can then be used with post_status |
563 | to attach media to statuses. | 593 | to attach media to statuses. |
564 | 594 | ||
595 | .. _media_post(): | ||
596 | |||
565 | .. automethod:: Mastodon.media_post | 597 | .. automethod:: Mastodon.media_post |
566 | 598 | ||
567 | Writing data: Reports | 599 | Writing data: Reports |
diff --git a/mastodon/Mastodon.py b/mastodon/Mastodon.py index 2e3935c..af450ec 100644 --- a/mastodon/Mastodon.py +++ b/mastodon/Mastodon.py | |||
@@ -72,16 +72,16 @@ class Mastodon: | |||
72 | def create_app(client_name, scopes=['read', 'write', 'follow'], redirect_uris=None, website=None, to_file=None, | 72 | def create_app(client_name, scopes=['read', 'write', 'follow'], redirect_uris=None, website=None, to_file=None, |
73 | api_base_url=__DEFAULT_BASE_URL, request_timeout=__DEFAULT_TIMEOUT): | 73 | api_base_url=__DEFAULT_BASE_URL, request_timeout=__DEFAULT_TIMEOUT): |
74 | """ | 74 | """ |
75 | Create a new app with given client_name and scopes (read, write, follow) | 75 | Create a new app with given `client_name` and `scopes` (read, write, follow) |
76 | 76 | ||
77 | Specify redirect_uris if you want users to be redirected to a certain page after authenticating. | 77 | Specify `redirect_uris` if you want users to be redirected to a certain page after authenticating. |
78 | Specify to_file to persist your apps info to a file so you can use them in the constructor. | 78 | Specify `to_file` to persist your apps info to a file so you can use them in the constructor. |
79 | Specify api_base_url if you want to register an app on an instance different from the flagship one. | 79 | Specify `api_base_url` if you want to register an app on an instance different from the flagship one. |
80 | 80 | ||
81 | Presently, app registration is open by default, but this is not guaranteed to be the case for all | 81 | Presently, app registration is open by default, but this is not guaranteed to be the case for all |
82 | future mastodon instances or even the flagship instance in the future. | 82 | future mastodon instances or even the flagship instance in the future. |
83 | 83 | ||
84 | Returns client_id and client_secret. | 84 | Returns `client_id` and `client_secret`, both as strings. |
85 | """ | 85 | """ |
86 | api_base_url = Mastodon.__protocolize(api_base_url) | 86 | api_base_url = Mastodon.__protocolize(api_base_url) |
87 | 87 | ||
@@ -118,13 +118,13 @@ class Mastodon: | |||
118 | ratelimit_method="wait", ratelimit_pacefactor=1.1, | 118 | ratelimit_method="wait", ratelimit_pacefactor=1.1, |
119 | request_timeout=__DEFAULT_TIMEOUT, mastodon_version=None): | 119 | request_timeout=__DEFAULT_TIMEOUT, mastodon_version=None): |
120 | """ | 120 | """ |
121 | Create a new API wrapper instance based on the given client_secret and client_id. If you | 121 | Create a new API wrapper instance based on the given `client_secret` and `client_id`. If you |
122 | give a client_id and it is not a file, you must also give a secret. | 122 | give a `client_id` and it is not a file, you must also give a secret. |
123 | 123 | ||
124 | You can also specify an access_token, directly or as a file (as written by log_in). | 124 | You can also specify an `access_token`, directly or as a file (as written by `log_in()`_). |
125 | 125 | ||
126 | Mastodon.py can try to respect rate limits in several ways, controlled by ratelimit_method. | 126 | Mastodon.py can try to respect rate limits in several ways, controlled by `ratelimit_method`. |
127 | "throw" makes functions throw a MastodonRatelimitError when the rate | 127 | "throw" makes functions throw a `MastodonRatelimitError` when the rate |
128 | limit is hit. "wait" mode will, once the limit is hit, wait and retry the request as soon | 128 | limit is hit. "wait" mode will, once the limit is hit, wait and retry the request as soon |
129 | as the rate limit resets, until it succeeds. "pace" works like throw, but tries to wait in | 129 | as the rate limit resets, until it succeeds. "pace" works like throw, but tries to wait in |
130 | between calls so that the limit is generally not hit (How hard it tries to not hit the rate | 130 | between calls so that the limit is generally not hit (How hard it tries to not hit the rate |
@@ -132,15 +132,15 @@ class Mastodon: | |||
132 | even in "wait" and "pace" mode, requests can still fail due to network or other problems! Also | 132 | even in "wait" and "pace" mode, requests can still fail due to network or other problems! Also |
133 | note that "pace" and "wait" are NOT thread safe. | 133 | note that "pace" and "wait" are NOT thread safe. |
134 | 134 | ||
135 | Specify api_base_url if you wish to talk to an instance other than the flagship one. | 135 | Specify `api_base_url` if you wish to talk to an instance other than the flagship one. |
136 | If a file is given as client_id, read client ID and secret from that file. | 136 | If a file is given as `client_id`, client ID and secret are read from that file. |
137 | 137 | ||
138 | By default, a timeout of 300 seconds is used for all requests. If you wish to change this, | 138 | By default, a timeout of 300 seconds is used for all requests. If you wish to change this, |
139 | pass the desired timeout (in seconds) as request_timeout. | 139 | pass the desired timeout (in seconds) as `request_timeout`. |
140 | 140 | ||
141 | The mastodon_version parameter can be used to specify the version of Mastodon that Mastodon.py will | 141 | The `mastodon_version` parameter can be used to specify the version of Mastodon that Mastodon.py will |
142 | expect to be installed on the server. The function will throw an error if an unparseable | 142 | expect to be installed on the server. The function will throw an error if an unparseable |
143 | Version is specified. If no version is specified, Mastodon.py will set mastodon_version to the | 143 | Version is specified. If no version is specified, Mastodon.py will set `mastodon_version` to the |
144 | detected version. | 144 | detected version. |
145 | """ | 145 | """ |
146 | self.api_base_url = Mastodon.__protocolize(api_base_url) | 146 | self.api_base_url = Mastodon.__protocolize(api_base_url) |
@@ -240,21 +240,21 @@ class Mastodon: | |||
240 | code=None, redirect_uri="urn:ietf:wg:oauth:2.0:oob", refresh_token=None, | 240 | code=None, redirect_uri="urn:ietf:wg:oauth:2.0:oob", refresh_token=None, |
241 | scopes=['read', 'write', 'follow'], to_file=None): | 241 | scopes=['read', 'write', 'follow'], to_file=None): |
242 | """ | 242 | """ |
243 | Your username is the e-mail you use to log in into mastodon. | 243 | Get the access token for a user. |
244 | 244 | ||
245 | Can persist access token to file, to be used in the constructor. | 245 | The username is the e-mail used to log in into mastodon. |
246 | |||
247 | Supports refresh_token but Mastodon.social doesn't implement it at the moment. | ||
248 | 246 | ||
249 | Handles password, authorization_code, and refresh_token authentication. | 247 | Can persist access token to file `to_file`, to be used in the constructor. |
250 | 248 | ||
251 | Will throw a MastodonIllegalArgumentError if username / password | 249 | Handles password and OAuth-based authorization. |
250 | |||
251 | Will throw a `MastodonIllegalArgumentError` if username / password | ||
252 | are wrong, scopes are not valid or granted scopes differ from requested. | 252 | are wrong, scopes are not valid or granted scopes differ from requested. |
253 | 253 | ||
254 | For OAuth2 documentation, compare | 254 | For OAuth2 documentation, compare |
255 | https://github.com/doorkeeper-gem/doorkeeper/wiki/Interacting-as-an-OAuth-client-with-Doorkeeper | 255 | https://github.com/doorkeeper-gem/doorkeeper/wiki/Interacting-as-an-OAuth-client-with-Doorkeeper |
256 | 256 | ||
257 | Returns the access token. | 257 | Returns the access token as a string. |
258 | """ | 258 | """ |
259 | if username is not None and password is not None: | 259 | if username is not None and password is not None: |
260 | params = self.__generate_params(locals(), ['scopes', 'to_file', 'code', 'refresh_token']) | 260 | params = self.__generate_params(locals(), ['scopes', 'to_file', 'code', 'refresh_token']) |
@@ -306,7 +306,7 @@ class Mastodon: | |||
306 | """ | 306 | """ |
307 | Retrieve basic information about the instance, including the URI and administrative contact email. | 307 | Retrieve basic information about the instance, including the URI and administrative contact email. |
308 | 308 | ||
309 | Returns an instance dict. | 309 | Returns an `instance dict`_. |
310 | """ | 310 | """ |
311 | return self.__instance() | 311 | return self.__instance() |
312 | 312 | ||
@@ -322,13 +322,13 @@ class Mastodon: | |||
322 | @api_version("1.0.0") | 322 | @api_version("1.0.0") |
323 | def timeline(self, timeline="home", max_id=None, since_id=None, limit=None): | 323 | def timeline(self, timeline="home", max_id=None, since_id=None, limit=None): |
324 | """ | 324 | """ |
325 | Fetch statuses, most recent ones first. Timeline can be 'home', 'local', 'public', | 325 | Fetch statuses, most recent ones first. `timeline` can be 'home', 'local', 'public', |
326 | or 'tag/hashtag'. See the following functions documentation for what those do. | 326 | or 'tag/hashtag'. See the following functions documentation for what those do. |
327 | Local hashtag timelines are supported via the timeline_hashtag() function. | 327 | Local hashtag timelines are supported via the `timeline_hashtag()`_ function. |
328 | 328 | ||
329 | The default timeline is the "home" timeline. | 329 | The default timeline is the "home" timeline. |
330 | 330 | ||
331 | Returns a list of toot dicts. | 331 | Returns a list of `toot dicts`_. |
332 | """ | 332 | """ |
333 | if max_id != None: | 333 | if max_id != None: |
334 | max_id = self.__unpack_id(max_id) | 334 | max_id = self.__unpack_id(max_id) |
@@ -349,9 +349,9 @@ class Mastodon: | |||
349 | @api_version("1.0.0") | 349 | @api_version("1.0.0") |
350 | def timeline_home(self, max_id=None, since_id=None, limit=None): | 350 | def timeline_home(self, max_id=None, since_id=None, limit=None): |
351 | """ | 351 | """ |
352 | Fetch the authenticated users home timeline (i.e. followed users and self). | 352 | Fetch the logged-in users home timeline (i.e. followed users and self). |
353 | 353 | ||
354 | Returns a list of toot dicts. | 354 | Returns a list of `toot dicts`_. |
355 | """ | 355 | """ |
356 | return self.timeline('home', max_id=max_id, since_id=since_id, | 356 | return self.timeline('home', max_id=max_id, since_id=since_id, |
357 | limit=limit) | 357 | limit=limit) |
@@ -361,7 +361,7 @@ class Mastodon: | |||
361 | """ | 361 | """ |
362 | Fetches the local / instance-wide timeline, not including replies. | 362 | Fetches the local / instance-wide timeline, not including replies. |
363 | 363 | ||
364 | Returns a list of toot dicts. | 364 | Returns a list of `toot dicts`_. |
365 | """ | 365 | """ |
366 | return self.timeline('local', max_id=max_id, since_id=since_id, | 366 | return self.timeline('local', max_id=max_id, since_id=since_id, |
367 | limit=limit) | 367 | limit=limit) |
@@ -371,7 +371,7 @@ class Mastodon: | |||
371 | """ | 371 | """ |
372 | Fetches the public / visible-network timeline, not including replies. | 372 | Fetches the public / visible-network timeline, not including replies. |
373 | 373 | ||
374 | Returns a list of toot dicts. | 374 | Returns a list of `toot dicts`_. |
375 | """ | 375 | """ |
376 | return self.timeline('public', max_id=max_id, since_id=since_id, | 376 | return self.timeline('public', max_id=max_id, since_id=since_id, |
377 | limit=limit) | 377 | limit=limit) |
@@ -382,9 +382,9 @@ class Mastodon: | |||
382 | Fetch a timeline of toots with a given hashtag. The hashtag parameter | 382 | Fetch a timeline of toots with a given hashtag. The hashtag parameter |
383 | should not contain the leading #. | 383 | should not contain the leading #. |
384 | 384 | ||
385 | Set "local" to True to retrieve only instance-local tagged posts. | 385 | Set `local` to True to retrieve only instance-local tagged posts. |
386 | 386 | ||
387 | Returns a list of toot dicts. | 387 | Returns a list of `toot dicts`_. |
388 | """ | 388 | """ |
389 | if hashtag.startswith("#"): | 389 | if hashtag.startswith("#"): |
390 | raise MastodonIllegalArgumentError("Hashtag parameter should omit leading #") | 390 | raise MastodonIllegalArgumentError("Hashtag parameter should omit leading #") |
@@ -413,7 +413,7 @@ class Mastodon: | |||
413 | """ | 413 | """ |
414 | Fetch information about a single toot. | 414 | Fetch information about a single toot. |
415 | 415 | ||
416 | Returns a toot dict. | 416 | Returns a `toot dict`_. |
417 | """ | 417 | """ |
418 | id = self.__unpack_id(id) | 418 | id = self.__unpack_id(id) |
419 | url = '/api/v1/statuses/{0}'.format(str(id)) | 419 | url = '/api/v1/statuses/{0}'.format(str(id)) |
@@ -425,7 +425,7 @@ class Mastodon: | |||
425 | Fetch a card associated with a status. A card describes an object (such as an | 425 | Fetch a card associated with a status. A card describes an object (such as an |
426 | external video or link) embedded into a status. | 426 | external video or link) embedded into a status. |
427 | 427 | ||
428 | Returns a card dict. | 428 | Returns a `card dict`_. |
429 | """ | 429 | """ |
430 | id = self.__unpack_id(id) | 430 | id = self.__unpack_id(id) |
431 | url = '/api/v1/statuses/{0}/card'.format(str(id)) | 431 | url = '/api/v1/statuses/{0}/card'.format(str(id)) |
@@ -436,7 +436,7 @@ class Mastodon: | |||
436 | """ | 436 | """ |
437 | Fetch information about ancestors and descendants of a toot. | 437 | Fetch information about ancestors and descendants of a toot. |
438 | 438 | ||
439 | Returns a context dict. | 439 | Returns a `context dict`_. |
440 | """ | 440 | """ |
441 | id = self.__unpack_id(id) | 441 | id = self.__unpack_id(id) |
442 | url = '/api/v1/statuses/{0}/context'.format(str(id)) | 442 | url = '/api/v1/statuses/{0}/context'.format(str(id)) |
@@ -447,7 +447,7 @@ class Mastodon: | |||
447 | """ | 447 | """ |
448 | Fetch a list of users that have reblogged a status. | 448 | Fetch a list of users that have reblogged a status. |
449 | 449 | ||
450 | Returns a list of user dicts. | 450 | Returns a list of `user dicts`_. |
451 | """ | 451 | """ |
452 | id = self.__unpack_id(id) | 452 | id = self.__unpack_id(id) |
453 | url = '/api/v1/statuses/{0}/reblogged_by'.format(str(id)) | 453 | url = '/api/v1/statuses/{0}/reblogged_by'.format(str(id)) |
@@ -458,7 +458,7 @@ class Mastodon: | |||
458 | """ | 458 | """ |
459 | Fetch a list of users that have favourited a status. | 459 | Fetch a list of users that have favourited a status. |
460 | 460 | ||
461 | Returns a list of user dicts. | 461 | Returns a list of `user dicts`_. |
462 | """ | 462 | """ |
463 | id = self.__unpack_id(id) | 463 | id = self.__unpack_id(id) |
464 | url = '/api/v1/statuses/{0}/favourited_by'.format(str(id)) | 464 | url = '/api/v1/statuses/{0}/favourited_by'.format(str(id)) |
@@ -470,12 +470,12 @@ class Mastodon: | |||
470 | @api_version("1.0.0") | 470 | @api_version("1.0.0") |
471 | def notifications(self, id=None, max_id=None, since_id=None, limit=None): | 471 | def notifications(self, id=None, max_id=None, since_id=None, limit=None): |
472 | """ | 472 | """ |
473 | Fetch notifications (mentions, favourites, reblogs, follows) for the authenticated | 473 | Fetch notifications (mentions, favourites, reblogs, follows) for the logged-in |
474 | user. | 474 | user. |
475 | 475 | ||
476 | Can be passed an id to fetch a single notification. | 476 | Can be passed an `id` to fetch a single notification. |
477 | 477 | ||
478 | Returns a list of notification dicts. | 478 | Returns a list of `notification dicts`_. |
479 | """ | 479 | """ |
480 | if max_id != None: | 480 | if max_id != None: |
481 | max_id = self.__unpack_id(max_id) | 481 | max_id = self.__unpack_id(max_id) |
@@ -497,9 +497,9 @@ class Mastodon: | |||
497 | @api_version("1.0.0") | 497 | @api_version("1.0.0") |
498 | def account(self, id): | 498 | def account(self, id): |
499 | """ | 499 | """ |
500 | Fetch account information by user id. | 500 | Fetch account information by user `id`. |
501 | 501 | ||
502 | Returns a user dict. | 502 | Returns a `user dict`_. |
503 | """ | 503 | """ |
504 | id = self.__unpack_id(id) | 504 | id = self.__unpack_id(id) |
505 | url = '/api/v1/accounts/{0}'.format(str(id)) | 505 | url = '/api/v1/accounts/{0}'.format(str(id)) |
@@ -508,18 +508,21 @@ class Mastodon: | |||
508 | @api_version("1.0.0") | 508 | @api_version("1.0.0") |
509 | def account_verify_credentials(self): | 509 | def account_verify_credentials(self): |
510 | """ | 510 | """ |
511 | Fetch authenticated user's account information. | 511 | Fetch logged-in user's account information. |
512 | 512 | ||
513 | Returns a user dict (Starting from 2.1.0, with an additional "source" field). | 513 | Returns a `user dict`_ (Starting from 2.1.0, with an additional "source" field). |
514 | """ | 514 | """ |
515 | return self.__api_request('GET', '/api/v1/accounts/verify_credentials') | 515 | return self.__api_request('GET', '/api/v1/accounts/verify_credentials') |
516 | 516 | ||
517 | @api_version("1.0.0") | 517 | @api_version("1.0.0") |
518 | def account_statuses(self, id, max_id=None, since_id=None, limit=None): | 518 | def account_statuses(self, id, max_id=None, since_id=None, limit=None): |
519 | """ | 519 | """ |
520 | Fetch statuses by user id. Same options as timeline are permitted. | 520 | Fetch statuses by user `id`. Same options as `timeline()`_ are permitted. |
521 | Returned toots are from the perspective of the logged-in user, i.e. | ||
522 | all statuses visible to the logged-in user (including DMs) are | ||
523 | included. | ||
521 | 524 | ||
522 | Returns a list of toot dicts. | 525 | Returns a list of `toot dicts`_. |
523 | """ | 526 | """ |
524 | id = self.__unpack_id(id) | 527 | id = self.__unpack_id(id) |
525 | if max_id != None: | 528 | if max_id != None: |
@@ -537,7 +540,7 @@ class Mastodon: | |||
537 | """ | 540 | """ |
538 | Fetch users the given user is following. | 541 | Fetch users the given user is following. |
539 | 542 | ||
540 | Returns a list of user dicts. | 543 | Returns a list of `user dicts`_. |
541 | """ | 544 | """ |
542 | id = self.__unpack_id(id) | 545 | id = self.__unpack_id(id) |
543 | if max_id != None: | 546 | if max_id != None: |
@@ -555,7 +558,7 @@ class Mastodon: | |||
555 | """ | 558 | """ |
556 | Fetch users the given user is followed by. | 559 | Fetch users the given user is followed by. |
557 | 560 | ||
558 | Returns a list of user dicts. | 561 | Returns a list of `user dicts`_. |
559 | """ | 562 | """ |
560 | id = self.__unpack_id(id) | 563 | id = self.__unpack_id(id) |
561 | if max_id != None: | 564 | if max_id != None: |
@@ -572,9 +575,9 @@ class Mastodon: | |||
572 | def account_relationships(self, id): | 575 | def account_relationships(self, id): |
573 | """ | 576 | """ |
574 | Fetch relationship (following, followed_by, blocking, follow requested) of | 577 | Fetch relationship (following, followed_by, blocking, follow requested) of |
575 | the logged in user to a given account. id can be a list. | 578 | the logged in user to a given account. `id` can be a list. |
576 | 579 | ||
577 | Returns a list of relationship dicts. | 580 | Returns a list of `relationship dicts`_. |
578 | """ | 581 | """ |
579 | id = self.__unpack_id(id) | 582 | id = self.__unpack_id(id) |
580 | params = self.__generate_params(locals()) | 583 | params = self.__generate_params(locals()) |
@@ -587,7 +590,7 @@ class Mastodon: | |||
587 | Fetch matching accounts. Will lookup an account remotely if the search term is | 590 | Fetch matching accounts. Will lookup an account remotely if the search term is |
588 | in the username@domain format and not yet in the database. | 591 | in the username@domain format and not yet in the database. |
589 | 592 | ||
590 | Returns a list of user dicts. | 593 | Returns a list of `user dicts`_. |
591 | """ | 594 | """ |
592 | params = self.__generate_params(locals()) | 595 | params = self.__generate_params(locals()) |
593 | return self.__api_request('GET', '/api/v1/accounts/search', params) | 596 | return self.__api_request('GET', '/api/v1/accounts/search', params) |
@@ -601,7 +604,7 @@ class Mastodon: | |||
601 | Fetch matching hashtags, accounts and statuses. Will search federated | 604 | Fetch matching hashtags, accounts and statuses. Will search federated |
602 | instances if resolve is True. | 605 | instances if resolve is True. |
603 | 606 | ||
604 | Returns a search result dict. | 607 | Returns a `search result dict`_. |
605 | """ | 608 | """ |
606 | params = self.__generate_params(locals()) | 609 | params = self.__generate_params(locals()) |
607 | return self.__api_request('GET', '/api/v1/search', params) | 610 | return self.__api_request('GET', '/api/v1/search', params) |
@@ -614,7 +617,7 @@ class Mastodon: | |||
614 | """ | 617 | """ |
615 | Fetch a list of all the Lists by the logged-in user. | 618 | Fetch a list of all the Lists by the logged-in user. |
616 | 619 | ||
617 | Returns a list of list dicts. | 620 | Returns a list of `list dicts`_. |
618 | """ | 621 | """ |
619 | return self.__api_request('GET', '/api/v1/lists') | 622 | return self.__api_request('GET', '/api/v1/lists') |
620 | 623 | ||
@@ -624,9 +627,9 @@ class Mastodon: | |||
624 | @api_version("1.1.0") | 627 | @api_version("1.1.0") |
625 | def mutes(self, max_id=None, since_id=None, limit=None): | 628 | def mutes(self, max_id=None, since_id=None, limit=None): |
626 | """ | 629 | """ |
627 | Fetch a list of users muted by the authenticated user. | 630 | Fetch a list of users muted by the logged-in user. |
628 | 631 | ||
629 | Returns a list of user dicts. | 632 | Returns a list of `user dicts`_. |
630 | """ | 633 | """ |
631 | if max_id != None: | 634 | if max_id != None: |
632 | max_id = self.__unpack_id(max_id) | 635 | max_id = self.__unpack_id(max_id) |
@@ -640,9 +643,9 @@ class Mastodon: | |||
640 | @api_version("1.0.0") | 643 | @api_version("1.0.0") |
641 | def blocks(self, max_id=None, since_id=None, limit=None): | 644 | def blocks(self, max_id=None, since_id=None, limit=None): |
642 | """ | 645 | """ |
643 | Fetch a list of users blocked by the authenticated user. | 646 | Fetch a list of users blocked by the logged-in user. |
644 | 647 | ||
645 | Returns a list of user dicts. | 648 | Returns a list of `user dicts`_. |
646 | """ | 649 | """ |
647 | if max_id != None: | 650 | if max_id != None: |
648 | max_id = self.__unpack_id(max_id) | 651 | max_id = self.__unpack_id(max_id) |
@@ -659,12 +662,12 @@ class Mastodon: | |||
659 | @api_version("1.1.0") | 662 | @api_version("1.1.0") |
660 | def reports(self): | 663 | def reports(self): |
661 | """ | 664 | """ |
662 | Fetch a list of reports made by the authenticated user. | 665 | Fetch a list of reports made by the logged-in user. |
663 | 666 | ||
664 | Returns a list of report dicts. | 667 | Returns a list of `report dicts`_. |
665 | 668 | ||
666 | Warning: According to the official API documentation, this | 669 | Warning: According to the official API documentation, this |
667 | method is to be treated as not finalized as of Mastodon 2.0.0. | 670 | method is to be treated as not finalized as of Mastodon 2.1.0. |
668 | """ | 671 | """ |
669 | return self.__api_request('GET', '/api/v1/reports') | 672 | return self.__api_request('GET', '/api/v1/reports') |
670 | 673 | ||
@@ -674,9 +677,9 @@ class Mastodon: | |||
674 | @api_version("1.0.0") | 677 | @api_version("1.0.0") |
675 | def favourites(self, max_id=None, since_id=None, limit=None): | 678 | def favourites(self, max_id=None, since_id=None, limit=None): |
676 | """ | 679 | """ |
677 | Fetch the authenticated user's favourited statuses. | 680 | Fetch the logged-in user's favourited statuses. |
678 | 681 | ||
679 | Returns a list of toot dicts. | 682 | Returns a list of `toot dicts`_. |
680 | """ | 683 | """ |
681 | if max_id != None: | 684 | if max_id != None: |
682 | max_id = self.__unpack_id(max_id) | 685 | max_id = self.__unpack_id(max_id) |
@@ -693,9 +696,9 @@ class Mastodon: | |||
693 | @api_version("1.0.0") | 696 | @api_version("1.0.0") |
694 | def follow_requests(self, max_id=None, since_id=None, limit=None): | 697 | def follow_requests(self, max_id=None, since_id=None, limit=None): |
695 | """ | 698 | """ |
696 | Fetch the authenticated user's incoming follow requests. | 699 | Fetch the logged-in user's incoming follow requests. |
697 | 700 | ||
698 | Returns a list of user dicts. | 701 | Returns a list of `user dicts`_. |
699 | """ | 702 | """ |
700 | if max_id != None: | 703 | if max_id != None: |
701 | max_id = self.__unpack_id(max_id) | 704 | max_id = self.__unpack_id(max_id) |
@@ -712,7 +715,7 @@ class Mastodon: | |||
712 | @api_version("1.4.0") | 715 | @api_version("1.4.0") |
713 | def domain_blocks(self, max_id=None, since_id=None, limit=None): | 716 | def domain_blocks(self, max_id=None, since_id=None, limit=None): |
714 | """ | 717 | """ |
715 | Fetch the authenticated user's blocked domains. | 718 | Fetch the logged-in user's blocked domains. |
716 | 719 | ||
717 | Returns a list of blocked domain URLs (as strings, without protocol specifier). | 720 | Returns a list of blocked domain URLs (as strings, without protocol specifier). |
718 | """ | 721 | """ |
@@ -733,7 +736,7 @@ class Mastodon: | |||
733 | """ | 736 | """ |
734 | Fetch the list of custom emoji the instance has installed. | 737 | Fetch the list of custom emoji the instance has installed. |
735 | 738 | ||
736 | Returns a list of emoji dicts. | 739 | Returns a list of `emoji dicts`_. |
737 | 740 | ||
738 | """ | 741 | """ |
739 | return self.__api_request('GET', '/api/v1/custom_emojis') | 742 | return self.__api_request('GET', '/api/v1/custom_emojis') |
@@ -746,11 +749,11 @@ class Mastodon: | |||
746 | sensitive=False, visibility='', spoiler_text=None): | 749 | sensitive=False, visibility='', spoiler_text=None): |
747 | """ | 750 | """ |
748 | Post a status. Can optionally be in reply to another status and contain | 751 | Post a status. Can optionally be in reply to another status and contain |
749 | up to four pieces of media (Uploaded via media_post()). media_ids can | 752 | up to four pieces of media (Uploaded via `media_post()`_). media_ids can |
750 | also be the media dicts returned by media_post - they are unpacked | 753 | also be the `media dicts`_ returned by `media_post()`_ - they are unpacked |
751 | automatically. | 754 | automatically. |
752 | 755 | ||
753 | The 'sensitive' boolean decides whether or not media attached to the post | 756 | The `sensitive` boolean decides whether or not media attached to the post |
754 | should be marked as sensitive, which hides it by default on the Mastodon | 757 | should be marked as sensitive, which hides it by default on the Mastodon |
755 | web front-end. | 758 | web front-end. |
756 | 759 | ||
@@ -766,11 +769,11 @@ class Mastodon: | |||
766 | locked setting - private if the account is locked, public otherwise | 769 | locked setting - private if the account is locked, public otherwise |
767 | (for Mastodon versions lower than 1.6). | 770 | (for Mastodon versions lower than 1.6). |
768 | 771 | ||
769 | The spoiler_text parameter is a string to be shown as a warning before | 772 | The `spoiler_text` parameter is a string to be shown as a warning before |
770 | the text of the status. If no text is passed in, no warning will be | 773 | the text of the status. If no text is passed in, no warning will be |
771 | displayed. | 774 | displayed. |
772 | 775 | ||
773 | Returns a toot dict with the new status. | 776 | Returns a `toot dict`_ with the new status. |
774 | """ | 777 | """ |
775 | if in_reply_to_id != None: | 778 | if in_reply_to_id != None: |
776 | in_reply_to_id = self.__unpack_id(in_reply_to_id) | 779 | in_reply_to_id = self.__unpack_id(in_reply_to_id) |
@@ -806,11 +809,11 @@ class Mastodon: | |||
806 | @api_version("1.0.0") | 809 | @api_version("1.0.0") |
807 | def toot(self, status): | 810 | def toot(self, status): |
808 | """ | 811 | """ |
809 | Synonym for status_post that only takes the status text as input. | 812 | Synonym for `status_post()`_ that only takes the status text as input. |
810 | 813 | ||
811 | Usage in production code is not recommended. | 814 | Usage in production code is not recommended. |
812 | 815 | ||
813 | Returns a toot dict with the new status. | 816 | Returns a `toot dict`_ with the new status. |
814 | """ | 817 | """ |
815 | return self.status_post(status) | 818 | return self.status_post(status) |
816 | 819 | ||
@@ -818,19 +821,17 @@ class Mastodon: | |||
818 | def status_delete(self, id): | 821 | def status_delete(self, id): |
819 | """ | 822 | """ |
820 | Delete a status | 823 | Delete a status |
821 | |||
822 | Returns an empty dict for good measure. | ||
823 | """ | 824 | """ |
824 | id = self.__unpack_id(id) | 825 | id = self.__unpack_id(id) |
825 | url = '/api/v1/statuses/{0}'.format(str(id)) | 826 | url = '/api/v1/statuses/{0}'.format(str(id)) |
826 | return self.__api_request('DELETE', url) | 827 | self.__api_request('DELETE', url) |
827 | 828 | ||
828 | @api_version("1.0.0") | 829 | @api_version("1.0.0") |
829 | def status_reblog(self, id): | 830 | def status_reblog(self, id): |
830 | """ | 831 | """ |
831 | Reblog a status. | 832 | Reblog a status. |
832 | 833 | ||
833 | Returns a toot dict with a new status that wraps around the reblogged one. | 834 | Returns a `toot dict`_ with a new status that wraps around the reblogged one. |
834 | """ | 835 | """ |
835 | id = self.__unpack_id(id) | 836 | id = self.__unpack_id(id) |
836 | url = '/api/v1/statuses/{0}/reblog'.format(str(id)) | 837 | url = '/api/v1/statuses/{0}/reblog'.format(str(id)) |
@@ -841,7 +842,7 @@ class Mastodon: | |||
841 | """ | 842 | """ |
842 | Un-reblog a status. | 843 | Un-reblog a status. |
843 | 844 | ||
844 | Returns a toot dict with the status that used to be reblogged. | 845 | Returns a `toot dict`_ with the status that used to be reblogged. |
845 | """ | 846 | """ |
846 | id = self.__unpack_id(id) | 847 | id = self.__unpack_id(id) |
847 | url = '/api/v1/statuses/{0}/unreblog'.format(str(id)) | 848 | url = '/api/v1/statuses/{0}/unreblog'.format(str(id)) |
@@ -852,7 +853,7 @@ class Mastodon: | |||
852 | """ | 853 | """ |
853 | Favourite a status. | 854 | Favourite a status. |
854 | 855 | ||
855 | Returns a toot dict with the favourited status. | 856 | Returns a `toot dict`_ with the favourited status. |
856 | """ | 857 | """ |
857 | id = self.__unpack_id(id) | 858 | id = self.__unpack_id(id) |
858 | url = '/api/v1/statuses/{0}/favourite'.format(str(id)) | 859 | url = '/api/v1/statuses/{0}/favourite'.format(str(id)) |
@@ -863,7 +864,7 @@ class Mastodon: | |||
863 | """ | 864 | """ |
864 | Un-favourite a status. | 865 | Un-favourite a status. |
865 | 866 | ||
866 | Returns a toot dict with the un-favourited status. | 867 | Returns a `toot dict`_ with the un-favourited status. |
867 | """ | 868 | """ |
868 | id = self.__unpack_id(id) | 869 | id = self.__unpack_id(id) |
869 | url = '/api/v1/statuses/{0}/unfavourite'.format(str(id)) | 870 | url = '/api/v1/statuses/{0}/unfavourite'.format(str(id)) |
@@ -874,7 +875,7 @@ class Mastodon: | |||
874 | """ | 875 | """ |
875 | Mute notifications for a status. | 876 | Mute notifications for a status. |
876 | 877 | ||
877 | Returns a toot dict with the now muted status | 878 | Returns a `toot dict`_ with the now muted status |
878 | """ | 879 | """ |
879 | id = self.__unpack_id(id) | 880 | id = self.__unpack_id(id) |
880 | url = '/api/v1/statuses/{0}/mute'.format(str(id)) | 881 | url = '/api/v1/statuses/{0}/mute'.format(str(id)) |
@@ -885,7 +886,7 @@ class Mastodon: | |||
885 | """ | 886 | """ |
886 | Unmute notifications for a status. | 887 | Unmute notifications for a status. |
887 | 888 | ||
888 | Returns a toot dict with the status that used to be muted. | 889 | Returns a `toot dict`_ with the status that used to be muted. |
889 | """ | 890 | """ |
890 | id = self.__unpack_id(id) | 891 | id = self.__unpack_id(id) |
891 | url = '/api/v1/statuses/{0}/unmute'.format(str(id)) | 892 | url = '/api/v1/statuses/{0}/unmute'.format(str(id)) |
@@ -899,7 +900,7 @@ class Mastodon: | |||
899 | """ | 900 | """ |
900 | Clear out a users notifications | 901 | Clear out a users notifications |
901 | """ | 902 | """ |
902 | return self.__api_request('POST', '/api/v1/notifications/clear') | 903 | self.__api_request('POST', '/api/v1/notifications/clear') |
903 | 904 | ||
904 | 905 | ||
905 | @api_version("1.3.0") | 906 | @api_version("1.3.0") |
@@ -909,7 +910,7 @@ class Mastodon: | |||
909 | """ | 910 | """ |
910 | id = self.__unpack_id(id) | 911 | id = self.__unpack_id(id) |
911 | params = self.__generate_params(locals()) | 912 | params = self.__generate_params(locals()) |
912 | return self.__api_request('POST', '/api/v1/notifications/dismiss', params) | 913 | self.__api_request('POST', '/api/v1/notifications/dismiss', params) |
913 | 914 | ||
914 | ### | 915 | ### |
915 | # Writing data: Accounts | 916 | # Writing data: Accounts |
@@ -919,7 +920,7 @@ class Mastodon: | |||
919 | """ | 920 | """ |
920 | Follow a user. | 921 | Follow a user. |
921 | 922 | ||
922 | Returns a relationship dict containing the updated relationship to the user. | 923 | Returns a `relationship dict`_ containing the updated relationship to the user. |
923 | """ | 924 | """ |
924 | id = self.__unpack_id(id) | 925 | id = self.__unpack_id(id) |
925 | url = '/api/v1/accounts/{0}/follow'.format(str(id)) | 926 | url = '/api/v1/accounts/{0}/follow'.format(str(id)) |
@@ -930,7 +931,7 @@ class Mastodon: | |||
930 | """ | 931 | """ |
931 | Follow a remote user by uri (username@domain). | 932 | Follow a remote user by uri (username@domain). |
932 | 933 | ||
933 | Returns a user dict. | 934 | Returns a `user dict`_. |
934 | """ | 935 | """ |
935 | params = self.__generate_params(locals()) | 936 | params = self.__generate_params(locals()) |
936 | return self.__api_request('POST', '/api/v1/follows', params) | 937 | return self.__api_request('POST', '/api/v1/follows', params) |
@@ -940,7 +941,7 @@ class Mastodon: | |||
940 | """ | 941 | """ |
941 | Unfollow a user. | 942 | Unfollow a user. |
942 | 943 | ||
943 | Returns a relationship dict containing the updated relationship to the user. | 944 | Returns a `relationship dict`_ containing the updated relationship to the user. |
944 | """ | 945 | """ |
945 | id = self.__unpack_id(id) | 946 | id = self.__unpack_id(id) |
946 | url = '/api/v1/accounts/{0}/unfollow'.format(str(id)) | 947 | url = '/api/v1/accounts/{0}/unfollow'.format(str(id)) |
@@ -951,7 +952,7 @@ class Mastodon: | |||
951 | """ | 952 | """ |
952 | Block a user. | 953 | Block a user. |
953 | 954 | ||
954 | Returns a relationship dict containing the updated relationship to the user. | 955 | Returns a `relationship dict`_ containing the updated relationship to the user. |
955 | """ | 956 | """ |
956 | id = self.__unpack_id(id) | 957 | id = self.__unpack_id(id) |
957 | url = '/api/v1/accounts/{0}/block'.format(str(id)) | 958 | url = '/api/v1/accounts/{0}/block'.format(str(id)) |
@@ -962,7 +963,7 @@ class Mastodon: | |||
962 | """ | 963 | """ |
963 | Unblock a user. | 964 | Unblock a user. |
964 | 965 | ||
965 | Returns a relationship dict containing the updated relationship to the user. | 966 | Returns a `relationship dict`_ containing the updated relationship to the user. |
966 | """ | 967 | """ |
967 | id = self.__unpack_id(id) | 968 | id = self.__unpack_id(id) |
968 | url = '/api/v1/accounts/{0}/unblock'.format(str(id)) | 969 | url = '/api/v1/accounts/{0}/unblock'.format(str(id)) |
@@ -973,7 +974,7 @@ class Mastodon: | |||
973 | """ | 974 | """ |
974 | Mute a user. | 975 | Mute a user. |
975 | 976 | ||
976 | Returns a relationship dict containing the updated relationship to the user. | 977 | Returns a `relationship dict`_ containing the updated relationship to the user. |
977 | """ | 978 | """ |
978 | id = self.__unpack_id(id) | 979 | id = self.__unpack_id(id) |
979 | url = '/api/v1/accounts/{0}/mute'.format(str(id)) | 980 | url = '/api/v1/accounts/{0}/mute'.format(str(id)) |
@@ -984,7 +985,7 @@ class Mastodon: | |||
984 | """ | 985 | """ |
985 | Unmute a user. | 986 | Unmute a user. |
986 | 987 | ||
987 | Returns a relationship dict containing the updated relationship to the user. | 988 | Returns a `relationship dict`_ containing the updated relationship to the user. |
988 | """ | 989 | """ |
989 | id = self.__unpack_id(id) | 990 | id = self.__unpack_id(id) |
990 | url = '/api/v1/accounts/{0}/unmute'.format(str(id)) | 991 | url = '/api/v1/accounts/{0}/unmute'.format(str(id)) |
@@ -994,12 +995,14 @@ class Mastodon: | |||
994 | def account_update_credentials(self, display_name=None, note=None, | 995 | def account_update_credentials(self, display_name=None, note=None, |
995 | avatar=None, header=None): | 996 | avatar=None, header=None): |
996 | """ | 997 | """ |
997 | Update the profile for the currently authenticated user. | 998 | Update the profile for the currently logged-in user. |
998 | 999 | ||
999 | 'note' is the user's bio. | 1000 | 'note' is the user's bio. |
1000 | 1001 | ||
1001 | 'avatar' and 'header' are images encoded in base64, prepended by a content-type | 1002 | 'avatar' and 'header' are images encoded in base64, prepended by a content-type |
1002 | (for example: '[...]') | 1003 | (for example: '[...]') |
1004 | |||
1005 | Returns the updated `user dict` of the logged-in user. | ||
1003 | """ | 1006 | """ |
1004 | params = self.__generate_params(locals()) | 1007 | params = self.__generate_params(locals()) |
1005 | return self.__api_request('PATCH', '/api/v1/accounts/update_credentials', params) | 1008 | return self.__api_request('PATCH', '/api/v1/accounts/update_credentials', params) |
@@ -1014,7 +1017,7 @@ class Mastodon: | |||
1014 | 1017 | ||
1015 | Accepts a list of toot IDs associated with the report, and a comment. | 1018 | Accepts a list of toot IDs associated with the report, and a comment. |
1016 | 1019 | ||
1017 | Returns a report dict. | 1020 | Returns a `report dict`_. |
1018 | """ | 1021 | """ |
1019 | account_id = self.__unpack_id(account_id) | 1022 | account_id = self.__unpack_id(account_id) |
1020 | status_ids = map(lambda x: self.__unpack_id(x), status_ids) | 1023 | status_ids = map(lambda x: self.__unpack_id(x), status_ids) |
@@ -1028,23 +1031,19 @@ class Mastodon: | |||
1028 | def follow_request_authorize(self, id): | 1031 | def follow_request_authorize(self, id): |
1029 | """ | 1032 | """ |
1030 | Accept an incoming follow request. | 1033 | Accept an incoming follow request. |
1031 | |||
1032 | Returns an empty dict. | ||
1033 | """ | 1034 | """ |
1034 | id = self.__unpack_id(id) | 1035 | id = self.__unpack_id(id) |
1035 | url = '/api/v1/follow_requests/{0}/authorize'.format(str(id)) | 1036 | url = '/api/v1/follow_requests/{0}/authorize'.format(str(id)) |
1036 | return self.__api_request('POST', url) | 1037 | self.__api_request('POST', url) |
1037 | 1038 | ||
1038 | @api_version("1.0.0") | 1039 | @api_version("1.0.0") |
1039 | def follow_request_reject(self, id): | 1040 | def follow_request_reject(self, id): |
1040 | """ | 1041 | """ |
1041 | Reject an incoming follow request. | 1042 | Reject an incoming follow request. |
1042 | |||
1043 | Returns an empty dict. | ||
1044 | """ | 1043 | """ |
1045 | id = self.__unpack_id(id) | 1044 | id = self.__unpack_id(id) |
1046 | url = '/api/v1/follow_requests/{0}/reject'.format(str(id)) | 1045 | url = '/api/v1/follow_requests/{0}/reject'.format(str(id)) |
1047 | return self.__api_request('POST', url) | 1046 | self.__api_request('POST', url) |
1048 | 1047 | ||
1049 | ### | 1048 | ### |
1050 | # Writing data: Media | 1049 | # Writing data: Media |
@@ -1052,15 +1051,15 @@ class Mastodon: | |||
1052 | @api_version("1.0.0") | 1051 | @api_version("1.0.0") |
1053 | def media_post(self, media_file, mime_type=None, description=None): | 1052 | def media_post(self, media_file, mime_type=None, description=None): |
1054 | """ | 1053 | """ |
1055 | Post an image. media_file can either be image data or | 1054 | Post an image. `media_file` can either be image data or |
1056 | a file name. If image data is passed directly, the mime | 1055 | a file name. If image data is passed directly, the mime |
1057 | type has to be specified manually, otherwise, it is | 1056 | type has to be specified manually, otherwise, it is |
1058 | determined from the file name. | 1057 | determined from the file name. |
1059 | 1058 | ||
1060 | Throws a MastodonIllegalArgumentError if the mime type of the | 1059 | Throws a `MastodonIllegalArgumentError` if the mime type of the |
1061 | passed data or file can not be determined properly. | 1060 | passed data or file can not be determined properly. |
1062 | 1061 | ||
1063 | Returns a media dict. This contains the id that can be used in | 1062 | Returns a `media dict`_. This contains the id that can be used in |
1064 | status_post to attach the media file to a toot. | 1063 | status_post to attach the media file to a toot. |
1065 | """ | 1064 | """ |
1066 | if mime_type is None and os.path.isfile(media_file): | 1065 | if mime_type is None and os.path.isfile(media_file): |
@@ -1090,7 +1089,7 @@ class Mastodon: | |||
1090 | Add a block for all statuses originating from the specified domain for the logged-in user. | 1089 | Add a block for all statuses originating from the specified domain for the logged-in user. |
1091 | """ | 1090 | """ |
1092 | params = self.__generate_params(locals()) | 1091 | params = self.__generate_params(locals()) |
1093 | return self.__api_request('POST', '/api/v1/domain_blocks', params) | 1092 | self.__api_request('POST', '/api/v1/domain_blocks', params) |
1094 | 1093 | ||
1095 | @api_version("1.4.0") | 1094 | @api_version("1.4.0") |
1096 | def domain_unblock(self, domain=None): | 1095 | def domain_unblock(self, domain=None): |
@@ -1098,7 +1097,7 @@ class Mastodon: | |||
1098 | Remove a domain block for the logged-in user. | 1097 | Remove a domain block for the logged-in user. |
1099 | """ | 1098 | """ |
1100 | params = self.__generate_params(locals()) | 1099 | params = self.__generate_params(locals()) |
1101 | return self.__api_request('DELETE', '/api/v1/domain_blocks', params) | 1100 | self.__api_request('DELETE', '/api/v1/domain_blocks', params) |
1102 | 1101 | ||
1103 | ### | 1102 | ### |
1104 | # Pagination | 1103 | # Pagination |