|
- # -*- 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
- elif self.msg_type == "voice":
- self.ctype = ContextType.TEXT
- self.content = xmlData.find("Recognition").text # 接收语音识别结果
- # other voice_to_text method not implemented yet
- if self.content == None:
- self.content = "你好"
- elif self.msg_type == "image":
- # not implemented yet
- 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
|