Browse Source

Реализовал отлючение просроченных услуг в кроне

devel
bashmak 9 years ago
parent
commit
72e0ae36f9
  1. 29
      cron.py

29
cron.py

@ -2,14 +2,13 @@
# -*- coding: utf-8 -*-
import os
import django
if __name__ == "__main__":
os.environ.setdefault("DJANGO_SETTINGS_MODULE", "djing.settings")
django.setup()
from abonapp.models import Abon
from agent import Transmitter
from abonapp.models import Abon, LogicError
from agent import Transmitter, NasNetworkError, NasFailedResult
def main():
tm = Transmitter()
# получим инфу о записях в NAS
@ -17,6 +16,9 @@ if __name__ == "__main__":
users = Abon.objects.all()
for user in users:
try:
# бдим за услугами абонента: просроченные отключить, заказанные подключить
user.activate_next_tariff(user)
# если нет ip то и нет смысла лезть в NAS
if user.ip_address is None:
@ -35,7 +37,7 @@ if __name__ == "__main__":
# ищем абонента в списке инфы из nas
abons = [queue for queue in queues if queue is not None]
abons = [{'abon': queue.abon, 'mikro_id': queue.sid} for queue in queues if queue.abon.uid == user.pk]
abons = [{'abon': queue.abon, 'mikro_id': queue.sid} for queue in abons if queue.abon.uid == user.pk]
abons_len = len(abons)
if abons_len < 1:
# абонент не найден в nas, добавим
@ -59,3 +61,18 @@ if __name__ == "__main__":
tm.start_user(abons[0]['mikro_id'])
else:
tm.pause_user(abons[0]['mikro_id'])
except NasNetworkError as er:
print("Error:", er)
except NasFailedResult as er:
print("Error:", er)
except LogicError as er:
print("Notice:", er)
if __name__ == "__main__":
try:
main()
except NasNetworkError as e:
print(e)
except NasFailedResult as e:
print(e)
Loading…
Cancel
Save