Source code for pcapkit.vendor.ipv4.option_number
# -*- coding: utf-8 -*-
"""IPv4 Option Numbers"""
import collections
import csv
import re
from pcapkit.vendor.default import Vendor
__all__ = ['OptionNumber']
[docs]class OptionNumber(Vendor):
"""IP Option Numbers"""
#: Value limit checker.
FLAG = 'isinstance(value, int) and 0 <= value <= 255'
#: Link to registry.
LINK = 'https://www.iana.org/assignments/ip-parameters/ip-parameters-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[4]), # pylint: disable=map-builtin-not-iterating
filter(lambda item: len(item[3].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 = [
"extend_enum(cls, 'Unassigned_%d' % value, value)",
'return cls(value)'
]
for item in reader:
code = item[3]
dscp = item[4]
rfcs = item[5]
temp = list()
for rfc in filter(None, re.split(r'\[|\]', rfcs)):
if re.match(r'\d+', rfc):
continue
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('_', ' '))
tmp1 = f" {''.join(temp)}" if rfcs else ''
abbr, name = re.split(r'\W+-\W+', dscp)
tmp2 = re.sub(r'\[\d+\]', '', name)
name = f'{" - " if abbr else ""}{tmp2}' if tmp2 else ''
desc = self.wrap_comment(f'{abbr}{name}{tmp1}')
renm = self.rename(abbr or f'Unassigned_{code}', code, original=dscp)
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}')
return enum, miss
if __name__ == "__main__":
OptionNumber()