mirror of
https://github.com/danny-avila/LibreChat.git
synced 2025-12-23 11:50:14 +01:00
* refactor: Agent CodeFiles, abortUpload WIP * feat: code environment file upload * refactor: useLazyEffect * refactor: - Add `watch` from `useFormContext` to check if code execution is enabled - Disable file upload button if `agent_id` is not selected or code execution is disabled * WIP: primeCodeFiles; refactor: rename sessionId to session_id for uniformity * Refactor: Rename session_id to sessionId for uniformity in AuthService.js * chore: bump @librechat/agents to version 1.7.1 * WIP: prime code files * refactor: Update code env file upload method to use read stream * feat: reupload code env file if no longer active * refactor: isAssistantTool -> isEntityTool + address type issues * feat: execute code tool hook * refactor: Rename isPluginAuthenticated to checkPluginAuth in PluginController.js * refactor: Update PluginController.js to use AuthType constant for comparison * feat: verify tool authentication (execute_code) * feat: enter librechat_code_api_key * refactor: Remove unused imports in BookmarkForm.tsx * feat: authenticate code tool * refactor: Update Action.tsx to conditionally render the key and revoke key buttons * refactor(Code/Action): prevent uncheck-able 'Run Code' capability when key is revoked * refactor(Code/Action): Update Action.tsx to conditionally render the key and revoke key buttons * fix: agent file upload edge cases * chore: bump @librechat/agents * fix: custom endpoint providerValue icon * feat: ollama meta modal token values + context * feat: ollama agents * refactor: Update token models for Ollama models * chore: Comment out CodeForm * refactor: Update token models for Ollama and Meta models
68 lines
2.3 KiB
JavaScript
68 lines
2.3 KiB
JavaScript
const { Run, Providers } = require('@librechat/agents');
|
|
const { providerEndpointMap } = require('librechat-data-provider');
|
|
|
|
/**
|
|
* @typedef {import('@librechat/agents').t} t
|
|
* @typedef {import('@librechat/agents').StreamEventData} StreamEventData
|
|
* @typedef {import('@librechat/agents').ClientOptions} ClientOptions
|
|
* @typedef {import('@librechat/agents').EventHandler} EventHandler
|
|
* @typedef {import('@librechat/agents').GraphEvents} GraphEvents
|
|
* @typedef {import('@librechat/agents').IState} IState
|
|
*/
|
|
|
|
/**
|
|
* Creates a new Run instance with custom handlers and configuration.
|
|
*
|
|
* @param {Object} options - The options for creating the Run instance.
|
|
* @param {ServerRequest} [options.req] - The server request.
|
|
* @param {string | undefined} [options.runId] - Optional run ID; otherwise, a new run ID will be generated.
|
|
* @param {Agent} options.agent - The agent for this run.
|
|
* @param {StructuredTool[] | undefined} [options.tools] - The tools to use in the run.
|
|
* @param {Record<string, StructuredTool[]> | undefined} [options.toolMap] - The tool map for the run.
|
|
* @param {Record<GraphEvents, EventHandler> | undefined} [options.customHandlers] - Custom event handlers.
|
|
* @param {ClientOptions} [options.modelOptions] - Optional model to use; if not provided, it will use the default from modelMap.
|
|
* @param {boolean} [options.streaming=true] - Whether to use streaming.
|
|
* @param {boolean} [options.streamUsage=true] - Whether to stream usage information.
|
|
* @returns {Promise<Run<IState>>} A promise that resolves to a new Run instance.
|
|
*/
|
|
async function createRun({
|
|
runId,
|
|
tools,
|
|
agent,
|
|
toolMap,
|
|
modelOptions,
|
|
customHandlers,
|
|
streaming = true,
|
|
streamUsage = true,
|
|
}) {
|
|
const provider = providerEndpointMap[agent.provider] ?? agent.provider;
|
|
const llmConfig = Object.assign(
|
|
{
|
|
provider,
|
|
streaming,
|
|
streamUsage,
|
|
},
|
|
modelOptions,
|
|
);
|
|
|
|
const graphConfig = {
|
|
tools,
|
|
toolMap,
|
|
llmConfig,
|
|
instructions: agent.instructions,
|
|
additional_instructions: agent.additional_instructions,
|
|
};
|
|
|
|
// TEMPORARY FOR TESTING
|
|
if (agent.provider === Providers.ANTHROPIC) {
|
|
graphConfig.streamBuffer = 2000;
|
|
}
|
|
|
|
return Run.create({
|
|
runId,
|
|
graphConfig,
|
|
customHandlers,
|
|
});
|
|
}
|
|
|
|
module.exports = { createRun };
|