o
    <6je  ã                   @   s¢   d dl Z d dlmZmZ d dlmZ d dlmZ d dlmZ d dl	m
Z
 d dlmZ d dlmZ d d	lmZmZ d d
lmZ dZdZdede
dedefdd„ZdS )é    N)ÚdatetimeÚtimezone)ÚBot)ÚTelegramBadRequest)Úlogger)ÚAsyncSession)Úsettings)Úupsert_movie)ÚSyncLogÚ
SyncStatus)Úparse_captioné2   i † ÚbotÚsessionÚtriggered_byÚreturnc                 Ã   sl  t tj|d}| |¡ | ¡ I dH  | |¡I dH  d}d}d}d}zjzñt dtj	› d|› ¡ d}d}	|t
krz¥| j|tj	|dI dH }
d}	z| j||
jdI dH  W n	 tya   Y nw |
jpg|
j}|
jrq|
jd	 jnd}|rÜt||ƒ}|r×td$i d
|“d|j“d|“d|j“d|j“d|j“d|j“d|j“d|j“d|j“d|j“d|j“d|j“d|j “d|j!“d|j"“d|j#“d|“ŽI dH \}}|rÒ|d7 }n|d7 }n	|d7 }n|d7 }W n  t$y   |	d7 }	|	t%krÿt dt%› d|› d¡ Y nY nw |d7 }t& 'd¡I dH  |t
ks<tj(|_)W n( ty? } zt *d |› ¡ tj+|_)t,|ƒ|_-t,|ƒ}W Y d}~n-d}~ww W ||_.||_/||_0t1 2t3j4¡|_5| ¡ I dH  t d!|› d"|› d#|› ¡ |S W ||_.||_/||_0t1 2t3j4¡|_5| ¡ I dH  t d!|› d"|› d#|› ¡ |S ||_.||_/||_0t1 2t3j4¡|_5| ¡ I dH  t d!|› d"|› d#|› ¡ w )%aH  
    Kino kanalidan barcha kinolarni DB'ga sync qiladi.

    Jarayon:
    1. Har bir message_id uchun forward_message orqali xabarni admin chatiga yuboradi
    2. Caption'ni parse qilib kinoni DB'ga upsert qiladi
    3. Forward qilingan xabarni admin chatidan o'chiradi
    4. 50 ta ketma-ket topilmagan message_id kelsa to'xtatiladi
    5. Sync natijasini SyncLog'ga yozadi

    Eslatma: Bot API kanaldan tarix o'qishni qo'llab-quvvatlamaydi, shuning
    uchun biz forward_message "probe" usulidan foydalanamiz. Admin chatida
    xabarlar bir zumga ko'rinib, darhol o'chiriladi.
    )Ústatusr   Nr   zSync boshlandi. Kanal: z	, admin: é   )Úchat_idÚfrom_chat_idÚ
message_id)r   r   éÿÿÿÿr   ÚcodeÚchannel_message_idÚtitle_uzÚtitle_ruÚtitle_enÚdescription_uzÚdescription_ruÚdescription_enÚyearÚdurationÚcountryÚdirectorÚcastÚimdb_ratingÚkinopoisk_ratingÚ
age_ratingÚposter_file_idzSync: u7    ta ketma-ket topilmadi â€” to'xtatildi (oxirgi msg_id=ú)gš™™™™™©?zSync xatolik: zSync yakunlandi: added=z
, updated=z
, skipped=© )6r
   r   ÚRUNNINGÚaddÚcommitÚrefreshr   Úinfor   Úmovie_channel_idÚ_MAX_MSG_IDÚforward_messageÚdelete_messager   Ú	ExceptionÚcaptionÚtextÚphotoÚfile_idr   r	   r   r   r   r   r   r   r   r    r!   r"   r#   r$   r%   r&   r'   r   Ú_MAX_CONSECUTIVE_FAILSÚasyncioÚsleepÚDONEr   ÚerrorÚFAILEDÚstrÚerror_messageÚmovies_addedÚmovies_updatedÚmovies_skippedr   Únowr   ÚutcÚfinished_at)r   r   r   Úsync_logÚaddedÚupdatedÚskippedÚ	error_msgÚmsg_idÚconsecutive_failsÚ	forwardedr5   Úphoto_file_idÚparsedÚ_ÚcreatedÚer*   r*   úD/var/www/www-root/data/www/ai-bot.pdev.uz/bot/services/movie_sync.pyÚsync_movies_from_channel   s  €þ

ýþÿ
ÿþýüûúùø	÷
öõôóòñðïî


€ÿÿûþ	ÁA
€üþ	ÿóÿöÿrU   )r:   r   r   Úaiogramr   Úaiogram.exceptionsr   Úlogurur   Úsqlalchemy.ext.asyncior   Ú
bot.configr   Úbot.database.crud.movier	   Úbot.database.modelsr
   r   Úbot.services.caption_parserr   r9   r1   ÚintrU   r*   r*   r*   rT   Ú<module>   s*    ÿþýü