kopia lustrzana https://github.com/Yakifo/amqtt
Factorize VariableHeader with packet id
rodzic
3da64bc65d
commit
9c14f6d01d
|
|
@ -210,3 +210,19 @@ class MQTTPacket:
|
||||||
|
|
||||||
def __repr__(self):
|
def __repr__(self):
|
||||||
return 'MQPacket(fixed={0!r}, variable={1!r}, payload={2!r})'.format(self.fixed_header, self.variable_header, self.payload)
|
return 'MQPacket(fixed={0!r}, variable={1!r}, payload={2!r})'.format(self.fixed_header, self.variable_header, self.payload)
|
||||||
|
|
||||||
|
|
||||||
|
class PacketIdVariableHeader(MQTTVariableHeader):
|
||||||
|
def __init__(self, packet_id):
|
||||||
|
super().__init__()
|
||||||
|
self.packet_id = packet_id
|
||||||
|
|
||||||
|
def to_bytes(self):
|
||||||
|
out = b''
|
||||||
|
out += int_to_bytes(self.packet_id, 2)
|
||||||
|
return out
|
||||||
|
|
||||||
|
@classmethod
|
||||||
|
def from_stream(cls, reader: asyncio.StreamReader, fixed_header: MQTTFixedHeader):
|
||||||
|
packet_id = yield from decode_packet_id(reader)
|
||||||
|
return cls(packet_id)
|
||||||
|
|
|
||||||
|
|
@ -1,32 +1,15 @@
|
||||||
# Copyright (c) 2015 Nicolas JOUANIN
|
# Copyright (c) 2015 Nicolas JOUANIN
|
||||||
#
|
#
|
||||||
# See the file license.txt for copying permission.
|
# See the file license.txt for copying permission.
|
||||||
from hbmqtt.mqtt.packet import MQTTPacket, MQTTFixedHeader, PacketType, MQTTVariableHeader
|
from hbmqtt.mqtt.packet import MQTTPacket, MQTTFixedHeader, PacketType, PacketIdVariableHeader
|
||||||
from hbmqtt.errors import HBMQTTException
|
from hbmqtt.errors import HBMQTTException
|
||||||
from hbmqtt.codecs import *
|
|
||||||
|
|
||||||
|
|
||||||
class PubackVariableHeader(MQTTVariableHeader):
|
|
||||||
def __init__(self, packet_id):
|
|
||||||
super().__init__()
|
|
||||||
self.packet_id = packet_id
|
|
||||||
|
|
||||||
def to_bytes(self):
|
|
||||||
out = b''
|
|
||||||
out += int_to_bytes(self.packet_id, 2)
|
|
||||||
return out
|
|
||||||
|
|
||||||
@classmethod
|
|
||||||
def from_stream(cls, reader: asyncio.StreamReader, fixed_header: MQTTFixedHeader):
|
|
||||||
packet_id = yield from decode_packet_id(reader)
|
|
||||||
return cls(packet_id)
|
|
||||||
|
|
||||||
|
|
||||||
class PubackPacket(MQTTPacket):
|
class PubackPacket(MQTTPacket):
|
||||||
VARIABLE_HEADER = PubackVariableHeader
|
VARIABLE_HEADER = PacketIdVariableHeader
|
||||||
PAYLOAD = None
|
PAYLOAD = None
|
||||||
|
|
||||||
def __init__(self, fixed: MQTTFixedHeader=None, variable_header: PubackVariableHeader=None, payload=None):
|
def __init__(self, fixed: MQTTFixedHeader=None, variable_header: PacketIdVariableHeader=None, payload=None):
|
||||||
if fixed is None:
|
if fixed is None:
|
||||||
header = MQTTFixedHeader(PacketType.PUBACK, 0x00)
|
header = MQTTFixedHeader(PacketType.PUBACK, 0x00)
|
||||||
else:
|
else:
|
||||||
|
|
|
||||||
|
|
@ -1,32 +1,15 @@
|
||||||
# Copyright (c) 2015 Nicolas JOUANIN
|
# Copyright (c) 2015 Nicolas JOUANIN
|
||||||
#
|
#
|
||||||
# See the file license.txt for copying permission.
|
# See the file license.txt for copying permission.
|
||||||
from hbmqtt.mqtt.packet import MQTTPacket, MQTTFixedHeader, PacketType, MQTTVariableHeader
|
from hbmqtt.mqtt.packet import MQTTPacket, MQTTFixedHeader, PacketType, PacketIdVariableHeader
|
||||||
from hbmqtt.errors import HBMQTTException
|
from hbmqtt.errors import HBMQTTException
|
||||||
from hbmqtt.codecs import *
|
|
||||||
|
|
||||||
|
|
||||||
class PubcompVariableHeader(MQTTVariableHeader):
|
|
||||||
def __init__(self, packet_id):
|
|
||||||
super().__init__()
|
|
||||||
self.packet_id = packet_id
|
|
||||||
|
|
||||||
def to_bytes(self):
|
|
||||||
out = b''
|
|
||||||
out += int_to_bytes(self.packet_id, 2)
|
|
||||||
return out
|
|
||||||
|
|
||||||
@classmethod
|
|
||||||
def from_stream(cls, reader: asyncio.StreamReader, fixed_header: MQTTFixedHeader):
|
|
||||||
packet_id = yield from decode_packet_id(reader)
|
|
||||||
return cls(packet_id)
|
|
||||||
|
|
||||||
|
|
||||||
class PubcompPacket(MQTTPacket):
|
class PubcompPacket(MQTTPacket):
|
||||||
VARIABLE_HEADER = PubcompVariableHeader
|
VARIABLE_HEADER = PacketIdVariableHeader
|
||||||
PAYLOAD = None
|
PAYLOAD = None
|
||||||
|
|
||||||
def __init__(self, fixed: MQTTFixedHeader=None, variable_header: PubcompVariableHeader=None, payload=None):
|
def __init__(self, fixed: MQTTFixedHeader=None, variable_header: PacketIdVariableHeader=None, payload=None):
|
||||||
if fixed is None:
|
if fixed is None:
|
||||||
header = MQTTFixedHeader(PacketType.PUBCOMP, 0x00)
|
header = MQTTFixedHeader(PacketType.PUBCOMP, 0x00)
|
||||||
else:
|
else:
|
||||||
|
|
|
||||||
|
|
@ -1,32 +1,15 @@
|
||||||
# Copyright (c) 2015 Nicolas JOUANIN
|
# Copyright (c) 2015 Nicolas JOUANIN
|
||||||
#
|
#
|
||||||
# See the file license.txt for copying permission.
|
# See the file license.txt for copying permission.
|
||||||
from hbmqtt.mqtt.packet import MQTTPacket, MQTTFixedHeader, PacketType, MQTTVariableHeader
|
from hbmqtt.mqtt.packet import MQTTPacket, MQTTFixedHeader, PacketType, PacketIdVariableHeader
|
||||||
from hbmqtt.errors import HBMQTTException
|
from hbmqtt.errors import HBMQTTException
|
||||||
from hbmqtt.codecs import *
|
|
||||||
|
|
||||||
|
|
||||||
class PubrecVariableHeader(MQTTVariableHeader):
|
|
||||||
def __init__(self, packet_id):
|
|
||||||
super().__init__()
|
|
||||||
self.packet_id = packet_id
|
|
||||||
|
|
||||||
def to_bytes(self):
|
|
||||||
out = b''
|
|
||||||
out += int_to_bytes(self.packet_id, 2)
|
|
||||||
return out
|
|
||||||
|
|
||||||
@classmethod
|
|
||||||
def from_stream(cls, reader: asyncio.StreamReader, fixed_header: MQTTFixedHeader):
|
|
||||||
packet_id = yield from decode_packet_id(reader)
|
|
||||||
return cls(packet_id)
|
|
||||||
|
|
||||||
|
|
||||||
class PubrecPacket(MQTTPacket):
|
class PubrecPacket(MQTTPacket):
|
||||||
VARIABLE_HEADER = PubrecVariableHeader
|
VARIABLE_HEADER = PacketIdVariableHeader
|
||||||
PAYLOAD = None
|
PAYLOAD = None
|
||||||
|
|
||||||
def __init__(self, fixed: MQTTFixedHeader=None, variable_header: PubrecVariableHeader=None, payload=None):
|
def __init__(self, fixed: MQTTFixedHeader=None, variable_header: PacketIdVariableHeader=None, payload=None):
|
||||||
if fixed is None:
|
if fixed is None:
|
||||||
header = MQTTFixedHeader(PacketType.PUBREC, 0x00)
|
header = MQTTFixedHeader(PacketType.PUBREC, 0x00)
|
||||||
else:
|
else:
|
||||||
|
|
|
||||||
|
|
@ -1,32 +1,15 @@
|
||||||
# Copyright (c) 2015 Nicolas JOUANIN
|
# Copyright (c) 2015 Nicolas JOUANIN
|
||||||
#
|
#
|
||||||
# See the file license.txt for copying permission.
|
# See the file license.txt for copying permission.
|
||||||
from hbmqtt.mqtt.packet import MQTTPacket, MQTTFixedHeader, PacketType, MQTTVariableHeader
|
from hbmqtt.mqtt.packet import MQTTPacket, MQTTFixedHeader, PacketType, PacketIdVariableHeader
|
||||||
from hbmqtt.errors import HBMQTTException
|
from hbmqtt.errors import HBMQTTException
|
||||||
from hbmqtt.codecs import *
|
|
||||||
|
|
||||||
|
|
||||||
class PubrelVariableHeader(MQTTVariableHeader):
|
|
||||||
def __init__(self, packet_id):
|
|
||||||
super().__init__()
|
|
||||||
self.packet_id = packet_id
|
|
||||||
|
|
||||||
def to_bytes(self):
|
|
||||||
out = b''
|
|
||||||
out += int_to_bytes(self.packet_id, 2)
|
|
||||||
return out
|
|
||||||
|
|
||||||
@classmethod
|
|
||||||
def from_stream(cls, reader: asyncio.StreamReader, fixed_header: MQTTFixedHeader):
|
|
||||||
packet_id = yield from decode_packet_id(reader)
|
|
||||||
return cls(packet_id)
|
|
||||||
|
|
||||||
|
|
||||||
class PubrelPacket(MQTTPacket):
|
class PubrelPacket(MQTTPacket):
|
||||||
VARIABLE_HEADER = PubrelVariableHeader
|
VARIABLE_HEADER = PacketIdVariableHeader
|
||||||
PAYLOAD = None
|
PAYLOAD = None
|
||||||
|
|
||||||
def __init__(self, fixed: MQTTFixedHeader=None, variable_header: PubrelVariableHeader=None, payload=None):
|
def __init__(self, fixed: MQTTFixedHeader=None, variable_header: PacketIdVariableHeader=None, payload=None):
|
||||||
if fixed is None:
|
if fixed is None:
|
||||||
header = MQTTFixedHeader(PacketType.PUBREL, 0x00)
|
header = MQTTFixedHeader(PacketType.PUBREL, 0x00)
|
||||||
else:
|
else:
|
||||||
|
|
|
||||||
|
|
@ -3,7 +3,7 @@
|
||||||
# See the file license.txt for copying permission.
|
# See the file license.txt for copying permission.
|
||||||
import unittest
|
import unittest
|
||||||
|
|
||||||
from hbmqtt.mqtt.puback import PubackPacket, PubackVariableHeader
|
from hbmqtt.mqtt.puback import PubackPacket, PacketIdVariableHeader
|
||||||
from hbmqtt.codecs import *
|
from hbmqtt.codecs import *
|
||||||
|
|
||||||
class PubackPacketTest(unittest.TestCase):
|
class PubackPacketTest(unittest.TestCase):
|
||||||
|
|
@ -18,7 +18,7 @@ class PubackPacketTest(unittest.TestCase):
|
||||||
self.assertEqual(message.variable_header.packet_id, 10)
|
self.assertEqual(message.variable_header.packet_id, 10)
|
||||||
|
|
||||||
def test_to_bytes(self):
|
def test_to_bytes(self):
|
||||||
variable_header = PubackVariableHeader(10)
|
variable_header = PacketIdVariableHeader(10)
|
||||||
publish = PubackPacket(variable_header=variable_header)
|
publish = PubackPacket(variable_header=variable_header)
|
||||||
out = publish.to_bytes()
|
out = publish.to_bytes()
|
||||||
self.assertEqual(out, b'\x40\x02\x00\x0a')
|
self.assertEqual(out, b'\x40\x02\x00\x0a')
|
||||||
|
|
@ -3,7 +3,7 @@
|
||||||
# See the file license.txt for copying permission.
|
# See the file license.txt for copying permission.
|
||||||
import unittest
|
import unittest
|
||||||
|
|
||||||
from hbmqtt.mqtt.pubcomp import PubcompPacket, PubcompVariableHeader
|
from hbmqtt.mqtt.pubcomp import PubcompPacket, PacketIdVariableHeader
|
||||||
from hbmqtt.codecs import *
|
from hbmqtt.codecs import *
|
||||||
|
|
||||||
class PubcompPacketTest(unittest.TestCase):
|
class PubcompPacketTest(unittest.TestCase):
|
||||||
|
|
@ -18,7 +18,7 @@ class PubcompPacketTest(unittest.TestCase):
|
||||||
self.assertEqual(message.variable_header.packet_id, 10)
|
self.assertEqual(message.variable_header.packet_id, 10)
|
||||||
|
|
||||||
def test_to_bytes(self):
|
def test_to_bytes(self):
|
||||||
variable_header = PubcompVariableHeader(10)
|
variable_header = PacketIdVariableHeader(10)
|
||||||
publish = PubcompPacket(variable_header=variable_header)
|
publish = PubcompPacket(variable_header=variable_header)
|
||||||
out = publish.to_bytes()
|
out = publish.to_bytes()
|
||||||
self.assertEqual(out, b'\x70\x02\x00\x0a')
|
self.assertEqual(out, b'\x70\x02\x00\x0a')
|
||||||
|
|
@ -3,7 +3,7 @@
|
||||||
# See the file license.txt for copying permission.
|
# See the file license.txt for copying permission.
|
||||||
import unittest
|
import unittest
|
||||||
|
|
||||||
from hbmqtt.mqtt.pubrec import PubrecPacket, PubrecVariableHeader
|
from hbmqtt.mqtt.pubrec import PubrecPacket, PacketIdVariableHeader
|
||||||
from hbmqtt.codecs import *
|
from hbmqtt.codecs import *
|
||||||
|
|
||||||
class PubrecPacketTest(unittest.TestCase):
|
class PubrecPacketTest(unittest.TestCase):
|
||||||
|
|
@ -18,7 +18,7 @@ class PubrecPacketTest(unittest.TestCase):
|
||||||
self.assertEqual(message.variable_header.packet_id, 10)
|
self.assertEqual(message.variable_header.packet_id, 10)
|
||||||
|
|
||||||
def test_to_bytes(self):
|
def test_to_bytes(self):
|
||||||
variable_header = PubrecVariableHeader(10)
|
variable_header = PacketIdVariableHeader(10)
|
||||||
publish = PubrecPacket(variable_header=variable_header)
|
publish = PubrecPacket(variable_header=variable_header)
|
||||||
out = publish.to_bytes()
|
out = publish.to_bytes()
|
||||||
self.assertEqual(out, b'\x50\x02\x00\x0a')
|
self.assertEqual(out, b'\x50\x02\x00\x0a')
|
||||||
|
|
@ -3,7 +3,7 @@
|
||||||
# See the file license.txt for copying permission.
|
# See the file license.txt for copying permission.
|
||||||
import unittest
|
import unittest
|
||||||
|
|
||||||
from hbmqtt.mqtt.pubrel import PubrelPacket, PubrelVariableHeader
|
from hbmqtt.mqtt.pubrel import PubrelPacket, PacketIdVariableHeader
|
||||||
from hbmqtt.codecs import *
|
from hbmqtt.codecs import *
|
||||||
|
|
||||||
class PubrelPacketTest(unittest.TestCase):
|
class PubrelPacketTest(unittest.TestCase):
|
||||||
|
|
@ -18,7 +18,7 @@ class PubrelPacketTest(unittest.TestCase):
|
||||||
self.assertEqual(message.variable_header.packet_id, 10)
|
self.assertEqual(message.variable_header.packet_id, 10)
|
||||||
|
|
||||||
def test_to_bytes(self):
|
def test_to_bytes(self):
|
||||||
variable_header = PubrelVariableHeader(10)
|
variable_header = PacketIdVariableHeader(10)
|
||||||
publish = PubrelPacket(variable_header=variable_header)
|
publish = PubrelPacket(variable_header=variable_header)
|
||||||
out = publish.to_bytes()
|
out = publish.to_bytes()
|
||||||
self.assertEqual(out, b'\x60\x02\x00\x0a')
|
self.assertEqual(out, b'\x60\x02\x00\x0a')
|
||||||
Ładowanie…
Reference in New Issue