Skip to content

Re Auth

API reference for diameter.message.commands.re_auth.

This module contains Re-Auth Request and Answer messages, implementing AVPs documented in rfc6733.

ReAuth

ReAuth(header: MessageHeader = None, avps: list[Avp] = None)

Bases: DefinedMessage

A Re-Auth message.

This message class lists message attributes based on the current RFC6733 as python properties, acessible as instance attributes. AVPs not listed in the base protocol can be retrieved using the ReAuth.find_avps search method.

Examples:

AVPs accessible either as instance attributes or by searching:

>>> msg = Message.from_bytes(b"...")
>>> msg.origin_realm
b'mvno.net'
>>> msg.find_avps((AVP_ORIGIN_REALM, 0))
[b'mvno.net']

When a diameter message is decoded using Message.from_bytes, it returns either an instance of ReAuthRequest or ReAuthAnswer automatically:

>>> msg = Message.from_bytes(b"...")
>>> assert msg.header.is_request is True
>>> assert isinstance(msg, ReAuthRequest)

When creating a new message by hand, the ReAuthRequest or ReAuthAnswer class should be instantiated directly, and values for AVPs set as class attributes:

>>> msg = ReAuthRequest()
>>> msg.origin_realm = b"mvno.net"

Other, custom AVPs can be appended to the message using the ReAuth.append_avp method, or by overwriting the avp attribute entirely. Regardless of the custom AVPs set, the mandatory values listed in RFC6733 must be set, however they can be set as None, if they are not to be used.

Warning

Every AVP documented for the subclasses of this command can be accessed as an instance attribute, even if the original network-received message did not contain that specific AVP. Such AVPs will be returned with the value None when accessed.

Every other AVP not mentioned here, and not present in a network-received message will raise an AttributeError when being accessed; their presence should be validated with hasattr before accessing.

ReAuthAnswer

ReAuthAnswer(header: MessageHeader = None, avps: list[Avp] = None)

Bases: ReAuth

A Re-Auth-Answer message.

auth_grace_period instance-attribute

auth_grace_period: int

authorization_lifetime instance-attribute

authorization_lifetime: int

configuration_token instance-attribute

configuration_token: list[bytes]

error_message instance-attribute

error_message: str

error_reporting_host instance-attribute

error_reporting_host: bytes

failed_avp instance-attribute

failed_avp: FailedAvp

idle_timeout instance-attribute

idle_timeout: int

origin_aaa_protocol instance-attribute

origin_aaa_protocol: int

origin_host instance-attribute

origin_host: bytes

origin_realm instance-attribute

origin_realm: bytes

origin_state_id instance-attribute

origin_state_id: int

prompt instance-attribute

prompt: int

proxy_info instance-attribute

proxy_info: list[ProxyInfo]

re_auth_request_type instance-attribute

re_auth_request_type: int

redirect_host instance-attribute

redirect_host: list[str]

redirect_host_usage instance-attribute

redirect_host_usage: int

redirect_max_cache_time instance-attribute

redirect_max_cache_time: int

reply_message instance-attribute

reply_message: list[str]

result_code instance-attribute

result_code: int

route_record instance-attribute

route_record: list[bytes]

service_type instance-attribute

service_type: int

session_id instance-attribute

session_id: str

state instance-attribute

state: bytes

state_class instance-attribute

state_class: list[bytes]

user_name instance-attribute

user_name: str

ReAuthRequest

ReAuthRequest(header: MessageHeader = None, avps: list[Avp] = None)

Bases: ReAuth

A Re-Auth-Request message.

acct_multi_session_id instance-attribute

acct_multi_session_id: str

acct_session_id instance-attribute

acct_session_id: bytes

auth_application_id instance-attribute

auth_application_id: int

called_station_id instance-attribute

called_station_id: str

calling_station_id instance-attribute

calling_station_id: str

charging_rule_install instance-attribute

charging_rule_install: list[ChargingRuleInstall]

charging_rule_remove instance-attribute

charging_rule_remove: list[ChargingRuleRemove]

destination_host instance-attribute

destination_host: bytes

destination_realm instance-attribute

destination_realm: bytes

framed_interface_id instance-attribute

framed_interface_id: int

framed_ip_address instance-attribute

framed_ip_address: bytes

framed_ipv6_prefix instance-attribute

framed_ipv6_prefix: list[bytes]

g_s_u_pool_identifier instance-attribute

g_s_u_pool_identifier: int

nas_identifier instance-attribute

nas_identifier: str

nas_ip_address instance-attribute

nas_ip_address: bytes

nas_ipv6_address instance-attribute

nas_ipv6_address: bytes

nas_port instance-attribute

nas_port: int

nas_port_id instance-attribute

nas_port_id: str

nas_port_type instance-attribute

nas_port_type: int

origin_aaa_protocol instance-attribute

origin_aaa_protocol: int

origin_host instance-attribute

origin_host: bytes

origin_realm instance-attribute

origin_realm: bytes

origin_state_id instance-attribute

origin_state_id: int

originating_line_info instance-attribute

originating_line_info: bytes

proxy_info instance-attribute

proxy_info: list[ProxyInfo]

rating_group instance-attribute

rating_group: int

re_auth_request_type instance-attribute

re_auth_request_type: int

reply_message instance-attribute

reply_message: list[str]

route_record instance-attribute

route_record: list[bytes]

service_identifier instance-attribute

service_identifier: int

service_type instance-attribute

service_type: int

session_id instance-attribute

session_id: str

state instance-attribute

state: bytes

state_class instance-attribute

state_class: list[bytes]

user_name instance-attribute

user_name: str