Переменные шаблона личного кабинета: відмінності між версіями
Sv (обговорення | внесок) Немає опису редагування |
Sv (обговорення | внесок) |
||
Рядок 36: | Рядок 36: | ||
</pre> | </pre> | ||
==user_info.dopdata | ==Дополнительные поля== | ||
user_info.dopdata - дополнительные поля учетной записи. Доступ осуществляется как: | |||
<pre> | <pre> | ||
Рядок 45: | Рядок 45: | ||
Вы должны учитывать то, что в базе данных иногда значения хранятся не так как отображаются. Например, поле "улица" в базе данных может храниться как номер улицы или как цепочка Город-улица (если используются зависимые выпадающие списки). Поэтому, скорее всего, вам нужно использовать метод show(), а не value. | Вы должны учитывать то, что в базе данных иногда значения хранятся не так как отображаются. Например, поле "улица" в базе данных может храниться как номер улицы или как цепочка Город-улица (если используются зависимые выпадающие списки). Поэтому, скорее всего, вам нужно использовать метод show(), а не value. | ||
Отобразить имя поля: | |||
<pre> | |||
{{ user_info.dopdata._adr_street.title }} | |||
</pre> | |||
==Соединения== | ==Соединения== |
Версія за 13:09, 25 березня 2019
В шаблоне base.html личного кабинета доступны такие переменные:
user_info.id : id пользователя user_info.name : логин user_info.fio : ФИО user_info.ppc : платежный код user_info.grp : номер группы клиента user_info.grp_name : имя группы user_info.state : on - доступ открыт, off - закрыт user_info.state_off : установлен если state равен off user_info.contract : договор user_info.contract_date : дата договора (timestamp) user_info.contract_date_as_text : дата договора в виде dd.mm.yyyy user_info.balance : баланс user_info.limit_balance : граница отключения user_info.block_if_limit : отключать ли запись при достижении границы отключения user_info.cstate : техническое состояние (настроить/ремонт/вирусы...) в виде числа user_info.cstate_time : время изменения поля cstate (timestamp) user_info.comment : комментарий user_info.lstate : нужна авторизация/всегда онлайн user_info.discount : скидка user_info.traf : суммарный трафик user_info.traf_in : суммарный трафик к клиенту user_info.traf_out : суммарный трафик от клиента user_info.traf1 : трафик в байтах направления 1 ... user_info.traf4 : трафик в байтах направления 4 user_info.in1 : входящий трафик направления 1 user_info.out1 : исходящий трафик направления 1 user_info.recommended_pay : рекомендованная сумма платежа user_info.full_info : блок информации об абоненте для администратора user_info.dopdata : дополнительные данные user_info.services : подключенные услуги user_info.ips : ip адреса user_info.ips : платежи
Дополнительные поля
user_info.dopdata - дополнительные поля учетной записи. Доступ осуществляется как:
user_info.dopdata._adr_street.show() : отображение поля _adr_street user_info.dopdata._adr_street.value : значение поля _adr_street
Вы должны учитывать то, что в базе данных иногда значения хранятся не так как отображаются. Например, поле "улица" в базе данных может храниться как номер улицы или как цепочка Город-улица (если используются зависимые выпадающие списки). Поэтому, скорее всего, вам нужно использовать метод show(), а не value.
Отобразить имя поля:
{{ user_info.dopdata._adr_street.title }}
Соединения
В случае, если у вас подключен модуль dhcp, добавляется еще одна переменная:
user_info.connection
В этой переменной хранится список соединений - это информация по ip и мак. Обычно, у абонента привязан один мак, поэтому его можно отобразить как:
{{ user_info.connection.0.mac }}
Или, например, мак устройства, к которому подключен абонент:
{{ user_info.connection.0.device_mac }}
Здесь 0 - индекс соединения (нумерация с нуля). При этом вы должны учитывать, что на одну учетную запись может быть несколько соединений. Поэтому, чтобы отобразить их все, нужно воспользоваться командой for:
{% for con in user_info.connection %} Ваш мак: {{ con.mac }}<br> {% endfor %}
На самом деле, конфигурация соединений такова, что мак не обязательно будет присутствовать в случае, когда учетке выделен ip адрес, но не привязан мак. Бывают и более сложные ситуации: привязано несколько ip и несколько мак. В этом случае, возможно есть смысл проверять, указан ли в соединении мак:
{% for con in user_info.connection %} {% if con.mac %} Ваш мак: {{ con.mac }}<br> {% endif %} {% endfor %}
Пример вывода полной информации по подключениям:
{% for con in user_info.connection %} Ваш мак: {{ con.mac }}, ip: {{ con.ipa }}, ip как число: {{ con.ip }}, тип: {{ con.type }}, один на порту: {% if con.oneconnect %}Да{% endif %}<br> {% endfor %}