Alibaba Provider
Alibaba Cloud Model Studio provides access to the Qwen model series, including advanced reasoning capabilities.
API keys can be obtained from the Console.
Setup
The Alibaba provider is available via the @ai-sdk/alibaba module. You can install it with:
pnpm add @ai-sdk/alibaba
Provider Instance
You can import the default provider instance alibaba from @ai-sdk/alibaba:
import { alibaba } from '@ai-sdk/alibaba';For custom configuration, you can import createAlibaba and create a provider instance with your settings:
import { createAlibaba } from '@ai-sdk/alibaba';
const alibaba = createAlibaba({ apiKey: process.env.ALIBABA_API_KEY ?? '',});You can use the following optional settings to customize the Alibaba provider instance:
-
baseURL string
Use a different URL prefix for API calls, e.g. to use proxy servers or regional endpoints. The default prefix is
https://dashscope-intl.aliyuncs.com/compatible-mode/v1. -
apiKey string
API key that is being sent using the
Authorizationheader. It defaults to theALIBABA_API_KEYenvironment variable. -
headers Record<string,string>
Custom headers to include in the requests.
-
fetch (input: RequestInfo, init?: RequestInit) => Promise<Response>
Custom fetch implementation.
-
includeUsage boolean
Include usage information in streaming responses. When enabled, token usage will be included in the final chunk. Defaults to
true.
Language Models
You can create language models using a provider instance:
import { alibaba } from '@ai-sdk/alibaba';import { generateText } from 'ai';
const { text } = await generateText({ model: alibaba('qwen-plus'), prompt: 'Write a vegetarian lasagna recipe for 4 people.',});You can also use the .chatModel() or .languageModel() factory methods:
const model = alibaba.chatModel('qwen-plus');// orconst model = alibaba.languageModel('qwen-plus');Alibaba language models can be used in the streamText function
(see AI SDK Core).
The following optional provider options are available for Alibaba models:
-
enableThinking boolean
Enable thinking/reasoning mode for supported models. When enabled, the model generates reasoning content before the response. Defaults to
false. -
thinkingBudget number
Maximum number of reasoning tokens to generate. Limits the length of thinking content.
-
parallelToolCalls boolean
Whether to enable parallel function calling during tool use. Defaults to
true.
Thinking Mode
Alibaba's Qwen models support thinking/reasoning mode for complex problem-solving:
import { alibaba } from '@ai-sdk/alibaba';import { generateText } from 'ai';
const { text, reasoning } = await generateText({ model: alibaba('qwen3-max'), providerOptions: { alibaba: { enableThinking: true, thinkingBudget: 2048, }, }, prompt: 'How many "r"s are in the word "strawberry"?',});
console.log('Reasoning:', reasoning);console.log('Answer:', text);For models that are thinking-only (like qwen3-235b-a22b-thinking-2507), thinking mode is enabled by default.
Tool Calling
Alibaba models support tool calling with parallel execution:
import { alibaba } from '@ai-sdk/alibaba';import { generateText, tool } from 'ai';import { z } from 'zod';
const { text } = await generateText({ model: alibaba('qwen-plus'), tools: { weather: tool({ description: 'Get the weather in a location', parameters: z.object({ location: z.string().describe('The location to get the weather for'), }), execute: async ({ location }) => ({ location, temperature: 72 + Math.floor(Math.random() * 21) - 10, }), }), }, prompt: 'What is the weather in San Francisco?',});Prompt Caching
Alibaba supports both implicit and explicit prompt caching to reduce costs for repeated prompts.
Implicit caching works automatically - the provider caches appropriate content without any configuration. For more control, you can use explicit caching by marking specific messages with cacheControl:
import { alibaba } from '@ai-sdk/alibaba';import { generateText } from 'ai';
const { text, usage } = await generateText({ model: alibaba('qwen-plus'), messages: [ { role: 'system', content: 'You are a helpful assistant. [... long system prompt ...]', providerMetadata: { alibaba: { cacheControl: { type: 'ephemeral' }, }, }, }, { role: 'user', content: 'What is the capital of France?', }, ],});Model Capabilities
Please see the Alibaba Cloud Model Studio docs for a full list of available models. You can also pass any available provider model ID as a string if needed.