Перейти к содержимому
Local

Рекомендованные сообщения

Стабильный релиз Ubilling 0.8.1 rev 5330

 

Основные изменения:

  • Изменения в структуре БД, см дамп.
  • alter.ini: добавлена новая опция ADMIN_NAMES включающая показ ФИО администраторов в некоторых модулях.
  • alter.ini: добавлена новая опция TASKREPORT_ENABLED включающая отчет по задачам.
  • alter.ini: добавлена новая опция TASKREPORT_JOBTYPES указывающая типы работ для отчета.
  • alter.ini: добавлена новая опция TASKREPORT_SIGNUPJOBTYPES указывающая типы работ являющиеся подключательными.
  • alter.ini: добавлена новая опция TASKREPORT_NOTESTAGIDS указывающая ID тегов попадающих в примечания.
  • alter.ini: добавлена новая опция TASKREPORT_SIGPAYID указывающая тип платежей за подключение.
  • alter.ini: добавлена новая опция POLICEDOG_ENABLED включающая «Собаку-полицияку».
  • alter.ini: добавлена новая необязательная опция SWITCH_PING_INTERVAL указывающая интервал переопроса свитчей.
  • Модуль «ПОНизатор»: теперь при создании, редактировании и удалении ONU происходит ребилд сетевых хендлеров.
  • Модуль «Экзистенциальный конь»: в Askozia больше не учитываются повисшие звонки с длительностью более 24 часов.
  • Кабинет пользователя: модуля замораживания счета, кредитования и смены тарифа теперь производят нормальное логирование.
  • Опрос свичей посредством SNMP: добавлен еще вагон шаблонов для разных Dlink и Eltex. Спасибо Cidjey Miles.
  • Модуль «Собака-посылака»: добавлена поддержка сервиса Red SMS. Это тоже на совести Cidjey Miles.
  • Модуль «Работники»: теперь, при всех изменениях очищает кеш логинов сотрудников.
  • Модуль «Движение средств»: логины администраторов теперь по возможности заменены ФИО сотрудников из соответствующего справочника.
  • Модуль «Экзистенциальный конь»: исправлена подпись графиков для финансов УКВ.
  • Новый модуль Отчет по задачам: позволяет оценить затраты на определенные типы задач. В основном на подключения.
  • Модуль «Планирование работ»: при создании задачи теперь выкусываются лишние пробелы вокруг адреса.
  • Модуль «Возможности подключений»: в интерфейс редактирования, добавлена возможность создания задачи для «планирования работ».
  • Модуль «Возможности подключений»: добавлена статистика по состояниям.
  • Модуль «Детали подключения»: добавлено фильтрование данных для полей длины и стоимости.
  • Модуль «Megogo»: исправлена паника при ручном удалении подписки.
  • Модуль «Заявки на подключение»: календарик теперь показывает заявки за все время.
  • Модуль «OpenPayz»: теперь сортировка транзакций по-умолчанию - от последних к старым.
  • Модуль «Склад»: теперь приходные и расходные операции отсортированы от самых свежих к самым древним.
  • Модуль «Отчет по услуге кредитования»: селектор года, теперь запоминает свое состояние.
  • Модуль «Отчет по услуге кредитования»: для отрисовки графиков теперь используется Google charts.
  • Модуль «Заявки на подключение»: для показа списка заявок, теперь используется jQuery DataTables.
  • Модуль «Перечень возможностей подключения»: переехал на jQuery DataTables.
  • Модуль «Перечень возможностей подключения»: добавлена подсветка уже возможно подключенных заявок.
  • Новый коммерческий модуль Собака-полицияка: позволяет осуществлять поиск по базе определенных MAC.
  • Модуль УКВ: для профилей пользователей добавлена возможность установки существующих тегов из общего справочника.
  • Модуль «УКВ»: добавлен отчет по установленным на пользователей тегам.
  • Модуль «УКВ»: показ списка ранее загруженных банковских выписок переехал на jQuery DataTables.
  • Модуль «Свитчи»: при редактировании свитча, контрол опроса по SNMP теперь показывается, только в случае SWPOLL устройства.
  • Модуль «Свитчи»: теперь машина времени умеет опционально показывать время простоя для каждого свитча из топа.
  • Модуль «Учет зарплат»: теперь в формировании табеля и зарплатных ведомостях, фигурируют только работники из встроенного справочника зарплат.
  • Модуль «Хелпдеск»: календарик теперь показывает тикеты за все время.
  • Модуль «Собака-наблюдака»: исправлен порядок сортировки, при показе существующих задач.
  • Модуль «Живи с этим»: добавлены колонки Ф.И.О. и адреса.
  • RemoteAPI: новый вызов policedog запускающий быстрое сканирование собакой-полициякой.
  • Кабинет пользователя: для Megogo исправлена индикация наличия бесплатного периода подписки.
  • OpenPayz: добавлен фронтенд для получения платежей от банка "Фамильный".
  • OpenPayz: Добавлены фронтенд и бекенд для получения платежей от банка "Тинькофф". Спасибо vik_k.
  • Глобально: умолчательный селектор года расширен до 10-ти лет.
  • UBinstaller: собраны новые бинарные пакеты для FreeBSD 11.0 amd64.
 
Полный чейнджлог
Рекомендации к обновлению
Свежая демка
 
C0ykwZlWEAArYrv.jpg_large.jpeg

Поделиться сообщением


Ссылка на сообщение
Поделиться на других сайтах

 

 

Модуль «OpenPayz»: теперь сортировка транзакций по-умолчанию - от последних к старым.

О, те що давно мучило :D 

Поделиться сообщением


Ссылка на сообщение
Поделиться на других сайтах

Доброго времени суток! 

Предистория: сделали сегментацию сети по VLAN-ам. На Freebsd прописали ifconfig vlanXY create vlan XY vlandev emZ a.b.c.d netmask 255.255.255.e.  В пользователей все работает, но с биллинга не все пингуются (некоторые только по

МАК-адресу, некоторые непосредственно чарез пинг, некоторые вообще не пингуются, но работают). 

Схемка сети такова - Биллинг на одном сервере и NASы на других серверах (rscriptd FreeBSD 10). на нас серверах подсети разбиты на несколько частей (напр 192,168,1,1/25, 192.168.1. 192.168.1.128/26, 192.168.1.192/27, 192.168.1.224/27)

Вопрос: как правильно прописать настройки сети на сервере биллинга чтоб следить за всеми подсетями и VLANами стандартными средствами убиллинга (Пинг и Пинг по МАК)?

 

Я предполагаю что на сервере нужно прописать алиасы для каждой потсети и соответствующему ей влану, но не работает (в одном влане прописал (ifconfig vlan111 inet192.168.1.126/25 напр) а добавить в тот же влан alias inet192.168.1.220/27 - пишет чтото вроде wrong inet  )

Поделиться сообщением


Ссылка на сообщение
Поделиться на других сайтах

Доброго времени суток! 

Предистория: сделали сегментацию сети по VLAN-ам. На Freebsd прописали ifconfig vlanXY create vlan XY vlandev emZ a.b.c.d netmask 255.255.255.e.  В пользователей все работает, но с биллинга не все пингуются (некоторые только по

МАК-адресу, некоторые непосредственно чарез пинг, некоторые вообще не пингуются, но работают). 

Схемка сети такова - Биллинг на одном сервере и NASы на других серверах (rscriptd FreeBSD 10). на нас серверах подсети разбиты на несколько частей (напр 192,168,1,1/25, 192.168.1. 192.168.1.128/26, 192.168.1.192/27, 192.168.1.224/27)

Вопрос: как правильно прописать настройки сети на сервере биллинга чтоб следить за всеми подсетями и VLANами стандартными средствами убиллинга (Пинг и Пинг по МАК)?

 

Я предполагаю что на сервере нужно прописать алиасы для каждой потсети и соответствующему ей влану, но не работает (в одном влане прописал (ifconfig vlan111 inet192.168.1.126/25 напр) а добавить в тот же влан alias inet192.168.1.220/27 - пишет чтото вроде wrong inet  )

На биллинговом сервере нужно создать те же вланы что и на НАСе.

Поделиться сообщением


Ссылка на сообщение
Поделиться на других сайтах

+ добавить в бридж с флагом private и перевесить туда dhcp, arping и прочие интерфейсы из конфигов.

Поделиться сообщением


Ссылка на сообщение
Поделиться на других сайтах

Если так уже за VLAN заговорили, то закрался вопрос ))

Если я использую VLAN на дом, то как то можно прикрутить UHW?

Поделиться сообщением


Ссылка на сообщение
Поделиться на других сайтах

 

 

Если я использую VLAN на дом, то как то можно прикрутить UHW?

А в чем проблема? Протащить к юзеру dhcp ответы с "гостевой" сетью? Ну дык бриджи либо тот же dhcp relay вам в помощь.

Поделиться сообщением


Ссылка на сообщение
Поделиться на других сайтах

Я так понимаю что на порту снимается тег VLAN напрпимер 100.

Если гостевая подсеть например в 300-м VLAN? На порту комутатора тогда нужно менять PVID на сколько я понимаю....

Поделиться сообщением


Ссылка на сообщение
Поделиться на других сайтах

 

 

Если гостевая подсеть например в 300-м VLAN? На порту комутатора тогда нужно менять PVID на сколько я понимаю....

Почему она не может жить во всех вланах?

Поделиться сообщением


Ссылка на сообщение
Поделиться на других сайтах

+ добавить в бридж с флагом private и перевесить туда dhcp, arping и прочие интерфейсы из конфигов.

cloned_interfaces="bridge0 vlan111"

ifconfig_bridge0="addm vlan111 addm em0 up"

 

Както-так?

Поделиться сообщением


Ссылка на сообщение
Поделиться на других сайтах

недавно в соцсетях поймали радугу)))

post-37955-0-83274800-1486592519_thumb.jpg

Поделиться сообщением


Ссылка на сообщение
Поделиться на других сайтах

На странице сети и услуги после добавления сетей начали вываливаться два варнинга.

Warning: Invalid argument supplied for foreach() in /usr/local/www/apache24/data/billing/api/libs/api.vlan.php on line 2474

Warning: Invalid argument supplied for foreach() in /usr/local/www/apache24/data/billing/api/libs/api.vlan.php on line 2450

 

Как пофиксить?

Поделиться сообщением


Ссылка на сообщение
Поделиться на других сайтах

хм, а покажите что в вышеуказанном файле на этих строчках у вас?

Изменено пользователем l1ght

Поделиться сообщением


Ссылка на сообщение
Поделиться на других сайтах

Есть вопрос по обновлению... Короче, есть биллинг версии 0.7.6 нужно обновить до актуальной. Обновление идут кумулятивные или надо обновлять пошагово? Вопрос касается также и рекомендаций к обновлениям.

Поделиться сообщением


Ссылка на сообщение
Поделиться на других сайтах

Когда-то обещали реализовать поддержку филиалов, еще в конце 2015 года, стоит ждать?

Поделиться сообщением


Ссылка на сообщение
Поделиться на других сайтах

 

 

обновлять пошагово? Вопрос касается также и рекомендаций к обновлениям.

 

Выполняете ВСЕ рекомендации и потом обновляете по шагово

Поделиться сообщением


Ссылка на сообщение
Поделиться на других сайтах

хм, а покажите что в вышеуказанном файле на этих строчках у вас?

Вот какие выводы сделал.

Эти ошибки ссылаются на вот этот кусок кода

function GetAllUserIp() {
    $query       = "SELECT ip,login FROM `users`";
    $data        = simple_queryall($query);
    $result      = array();
    foreach ($data as $each) {
        $result[$each['ip']] = $each['login'];
    }
    return($result);
}


function GetAllUserOnu() {
    $query       = "SELECT * FROM `pononu`";
    $result      = array();
    $data        = simple_queryall($query);
    foreach ($data as $each) {
        $result[$each['login']] = $each['mac'];
    }
    return($result);
}

То есть, если не внесено ни одного абонента и ни одного ОНУ тогда вываливается эта ошибка.

Поделиться сообщением


Ссылка на сообщение
Поделиться на других сайтах

 

 

foreach ($data as $each) {

Ну да, там по хорошему это все должно бы быть завернуто в if (!empty($data)) {

Поделиться сообщением


Ссылка на сообщение
Поделиться на других сайтах

 

foreach ($data as $each) {

Ну да, там по хорошему это все должно бы быть завернуто в if (!empty($data)) {

 

И я о том же )

Поделиться сообщением


Ссылка на сообщение
Поделиться на других сайтах

ой всё

:D

Поделиться сообщением


Ссылка на сообщение
Поделиться на других сайтах

UPD

пофиксил в 5382 билде

заодно ещё пройдусь по модулям, может там тоже где-то такая херня спряталась

Поделиться сообщением


Ссылка на сообщение
Поделиться на других сайтах

Не могу понять в чем прикол. Добавляю ОЛТ в биллинг, а он не отображается как ОЛТ

 

icon_active.gif Живые свитчи - 2 (2+0)
icon_inactive.gif Мертвые свичи - 0
yellow_led.png NP свитчи - 0
snmp.png SWPOLL опрос - 0
wifi.png MTSIGMON устройства - 0
pon_icon.gif OLT устройства - 0

Поделиться сообщением


Ссылка на сообщение
Поделиться на других сайтах

Не могу понять в чем прикол. Добавляю ОЛТ в биллинг, а он не отображается как ОЛТ

 

icon_active.gif Живые свитчи - 2 (2+0)

icon_inactive.gif Мертвые свичи - 0

yellow_led.png NP свитчи - 0

snmp.png SWPOLL опрос - 0

wifi.png MTSIGMON устройства - 0

pon_icon.gif OLT устройства - 0

Читаем:

http://wiki.ubilling.net.ua/doku.php?id=ponizer

проверяем.....

Поделиться сообщением


Ссылка на сообщение
Поделиться на других сайтах

 

Не могу понять в чем прикол. Добавляю ОЛТ в биллинг, а он не отображается как ОЛТ

 

icon_active.gif Живые свитчи - 2 (2+0)

icon_inactive.gif Мертвые свичи - 0

yellow_led.png NP свитчи - 0

snmp.png SWPOLL опрос - 0

wifi.png MTSIGMON устройства - 0

pon_icon.gif OLT устройства - 0

Читаем:

http://wiki.ubilling.net.ua/doku.php?id=ponizer

проверяем.....

 

Я там уже все пересмотрел. Добавил ОЛТ, Указал шаблон СНМП БДКОМ. И один фиг не высвечивается как ОЛТ....

Поделиться сообщением


Ссылка на сообщение
Поделиться на других сайтах

Создайте аккаунт или войдите в него для комментирования

Вы должны быть пользователем, чтобы оставить комментарий

Создать аккаунт

Зарегистрируйтесь для получения аккаунта. Это просто!

Зарегистрировать аккаунт

Войти

Уже зарегистрированы? Войдите здесь.

Войти сейчас

  • Сейчас на странице   0 пользователей

    Нет пользователей, просматривающих эту страницу.

  • Похожие публикации

    • Автор: dycost
      Такая проблема.
      Был написан модуль для получения mac абонента с порта коммутатора. Модуль перестал работать после обновления биллинга. Обновлялся точно не скажу с какого релиза, ориентировочно 0.8.9 или 0.9.0.
       
      Суть вот в чем.
      Модуль использует скрипт на питоне вызываемый через popen, в принципе весь код вот:
      if (cfr('GET_MAC')) { $inputs = wf_TextInput('switch_address', __('Enter switch address'), '', true, '10'); $inputs.= wf_TextInput('switch_port', __('Enter switch port'), '', true, '10'); $inputs.= wf_Submit(__('Get')); $form = wf_Form("", 'POST', $inputs, 'glamour'); show_window(__('Get mac address from switch port'), $form); if (isset ($_POST['switch_address'])) { $process = popen(escapeshellcmd('/usr/local/www/apache22/data/billing/modules/general/get_mac/get_mac.py ' . $_POST['switch_address'] . ' ' . $_POST['switch_port']), "r"); $mac = fread($process, 2096); show_window(__('Active mac address: '), $mac); pclose($process); }; } else { show_error(__('Access denied')); } Питон потому, что парсинг на php я не осилил..
      из питона вызывается snmpwalk через  popen (да, такая вот матрешка), собственно для получения mac.
      До обновления все работало, и сейчас если выполнить  из консоли что-то типа такого:
      <?php $process = popen(escapeshellcmd('/usr/local/www/apache22/data/billing/modules/general/get_mac/get_mac.py 172.16.0.182 2', "r"); $mac = fread($process, 2096); echo "$mac"; ?> то все работает.
      При выполнении из биллинга питон не создает процесс-потомок snmpwalk.
      Какие настройки php или биллинга копать?
    • Автор: init
      Добрый день! Появилась необходимость обновить Ubilling с версии 0.7.2 до текущей, как бы это сделать быстро и безболезненно?
      Я так понимаю надо с версии на версию прыгать? или есть какой-то инструмент который инкрементно обновит до текущей версии?
      Благодарю
    • Автор: Baneff
      Всем привет.
      Давно использую freebsd + ipfw + dummynet + kernel nat + ещё куча всякого разного и всё на одном серваке. Менять платформу не хочу - старый я уже для этого. Так вот. Нагрузка постепенно растёт, пора как-бы железо менять в очередной раз, но есть проблема. Всё в этой схеме прекрасно параллелится на мультиядерной системе. Всё, кроме старичка DUMMYNET. В очередной раз смотрю на процесс kernel{dummynet} и в очередной раз вижу конкретное узкое место во всй системе. Обойти невозможно, работает только в один поток и когда загрузка превышает 80-90% начинаются естественные проблемы. Все остальное работает с большим запасом по нагрузке. Вот и вопрос: как-то эту проблему удаётся решать? Чем шейпить юзеров, если не дамминетом? Или может появилась возможность как-то его параллелить? Или, возможно, какие-то новые методы позволяют как-то снизить нагрузку на дамминет? В документации появились некие новые варианты настроек CoDel, PIE, FQ-CoDel и FQ-PIE в дополнение к старым, может они помогут? Кто-то пробовал?
      Спасибо.
    • Автор: 005836
      Помогите пожалуйста.
      ОС freebsd 12/freeradius3/mikrotik os 5.24
      Настраивал Ubilling + Mikrotik pppoe по радиусу
      В дебаг режиме радиус говорит

       
    • Автор: nightfly
      Мы знаем, всем уже надоело ждать. Вот, первый в этом году стабильный релиз Ubilling 0.9.5 rev 6653 syoubu da
       
      Из основных изменений
      Изменения в структуре БД. см. дамп. alter.ini: новые опции FWTBT_* управляющие знанием о том, по ком звонит колокол. alter.ini: новая опция CALLSHIST_ENABLED включающая модуль «История звонков». alter.ini: новые необязательные опции PON_UONU_USER_BY_MAC_SEARCH_* управляющие возможностью поиска пользователя по МАС при регистрации ONU из «неизвестных ONU». alter.ini: новая опция IPCHANGE_ARP_CLEANUP указывающая на необходимость очистки от старых arp-записей при смене IP пользователя. alter.ini: новая опция STICKY_REVELATIONS_ENABLED включающая механику откровений. alter.ini: новая опция ISHIMURA_ENABLED включающая планетарный потрошитель Ишимура. alter.ini: новая опция PONCPE_CONTROLS_ENABLED включающая отображение элементов управления для присваивания PON CPE в профиле пользователя. alter.ini: новая необязательная опция PONCPE_TARIFFMASK указывающая маску имени тарифа, для пользователей, для которых требуется учет PON CPE. userstats.ini: добавлена новая необязательная опция AF_TARIFF_ALLOW_ANY позволяющая включить возможность заморозки счета из личного кабинета не взирая на тарифный план абонента. userstats.ini: новая опция ISHIMURA_ENABLED включающая использование трафика Ишимуры при показе статистики. userstats.ini: новая необязательная опция MG_TARIFFSALLOWED при помощи которой можно ограничить тарифы на которых разрешено использование Megogo. Модуль «Планирование работ»: исправлена ошибка, появляющейся при фильтра заявок «Показать задачи только для меня» Модуль «Печать документов»: исправлена работа макроса {CONTRACT} при использовании не уникальных номеров договоров. Модуль «Возможности подключений»: добавлена текстовая пометка о телепатической угаданности пользователя, для упрощения фильтрования. Модуль «Отчет по подключениям»: в статистику мертвых пользователей добавлен раздельный счетчик замороженных. Модуль «Учет зарплат»: для зарплатных ведомостей реализована возможность просмотра/печати без графиков. Модуль SMSZilla: для направления «Интернет» добавлен фильтр активности пользователя. Модуль «Сети и услуги»: из модуля «Смена IP» портирована статистика использования адресов. Модуль «Работники»: добавлена возможность ограничивать сумму пополнения абонентов в месяц Модуль «Финансовый отчет»: исправлена сортировка в сводке за год. Модуль «Отчет по подключениям»: селектор года теперь сохраняет свое состояние. Модуль «Финансовый отчет»: селектор года теперь сохраняет свое состояние. Модуль «Импорт банковских выписок»: оптимизировано быстродействие, возможно исправлена проблема повторного внесения некоторых платежей. Новый модуль По ком звонит колокол: позволяет получать near real-time оповещения о входящих звонках. Модуль [По ком звонит колокол]: исправлены дубликаты отображения входящих звонков Модуль «Текущий кеш FDB»: добавлена возможность навигации из модуля в профиль свитча. askozianum: теперь также логирует входящие звонки в базу. Новый модуль «История звонков»: позволяет просматривать предыдущие входящие звонки ваших абонентов. Модуль Учет зарплат: добавлена возможность отметить для выплаты все работы одним кликом. Модуль «Планирование работ»: исправлена ошибка приводившая к невозможности удаления задач в некоторых ситуациях. Модуль «Телефонный справочник»: теперь использует JQuery Data Tables для показа списка контактов. Модуль «Смена IP»: теперь также умеет чистить за собой старые arp записи при смене IP. Модуль «Объявления»: полностью переделан код, скорость загрузки модуля увеличилось в много раз. Модуль «Персональные заметки и напоминания»: добавлена возможность осыпать всех откровениями. Модуль «Удаление пользователя»: теперь при удалении пользователя также очищаются его детали подключения. Модуль SMSZilla: исправлена работа фильтра «денег не хватит на следующий месяц». Модуль «TrinityTV»: добавлен функционал привязки устройств из личного кабинета абонента. Модуль «Отчет по задачам»: исправлен показ дат в печати. Модуль Склад: история бронирования теперь позволяет нормально отслеживать историю конкретной брони. Модуль «Склад»: теперь умеет рассылать сотрудникам зарезервированные на них ТМЦ скопом, для сверки того что у них в багажниках. Модуль «Статистика по трафику»: теперь также агрегирует при показе нативный трафик коллекторов с трафиком Ишимуры. Модуль «Онлайн»: теперь также агрегирует при показе нативный трафик коллекторов с трафиком Ишимуры. Понизатор: добавлена возможность поиска пользователя(логина и IP) по МАС при регистрации ONU из «неизвестных ONU». Так же для тех, кто использует ONU с NAT, у которых МАС WAN-подключения изменяется на какое-то значение добавлена возможность инкремента/декремента МАС адреса ONU. Модуль «Права администраторов»: добавлена возможность на ходу перелогиниваться в режиме призрака, под другими администраторами. Модуль «Состояние системы»: добавлена возможность уничтожения отдельных ключей кэша. RemoteAPI: добавлен новый вызов warehousetelegram для рассылки зарезервированных ТМЦ. Глобально: в диалогах выбора года расширен диапазон доступных для выбора лет. Глобально: исправлен фильтр ввода email, теперь email может содержать тире Кабинет пользователя: подавлены попытки Google Chrome пытаться автоматически переводить страницу. Кабинет пользователя: исправлены проблемы со входом по логину/паролю. Кабинет пользователя: модуль «Статистика по трафику» теперь также агрегирует нативный трафик коллектора с трафиком Ишимуры при показе. Кабинет пользователя: модуль «Megogo» теперь умеет ограничивать использование сервиса относительно тарифов пользователя. OpenPayz: добавлен фронтэнд для работы с ПриватБанком «PRIVATX_STRICT», призванный обеспечить слегка противоположный фронтэнду «PRIVATMULTI» функционал. OpenPayz: фронтенд «IBOX» - добавлена отдача информации по пользователю UBinstaller: собарны бинарные пакеты для установки биллинга на FreeBSD 12.0 amd64. UBinstaller: для конфигуратора NAS на rscriptd собраны бинарные пакеты для FreeBSD 12.0 amd64. UBinstaller: на мороз выкинуты все неактуальные и не поддерживаемые на данный момент релизы FreeBSD.  
      Также вы можете:
      Почитать полный чейнджлог: http://wiki.ubilling.net.ua/doku.php?id=changelog2019#rev_6653
      Ознакомиться с рекомендациями к обновлению: http://wiki.ubilling.net.ua/doku.php?id=relnotes#section095
      Потрогать руками демку: http://ubilling.net.ua/?module=fnpages&pid=demo
       

×