Spaces:
Running
Running
orztv
commited on
Commit
·
03641be
1
Parent(s):
93a3579
update
Browse files
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():
|