При возникновении ошибок отправляются уведомления в RocketChat. Проверка доступности сервера 1С перед отправкой чеков.

This commit is contained in:
2025-08-07 16:21:42 +03:00
parent 0256f1435a
commit c95ea39edf

View File

@ -3,12 +3,44 @@ from datetime import datetime
from pathlib import Path from pathlib import Path
from time import sleep from time import sleep
from icecream import ic from icecream import ic
from socket import create_connection
def check_server(ip, port):
"""Проверять доступность сервера"""
try:
create_connection((ip, port), timeout=2)
return True
except OSError:
return False
def send_rocketchat_notification(text, proccess='Разобраться!'):
ROCKET_CHAT_WEBHOOK_URL = 'https://chat.maverik.ru/hooks/6881da844a6bb0ff6126fb0c/sQXCxLCrfNCtYumnWaEKbyqYvFhHSFCSevy8iBR3T2beP8j5'
data = {
"alias": "Чеки Мэверик",
"text": text,
"attachments": [
{
"text": f"**{proccess}**",
"color": "#5B34E7"
}
]
}
headers = {'Content-Type': 'application/json'}
try:
response = requests.post(ROCKET_CHAT_WEBHOOK_URL, json=data, headers=headers)
if response.status_code != 200:
print(f"Ошибка отправки уведомления: {response.text}")
except Exception as e:
print(f"Ошибка при отправке уведомления: {e}")
ic.disable() ic.disable()
ID = [ ('7385440800019283','c9722276-9dce-11ef-86ff-8a456ecaea20','Хабаровск'), ID = [ ('7385440800019283','c9722276-9dce-11ef-86ff-8a456ecaea20','Хабаровск'),
('9961440300761252','34dfe5e2-9f7c-11ec-ed95-0cc47ab40806','Комсомольск_на_Амуре'), ('7381440900804318','34dfe5e2-9f7c-11ec-ed95-0cc47ab40806','Комсомольск_на_Амуре'),
('7385440800015768','7f8bb0cc-d7a5-11ee-85fe-8a456ecaea20','Береста 6'), ('7385440800015768','7f8bb0cc-d7a5-11ee-85fe-8a456ecaea20','Береста 6'),
('7381440900865598','b0657834-65f9-11f0-8bb1-74563c59aa03','Новороссийск'),
] ]
while True: while True:
@ -34,8 +66,10 @@ while True:
ic(result.text) ic(result.text)
ic(sessionToken) ic(sessionToken)
try: try:
n = 0
result = requests.get(f"https://api-lk-ofd.taxcom.ru/API/v2/ShiftList?fn={fn}&begin={prevDate}T00:00:00&end={CurDate}T23:59:59", headers=headers, timeout=(20, 240)) result = requests.get(f"https://api-lk-ofd.taxcom.ru/API/v2/ShiftList?fn={fn}&begin={prevDate}T00:00:00&end={CurDate}T23:59:59", headers=headers, timeout=(20, 240))
for i in result.json()['records']: for i in result.json()['records']:
n += 1
shiftNumber = i['shiftNumber'] shiftNumber = i['shiftNumber']
fnFactoryNumber = i['fnFactoryNumber'] fnFactoryNumber = i['fnFactoryNumber']
ic(result.text) ic(result.text)
@ -45,31 +79,45 @@ while True:
cheks = result.json()['records'] cheks = result.json()['records']
except: except:
ic() ic()
requests.get(f'https://api.telegram.org/bot5374522720:AAGoNUYCEyJ-7-bSAQPT7aV_W2GWcinnkQU/sendMessage?parse_mode=HTML&chat_id=394151541&text=<b>Taxcom:</b>\nЧека нет') # requests.get(f'https://api.telegram.org/bot5374522720:AAGoNUYCEyJ-7-bSAQPT7aV_W2GWcinnkQU/sendMessage?parse_mode=HTML&chat_id=394151541&text=<b>Taxcom Maverik:</b>\nЧека нет')
# send_rocketchat_notification(f'Чеков нет: {kassa}', 'Taxcom Maverik')
continue continue
with open('check', 'w', encoding='utf-8') as f: with open(f'check_{n}', 'w', encoding='utf-8') as f:
f.write(str(cheks)) f.write(str(cheks))
if Path('check').is_file(): if Path(f'check_{n}').is_file():
if Path(kassa).is_file(): if Path(f'{kassa}_{n}').is_file():
if filecmp.cmp('check', kassa): if filecmp.cmp(f'check_{n}', f'{kassa}_{n}'):
print(f'{kassa} -- Новые чеки отсутствуют') print(f'{kassa} -- Новые чеки отсутствуют')
continue continue
shutil.copy('check', kassa) shutil.copy(f'check_{n}', f'{kassa}_{n}')
Path('check').unlink() Path(f'check_{n}').unlink()
data = {"salepoint": salepoint, data = {"salepoint": salepoint,
"res": str(cheks)} "res": str(cheks)}
data = json.dumps(data, ensure_ascii=False).encode('utf-8') data = json.dumps(data, ensure_ascii=False).encode('utf-8')
print(kassa) print(kassa)
result = requests.post('http://10.15.0.3/bso_maverik/hs/exchange/saveTaxcomDocs', data=data, allow_redirects=False, auth=('robot', 's38*Cqy2L*PB'), timeout=(10, 120)) if check_server('1c.maverik.ru', 443):
result = requests.post('https://1c.maverik.ru/bso_maverik/hs/exchange/saveTaxcomDocs', data=data, allow_redirects=False, auth=('robot', 's38*Cqy2L*PB'), timeout=(10, 120))
elif check_server('10.15.0.3', 80):
result = requests.post('http://10.15.0.3/bso_maverik/hs/exchange/saveTaxcomDocs', data=data, allow_redirects=False, auth=('robot', 's38*Cqy2L*PB'), timeout=(10, 120))
else:
if Path(f'{kassa}_{n}').is_file():
Path(f'{kassa}_{n}').unlink()
print('Ошибка загрузки чеков в 1С.\nСервер не доступен!\nЗагрузка повторится позже.')
send_rocketchat_notification('Ошибка загрузки чеков в 1С.\nСервер не доступен!\nЗагрузка повторится через 1 час.', 'Taxcom Maverik')
sleep(3600)
break
print(result.text) print(result.text)
print('-----------------') print('-----------------')
except: except Exception as e:
# requests.get(f'https://api.telegram.org/bot5374522720:AAGoNUYCEyJ-7-bSAQPT7aV_W2GWcinnkQU/sendMessage?parse_mode=HTML&chat_id=394151541&text=<b>Taxcom Maverik:</b>\n{e}')
send_rocketchat_notification(e, 'Taxcom Maverik')
continue continue
print('#################') print('#################')
except Exception as e: except Exception as e:
requests.get(f'https://api.telegram.org/bot5374522720:AAGoNUYCEyJ-7-bSAQPT7aV_W2GWcinnkQU/sendMessage?parse_mode=HTML&chat_id=394151541&text=<b>Taxcom:</b>\n{e}') # requests.get(f'https://api.telegram.org/bot5374522720:AAGoNUYCEyJ-7-bSAQPT7aV_W2GWcinnkQU/sendMessage?parse_mode=HTML&chat_id=394151541&text=<b>Taxcom Maverik:</b>\n{e}')
send_rocketchat_notification(e, 'Taxcom Maverik')
print('#################') print('continue\n\n')
print('#################') # print('#################')
print('#################') # print('#################')
sleep(120) sleep(120)