При возникновении ошибок отправляются уведомления в RocketChat. Проверка доступности сервера 1С перед отправкой чеков.
This commit is contained in:
@ -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)
|
||||||
Reference in New Issue
Block a user