123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115 |
- """DNS Opcodes."""
- import dns.enum
- import dns.exception
- class Opcode(dns.enum.IntEnum):
-
- QUERY = 0
-
- IQUERY = 1
-
- STATUS = 2
-
- NOTIFY = 4
-
- UPDATE = 5
- @classmethod
- def _maximum(cls):
- return 15
- @classmethod
- def _unknown_exception_class(cls):
- return UnknownOpcode
- class UnknownOpcode(dns.exception.DNSException):
- """An DNS opcode is unknown."""
- def from_text(text):
- """Convert text into an opcode.
- *text*, a ``str``, the textual opcode
- Raises ``dns.opcode.UnknownOpcode`` if the opcode is unknown.
- Returns an ``int``.
- """
- return Opcode.from_text(text)
- def from_flags(flags):
- """Extract an opcode from DNS message flags.
- *flags*, an ``int``, the DNS flags.
- Returns an ``int``.
- """
- return (flags & 0x7800) >> 11
- def to_flags(value):
- """Convert an opcode to a value suitable for ORing into DNS message
- flags.
- *value*, an ``int``, the DNS opcode value.
- Returns an ``int``.
- """
- return (value << 11) & 0x7800
- def to_text(value):
- """Convert an opcode to text.
- *value*, an ``int`` the opcode value,
- Raises ``dns.opcode.UnknownOpcode`` if the opcode is unknown.
- Returns a ``str``.
- """
- return Opcode.to_text(value)
- def is_update(flags):
- """Is the opcode in flags UPDATE?
- *flags*, an ``int``, the DNS message flags.
- Returns a ``bool``.
- """
- return from_flags(flags) == Opcode.UPDATE
- QUERY = Opcode.QUERY
- IQUERY = Opcode.IQUERY
- STATUS = Opcode.STATUS
- NOTIFY = Opcode.NOTIFY
- UPDATE = Opcode.UPDATE
|