51 lines
1.5 KiB
Plaintext

# -*- coding:utf-8 -*-
# POST /api/submit - 提交Demucs人声分离任务
import json
import uuid
from ahserver.serverenv import ServerEnv
method = request.method
if method == 'POST':
audio_path = params_kw.get('audio_path', '')
if not audio_path:
return json.dumps({'error': 'audio_path is required'}, ensure_ascii=False)
task_id = params_kw.get('task_id', str(uuid.uuid4()).replace("-", "")[:12])
model = params_kw.get('model', 'htdemucs')
payload = {
'task_type': 'separate',
'task_id': task_id,
'audio_path': audio_path,
'model': model
}
env = ServerEnv()
longtasks = env.longtasks
if longtasks is None:
return json.dumps({'error': 'service not ready'}, ensure_ascii=False)
result = await longtasks.submit_task(payload)
real_task_id = result.get('task_id', str(result)) if isinstance(result, dict) else str(result)
return json.dumps({
'task_id': real_task_id,
'status': 'queued',
'audio_path': audio_path,
'model': model,
'message': 'task submitted',
'check_url': f'/api/task?task_id={real_task_id}'
}, ensure_ascii=False)
else:
return json.dumps({
'usage': 'POST with JSON body',
'params': {
'audio_path': 'string (required, server path to audio file)',
'model': 'string (default htdemucs, options: htdemucs/htdemucs_ft/mdx_extra_q)',
'task_id': 'string (optional, auto-generated)',
}
}, ensure_ascii=False)