ub4tg/src/updatenotif.py

36 lines
1.6 KiB
Python
Raw Normal View History

from loguru import logger
import os
import asyncio
2024-12-18 22:38:40 +02:00
import shlex
async def git_notifications_update():
logger.info('module for checking updates started')
2024-12-18 10:54:05 +02:00
cwd = os.getcwd()
os.chdir(cwd)
while True:
termux_api = os.system('termux-api-start')
if termux_api == 0:
logger.info('Checking for updates...')
fetching_git = os.system('git fetch')
if fetching_git == 0:
2024-12-18 20:45:33 +02:00
commits = os.popen(
"git log --pretty=format:'%h %s%n%b' HEAD..origin/$(git rev-parse --abbrev-ref HEAD)").read()
2024-12-18 10:54:05 +02:00
if len(commits) <= 5:
logger.info('updates not found, nothing to do')
else:
2024-12-18 22:38:40 +02:00
commits = shlex.quote(commits)
2024-12-18 20:45:33 +02:00
os.system(
2024-12-18 22:43:52 +02:00
f"termux-notification -i ub4tgupd --title 'ub4tg: update avalaible!' --content 'For apply tap button Get update and restart bot\nChanges:\n{commits}' --button1 'Get update' --button1-action 'termux-notification-remove ub4tgupd; cd {cwd}; git pull; termux-toast 'ub4tg updated, now restart it for apply update'")
else:
2024-12-18 20:45:33 +02:00
os.system(
"termux-toast '[ub4tg]: failed fetching update, maybe connection error, check console log for more info'")
else:
2024-12-18 20:45:33 +02:00
logger.warning(
'For getting updates via notifications, you should:')
logger.warning('pkg install termux-api')
2024-12-18 20:45:33 +02:00
logger.warning(
'download the apk: https://f-droid.org/repo/com.termux.api_51.apk')
2024-12-18 10:54:05 +02:00
logger.debug('next update will be check after 6 hours')
await asyncio.sleep(6 * 60 * 60)