394 lines
14 KiB
SQL
394 lines
14 KiB
SQL
-- ============================================================
|
||
-- MiniMax M3 接入 + M2.7-highspeed + 补充全模型定价
|
||
-- 生成时间: 2026-06-12
|
||
-- 数据来源: token.opencomputing.cn 实时查询 (bugfix/execute_sql)
|
||
-- 参考: qwen3.7-max (llm:u1EtkR9xRcmwMvdoCZRC8, ppid:5i1JIpqERgCWqKQ4DCegD)
|
||
-- 接口: 使用uapi模块, upappid=minimax, baseurl=https://api.minimaxi.com/v1
|
||
-- ============================================================
|
||
|
||
-- ============================================================
|
||
-- 1. 新增 uapi: minimax t2t (纯文本对话, OpenAI兼容)
|
||
-- 复用ioid: Is8l4TGkcZcqFSjbbeIK2 (文本会话, 共享)
|
||
-- ============================================================
|
||
REPLACE INTO `uapi` (`id`, `name`, `need_auth`, `stream`, `path`, `httpmethod`, `chunk_match`, `headers`, `params`, `data`, `response`, `ioid`, `callbackurl`, `upappid`)
|
||
VALUES (
|
||
'mm_minimax_t2t',
|
||
't2t',
|
||
'0',
|
||
'stream',
|
||
'/chat/completions',
|
||
'POST',
|
||
'data: ',
|
||
'{
|
||
"Authorization": "Bearer {{apikey}}",
|
||
"Content-Type": "application/json"
|
||
}',
|
||
NULL,
|
||
'{
|
||
{% if stream %}
|
||
"stream_options":{
|
||
"include_usage": true
|
||
},
|
||
{% endif %}
|
||
{% if tools %}
|
||
"tools": {{json.dumps(tools, ensure_ascii=False)}},
|
||
{% endif %}
|
||
{% if tool_choice %}
|
||
"tool_choice": "{{tool_choice}}",
|
||
{% endif %}
|
||
{% if messages %}
|
||
"messages": {{json.dumps(messages, ensure_ascii=False)}},
|
||
{% else %}
|
||
"messages": [
|
||
{% if sys_prompt %}
|
||
{
|
||
"role": "system",
|
||
"content": {{json.dumps(sys_prompt, ensure_ascii=False)}}
|
||
},
|
||
{% endif %}
|
||
{
|
||
"role": "user",
|
||
"content": {{json.dumps(prompt, ensure_ascii=False)}}
|
||
}
|
||
],
|
||
{% endif %}
|
||
{% if stream %}
|
||
"stream":true,
|
||
{% endif %}
|
||
"model": "{{model}}"
|
||
}
|
||
',
|
||
'{
|
||
"id": "{{id}}",
|
||
"object": "{{object}}",
|
||
"created": {{created}},
|
||
"choices": {{json.dumps(choices, ensure_ascii=False)}},
|
||
"model": "{{model}}",
|
||
{% if object == "chat.completion" %}
|
||
"reasoning_content": {{json.dumps(choices[0].message.reasoning_content, ensure_ascii=False)}},
|
||
"content":{{json.dumps(choices[0].message.content, ensure_ascii=False)}},
|
||
{% elif len(choices)>0 %}
|
||
"reasoning_content": {{json.dumps(choices[0].delta.reasoning_content, ensure_ascii=False)}},
|
||
"content":{{json.dumps(choices[0].delta.content, ensure_ascii=False)}},
|
||
{% endif %}
|
||
{% if usage %}
|
||
{% set usage1 = usage.update({"model": model}) %}
|
||
"finish": "1",
|
||
"usage":{{json.dumps(usage)}}
|
||
{% else %}
|
||
"finish":"0"
|
||
{% endif %}
|
||
}',
|
||
'Is8l4TGkcZcqFSjbbeIK2',
|
||
NULL,
|
||
'minimax'
|
||
);
|
||
|
||
-- ============================================================
|
||
-- 2. 新增 uapi: minimax tm2t (多模态对话, 支持图片/视频/音频)
|
||
-- 复用ioid: t-ujII59ku45tIPcdXu4O (文本媒体转文本, 共享)
|
||
-- ============================================================
|
||
INSERT IGNORE INTO `uapi` (`id`, `name`, `need_auth`, `stream`, `path`, `httpmethod`, `chunk_match`, `headers`, `params`, `data`, `response`, `ioid`, `callbackurl`, `upappid`)
|
||
VALUES (
|
||
'mm_minimax_tm2t',
|
||
'tm2t',
|
||
'0',
|
||
'stream',
|
||
'/chat/completions',
|
||
'POST',
|
||
'data: ',
|
||
'{
|
||
"Authorization": "Bearer {{apikey}}",
|
||
"Content-Type": "application/json"
|
||
}',
|
||
NULL,
|
||
'{
|
||
"model": "{{model}}",
|
||
"stream_options":{
|
||
"include_usage": true
|
||
},
|
||
"messages": [
|
||
{% if sys_prompt %}
|
||
{
|
||
"role": "system",
|
||
"content": {{json.dumps(sys_prompt, ensure_ascii=False)}}
|
||
},
|
||
{% endif %}
|
||
{
|
||
"role": "user",
|
||
"content": [
|
||
{% if image_file %}
|
||
{
|
||
"type": "image_url",
|
||
"image_url":"{{b64media2url(request, image_file)}}"
|
||
},
|
||
{% endif %}
|
||
{% if video_file %}
|
||
{
|
||
"type": "video_url",
|
||
"video_url":"{{b64media2url(request, video_file)}}"
|
||
},
|
||
{% endif %}
|
||
{% if audio_file %}
|
||
{
|
||
"type": "audio_url",
|
||
"audio_url":"{{b64media2url(request, audio_file)}}"
|
||
},
|
||
{% endif %}
|
||
{
|
||
"type": "text",
|
||
"text": {{json.dumps(prompt, ensure_ascii=False)}}
|
||
}
|
||
]
|
||
}
|
||
],
|
||
"stream":true
|
||
}',
|
||
'{
|
||
"model": "{{model}}",
|
||
{% if object == "chat.completion" %}
|
||
"reasoning_content": {{json.dumps(choices[0].message.reasoning_content, ensure_ascii=False)}},
|
||
"content":{{json.dumps(choices[0].message.content, ensure_ascii=False)}},
|
||
{% elif len(choices)>0 %}
|
||
"reasoning_content": {{json.dumps(choices[0].delta.reasoning_content, ensure_ascii=False)}},
|
||
"content":{{json.dumps(choices[0].delta.content, ensure_ascii=False)}},
|
||
{% endif %}
|
||
{% if usage %}
|
||
"finish": "1",
|
||
"usage": {{json.dumps(usage)}}
|
||
{% else %}
|
||
"finish":"0"
|
||
{% endif %}
|
||
}',
|
||
't-ujII59ku45tIPcdXu4O',
|
||
NULL,
|
||
'minimax'
|
||
);
|
||
|
||
-- ============================================================
|
||
-- 3. 新增 llm: MiniMax-M3
|
||
-- ============================================================
|
||
INSERT IGNORE INTO `llm` (`id`, `name`, `model`, `description`, `iconid`, `upappid`, `providerid`, `ownerid`, `enabled_date`, `expired_date`, `min_balance`, `status`)
|
||
VALUES (
|
||
'mm3_MiniMax_M3',
|
||
'MiniMax M3',
|
||
'MiniMax-M3',
|
||
'MiniMax M3: 编程及Agent SOTA, 1M超长上下文, 多模态, 交错思维链。≤512K永久五折。',
|
||
'minimax',
|
||
'minimax',
|
||
'ww4e_kfX3Lh65Sdys0Vku',
|
||
'0',
|
||
'2026-06-12',
|
||
'9999-12-31',
|
||
10.00,
|
||
'published'
|
||
);
|
||
|
||
-- ============================================================
|
||
-- 4. 新增 llm: MiniMax-M2.7-highspeed
|
||
-- ============================================================
|
||
INSERT IGNORE INTO `llm` (`id`, `name`, `model`, `description`, `iconid`, `upappid`, `providerid`, `ownerid`, `enabled_date`, `expired_date`, `min_balance`, `status`)
|
||
VALUES (
|
||
'mm_m27_highspeed',
|
||
'MiniMax M2.7 Highspeed',
|
||
'MiniMax-M2.7-highspeed',
|
||
'MiniMax M2.7高速版, 更快速度, 适合低延迟场景。输入¥4.2/百万tokens, 输出¥16.8/百万tokens。',
|
||
'minimax',
|
||
'minimax',
|
||
'ww4e_kfX3Lh65Sdys0Vku',
|
||
'0',
|
||
'2026-06-12',
|
||
'9999-12-31',
|
||
10.00,
|
||
'published'
|
||
);
|
||
|
||
-- ============================================================
|
||
-- 5. 新增 llm_api_map: MiniMax-M3 (t2t)
|
||
-- apiname='t2t' → 匹配 uapi name='t2t' + upappid='minimax'
|
||
-- ============================================================
|
||
INSERT IGNORE INTO `llm_api_map` (`id`, `llmid`, `llmcatelogid`, `apiname`, `query_apiname`, `query_period`, `ppid`, `isdefaultcatelog`)
|
||
VALUES (
|
||
'mm3_map_t2t',
|
||
'mm3_MiniMax_M3',
|
||
't2t',
|
||
't2t',
|
||
NULL,
|
||
NULL,
|
||
'5jmzupARABxkDFwUraFiQ',
|
||
'1'
|
||
);
|
||
|
||
-- ============================================================
|
||
-- 6. 新增 llm_api_map: MiniMax-M3 (tm2t, 多模态)
|
||
-- ============================================================
|
||
INSERT IGNORE INTO `llm_api_map` (`id`, `llmid`, `llmcatelogid`, `apiname`, `query_apiname`, `query_period`, `ppid`, `isdefaultcatelog`)
|
||
VALUES (
|
||
'mm3_map_tm2t',
|
||
'mm3_MiniMax_M3',
|
||
'tm2t',
|
||
'tm2t',
|
||
NULL,
|
||
NULL,
|
||
'5jmzupARABxkDFwUraFiQ',
|
||
'0'
|
||
);
|
||
|
||
-- ============================================================
|
||
-- 7. 新增 llm_api_map: MiniMax-M2.7-highspeed (t2t)
|
||
-- ============================================================
|
||
INSERT IGNORE INTO `llm_api_map` (`id`, `llmid`, `llmcatelogid`, `apiname`, `query_apiname`, `query_period`, `ppid`, `isdefaultcatelog`)
|
||
VALUES (
|
||
'mm_m27hs_map_t2t',
|
||
'mm_m27_highspeed',
|
||
't2t',
|
||
't2t',
|
||
NULL,
|
||
NULL,
|
||
'5jmzupARABxkDFwUraFiQ',
|
||
'1'
|
||
);
|
||
|
||
-- ============================================================
|
||
-- 8. 补充现有模型 llm_api_map.ppid
|
||
-- ============================================================
|
||
|
||
-- 8a. MiniMax-Hailuo-2.3 (视频i2v) → 0V89
|
||
UPDATE `llm_api_map` SET `ppid` = '0V89eilc_UQ2KiZIRJO8M'
|
||
WHERE `llmid` = 'AU1f40HV3tqFjxcVWWpyR' AND (`ppid` IS NULL OR `ppid` = '');
|
||
|
||
-- 8b. Minimax海螺参考生视频 S2V-01 (视频i2v) → 0V89
|
||
UPDATE `llm_api_map` SET `ppid` = '0V89eilc_UQ2KiZIRJO8M'
|
||
WHERE `llmid` = 'oks-VG9D8p2b0Agvs-LeQ' AND (`ppid` IS NULL OR `ppid` = '');
|
||
|
||
-- 8c. music-2.0 (音乐) → fQzk
|
||
UPDATE `llm_api_map` SET `ppid` = 'fQzkUeS6t6NBz_Fu4Fi77'
|
||
WHERE `llmid` = 'ns7egG9aXi91wjI62yKfu' AND (`ppid` IS NULL OR `ppid` = '');
|
||
|
||
-- 8d. speech-2.6-hd (TTS) → mm_tts_pricing
|
||
UPDATE `llm_api_map` SET `ppid` = 'mm_tts_pricing'
|
||
WHERE `llmid` = 'q6rdMUsGD1z3S3NyZh_A_' AND (`ppid` IS NULL OR `ppid` = '');
|
||
|
||
-- 8e. speech-2.6-turbo (TTS) → mm_tts_pricing
|
||
UPDATE `llm_api_map` SET `ppid` = 'mm_tts_pricing'
|
||
WHERE `llmid` = 'CEYD4YWRxjCj4k_6bpzIM' AND (`ppid` IS NULL OR `ppid` = '');
|
||
|
||
-- 8f. speech-2.5-hd-preview (TTS) → mm_tts_pricing
|
||
UPDATE `llm_api_map` SET `ppid` = 'mm_tts_pricing'
|
||
WHERE `llmid` = 'Si2g0XJ9ym3P5jlrdmcfB' AND (`ppid` IS NULL OR `ppid` = '');
|
||
|
||
-- ============================================================
|
||
-- 9. 新增 pricing_program: MiniMax TTS定价 (元/万字符)
|
||
-- ============================================================
|
||
INSERT IGNORE INTO `pricing_program` (`id`, `name`, `ownerid`, `providerid`, `pricing_belong`, `discount`, `description`, `pricing_spec`)
|
||
VALUES (
|
||
'mm_tts_pricing',
|
||
'MiniMax语音合成定价',
|
||
'0',
|
||
'ww4e_kfX3Lh65Sdys0Vku',
|
||
'provider',
|
||
1.000,
|
||
'MiniMax speech系列TTS定价,按万字符计费',
|
||
'fields:\n model:\n type: str\n label: 模型\n formula:\n type: str\n label: 公式\n'
|
||
);
|
||
|
||
-- ============================================================
|
||
-- 10. 新增 pricing_program_timing: MiniMax TTS
|
||
-- ============================================================
|
||
INSERT IGNORE INTO `pricing_program_timing` (`id`, `ppid`, `name`, `enabled_date`, `expired_date`, `pricing_data`)
|
||
VALUES (
|
||
'mm_tts_timing',
|
||
'mm_tts_pricing',
|
||
'MiniMax TTS全价',
|
||
'2026-06-12',
|
||
'9999-12-31',
|
||
'unit_values:\n 万字符: 10000\nfields:\n price_factors:\n type: string\n role: factor\n label: 计价因子\n unit_prices:\n type: float\n role: factor\n label: 单位定价\n unit:\n type: string\n role: factor\n label: 计价单位\n model:\n type: string\n role: filter\n label: model\npricings:\n- price_factors: flat\n unit_prices: 3.5\n unit: 万字符\n filters:\n - model: speech-2.6-hd\n- price_factors: flat\n unit_prices: 2.0\n unit: 万字符\n filters:\n - model: speech-2.6-turbo\n- price_factors: flat\n unit_prices: 3.5\n unit: 万字符\n filters:\n - model: speech-2.5-hd-preview\n'
|
||
);
|
||
|
||
-- ============================================================
|
||
-- 11a. 更新 5jmzup fields: 添加 prompt_tokens 字段定义
|
||
-- 用于分段定价的 range filter,需要 value_mode: between
|
||
-- ============================================================
|
||
UPDATE `pricing_program_timing`
|
||
SET `pricing_data` = REPLACE(`pricing_data`,
|
||
' model:\n type: string\n role: filter\n label: model',
|
||
' model:\n type: string\n role: filter\n label: model\n prompt_tokens:\n type: int\n role: filter\n label: prompt_tokens\n value_mode: between')
|
||
WHERE `ppid` = '5jmzupARABxkDFwUraFiQ' AND `enabled_date` = '2026-04-12';
|
||
|
||
-- ============================================================
|
||
-- 11b. 更新 5jmzup timing: 添加 MiniMax-M3 分段定价
|
||
-- M3 ≤512K永久五折: 输入2.1/输出8.4/缓存0.42 元/百万tokens
|
||
-- M3 512K~1M: 输入4.2/输出16.8/缓存0.84
|
||
-- 使用 prompt_tokens range filter 区分两个计价段
|
||
-- ============================================================
|
||
UPDATE `pricing_program_timing`
|
||
SET `pricing_data` = CONCAT(`pricing_data`, '
|
||
- price_factors: prompt_tokens
|
||
unit_prices: 2.1
|
||
unit: 百万
|
||
filters:
|
||
- model: MiniMax-M3
|
||
prompt_tokens: 0 =~ 524288
|
||
value_mode: between
|
||
- price_factors: completion_tokens
|
||
unit_prices: 8.4
|
||
unit: 百万
|
||
filters:
|
||
- model: MiniMax-M3
|
||
prompt_tokens: 0 =~ 524288
|
||
value_mode: between
|
||
- price_factors: cached_tokens
|
||
unit_prices: 0.42
|
||
unit: 百万
|
||
filters:
|
||
- model: MiniMax-M3
|
||
prompt_tokens: 0 =~ 524288
|
||
value_mode: between
|
||
- price_factors: prompt_tokens
|
||
unit_prices: 4.2
|
||
unit: 百万
|
||
filters:
|
||
- model: MiniMax-M3
|
||
prompt_tokens: 524288 =~ 1048576
|
||
value_mode: between
|
||
- price_factors: completion_tokens
|
||
unit_prices: 16.8
|
||
unit: 百万
|
||
filters:
|
||
- model: MiniMax-M3
|
||
prompt_tokens: 524288 =~ 1048576
|
||
value_mode: between
|
||
- price_factors: cached_tokens
|
||
unit_prices: 0.84
|
||
unit: 百万
|
||
filters:
|
||
- model: MiniMax-M3
|
||
prompt_tokens: 524288 =~ 1048576
|
||
value_mode: between
|
||
')
|
||
WHERE `ppid` = '5jmzupARABxkDFwUraFiQ' AND `enabled_date` = '2026-04-12';
|
||
|
||
-- ============================================================
|
||
-- 12. 更新 pricing_program 5jmzup: 添加M3到模型选项
|
||
-- ============================================================
|
||
UPDATE `pricing_program`
|
||
SET `pricing_spec` = 'fields:\n model:\n type: str\n label: 模型\n options:\n - MiniMax-M3\n - MiniMax-M2.7\n - MiniMax-M2.7-highspeed\n - MiniMax-M2.5\n - MiniMax-M2.5-highspeed\n - M2-her\n formula:\n type: str\n label: 公式\n'
|
||
WHERE `id` = '5jmzupARABxkDFwUraFiQ';
|
||
|
||
|
||
-- ============================================================
|
||
-- ROLLBACK 语句 (如需回滚)
|
||
-- ============================================================
|
||
-- DELETE FROM `uapi` WHERE `id` IN ('mm_minimax_t2t', 'mm_minimax_tm2t');
|
||
-- DELETE FROM `llm` WHERE `id` IN ('mm3_MiniMax_M3', 'mm_m27_highspeed');
|
||
-- DELETE FROM `llm_api_map` WHERE `id` IN ('mm3_map_t2t', 'mm3_map_tm2t', 'mm_m27hs_map_t2t');
|
||
-- UPDATE `llm_api_map` SET `ppid` = NULL WHERE `llmid` = 'AU1f40HV3tqFjxcVWWpyR';
|
||
-- UPDATE `llm_api_map` SET `ppid` = NULL WHERE `llmid` = 'oks-VG9D8p2b0Agvs-LeQ';
|
||
-- UPDATE `llm_api_map` SET `ppid` = NULL WHERE `llmid` = 'ns7egG9aXi91wjI62yKfu';
|
||
-- UPDATE `llm_api_map` SET `ppid` = NULL WHERE `llmid` = 'q6rdMUsGD1z3S3NyZh_A_';
|
||
-- UPDATE `llm_api_map` SET `ppid` = NULL WHERE `llmid` = 'CEYD4YWRxjCj4k_6bpzIM';
|
||
-- UPDATE `llm_api_map` SET `ppid` = NULL WHERE `llmid` = 'Si2g0XJ9ym3P5jlrdmcfB';
|
||
-- DELETE FROM `pricing_program` WHERE `id` = 'mm_tts_pricing';
|
||
-- DELETE FROM `pricing_program_timing` WHERE `id` = 'mm_tts_timing';
|
||
-- -- 5jmzup的pricing_data CONCAT追加需手动编辑YAML移除M3条目
|