2024-04-16 23:16:22 +08:00
|
|
|
# -*- coding: utf-8 -*-#
|
|
|
|
# -------------------------------------------------------------------------------
|
|
|
|
# Name: MediaMSG_parsing.py
|
|
|
|
# Description:
|
|
|
|
# Author: xaoyaoo
|
|
|
|
# Date: 2024/04/15
|
|
|
|
# -------------------------------------------------------------------------------
|
|
|
|
from .dbbase import DatabaseBase
|
|
|
|
from .utils import silk2audio
|
|
|
|
|
|
|
|
|
2024-08-03 00:21:16 +08:00
|
|
|
class MediaHandler(DatabaseBase):
|
2024-04-19 12:23:56 +08:00
|
|
|
_class_name = "MediaMSG"
|
2024-08-03 00:21:16 +08:00
|
|
|
Media_required_tables = ["Media"]
|
|
|
|
|
|
|
|
def Media_tables_exist(self):
|
|
|
|
"""
|
|
|
|
判断该类所需要的表是否存在
|
|
|
|
"""
|
|
|
|
return self.check_tables_exist(self.Media_required_tables)
|
2024-04-16 23:16:22 +08:00
|
|
|
|
|
|
|
def get_audio(self, MsgSvrID, is_play=False, is_wave=False, save_path=None, rate=24000):
|
2024-04-19 12:23:56 +08:00
|
|
|
sql = "select Buf from Media where Reserved0=? "
|
2024-08-03 00:21:16 +08:00
|
|
|
DBdata = self.execute(sql, (MsgSvrID,))
|
2024-04-19 21:49:07 +08:00
|
|
|
if not DBdata:
|
|
|
|
return False
|
2024-04-16 23:16:22 +08:00
|
|
|
if len(DBdata) == 0:
|
|
|
|
return False
|
|
|
|
data = DBdata[0][0] # [1:] + b'\xFF\xFF'
|
|
|
|
try:
|
|
|
|
pcm_data = silk2audio(buf_data=data, is_play=is_play, is_wave=is_wave, save_path=save_path, rate=rate)
|
|
|
|
return pcm_data
|
|
|
|
except Exception as e:
|
|
|
|
return False
|