From 6bb08c2297be1b6415c8bc02e6917eba6ee355e5 Mon Sep 17 00:00:00 2001
From: shimai <shimai@example.com>
Date: Fri, 03 Apr 2026 10:42:08 +0800
Subject: [PATCH] Merge remote-tracking branch 'origin/test/tony.cheng/260312' into test/shimai.huang/260309

---
 web-app/src/services/OutboundBotAPIService.js |   30 ++++++++++++++++++++++++++++--
 1 files changed, 28 insertions(+), 2 deletions(-)

diff --git a/web-app/src/services/OutboundBotAPIService.js b/web-app/src/services/OutboundBotAPIService.js
index dcc64ca..b181d6b 100644
--- a/web-app/src/services/OutboundBotAPIService.js
+++ b/web-app/src/services/OutboundBotAPIService.js
@@ -27,8 +27,8 @@
    * 获取通话录音接口
    * GET /api/v1/outbound-bot/conversation-log
    * @param {Object} params - 查询参数
-   * @param {string} params.caseRef - 案件引用ID
-   * @param {string} params.phoneNumber - 电话号码
+   * @param {string} params.caseId - 案件ID
+   * @param {string} params.personId - 当事人ID
    * @param {string} params.jobId - 工作ID
    * @returns {Promise} 通话记录
    */
@@ -68,6 +68,32 @@
   static backfillConversationByCase(data) {
     return request.post('/api/v1/outbound-bot/backfill-conversation-by-case', data);
   }
+
+  /**
+   * 获取通话录音文件
+   * GET /api/v1/outbound-bot/file-play
+   * @param {string} recordUrl - 录音文件相对路径
+   * @returns {Promise} 音频文件Blob
+   */
+  static async getAudioFile(recordUrl) {
+    try {
+      const response = await request.get('/api/v1/outbound-bot/file-play', {
+        recordUrl
+      }, {
+        responseType: 'blob',
+        headers: {
+          'Content-Type': 'audio/wav',
+          'Content-Disposition': 'inline'
+        }
+      });
+      
+      // axios返回的是response对象,blob在response.data中
+      return response.data;
+    } catch (error) {
+      console.error('获取录音文件失败:', error);
+      throw error;
+    }
+  }
 }
 
 export default OutboundBotAPIService;

--
Gitblit v1.8.0