large-models-interface
Version:
A comprehensive, unified interface for all types of AI models - natural language, vision, audio, and video. Supports 51 providers with dynamic model discovery and multi-modal capabilities.
84 lines (73 loc) • 2.55 kB
JavaScript
/**
* @file src/interfaces/moonshot.js
* @class Moonshot
* @description Wrapper class for the Moonshot AI (Kimi) API.
* @param {string} apiKey - The API key for the Moonshot AI API.
*/
const BaseInterface = require('./baseInterface.js');
const { moonshotApiKey } = require('../utils/loadApiKeysFromEnv.js');
const { getConfig, loadProviderConfig } = require('../utils/configManager.js');
const interfaceName = 'moonshot';
loadProviderConfig(interfaceName);
const config = getConfig();
class Moonshot extends BaseInterface {
constructor(apiKey) {
super(interfaceName, apiKey || moonshotApiKey, config[interfaceName].url);
}
/**
* Builds the request body for the Moonshot AI API request.
* @param {string} model - The model to use for the request.
* @param {Array<object>} messages - An array of message objects.
* @param {number} max_tokens - The maximum number of tokens for the response.
* @param {object} options - Additional options for the API request.
* @returns {object} The constructed request body.
*/
buildRequestBody(model, messages, max_tokens, options) {
return {
model: model,
messages: messages,
max_tokens: max_tokens,
temperature: options.temperature || 0.7,
top_p: options.top_p || 0.9,
stream: options.stream || false,
...options
};
}
/**
* Parse models response for Moonshot AI format
* @param {object} data - API response data
* @returns {Array} Array of model objects
*/
parseModelsResponse(data) {
// Handle Moonshot specific response format (OpenAI-compatible)
if (data.data && Array.isArray(data.data)) {
return data.data.map(model => ({
id: model.id,
name: model.id,
object: model.object || 'model',
created: model.created || Date.now(),
owned_by: 'moonshot'
}));
}
return [];
}
/**
* Detect model capabilities for Moonshot models
* @param {object} model - Model information
* @returns {object} Model capabilities
*/
detectModelCapabilities(model) {
const capabilities = super.detectModelCapabilities(model);
const name = (model.name || '').toLowerCase();
// Moonshot models (Kimi)
if (name.includes('moonshot') || name.includes('kimi')) {
capabilities.chat = true;
// Moonshot models support very long context
if (name.includes('128k') || name.includes('32k')) {
capabilities.longContext = true;
}
}
return capabilities;
}
}
module.exports = Moonshot;