1
This commit is contained in:
142
api/model/ai_call_records.js
Normal file
142
api/model/ai_call_records.js
Normal file
@@ -0,0 +1,142 @@
|
||||
const Sequelize = require('sequelize');
|
||||
|
||||
/**
|
||||
* AI调用记录表模型
|
||||
* 记录所有AI API调用的详细信息和Token使用情况
|
||||
*/
|
||||
module.exports = (db) => {
|
||||
const ai_call_records = db.define("ai_call_records", {
|
||||
user_id: {
|
||||
comment: '用户ID(如果是用户触发的调用)',
|
||||
type: Sequelize.INTEGER,
|
||||
allowNull: true,
|
||||
defaultValue: null
|
||||
},
|
||||
sn_code: {
|
||||
comment: '设备序列号',
|
||||
type: Sequelize.STRING(50),
|
||||
allowNull: true,
|
||||
defaultValue: null
|
||||
},
|
||||
service_type: {
|
||||
comment: '服务类型(如:chat, completion, embedding等)',
|
||||
type: Sequelize.STRING(50),
|
||||
allowNull: false,
|
||||
defaultValue: ''
|
||||
},
|
||||
model_name: {
|
||||
comment: 'AI模型名称(如:gpt-4, gpt-3.5-turbo等)',
|
||||
type: Sequelize.STRING(100),
|
||||
allowNull: false,
|
||||
defaultValue: ''
|
||||
},
|
||||
prompt_tokens: {
|
||||
comment: '输入Token数量',
|
||||
type: Sequelize.INTEGER,
|
||||
allowNull: false,
|
||||
defaultValue: 0
|
||||
},
|
||||
completion_tokens: {
|
||||
comment: '输出Token数量',
|
||||
type: Sequelize.INTEGER,
|
||||
allowNull: false,
|
||||
defaultValue: 0
|
||||
},
|
||||
total_tokens: {
|
||||
comment: '总Token数量',
|
||||
type: Sequelize.INTEGER,
|
||||
allowNull: false,
|
||||
defaultValue: 0
|
||||
},
|
||||
request_content: {
|
||||
comment: '请求内容(用户输入的prompt)',
|
||||
type: Sequelize.TEXT,
|
||||
allowNull: true,
|
||||
defaultValue: null
|
||||
},
|
||||
response_content: {
|
||||
comment: '响应内容(AI返回的结果)',
|
||||
type: Sequelize.TEXT,
|
||||
allowNull: true,
|
||||
defaultValue: null
|
||||
},
|
||||
cost_amount: {
|
||||
comment: '本次调用费用(元)',
|
||||
type: Sequelize.DECIMAL(10, 4),
|
||||
allowNull: true,
|
||||
defaultValue: null
|
||||
},
|
||||
status: {
|
||||
comment: '调用状态(success=成功, failed=失败, timeout=超时)',
|
||||
type: Sequelize.STRING(20),
|
||||
allowNull: false,
|
||||
defaultValue: 'success'
|
||||
},
|
||||
error_message: {
|
||||
comment: '错误信息(如果调用失败)',
|
||||
type: Sequelize.TEXT,
|
||||
allowNull: true,
|
||||
defaultValue: null
|
||||
},
|
||||
response_time: {
|
||||
comment: '响应时间(毫秒)',
|
||||
type: Sequelize.INTEGER,
|
||||
allowNull: true,
|
||||
defaultValue: null
|
||||
},
|
||||
api_provider: {
|
||||
comment: 'API提供商(openai, azure, anthropic等)',
|
||||
type: Sequelize.STRING(50),
|
||||
allowNull: false,
|
||||
defaultValue: 'openai'
|
||||
},
|
||||
business_type: {
|
||||
comment: '业务类型(job_filter, chat, resume_optimization等)',
|
||||
type: Sequelize.STRING(50),
|
||||
allowNull: true,
|
||||
defaultValue: null
|
||||
},
|
||||
reference_id: {
|
||||
comment: '关联业务ID(如job_posting_id, chat_record_id等)',
|
||||
type: Sequelize.INTEGER,
|
||||
allowNull: true,
|
||||
defaultValue: null
|
||||
},
|
||||
}, {
|
||||
timestamps: false,
|
||||
indexes: [
|
||||
{
|
||||
unique: false,
|
||||
fields: ['user_id']
|
||||
},
|
||||
{
|
||||
unique: false,
|
||||
fields: ['sn_code']
|
||||
},
|
||||
{
|
||||
unique: false,
|
||||
fields: ['service_type']
|
||||
},
|
||||
{
|
||||
unique: false,
|
||||
fields: ['status']
|
||||
},
|
||||
{
|
||||
unique: false,
|
||||
fields: ['create_time']
|
||||
},
|
||||
{
|
||||
unique: false,
|
||||
fields: ['business_type']
|
||||
},
|
||||
{
|
||||
unique: false,
|
||||
fields: ['reference_id']
|
||||
}
|
||||
]
|
||||
});
|
||||
|
||||
// ai_call_records.sync({ force: true });
|
||||
|
||||
return ai_call_records;
|
||||
}
|
||||
Reference in New Issue
Block a user