Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
* add support for 3.5 api * removed "unused" import by accident * Hardcoded values Appearantly TG decided to change the size of a send image (again) * test_official * Improve coverage * Finishing up * spelling error * pytest fixed tot < than 3.3 for python 3.3 support * flake8 * rollback requirements * as per CR * object for provider_data Make it possible to send an object that will be json-serialized for send_invoice + tests * shorten error message * using string_types
- Loading branch information
Showing
16 changed files
with
434 additions
and
16 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,6 @@ | ||
telegram.InputMedia | ||
=================== | ||
|
||
.. autoclass:: telegram.InputMedia | ||
:members: | ||
:show-inheritance: |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,6 @@ | ||
telegram.InputMediaPhoto | ||
======================== | ||
|
||
.. autoclass:: telegram.InputMediaPhoto | ||
:members: | ||
:show-inheritance: |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,6 @@ | ||
telegram.InputMediaVideo | ||
======================== | ||
|
||
.. autoclass:: telegram.InputMediaVideo | ||
:members: | ||
:show-inheritance: |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,31 @@ | ||
#!/usr/bin/env python | ||
# | ||
# A library that provides a Python interface to the Telegram Bot API | ||
# Copyright (C) 2015-2017 | ||
# Leandro Toledo de Souza <devs@python-telegram-bot.org> | ||
# | ||
# This program is free software: you can redistribute it and/or modify | ||
# it under the terms of the GNU Lesser Public License as published by | ||
# the Free Software Foundation, either version 3 of the License, or | ||
# (at your option) any later version. | ||
# | ||
# This program is distributed in the hope that it will be useful, | ||
# but WITHOUT ANY WARRANTY; without even the implied warranty of | ||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | ||
# GNU Lesser Public License for more details. | ||
# | ||
# You should have received a copy of the GNU Lesser Public License | ||
# along with this program. If not, see [http://www.gnu.org/licenses/]. | ||
"""Base class for Telegram InputMedia Objects.""" | ||
|
||
from telegram import TelegramObject | ||
|
||
|
||
class InputMedia(TelegramObject): | ||
"""Base class for Telegram InputMedia Objects. | ||
See :class:`telegram.InputMediaPhoto` and :class:`telegram.InputMediaVideo` for | ||
detailed use. | ||
""" | ||
pass |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,57 @@ | ||
#!/usr/bin/env python | ||
# | ||
# A library that provides a Python interface to the Telegram Bot API | ||
# Copyright (C) 2015-2017 | ||
# Leandro Toledo de Souza <devs@python-telegram-bot.org> | ||
# | ||
# This program is free software: you can redistribute it and/or modify | ||
# it under the terms of the GNU Lesser Public License as published by | ||
# the Free Software Foundation, either version 3 of the License, or | ||
# (at your option) any later version. | ||
# | ||
# This program is distributed in the hope that it will be useful, | ||
# but WITHOUT ANY WARRANTY; without even the implied warranty of | ||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | ||
# GNU Lesser Public License for more details. | ||
# | ||
# You should have received a copy of the GNU Lesser Public License | ||
# along with this program. If not, see [http://www.gnu.org/licenses/]. | ||
"""This module contains an object that represents a Telegram InputMediaPhoto.""" | ||
from telegram import InputMedia, PhotoSize | ||
|
||
|
||
class InputMediaPhoto(InputMedia): | ||
"""Represents a photo to be sent. | ||
Attributes: | ||
type (:obj:`str`): ``photo``. | ||
media (:obj:`str`): File to send. Pass a file_id to send a file that exists on the | ||
Telegram servers (recommended), pass an HTTP URL for Telegram to get a file from the | ||
Internet. Lastly you can pass an existing :class:`telegram.PhotoSize` object to send. | ||
caption (:obj:`str`): Optional. Caption of the photo to be sent, 0-200 characters. | ||
Args: | ||
media (:obj:`str`): File to send. Pass a file_id to send a file that exists on the | ||
Telegram servers (recommended), pass an HTTP URL for Telegram to get a file from the | ||
Internet. Lastly you can pass an existing :class:`telegram.PhotoSize` object to send. | ||
caption (:obj:`str`, optional ): Caption of the photo to be sent, 0-200 characters. | ||
Note: | ||
At the moment using a new file is not yet supported. | ||
""" | ||
|
||
# TODO: Make InputMediaPhoto, InputMediaVideo and send_media_group work with new files | ||
|
||
def __init__(self, media, caption=None): | ||
self.type = 'photo' | ||
|
||
if isinstance(media, PhotoSize): | ||
self.media = media.file_id | ||
elif hasattr(media, 'read'): | ||
raise ValueError( | ||
'Sending files is not supported (yet). Use file_id, url or PhotoSize') | ||
else: | ||
self.media = media | ||
|
||
if caption: | ||
self.caption = caption |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,74 @@ | ||
#!/usr/bin/env python | ||
# | ||
# A library that provides a Python interface to the Telegram Bot API | ||
# Copyright (C) 2015-2017 | ||
# Leandro Toledo de Souza <devs@python-telegram-bot.org> | ||
# | ||
# This program is free software: you can redistribute it and/or modify | ||
# it under the terms of the GNU Lesser Public License as published by | ||
# the Free Software Foundation, either version 3 of the License, or | ||
# (at your option) any later version. | ||
# | ||
# This program is distributed in the hope that it will be useful, | ||
# but WITHOUT ANY WARRANTY; without even the implied warranty of | ||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | ||
# GNU Lesser Public License for more details. | ||
# | ||
# You should have received a copy of the GNU Lesser Public License | ||
# along with this program. If not, see [http://www.gnu.org/licenses/]. | ||
"""This module contains an object that represents a Telegram InputMediaPhoto.""" | ||
from telegram import InputMedia, Video | ||
|
||
|
||
class InputMediaVideo(InputMedia): | ||
"""Represents a video to be sent. | ||
Attributes: | ||
type (:obj:`str`): ``video``. | ||
media (:obj:`str`): File to send. Pass a file_id to send a file that exists on the Telegram | ||
servers (recommended), pass an HTTP URL for Telegram to get a file from the Internet. | ||
Lastly you can pass an existing :class:`telegram.Video` object to send. | ||
caption (:obj:`str`): Optional. Caption of the video to be sent, 0-200 characters. | ||
width (:obj:`int`): Optional. Video width. | ||
height (:obj:`int`): Optional. Video height. | ||
duration (:obj:`int`): Optional. Video duration. | ||
Args: | ||
media (:obj:`str`): File to send. Pass a file_id to send a file that exists on the Telegram | ||
servers (recommended), pass an HTTP URL for Telegram to get a file from the Internet. | ||
Lastly you can pass an existing :class:`telegram.Video` object to send. | ||
caption (:obj:`str`, optional): Caption of the video to be sent, 0-200 characters. | ||
width (:obj:`int`, optional): Video width. | ||
height (:obj:`int`, optional): Video height. | ||
duration (:obj:`int`, optional): Video duration. | ||
Note: | ||
When using a :class:`telegram.Video` for the :attr:`media` attribute. It will take the | ||
width, height and duration from that video, unless otherwise specified with the optional | ||
arguments. | ||
At the moment using a new file is not yet supported. | ||
""" | ||
|
||
# TODO: Make InputMediaPhoto, InputMediaVideo and send_media_group work with new files | ||
|
||
def __init__(self, media, caption=None, width=None, height=None, duration=None): | ||
self.type = 'video' | ||
|
||
if isinstance(media, Video): | ||
self.media = media.file_id | ||
self.width = media.width | ||
self.height = media.height | ||
self.duration = media.duration | ||
elif hasattr(media, 'read'): | ||
raise ValueError('Sending files is not supported (yet). Use file_id, url or Video') | ||
else: | ||
self.media = media | ||
|
||
if caption: | ||
self.caption = caption | ||
if width: | ||
self.width = width | ||
if height: | ||
self.height = height | ||
if duration: | ||
self.duration = duration |
Oops, something went wrong.