const Transaction = require('./Transaction'); | |
/** | |
* Creates up to two transactions to record the spending of tokens. | |
* | |
* @function | |
* @async | |
* @param {Object} txData - Transaction data. | |
* @param {mongoose.Schema.Types.ObjectId} txData.user - The user ID. | |
* @param {String} txData.conversationId - The ID of the conversation. | |
* @param {String} txData.model - The model name. | |
* @param {String} txData.context - The context in which the transaction is made. | |
* @param {String} [txData.valueKey] - The value key (optional). | |
* @param {Object} tokenUsage - The number of tokens used. | |
* @param {Number} tokenUsage.promptTokens - The number of prompt tokens used. | |
* @param {Number} tokenUsage.completionTokens - The number of completion tokens used. | |
* @returns {Promise<void>} - Returns nothing. | |
* @throws {Error} - Throws an error if there's an issue creating the transactions. | |
*/ | |
const spendTokens = async (txData, tokenUsage) => { | |
const { promptTokens, completionTokens } = tokenUsage; | |
let prompt, completion; | |
try { | |
if (promptTokens >= 0) { | |
prompt = await Transaction.create({ | |
...txData, | |
tokenType: 'prompt', | |
rawAmount: -promptTokens, | |
}); | |
} | |
if (!completionTokens) { | |
this.debug && console.dir({ prompt, completion }, { depth: null }); | |
return; | |
} | |
completion = await Transaction.create({ | |
...txData, | |
tokenType: 'completion', | |
rawAmount: -completionTokens, | |
}); | |
this.debug && console.dir({ prompt, completion }, { depth: null }); | |
} catch (err) { | |
console.error(err); | |
} | |
}; | |
module.exports = spendTokens; | |