mirror of
https://github.com/LonamiWebs/Telethon.git
synced 2024-11-22 09:26:37 +03:00
Allow passing entities instead input_peers and more*
Some fixes to the interactive client (not handling invalid options, errors when uploading files)
This commit is contained in:
parent
8e48455cdc
commit
9ca4471bcd
|
@ -3,7 +3,7 @@ from getpass import getpass
|
|||
|
||||
from telethon import RPCError, TelegramClient
|
||||
from telethon.tl.types import UpdateShortChatMessage, UpdateShortMessage
|
||||
from telethon.utils import get_display_name, get_input_peer
|
||||
from telethon.utils import get_display_name
|
||||
|
||||
# Get the (current) number of lines in the terminal
|
||||
cols, rows = shutil.get_terminal_size()
|
||||
|
@ -106,11 +106,10 @@ class InteractiveTelegramClient(TelegramClient):
|
|||
i = None
|
||||
|
||||
except ValueError:
|
||||
pass
|
||||
i = None
|
||||
|
||||
# Retrieve the selected user (or chat, or channel)
|
||||
entity = entities[i]
|
||||
input_peer = get_input_peer(entity)
|
||||
|
||||
# Show some information
|
||||
print_title('Chat with "{}"'.format(get_display_name(entity)))
|
||||
|
@ -141,7 +140,7 @@ class InteractiveTelegramClient(TelegramClient):
|
|||
elif msg == '!h':
|
||||
# First retrieve the messages and some information
|
||||
total_count, messages, senders = self.get_message_history(
|
||||
input_peer, limit=10)
|
||||
entity, limit=10)
|
||||
# Iterate over all (in reverse order so the latest appears the last in the console)
|
||||
# and print them in "[hh:mm] Sender: Message" text format
|
||||
for msg, sender in zip(
|
||||
|
@ -166,17 +165,17 @@ class InteractiveTelegramClient(TelegramClient):
|
|||
# Send photo
|
||||
elif msg.startswith('!up '):
|
||||
# Slice the message to get the path
|
||||
self.send_photo(path=msg[len('!p '):], peer=input_peer)
|
||||
self.send_photo(path=msg[len('!up '):], entity=entity)
|
||||
|
||||
# Send file (document)
|
||||
elif msg.startswith('!uf '):
|
||||
# Slice the message to get the path
|
||||
self.send_document(path=msg[len('!f '):], peer=input_peer)
|
||||
self.send_document(path=msg[len('!uf '):], entity=entity)
|
||||
|
||||
# Download media
|
||||
elif msg.startswith('!dm '):
|
||||
# Slice the message to get message ID
|
||||
self.download_media(msg[len('!d '):])
|
||||
self.download_media(msg[len('!dm '):])
|
||||
|
||||
# Download profile photo
|
||||
elif msg == '!dp':
|
||||
|
@ -193,24 +192,24 @@ class InteractiveTelegramClient(TelegramClient):
|
|||
# Send chat message (if any)
|
||||
elif msg:
|
||||
self.send_message(
|
||||
input_peer, msg, markdown=True, no_web_page=True)
|
||||
entity, msg, markdown=True, no_web_page=True)
|
||||
|
||||
def send_photo(self, path, peer):
|
||||
def send_photo(self, path, entity):
|
||||
print('Uploading {}...'.format(path))
|
||||
input_file = self.upload_file(
|
||||
path, progress_callback=self.upload_progress_callback)
|
||||
|
||||
# After we have the handle to the uploaded file, send it to our peer
|
||||
self.send_photo_file(input_file, peer)
|
||||
self.send_photo_file(input_file, entity)
|
||||
print('Photo sent!')
|
||||
|
||||
def send_document(self, path, peer):
|
||||
def send_document(self, path, entity):
|
||||
print('Uploading {}...'.format(path))
|
||||
input_file = self.upload_file(
|
||||
path, progress_callback=self.upload_progress_callback)
|
||||
|
||||
# After we have the handle to the uploaded file, send it to our peer
|
||||
self.send_document_file(input_file, peer)
|
||||
self.send_document_file(input_file, entity)
|
||||
print('Document sent!')
|
||||
|
||||
def download_media(self, media_id):
|
||||
|
|
|
@ -33,8 +33,8 @@ from telethon.tl.types import (
|
|||
InputMediaUploadedDocument, InputMediaUploadedPhoto, InputPeerEmpty,
|
||||
MessageMediaContact, MessageMediaDocument, MessageMediaPhoto,
|
||||
UserProfilePhotoEmpty)
|
||||
from telethon.utils import (find_user_or_chat, get_appropiate_part_size,
|
||||
get_extension)
|
||||
from telethon.utils import (find_user_or_chat, get_input_peer,
|
||||
get_appropiate_part_size, get_extension)
|
||||
|
||||
|
||||
class TelegramClient:
|
||||
|
@ -282,11 +282,11 @@ class TelegramClient:
|
|||
# region Message requests
|
||||
|
||||
def send_message(self,
|
||||
input_peer,
|
||||
entity,
|
||||
message,
|
||||
markdown=False,
|
||||
no_web_page=False):
|
||||
"""Sends a message to the given input peer and returns the sent message ID"""
|
||||
"""Sends a message to the given entity (or input peer) and returns the sent message ID"""
|
||||
if markdown:
|
||||
msg, entities = parse_message_entities(message)
|
||||
else:
|
||||
|
@ -295,7 +295,7 @@ class TelegramClient:
|
|||
msg_id = utils.generate_random_long()
|
||||
self.invoke(
|
||||
SendMessageRequest(
|
||||
peer=input_peer,
|
||||
peer=get_input_peer(entity),
|
||||
message=msg,
|
||||
random_id=msg_id,
|
||||
entities=entities,
|
||||
|
@ -303,7 +303,7 @@ class TelegramClient:
|
|||
return msg_id
|
||||
|
||||
def get_message_history(self,
|
||||
input_peer,
|
||||
entity,
|
||||
limit=20,
|
||||
offset_date=None,
|
||||
offset_id=0,
|
||||
|
@ -311,9 +311,9 @@ class TelegramClient:
|
|||
min_id=0,
|
||||
add_offset=0):
|
||||
"""
|
||||
Gets the message history for the specified InputPeer
|
||||
Gets the message history for the specified entity
|
||||
|
||||
:param input_peer: The InputPeer from whom to retrieve the message history
|
||||
:param entity: The entity (or input peer) from whom to retrieve the message history
|
||||
:param limit: Number of messages to be retrieved
|
||||
:param offset_date: Offset date (messages *previous* to this date will be retrieved)
|
||||
:param offset_id: Offset message ID (only messages *previous* to the given ID will be retrieved)
|
||||
|
@ -326,7 +326,7 @@ class TelegramClient:
|
|||
"""
|
||||
result = self.invoke(
|
||||
GetHistoryRequest(
|
||||
input_peer,
|
||||
get_input_peer(entity),
|
||||
limit=limit,
|
||||
offset_date=offset_date,
|
||||
offset_id=offset_id,
|
||||
|
@ -349,7 +349,7 @@ class TelegramClient:
|
|||
|
||||
return total_messages, result.messages, users
|
||||
|
||||
def send_read_acknowledge(self, input_peer, messages=None, max_id=None):
|
||||
def send_read_acknowledge(self, entity, messages=None, max_id=None):
|
||||
"""Sends a "read acknowledge" (i.e., notifying the given peer that we've
|
||||
read their messages, also known as the "double check ✅✅").
|
||||
|
||||
|
@ -367,7 +367,7 @@ class TelegramClient:
|
|||
else:
|
||||
max_id = messages.id
|
||||
|
||||
return self.invoke(ReadHistoryRequest(peer=input_peer, max_id=max_id))
|
||||
return self.invoke(ReadHistoryRequest(peer=get_input_peer(entity), max_id=max_id))
|
||||
|
||||
# endregion
|
||||
|
||||
|
@ -445,15 +445,15 @@ class TelegramClient:
|
|||
name=file_name,
|
||||
md5_checksum=hash_md5.hexdigest())
|
||||
|
||||
def send_photo_file(self, input_file, input_peer, caption=''):
|
||||
def send_photo_file(self, input_file, entity, caption=''):
|
||||
"""Sends a previously uploaded input_file
|
||||
(which should be a photo) to an input_peer"""
|
||||
(which should be a photo) to the given entity (or input peer)"""
|
||||
self.send_media_file(
|
||||
InputMediaUploadedPhoto(input_file, caption), input_peer)
|
||||
InputMediaUploadedPhoto(input_file, caption), entity)
|
||||
|
||||
def send_document_file(self, input_file, input_peer, caption=''):
|
||||
def send_document_file(self, input_file, entity, caption=''):
|
||||
"""Sends a previously uploaded input_file
|
||||
(which should be a document) to an input_peer"""
|
||||
(which should be a document) to the given entity (or input peer)"""
|
||||
|
||||
# Determine mime-type and attributes
|
||||
# Take the first element by using [0] since it returns a tuple
|
||||
|
@ -473,13 +473,13 @@ class TelegramClient:
|
|||
mime_type=mime_type,
|
||||
attributes=attributes,
|
||||
caption=caption),
|
||||
input_peer)
|
||||
entity)
|
||||
|
||||
def send_media_file(self, input_media, input_peer):
|
||||
"""Sends any input_media (contact, document, photo...) to an input_peer"""
|
||||
def send_media_file(self, input_media, entity):
|
||||
"""Sends any input_media (contact, document, photo...) to the given entiy"""
|
||||
self.invoke(
|
||||
SendMediaRequest(
|
||||
peer=input_peer,
|
||||
peer=get_input_peer(entity),
|
||||
media=input_media,
|
||||
random_id=utils.generate_random_long()))
|
||||
|
||||
|
|
|
@ -44,6 +44,11 @@ def get_extension(media):
|
|||
def get_input_peer(entity):
|
||||
"""Gets the input peer for the given "entity" (user, chat or channel).
|
||||
Returns None if it was not found"""
|
||||
if (isinstance(entity, InputPeerUser) or
|
||||
isinstance(entity, InputPeerChat) or
|
||||
isinstance(entity, InputPeerChannel)):
|
||||
return entity
|
||||
|
||||
if isinstance(entity, User):
|
||||
return InputPeerUser(entity.id, entity.access_hash)
|
||||
if isinstance(entity, Chat):
|
||||
|
|
Loading…
Reference in New Issue
Block a user