This commit is contained in:
Tim Millwood 2025-06-19 16:14:53 +00:00 committed by GitHub
commit bdaf05fa30
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
3 changed files with 99 additions and 0 deletions

View File

@ -0,0 +1,95 @@
import { BaseProvider } 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';
import { createOpenAI } from '@ai-sdk/openai';
export default class CloudflareProvider extends BaseProvider {
name = 'Cloudflare';
getApiKeyLink = 'https://dash.cloudflare.com/profile/api-tokens';
config = {
apiTokenKey: 'CLOUDFLARE_API_TOKEN',
accountIdKey: 'CLOUDFLARE_ACCOUNT_ID',
};
staticModels: ModelInfo[] = [];
async getDynamicModels(
apiKeys?: Record<string, string>,
serverEnv: Record<string, string> = {},
): Promise<ModelInfo[]> {
const { apiKey } = this.getProviderBaseUrlAndKey({
apiKeys,
serverEnv: serverEnv as any,
defaultBaseUrlKey: '',
defaultApiTokenKey: 'CLOUDFLARE_API_TOKEN',
});
const accountId = serverEnv?.CLOUDFLARE_ACCOUNT_ID || process?.env?.CLOUDFLARE_ACCOUNT_ID;
if (!apiKey || !accountId) {
return [];
}
try {
const response = await fetch(
`https://api.cloudflare.com/client/v4/accounts/${accountId}/ai/models/search`,
{
headers: {
Authorization: `Bearer ${apiKey}`,
},
},
);
if (!response.ok) {
throw new Error(`Failed to fetch models: ${response.statusText}`);
}
const data = (await response.json()) as { result: Array<{ id: string }> };
return data.result.map((model: any) => ({
name: model.name,
label: model.name,
provider: this.name,
maxTokenAllowed: 100000,
}));
} catch (error) {
console.error('Error fetching Cloudflare models:', error);
return [];
}
}
getModelInstance(options: {
model: string;
serverEnv: Env;
apiKeys?: Record<string, string>;
providerSettings?: Record<string, IProviderSetting>;
}): LanguageModelV1 {
const { model, serverEnv, apiKeys, providerSettings } = options;
const { apiKey } = this.getProviderBaseUrlAndKey({
apiKeys,
providerSettings: providerSettings?.[this.name],
serverEnv: serverEnv as any,
defaultBaseUrlKey: '',
defaultApiTokenKey: 'CLOUDFLARE_API_TOKEN',
});
const accountId = serverEnv?.CLOUDFLARE_ACCOUNT_ID || process?.env?.CLOUDFLARE_ACCOUNT_ID;
if (!apiKey) {
throw new Error(`Missing API token for ${this.name} provider`);
}
if (!accountId) {
throw new Error(`Missing Account ID for ${this.name} provider`);
}
const openai = createOpenAI({
baseURL: `https://api.cloudflare.com/client/v4/accounts/${accountId}/ai/v1`,
apiKey,
});
return openai(model);
}
}

View File

@ -1,5 +1,6 @@
import AnthropicProvider from './providers/anthropic';
import CohereProvider from './providers/cohere';
import CloudflareProvider from './providers/cloudflare';
import DeepseekProvider from './providers/deepseek';
import GoogleProvider from './providers/google';
import GroqProvider from './providers/groq';
@ -19,6 +20,7 @@ import GithubProvider from './providers/github';
export {
AnthropicProvider,
CloudflareProvider,
CohereProvider,
DeepseekProvider,
GoogleProvider,

View File

@ -18,4 +18,6 @@ interface Env {
XAI_API_KEY: string;
PERPLEXITY_API_KEY: string;
AWS_BEDROCK_CONFIG: string;
CLOUDFLARE_API_KEY: string;
CLOUDFLARE_ACCOUNT_ID: string;
}