2024-04-16 23:16:22 +08:00
|
|
|
# -*- coding: utf-8 -*-#
|
|
|
|
# -------------------------------------------------------------------------------
|
2024-08-13 17:31:06 +08:00
|
|
|
# Name: MediaMSG.py
|
|
|
|
# Description: 负责处理语音数据库
|
2024-04-16 23:16:22 +08:00
|
|
|
# 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"]
|
|
|
|
|
2024-08-13 17:37:07 +08:00
|
|
|
def Media_add_index(self):
|
|
|
|
"""
|
|
|
|
添加索引, 加快查询速度
|
|
|
|
"""
|
|
|
|
if self.tables_exist("Media"):
|
|
|
|
self.execute("CREATE INDEX IF NOT EXISTS MsgSvrID ON Media(Reserved0)")
|
|
|
|
|
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-08-13 12:53:53 +08:00
|
|
|
if not self.tables_exist("Media"):
|
|
|
|
return False
|
|
|
|
|
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
|