Source code for pcapkit.vendor.ipv6.extension_header
# -*- coding: utf-8 -*-
"""IPv6 Extension Header Types"""
import collections
import csv
import re
from pcapkit.vendor.default import Vendor
__all__ = ['ExtensionHeader']
LINE = lambda NAME, DOCS, ENUM: f'''\
# -*- coding: utf-8 -*-
# pylint: disable=line-too-long
"""{DOCS}"""
from aenum import IntEnum, extend_enum
__all__ = ['{NAME}']
class {NAME}(IntEnum):
"""[{NAME}] {DOCS}"""
{ENUM}
@staticmethod
def get(key, default=-1):
"""Backport support for original codes."""
if isinstance(key, int):
return {NAME}(key)
if key not in {NAME}._member_map_: # pylint: disable=no-member
extend_enum({NAME}, key, default)
return {NAME}[key]
'''
[docs]class ExtensionHeader(Vendor):
"""IPv6 Extension Header Types"""
#: Link to registry.
LINK = 'https://www.iana.org/assignments/protocol-numbers/protocol-numbers-1.csv'
[docs] def count(self, data):
"""Count field records.
Args:
data (List[str]): CSV data.
Returns:
Counter: Field recordings.
"""
reader = csv.reader(data)
next(reader) # header
return collections.Counter(map(lambda item: self.safe_name(item[1] or item[2]), # pylint: disable=map-builtin-not-iterating
filter(lambda item: len(item[0].split('-')) != 2, reader))) # pylint: disable=filter-builtin-not-iterating
[docs] def process(self, data):
"""Process CSV data.
Args:
data (List[str]): CSV data.
Returns:
List[str]: Enumeration fields.
List[str]: Missing fields.
"""
reader = csv.reader(data)
next(reader) # header
enum = list()
miss = list()
for item in reader:
flag = item[3]
if flag != 'Y':
continue
name = item[1]
rfcs = item[4]
temp = list()
for rfc in filter(None, re.split(r'\[|\]', rfcs)):
if 'RFC' in rfc and re.match(r'\d+', rfc[3:]):
#temp.append(f'[{rfc[:3]} {rfc[3:]}]')
temp.append(f'[:rfc:`{rfc[3:]}`]')
else:
temp.append(f'[{rfc}]'.replace('_', ' '))
lrfc = re.sub(r'( )( )*', ' ', f" {''.join(temp)}".replace('\n', ' ')) if rfcs else ''
subd = re.sub(r'( )( )*', ' ', item[2].replace('\n', ' '))
tmp1 = f' {subd}' if item[2] else ''
split = name.split(' (', 1)
if len(split) == 2:
name, cmmt = split[0], f" ({split[1]}"
else:
name, cmmt = name, '' # pylint: disable=self-assigning-variable
if not name:
name, tmp1 = item[2], ''
desc = self.wrap_comment(f'{name}{lrfc}{tmp1}{cmmt}')
try:
code, _ = item[0], int(item[0])
if not name:
name, desc = item[2], ''
renm = self.rename(name, code, original=item[1])
pres = f"{renm} = {code}"
sufs = f"#: {desc}"
#if len(pres) > 74:
# sufs = f"\n{' '*80}{sufs}"
#enum.append(f'{pres.ljust(76)}{sufs}')
enum.append(f'{sufs}\n {pres}')
except ValueError:
start, stop = item[0].split('-')
miss.append(f'if {start} <= value <= {stop}:')
miss.append(f' #: {desc}')
miss.append(f" extend_enum(cls, '{self.safe_name(name)}_%d' % value, value)")
miss.append(' return cls(value)')
return enum
[docs] def context(self, data):
enum = self.process(data)
ENUM = '\n\n '.join(map(lambda s: s.rstrip(), enum))
return LINE(self.NAME, self.DOCS, ENUM)
if __name__ == '__main__':
ExtensionHeader()