orztv commited on
Commit
03641be
·
1 Parent(s): 93a3579
Files changed (1) hide show
  1. src/openai-edge-tts/app/server.py +46 -1
src/openai-edge-tts/app/server.py CHANGED
@@ -1,6 +1,6 @@
1
  # server.py
2
 
3
- from flask import Flask, request, send_file, jsonify
4
  from gevent.pywsgi import WSGIServer
5
  from dotenv import load_dotenv
6
  import os
@@ -20,6 +20,51 @@ DEFAULT_SPEED = float(os.getenv('DEFAULT_SPEED', 1.0))
20
 
21
  # DEFAULT_MODEL = os.getenv('DEFAULT_MODEL', 'tts-1')
22
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
23
  @app.route('/v1/audio/speech', methods=['POST'])
24
  @require_api_key
25
  def text_to_speech():
 
1
  # server.py
2
 
3
+ from flask import Flask, request, send_file, jsonify, render_template_string
4
  from gevent.pywsgi import WSGIServer
5
  from dotenv import load_dotenv
6
  import os
 
20
 
21
  # DEFAULT_MODEL = os.getenv('DEFAULT_MODEL', 'tts-1')
22
 
23
+ # 添加一个简单的 HTML 模板
24
+ HOME_TEMPLATE = """
25
+ <!DOCTYPE html>
26
+ <html lang="zh-CN">
27
+ <head>
28
+ <meta charset="UTF-8">
29
+ <meta name="viewport" content="width=device-width, initial-scale=1.0">
30
+ <title>OpenAI Edge TTS API</title>
31
+ <style>
32
+ body { font-family: Arial, sans-serif; line-height: 1.6; padding: 20px; max-width: 800px; margin: 0 auto; }
33
+ h1 { color: #333; }
34
+ pre { background-color: #f4f4f4; padding: 10px; border-radius: 5px; }
35
+ </style>
36
+ </head>
37
+ <body>
38
+ <h1>欢迎使用 OpenAI Edge TTS API</h1>
39
+ <p>这是一个基于 Edge TTS 的 OpenAI TTS API 替代品。</p>
40
+ <h2>API 端点:</h2>
41
+ <ul>
42
+ <li>TTS 生成:<code>/v1/audio/speech</code> (POST)</li>
43
+ <li>列出模型:<code>/v1/models</code> (GET/POST)</li>
44
+ <li>列出语音:<code>/v1/voices</code> (GET/POST)</li>
45
+ <li>列出所有语音:<code>/v1/voices/all</code> (GET/POST)</li>
46
+ </ul>
47
+ <h2>使用示例:</h2>
48
+ <pre>
49
+ curl http://localhost:{{ port }}/v1/audio/speech \
50
+ -H "Authorization: Bearer $API_KEY" \
51
+ -H "Content-Type: application/json" \
52
+ -d '{
53
+ "model": "tts-1",
54
+ "input": "Hello world!",
55
+ "voice": "alloy"
56
+ }' \
57
+ --output speech.mp3
58
+ </pre>
59
+ <p>更多信息请参考 API 文档。</p>
60
+ </body>
61
+ </html>
62
+ """
63
+
64
+ @app.route('/')
65
+ def home():
66
+ return render_template_string(HOME_TEMPLATE, port=PORT)
67
+
68
  @app.route('/v1/audio/speech', methods=['POST'])
69
  @require_api_key
70
  def text_to_speech():