-
-
Notifications
You must be signed in to change notification settings - Fork 2.8k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
* litellm agent support * lint * add LiteLLM provider config --------- Co-authored-by: Timothy Carambat <[email protected]>
- Loading branch information
1 parent
bce7988
commit cb4b0a8
Showing
6 changed files
with
143 additions
and
11 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,110 @@ | ||
const OpenAI = require("openai"); | ||
const Provider = require("./ai-provider.js"); | ||
const InheritMultiple = require("./helpers/classes.js"); | ||
const UnTooled = require("./helpers/untooled.js"); | ||
|
||
/** | ||
* The agent provider for LiteLLM. | ||
*/ | ||
class LiteLLMProvider extends InheritMultiple([Provider, UnTooled]) { | ||
model; | ||
|
||
constructor(config = {}) { | ||
super(); | ||
const { model = null } = config; | ||
const client = new OpenAI({ | ||
baseURL: process.env.LITE_LLM_BASE_PATH, | ||
apiKey: process.env.LITE_LLM_API_KEY ?? null, | ||
maxRetries: 3, | ||
}); | ||
|
||
this._client = client; | ||
this.model = model || process.env.LITE_LLM_MODEL_PREF; | ||
this.verbose = true; | ||
} | ||
|
||
get client() { | ||
return this._client; | ||
} | ||
|
||
async #handleFunctionCallChat({ messages = [] }) { | ||
return await this.client.chat.completions | ||
.create({ | ||
model: this.model, | ||
temperature: 0, | ||
messages, | ||
}) | ||
.then((result) => { | ||
if (!result.hasOwnProperty("choices")) | ||
throw new Error("LiteLLM chat: No results!"); | ||
if (result.choices.length === 0) | ||
throw new Error("LiteLLM chat: No results length!"); | ||
return result.choices[0].message.content; | ||
}) | ||
.catch((_) => { | ||
return null; | ||
}); | ||
} | ||
|
||
/** | ||
* Create a completion based on the received messages. | ||
* | ||
* @param messages A list of messages to send to the API. | ||
* @param functions | ||
* @returns The completion. | ||
*/ | ||
async complete(messages, functions = null) { | ||
try { | ||
let completion; | ||
if (functions.length > 0) { | ||
const { toolCall, text } = await this.functionCall( | ||
messages, | ||
functions, | ||
this.#handleFunctionCallChat.bind(this) | ||
); | ||
|
||
if (toolCall !== null) { | ||
this.providerLog(`Valid tool call found - running ${toolCall.name}.`); | ||
this.deduplicator.trackRun(toolCall.name, toolCall.arguments); | ||
return { | ||
result: null, | ||
functionCall: { | ||
name: toolCall.name, | ||
arguments: toolCall.arguments, | ||
}, | ||
cost: 0, | ||
}; | ||
} | ||
completion = { content: text }; | ||
} | ||
|
||
if (!completion?.content) { | ||
this.providerLog( | ||
"Will assume chat completion without tool call inputs." | ||
); | ||
const response = await this.client.chat.completions.create({ | ||
model: this.model, | ||
messages: this.cleanMsgs(messages), | ||
}); | ||
completion = response.choices[0].message; | ||
} | ||
|
||
// The UnTooled class inherited Deduplicator is mostly useful to prevent the agent | ||
// from calling the exact same function over and over in a loop within a single chat exchange | ||
// _but_ we should enable it to call previously used tools in a new chat interaction. | ||
this.deduplicator.reset("runs"); | ||
return { | ||
result: completion.content, | ||
cost: 0, | ||
}; | ||
} catch (error) { | ||
throw error; | ||
} | ||
} | ||
|
||
getCost(_usage) { | ||
return 0; | ||
} | ||
} | ||
|
||
module.exports = LiteLLMProvider; |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters