Создание бота по рекламе чатов
This commit is contained in:
184
.gitignore
vendored
Normal file
184
.gitignore
vendored
Normal file
@@ -0,0 +1,184 @@
|
|||||||
|
# .gitignore
|
||||||
|
# Файл, запрещающий экспорт определённых частей кода
|
||||||
|
|
||||||
|
# Игнорирование локального окружения и пользовательских конфигураций IDE
|
||||||
|
.*
|
||||||
|
.*/
|
||||||
|
.idea
|
||||||
|
.venv/
|
||||||
|
*.iml
|
||||||
|
|
||||||
|
# Игнорирование директорий сборки
|
||||||
|
build/
|
||||||
|
dist/
|
||||||
|
develop-eggs/
|
||||||
|
downloads/
|
||||||
|
eggs/
|
||||||
|
.eggs/
|
||||||
|
lib/
|
||||||
|
lib64/
|
||||||
|
parts/
|
||||||
|
sdist/
|
||||||
|
var/
|
||||||
|
wheels/
|
||||||
|
share/python-wheels/
|
||||||
|
*.egg-info/
|
||||||
|
.installed.cfg
|
||||||
|
*.egg
|
||||||
|
MANIFEST
|
||||||
|
|
||||||
|
# Игнорирование временных файлов операционной системы
|
||||||
|
Thumbs.db
|
||||||
|
|
||||||
|
# Игнорирование файлов логов
|
||||||
|
BotLogs/
|
||||||
|
*.log
|
||||||
|
*.logs
|
||||||
|
|
||||||
|
# Игнорирование всех скачанных данных логирования
|
||||||
|
BotFiles/
|
||||||
|
|
||||||
|
# Игнорирование базы данных пользователя
|
||||||
|
MySQL/user_data.db
|
||||||
|
MySQL/user_data.json
|
||||||
|
|
||||||
|
# Файл подсчёта строк
|
||||||
|
project_count_line.py
|
||||||
|
|
||||||
|
# Игнорирование байт-кодных / оптимизированных / DLL файлов
|
||||||
|
__pycache__/
|
||||||
|
*.py[cod]
|
||||||
|
*$py.class
|
||||||
|
|
||||||
|
# Игнорирование C-расширений
|
||||||
|
*.so
|
||||||
|
|
||||||
|
# PyInstaller
|
||||||
|
# Обычно эти файлы создаются скриптом Python из шаблона
|
||||||
|
# перед сборкой exe, чтобы внедрить дату или другую информацию.
|
||||||
|
*.manifest
|
||||||
|
*.spec
|
||||||
|
|
||||||
|
# Логи установщика
|
||||||
|
pip-log.txt
|
||||||
|
pip-delete-this-directory.txt
|
||||||
|
|
||||||
|
# Отчёты тестирования / покрытия кода
|
||||||
|
htmlcov/
|
||||||
|
.tox/
|
||||||
|
.nox/
|
||||||
|
.coverage
|
||||||
|
.coverage.*
|
||||||
|
.cache
|
||||||
|
nosetests.xml
|
||||||
|
coverage.xml
|
||||||
|
*.cover
|
||||||
|
*.py,cover
|
||||||
|
.hypothesis/
|
||||||
|
.pytest_cache/
|
||||||
|
cover/
|
||||||
|
|
||||||
|
# Файлы переводов
|
||||||
|
*.mo
|
||||||
|
*.pot
|
||||||
|
|
||||||
|
# Файлы Django
|
||||||
|
local_settings.py
|
||||||
|
db.sqlite3
|
||||||
|
db.sqlite3-journal
|
||||||
|
|
||||||
|
# Файлы Flask
|
||||||
|
instance/
|
||||||
|
.webassets-cache
|
||||||
|
|
||||||
|
# Файлы Scrapy
|
||||||
|
.scrapy
|
||||||
|
|
||||||
|
# Документация Sphinx
|
||||||
|
docs/_build/
|
||||||
|
|
||||||
|
# PyBuilder
|
||||||
|
.pybuilder/
|
||||||
|
target/
|
||||||
|
|
||||||
|
# Jupyter Notebook
|
||||||
|
.ipynb_checkpoints
|
||||||
|
|
||||||
|
# IPython
|
||||||
|
profile_default/
|
||||||
|
ipython_config.py
|
||||||
|
|
||||||
|
# pyenv
|
||||||
|
# Для библиотеки или пакета эти файлы можно игнорировать,
|
||||||
|
# так как код предназначен для выполнения в нескольких средах.
|
||||||
|
# .python-version
|
||||||
|
|
||||||
|
# pipenv
|
||||||
|
# Согласно pypa/pipenv#598, рекомендуется включать Pipfile.lock в контроль версий.
|
||||||
|
# Однако, при совместной разработке, если есть платформозависимые зависимости
|
||||||
|
# или зависимости без кроссплатформенной поддержки,
|
||||||
|
# pipenv может установить неподходящие зависимости.
|
||||||
|
#Pipfile.lock
|
||||||
|
|
||||||
|
# poetry
|
||||||
|
# Как и Pipfile.lock, рекомендуется включать poetry.lock в контроль версий,
|
||||||
|
# особенно для бинарных пакетов для обеспечения воспроизводимости.
|
||||||
|
#poetry.lock
|
||||||
|
|
||||||
|
# pdm
|
||||||
|
# Как и Pipfile.lock, рекомендуется включать pdm.lock в контроль версий.
|
||||||
|
#pdm.lock
|
||||||
|
# pdm хранит конфигурации проекта в .pdm.toml, но не рекомендуется включать его в контроль версий.
|
||||||
|
# .pdm.toml
|
||||||
|
|
||||||
|
# PEP 582 (например, используется в github.com/David-OConnor/pyflow и github.com/pdm-project/pdm)
|
||||||
|
__pypackages__/
|
||||||
|
|
||||||
|
# Файлы Celery
|
||||||
|
celerybeat-schedule
|
||||||
|
celerybeat.pid
|
||||||
|
|
||||||
|
# Разобранные файлы SageMath
|
||||||
|
*.sage.py
|
||||||
|
|
||||||
|
# Среды разработки
|
||||||
|
.env
|
||||||
|
.venv
|
||||||
|
env/
|
||||||
|
venv/
|
||||||
|
ENV/
|
||||||
|
env.bak/
|
||||||
|
venv.bak/
|
||||||
|
|
||||||
|
# Настройки проекта Spyder
|
||||||
|
.spyderproject
|
||||||
|
.spyproject
|
||||||
|
|
||||||
|
# Настройки проекта Rope
|
||||||
|
.ropeproject
|
||||||
|
|
||||||
|
# Документация mkdocs
|
||||||
|
/site
|
||||||
|
|
||||||
|
# Кэш mypy
|
||||||
|
.mypy_cache/
|
||||||
|
.dmypy.json
|
||||||
|
dmypy.json
|
||||||
|
|
||||||
|
# Анализатор типов Pyre
|
||||||
|
.pyre/
|
||||||
|
|
||||||
|
# Статический анализатор типов pytype
|
||||||
|
.pytype/
|
||||||
|
|
||||||
|
# Отладочные символы Cython
|
||||||
|
cython_debug/
|
||||||
|
|
||||||
|
# PyCharm
|
||||||
|
# JetBrains поддерживает отдельный шаблон JetBrains.gitignore,
|
||||||
|
# который можно найти здесь: https://github.com/github/gitignore/blob/main/Global/JetBrains.gitignore.
|
||||||
|
.idea/
|
||||||
|
|
||||||
|
# Отключение сессий
|
||||||
|
*.session
|
||||||
|
*.session-journal
|
||||||
8
.idea/.gitignore
generated
vendored
Normal file
8
.idea/.gitignore
generated
vendored
Normal file
@@ -0,0 +1,8 @@
|
|||||||
|
# Default ignored files
|
||||||
|
/shelf/
|
||||||
|
/workspace.xml
|
||||||
|
# Editor-based HTTP Client requests
|
||||||
|
/httpRequests/
|
||||||
|
# Datasource local storage ignored files
|
||||||
|
/dataSources/
|
||||||
|
/dataSources.local.xml
|
||||||
10
.idea/ReklamaWorldBot.iml
generated
Normal file
10
.idea/ReklamaWorldBot.iml
generated
Normal file
@@ -0,0 +1,10 @@
|
|||||||
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
<module type="PYTHON_MODULE" version="4">
|
||||||
|
<component name="NewModuleRootManager">
|
||||||
|
<content url="file://$MODULE_DIR$">
|
||||||
|
<excludeFolder url="file://$MODULE_DIR$/.venv" />
|
||||||
|
</content>
|
||||||
|
<orderEntry type="jdk" jdkName="Python 3.13 (ReklamaWorldBot)" jdkType="Python SDK" />
|
||||||
|
<orderEntry type="sourceFolder" forTests="false" />
|
||||||
|
</component>
|
||||||
|
</module>
|
||||||
13
.idea/easycode.ignore
generated
Normal file
13
.idea/easycode.ignore
generated
Normal file
@@ -0,0 +1,13 @@
|
|||||||
|
.idea
|
||||||
|
.vscode
|
||||||
|
node_modules/
|
||||||
|
dist/
|
||||||
|
vendor/
|
||||||
|
cache/
|
||||||
|
.*/
|
||||||
|
*.min.*
|
||||||
|
*.test.*
|
||||||
|
*.spec.*
|
||||||
|
*.bundle.*
|
||||||
|
*.bundle-min.*
|
||||||
|
*.log
|
||||||
6
.idea/inspectionProfiles/profiles_settings.xml
generated
Normal file
6
.idea/inspectionProfiles/profiles_settings.xml
generated
Normal file
@@ -0,0 +1,6 @@
|
|||||||
|
<component name="InspectionProjectProfileManager">
|
||||||
|
<settings>
|
||||||
|
<option name="USE_PROJECT_PROFILE" value="false" />
|
||||||
|
<version value="1.0" />
|
||||||
|
</settings>
|
||||||
|
</component>
|
||||||
8
.idea/modules.xml
generated
Normal file
8
.idea/modules.xml
generated
Normal file
@@ -0,0 +1,8 @@
|
|||||||
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
<project version="4">
|
||||||
|
<component name="ProjectModuleManager">
|
||||||
|
<modules>
|
||||||
|
<module fileurl="file://$PROJECT_DIR$/.idea/ReklamaWorldBot.iml" filepath="$PROJECT_DIR$/.idea/ReklamaWorldBot.iml" />
|
||||||
|
</modules>
|
||||||
|
</component>
|
||||||
|
</project>
|
||||||
6
.idea/vcs.xml
generated
Normal file
6
.idea/vcs.xml
generated
Normal file
@@ -0,0 +1,6 @@
|
|||||||
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
<project version="4">
|
||||||
|
<component name="VcsDirectoryMappings">
|
||||||
|
<mapping directory="$PROJECT_DIR$" vcs="Git" />
|
||||||
|
</component>
|
||||||
|
</project>
|
||||||
104
main.py
Normal file
104
main.py
Normal file
@@ -0,0 +1,104 @@
|
|||||||
|
# main.py
|
||||||
|
# Замена рекламщикам
|
||||||
|
|
||||||
|
import asyncio
|
||||||
|
import sys
|
||||||
|
from os import getenv
|
||||||
|
from pyrogram import Client
|
||||||
|
from loguru import logger
|
||||||
|
|
||||||
|
# Сообщение и путь к картинке, которую хотите отправить
|
||||||
|
image = 'img.png'
|
||||||
|
message = "<b>Привет! Это тестовое сообщение с картинкой.</b>"
|
||||||
|
|
||||||
|
# Список ID групп, куда будут отправляться сообщения
|
||||||
|
group_ids = [-1000000000,
|
||||||
|
]
|
||||||
|
|
||||||
|
# Ваши данные для авторизации
|
||||||
|
api_id = getenv('API_KEY') # Получите это на https://my.telegram.org
|
||||||
|
api_hash = getenv('API_HASH') # Получите это на https://my.telegram.org
|
||||||
|
phone_number = getenv('PHONE_NUMBER') # Ваш номер телефона в международном формате
|
||||||
|
password = getenv('PASSWORD') # Если включена двухфакторная аутентификация
|
||||||
|
bot_token = getenv('BOT_TOKEN')
|
||||||
|
Perm = "bot"
|
||||||
|
|
||||||
|
|
||||||
|
# Функция отправки по id
|
||||||
|
async def send_greetings(client):
|
||||||
|
# Проходим по каждой группе и отправляем сообщение
|
||||||
|
for group_id in group_ids:
|
||||||
|
try:
|
||||||
|
# Отправка картинки
|
||||||
|
await client.send_photo(group_id, photo=image, caption=message)
|
||||||
|
logger.bind(user=group_id).info("Сообщение успешно отправлено в группу")
|
||||||
|
except Exception as e:
|
||||||
|
logger.bind(user=group_id).error(f"Ошибка при отправке в группу: {e}")
|
||||||
|
|
||||||
|
|
||||||
|
# Функция бесконечного цикла сообщений
|
||||||
|
async def periodic_send(client):
|
||||||
|
while True:
|
||||||
|
await send_greetings(client)
|
||||||
|
# Ожидание 60 секунд перед отправкой следующего сообщения
|
||||||
|
await asyncio.sleep(14400) # 60 секунд = 1 минута, 1 час = 3600 секунд, 4 часа = 14400
|
||||||
|
|
||||||
|
|
||||||
|
# Функция создания логгеров
|
||||||
|
async def loger():
|
||||||
|
logger.remove()
|
||||||
|
max_size = '500 MB'
|
||||||
|
info_text = ("<green>{time:YYYY-MM-DD HH:mm:ss}</green> <red>|</red> "
|
||||||
|
"<blue>PRIMO-Message</blue> <red>|</red> "
|
||||||
|
"<red>{extra[user]} |</red> <level>{message}</level>")
|
||||||
|
error_text = ("<level>{time:YYYY-MM-DD HH:mm:ss} | "
|
||||||
|
"<bold>PRIMO-ERROR</bold> | "
|
||||||
|
"{extra[user]} | {message}</level>")
|
||||||
|
logger.add(sys.stderr,
|
||||||
|
colorize=True,
|
||||||
|
format=info_text,
|
||||||
|
level="INFO",
|
||||||
|
filter=lambda record: record["level"].name == "INFO",
|
||||||
|
) # Добавлен аргумент sink
|
||||||
|
logger.add(sys.stderr,
|
||||||
|
colorize=True,
|
||||||
|
format=error_text,
|
||||||
|
level="ERROR",
|
||||||
|
filter=lambda record: record["level"].name == "ERROR",
|
||||||
|
) # Добавлен аргумент sink
|
||||||
|
logger.add("start.log",
|
||||||
|
rotation=max_size,
|
||||||
|
format=info_text,
|
||||||
|
backtrace=True,
|
||||||
|
diagnose=True,
|
||||||
|
level="INFO",
|
||||||
|
filter=lambda record: record["level"].name == "INFO",)
|
||||||
|
logger.add("error.log",
|
||||||
|
rotation=max_size,
|
||||||
|
format=error_text,
|
||||||
|
backtrace=True,
|
||||||
|
diagnose=True,
|
||||||
|
level="ERROR",
|
||||||
|
filter=lambda record: record["level"].name == "ERROR",)
|
||||||
|
logger.bind(user="@Console").info("Программа запущена!\n")
|
||||||
|
|
||||||
|
|
||||||
|
# Основная функция запуска клиента
|
||||||
|
async def main():
|
||||||
|
await loger()
|
||||||
|
if Perm == 1: # Исправлено условие
|
||||||
|
# Создаем клиента с использованием api_id и api_hash
|
||||||
|
async with Client("user_session", api_id=api_id, api_hash=api_hash, in_memory=True,
|
||||||
|
phone_number=phone_number, password=password) as client:
|
||||||
|
# Запускаем периодическую отправку сообщений
|
||||||
|
await periodic_send(client)
|
||||||
|
else:
|
||||||
|
# Создаем клиента с использованием api_id, api_hash и bot_token
|
||||||
|
async with Client("bot_session", bot_token=bot_token) as client:
|
||||||
|
# Запускаем периодическую отправку сообщений
|
||||||
|
await periodic_send(client)
|
||||||
|
|
||||||
|
|
||||||
|
# Бесконечный запуск
|
||||||
|
if __name__ == "__main__":
|
||||||
|
asyncio.run(main())
|
||||||
BIN
requirements.txt
Normal file
BIN
requirements.txt
Normal file
Binary file not shown.
Reference in New Issue
Block a user