Spaces:
Paused
Paused
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():
|