mirror of
https://github.com/stackblitz-labs/bolt.diy
synced 2025-06-26 18:26:38 +00:00
Cerebras Integration
This commit is contained in:
parent
3be18e3f9d
commit
c57a35eb93
73
app/lib/modules/llm/providers/cerebras.ts
Normal file
73
app/lib/modules/llm/providers/cerebras.ts
Normal file
@ -0,0 +1,73 @@
|
|||||||
|
import { BaseProvider, getOpenAILikeModel } from '~/lib/modules/llm/base-provider';
|
||||||
|
import type { ModelInfo } from '~/lib/modules/llm/types';
|
||||||
|
import type { IProviderSetting } from '~/types/model';
|
||||||
|
import type { LanguageModelV1 } from 'ai';
|
||||||
|
|
||||||
|
export default class CerebrasProvider extends BaseProvider {
|
||||||
|
name = 'Cerebras';
|
||||||
|
baseUrl = 'https://api.cerebras.ai/v1';
|
||||||
|
getApiKeyLink = 'https://cloud.cerebras.ai/platform';
|
||||||
|
|
||||||
|
config = {
|
||||||
|
baseUrlKey: 'CEREBRAS_API_BASE_URL',
|
||||||
|
apiTokenKey: 'CEREBRAS_API_KEY',
|
||||||
|
};
|
||||||
|
|
||||||
|
staticModels: ModelInfo[] = [];
|
||||||
|
|
||||||
|
async getDynamicModels(
|
||||||
|
apiKeys?: Record<string, string>,
|
||||||
|
settings?: IProviderSetting,
|
||||||
|
serverEnv: Record<string, string> = {},
|
||||||
|
): Promise<ModelInfo[]> {
|
||||||
|
const { baseUrl, apiKey } = this.getProviderBaseUrlAndKey({
|
||||||
|
apiKeys,
|
||||||
|
providerSettings: { ...settings, baseUrl: this.baseUrl },
|
||||||
|
serverEnv,
|
||||||
|
defaultBaseUrlKey: `${this.config.baseUrlKey}`,
|
||||||
|
defaultApiTokenKey: `${this.config.apiTokenKey}`,
|
||||||
|
});
|
||||||
|
|
||||||
|
if (!baseUrl || !apiKey) {
|
||||||
|
return [];
|
||||||
|
}
|
||||||
|
|
||||||
|
const response = await fetch(`${baseUrl}/models`, {
|
||||||
|
headers: {
|
||||||
|
Authorization: `Bearer ${apiKey}`,
|
||||||
|
},
|
||||||
|
});
|
||||||
|
|
||||||
|
const res = (await response.json()) as any;
|
||||||
|
|
||||||
|
return res.data.map((model: any) => ({
|
||||||
|
name: model.id,
|
||||||
|
label: model.id,
|
||||||
|
provider: this.name,
|
||||||
|
maxTokenAllowed: 8000,
|
||||||
|
}));
|
||||||
|
}
|
||||||
|
|
||||||
|
getModelInstance(options: {
|
||||||
|
model: string;
|
||||||
|
serverEnv: Env;
|
||||||
|
apiKeys?: Record<string, string>;
|
||||||
|
providerSettings?: Record<string, IProviderSetting>;
|
||||||
|
}): LanguageModelV1 {
|
||||||
|
const { model, serverEnv, apiKeys, providerSettings } = options;
|
||||||
|
|
||||||
|
const { baseUrl, apiKey } = this.getProviderBaseUrlAndKey({
|
||||||
|
apiKeys,
|
||||||
|
providerSettings: { ...providerSettings?.[this.name], baseUrl: this.baseUrl },
|
||||||
|
serverEnv: serverEnv as any,
|
||||||
|
defaultBaseUrlKey: `${this.config.baseUrlKey}`,
|
||||||
|
defaultApiTokenKey: `${this.config.apiTokenKey}`,
|
||||||
|
});
|
||||||
|
|
||||||
|
if (!baseUrl || !apiKey) {
|
||||||
|
throw new Error(`Missing configuration for ${this.name} provider`);
|
||||||
|
}
|
||||||
|
|
||||||
|
return getOpenAILikeModel(baseUrl, apiKey, model);
|
||||||
|
}
|
||||||
|
}
|
||||||
@ -16,6 +16,7 @@ import XAIProvider from './providers/xai';
|
|||||||
import HyperbolicProvider from './providers/hyperbolic';
|
import HyperbolicProvider from './providers/hyperbolic';
|
||||||
import AmazonBedrockProvider from './providers/amazon-bedrock';
|
import AmazonBedrockProvider from './providers/amazon-bedrock';
|
||||||
import GithubProvider from './providers/github';
|
import GithubProvider from './providers/github';
|
||||||
|
import CerebrasProvider from './providers/cerebras';
|
||||||
|
|
||||||
export {
|
export {
|
||||||
AnthropicProvider,
|
AnthropicProvider,
|
||||||
@ -36,4 +37,5 @@ export {
|
|||||||
LMStudioProvider,
|
LMStudioProvider,
|
||||||
AmazonBedrockProvider,
|
AmazonBedrockProvider,
|
||||||
GithubProvider,
|
GithubProvider,
|
||||||
|
CerebrasProvider,
|
||||||
};
|
};
|
||||||
|
|||||||
Loading…
Reference in New Issue
Block a user