Fix token handling
Token was encoded as utf-8 string. However, token is a byte string that is not required to be utf-8 encodable. This patch changes token type in the Message class to string of bytes instead of string of characters. Signed-off-by: Hubert Miś <hubert.mis@gmail.com>
This commit is contained in:
parent
89d51737a9
commit
297404ce33
2 changed files with 6 additions and 11 deletions
coapthon
|
@ -115,15 +115,15 @@ class Message(object):
|
||||||
"""
|
"""
|
||||||
Set the Token of the message.
|
Set the Token of the message.
|
||||||
|
|
||||||
:type value: String
|
:type value: Bytes
|
||||||
:param value: the Token
|
:param value: the Token
|
||||||
:raise AttributeError: if value is longer than 256
|
:raise AttributeError: if value is longer than 256
|
||||||
"""
|
"""
|
||||||
if value is None:
|
if value is None:
|
||||||
self._token = value
|
self._token = value
|
||||||
return
|
return
|
||||||
if not isinstance(value, str):
|
if not isinstance(value, bytes):
|
||||||
value = str(value)
|
value = bytes(value)
|
||||||
if len(value) > 256:
|
if len(value) > 256:
|
||||||
raise AttributeError
|
raise AttributeError
|
||||||
self._token = value
|
self._token = value
|
||||||
|
|
|
@ -51,10 +51,7 @@ class Serializer(object):
|
||||||
message.type = message_type
|
message.type = message_type
|
||||||
message.mid = mid
|
message.mid = mid
|
||||||
if token_length > 0:
|
if token_length > 0:
|
||||||
fmt = "%ss" % token_length
|
message.token = datagram[pos:pos+token_length]
|
||||||
s = struct.Struct(fmt)
|
|
||||||
token_value = s.unpack_from(datagram[pos:])[0]
|
|
||||||
message.token = token_value.decode("utf-8")
|
|
||||||
else:
|
else:
|
||||||
message.token = None
|
message.token = None
|
||||||
|
|
||||||
|
@ -152,10 +149,8 @@ class Serializer(object):
|
||||||
values = [tmp, message.code, message.mid]
|
values = [tmp, message.code, message.mid]
|
||||||
|
|
||||||
if message.token is not None and tkl > 0:
|
if message.token is not None and tkl > 0:
|
||||||
|
fmt += "%ss" % tkl
|
||||||
for b in str(message.token):
|
values.append(message.token)
|
||||||
fmt += "c"
|
|
||||||
values.append(bytes(b, "utf-8"))
|
|
||||||
|
|
||||||
options = Serializer.as_sorted_list(message.options) # already sorted
|
options = Serializer.as_sorted_list(message.options) # already sorted
|
||||||
lastoptionnumber = 0
|
lastoptionnumber = 0
|
||||||
|
|
Loading…
Reference in a new issue