|
123456789101112131415161718192021222324252627282930313233343536373839404142434445 |
- # -*- coding: utf-8 -*-#
- # filename: receive.py
- import xml.etree.ElementTree as ET
- from bridge.context import ContextType
- from channel.chat_message import ChatMessage
- from common.log import logger
-
-
- def parse_xml(web_data):
- if len(web_data) == 0:
- return None
- xmlData = ET.fromstring(web_data)
- return WeChatMPMessage(xmlData)
-
- class WeChatMPMessage(ChatMessage):
- def __init__(self, xmlData):
- super().__init__(xmlData)
- self.to_user_id = xmlData.find('ToUserName').text
- self.from_user_id = xmlData.find('FromUserName').text
- self.create_time = xmlData.find('CreateTime').text
- self.msg_type = xmlData.find('MsgType').text
- try:
- self.msg_id = xmlData.find('MsgId').text
- except:
- self.msg_id = self.from_user_id+self.create_time
- self.is_group = False
-
- # reply to other_user_id
- self.other_user_id = self.from_user_id
-
- if self.msg_type == 'text':
- self.ctype = ContextType.TEXT
- self.content = xmlData.find('Content').text.encode("utf-8")
- elif self.msg_type == 'voice':
- self.ctype = ContextType.TEXT
- self.content = xmlData.find('Recognition').text.encode("utf-8") # 接收语音识别结果
- elif self.msg_type == 'image':
- # not implemented
- self.pic_url = xmlData.find('PicUrl').text
- self.media_id = xmlData.find('MediaId').text
- elif self.msg_type == 'event':
- self.content = xmlData.find('Event').text
- else: # video, shortvideo, location, link
- # not implemented
- pass
|