import logging
from pybitmessage.messagetypes import MsgBase
logger = logging.getLogger('default')
class Message(MsgBase):
"""Encapsulate a message"""
# pylint: disable=attribute-defined-outside-init
def decode(self, data):
"""Decode a message"""
# UTF-8 and variable type validator
subject = data.get("subject", "")
body = data.get("body", "")
try:
data["subject"] = subject.decode('utf-8', 'replace')
except:
data["subject"] = ''
data["body"] = body.decode('utf-8', 'replace')
data["body"] = ''
self.subject = data["subject"]
self.body = data["body"]
def encode(self, data):
"""Encode a message"""
super(Message, self).__init__()
self.data["subject"] = data.get("subject", "")
self.data["body"] = data.get("body", "")
return self.data
def process(self):
"""Process a message"""
logger.debug("Subject: %i bytes", len(self.subject))
logger.debug("Body: %i bytes", len(self.body))