Source code for pcapkit.const.mh.enumerating_algorithm
# -*- coding: utf-8 -*-
# pylint: disable=line-too-long,consider-using-f-string
"""Enumerating Algorithms
============================
.. module:: pcapkit.const.mh.enumerating_algorithm
This module contains the constant enumeration for **Enumerating Algorithms**,
which is automatically generated from :class:`pcapkit.vendor.mh.enumerating_algorithm.EnumeratingAlgorithm`.
"""
from aenum import IntEnum, extend_enum
__all__ = ['EnumeratingAlgorithm']
[docs]
class EnumeratingAlgorithm(IntEnum):
"""[EnumeratingAlgorithm] Enumerating Algorithms"""
#: Reserved (not available for assignment) [:rfc:`4285`]
Reserved_0 = 0
#: HMAC_SHA1_SPI [:rfc:`4285`]
HMAC_SHA1_SPI = 3
#: Reserved for use by 3GPP2 [:rfc:`4285`]
Reserved_for_use_by_3GPP2 = 5
@staticmethod
def get(key: 'int | str', default: 'int' = -1) -> 'EnumeratingAlgorithm':
"""Backport support for original codes.
Args:
key: Key to get enum item.
default: Default value if not found.
:meta private:
"""
if isinstance(key, int):
return EnumeratingAlgorithm(key)
if key not in EnumeratingAlgorithm._member_map_: # pylint: disable=no-member
return extend_enum(EnumeratingAlgorithm, key, default)
return EnumeratingAlgorithm[key] # type: ignore[misc]
[docs]
@classmethod
def _missing_(cls, value: 'int') -> 'EnumeratingAlgorithm':
"""Lookup function used when value is not found.
Args:
value: Value to get enum item.
"""
if not (isinstance(value, int) and 0 <= value <= 255):
raise ValueError('%r is not a valid %s' % (value, cls.__name__))
return extend_enum(cls, 'Unassigned_%d' % value, value)