/** * Dify Chat 服务端 API 模块 * * 提供 Node.js 服务端调用 FastAPI 后端的基础功能 * Dify 的 API_KEY 和 APP_ID 由 FastAPI 后端管理,前端只负责转发请求 * * 调用链路: * Remix Server → FastAPI /dify_chat/* → Dify * * @module api/dify-chat/client.server */ import { API_BASE_URL } from '~/config/api-config'; // ============================================================================ // 配置 // ============================================================================ /** * Dify Chat API 代理地址 * 通过 FastAPI 后端的 /dify_chat 路由代理访问 Dify * Dify 的认证(API_KEY)由 FastAPI 后端处理 */ const DIFY_CHAT_API_URL = `${API_BASE_URL}/dify_chat`; // ============================================================================ // 基础请求函数 // ============================================================================ /** * Dify Chat API 基础请求函数 * * 使用用户 JWT 认证通过 FastAPI 代理访问 Dify * FastAPI 后端会验证 JWT 并添加 Dify API_KEY * * @param endpoint - API 端点路径 * @param options - fetch 请求选项 * @param jwt - 用户 JWT 认证令牌 * @returns Response 对象 */ export async function difyFetch( endpoint: string, options: RequestInit = {}, jwt?: string ): Promise { const url = `${DIFY_CHAT_API_URL}/${endpoint.replace(/^\//, '')}`; const headers: HeadersInit = { 'Content-Type': 'application/json', ...options.headers, }; if (jwt) { (headers as Record)['Authorization'] = `Bearer ${jwt}`; } else { console.warn('[Dify Chat] 没有提供 JWT,FastAPI 请求可能失败'); } const response = await fetch(url, { ...options, headers, }); if (!response.ok) { const errorText = await response.text(); console.error('[Dify Chat] API 转发错误:', { status: response.status, statusText: response.statusText, error: errorText }); if (response.status === 401) { throw new Error('JWT认证失败,请重新登录'); } throw new Error(`Dify API Error: ${response.status} ${response.statusText}`); } return response; } // 重新导出 chat 模块的 difyClient export { difyClient } from './chat';