summaryrefslogtreecommitdiff
path: root/src/ipcam_server.py
diff options
context:
space:
mode:
authorEvgeny Zinoviev <me@ch1p.io>2022-06-12 01:54:10 +0300
committerEvgeny Zinoviev <me@ch1p.io>2022-06-12 01:54:10 +0300
commit0dc38ac37f9f2974bbf87824ae55283fa7308adb (patch)
tree1694037f1a2ad1f56b102b016621db0585477b3d /src/ipcam_server.py
parent4409c32892687e7c49a0eb60aa4fdeecd2f25bfe (diff)
ipcam_server: telegram notification (not tested... we'll see)
Diffstat (limited to 'src/ipcam_server.py')
-rwxr-xr-xsrc/ipcam_server.py47
1 files changed, 46 insertions, 1 deletions
diff --git a/src/ipcam_server.py b/src/ipcam_server.py
index 56b6e18..6856621 100755
--- a/src/ipcam_server.py
+++ b/src/ipcam_server.py
@@ -7,7 +7,7 @@ import time
from apscheduler.schedulers.asyncio import AsyncIOScheduler
from home.config import config
-from home.util import parse_addr
+from home.util import parse_addr, send_telegram_aio
from home import http
from home.database.sqlite import SQLiteBase
from home.camera import util as camutil
@@ -22,6 +22,11 @@ class TimeFilterType(Enum):
MOTION = 'motion'
+class TelegramLinkType(Enum):
+ FRAGMENT = 'fragment'
+ ORIGINAL_FILE = 'original_file'
+
+
def valid_recording_name(filename: str) -> bool:
return filename.startswith('record_') and filename.endswith('.mp4')
@@ -325,6 +330,46 @@ async def process_fragments(camera: int,
start_pos=start,
duration=duration)
+ try:
+ if fragments and config['motion']['telegram']:
+ asyncio.ensure_future(motion_notify_tg(camera, filename, fragments))
+ except KeyError:
+ pass
+
+
+async def motion_notify_tg(camera: int,
+ filename: str,
+ fragments: list[tuple[int, int]]):
+ dt_file = filename_to_datetime(filename)
+ fmt = '%H:%M:%S'
+
+ text = f'Camera: <b>{camera}</b>\n'
+ text += f'Original file: <b>{filename}</b> '
+ text += _tg_links(TelegramLinkType.ORIGINAL_FILE, camera, filename)
+
+ for start, end in fragments:
+ duration = end - start
+ if duration < 0:
+ duration = 0
+
+ dt1 = dt_file + timedelta(seconds=start)
+ dt2 = dt_file + timedelta(seconds=end)
+
+ text += f'\nFragment: <b>{duration}s</b>, {dt1.strftime(fmt)} - {dt2.strftime(fmt)} '
+ text += _tg_links(TelegramLinkType.FRAGMENT, camera, f'{dt1.strftime(datetime_format)}__{dt2.strftime(datetime_format)}.mp4')
+
+ await send_telegram_aio(text)
+
+
+def _tg_links(link_type: TelegramLinkType,
+ camera: int,
+ file: str) -> str:
+ links = []
+ for link_name, link_template in config['telegram'][f'{link_type.value}_url_templates']:
+ link = link_template.replace('{camera}', str(camera)).replace('{file}', file)
+ links.append(f'<a href="{link}">{link_name}</a>')
+ return ' '.join(links)
+
async def fix_job() -> None:
global fix_job_running