|
|
|
@ -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) |