5 Commits

Author SHA1 Message Date
Galen Reich
b9380e001a Fix missing info (#17)
* Use the user object from user deletion instead of user import
* Bump version
2024-02-13 15:23:52 +00:00
Galen Reich
fe57ce1443 Match accounts by id instead of username (#15)
* Replace account matching by (optional) username with (mandatory) id field
* Use get instead of direct key retrieval
* Bump version
2024-02-12 15:03:12 +00:00
msramalho
4011e916c8 removes unused imports 2024-02-08 17:50:41 +00:00
msramalho
2a503856c2 fix poetry build default env file is empty 2024-02-08 15:08:35 +00:00
msramalho
d7f5415a4e fixes .env not working from CLI 2024-02-08 12:52:50 +00:00
2 changed files with 24 additions and 17 deletions

View File

@@ -1,6 +1,6 @@
[tool.poetry]
name = "telegram-phone-number-checker"
version = "1.0.3"
version = "1.0.7"
description = "Check if phone numbers are connected to Telegram accounts."
authors = ["Bellingcat"]
license = "MIT"

View File

@@ -5,8 +5,6 @@ from dotenv import load_dotenv
from getpass import getpass
import click
load_dotenv()
def get_names(client, phone_number):
"""
This function takes in a phone number and returns the username first name and the last name of the user if the user exists. It does so by first adding the user's phones to the contact list, retrieving the information, and then deleting the user from the contact list.
@@ -14,23 +12,31 @@ def get_names(client, phone_number):
result = {}
print(f'Checking: {phone_number=} ...', end="", flush=True)
try:
# Create a contact
contact = InputPhoneContact(client_id = 0, phone = phone_number, first_name="", last_name="")
# Attempt to add the contact from the address book
contacts = client(functions.contacts.ImportContactsRequest([contact]))
username = contacts.to_dict()['users'][0]['username']
if not username:
result.update({"error": f'ERROR: no username detected'})
del_usr = client(functions.contacts.DeleteContactsRequest(id=[username]))
else:
result.update({"username": username})
del_usr = client(functions.contacts.DeleteContactsRequest(id=[username]))
# getting more information about the user
id = del_usr.to_dict()['users'][0]['id']
first_name = del_usr.to_dict()['users'][0]['first_name']
last_name = del_usr.to_dict()['users'][0]['last_name']
result.update({"first_name": first_name, "last_name": last_name, "id": id})
except IndexError as e:
result.update({"error": f'ERROR: no response, the user does not exist or has blocked contact adding.'})
users = contacts.to_dict().get('users', [])
number_of_matches = len(users)
if number_of_matches == 0:
result.update({"error": f'No response, the phone number is not on Telegram or has blocked contact adding.'})
elif number_of_matches == 1:
# Attempt to remove the contact from the address book
# The response from DeleteContactsRequest contains more information than from ImportContactsRequest
del_user = client(functions.contacts.DeleteContactsRequest(id=[users[0].get('id')]))
user = del_user.to_dict().get('users')[0]
# getting more information about the user
result.update({
"id": user.get('id'),
"username": user.get('username'),
"first_name": user.get('first_name'),
"last_name": user.get('last_name')
})
else:
result.update({"error": f'This phone number matched multiple Telegram accounts, which is unexpected. Please contact the developer: contact-tech@bellingcat.com'})
except TypeError as e:
result.update({"error": f"TypeError: {e}. --> The error might have occurred due to the inability to delete the {phone_number=} from the contact list."})
except Exception as e:
@@ -90,6 +96,7 @@ def show_results(output, res):
@click.option('--output', help='results filename, default to results.json', default="results.json", type=str)
def main_entrypoint(phone_numbers, api_id, api_hash, api_phone_number, output):
"""Check to see if one or more phone numbers belong to a valid Telegram account"""
load_dotenv(".env")
client = login(api_id, api_hash, api_phone_number)
res = validate_users(client, phone_numbers)
show_results(output, res)