Server Assignment
API reference for diameter.message.commands.server_assignment
.
This module contains Server-Assignment Request and Answer messages, implementing AVPs documented in 3GPP TS 29.229.
ServerAssignment ¶
ServerAssignment(
header: MessageHeader = None, avps: list[Avp] = None
)
Bases: DefinedMessage
A Server-Assignment base message.
This message class lists message attributes based on the current 3GPP TS 29.229 version 13.1.0 Release 13 as python properties, accessible as instance attributes. AVPs not listed in the spec protocol can be retrieved using the ServerAssignment.find_avps search method.
Examples:
AVPs accessible either as instance attributes or by searching:
>>> msg = Message.from_bytes(b"...")
>>> msg.session_id
dra1.mvno.net;2323;546
>>> msg.find_avps((AVP_SESSION_ID, 0))
['dra1.mvno.net;2323;546']
When diameter message is decoded using
Message.from_bytes, it returns
either an instance of ServerAssignmentRequest
or
ServerAssignmentAnswer
automatically:
>>> msg = Message.from_bytes(b"...")
>>> assert msg.header.is_request is True
>>> assert isinstance(msg, ServerAssignmentRequest)
When creating a new message, the ServerAssignmentRequest
or
ServerAssignmentAnswer
class should be instantiated directly, and
values for AVPs set as class attributes:
>>> msg = ServerAssignmentRequest()
>>> msg.session_id = "dra1.mvno.net;2323;546"
Other, custom AVPs can be appended to the message using the
ServerAssignment.append_avp method,
or by overwriting the avp
attribute entirely. Regardless of the custom
AVPs set, the mandatory values listed in TS 29.229 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.
ServerAssignmentAnswer ¶
ServerAssignmentAnswer(
header: MessageHeader = None, avps: list[Avp] = None
)
Bases: ServerAssignment
A Server-Assignment-Answer message.
allowed_waf_wwsf_identities
instance-attribute
¶
allowed_waf_wwsf_identities: AllowedWafWwsfIdentities
associated_registered_identities
instance-attribute
¶
associated_registered_identities: AssociatedRegisteredIdentities
vendor_specific_application_id
instance-attribute
¶
vendor_specific_application_id: VendorSpecificApplicationId
ServerAssignmentRequest ¶
ServerAssignmentRequest(
header: MessageHeader = None, avps: list[Avp] = None
)
Bases: ServerAssignment
A Server-Assignment-Request message.
vendor_specific_application_id
instance-attribute
¶
vendor_specific_application_id: VendorSpecificApplicationId