# toAISdkV4Messages() Converts messages from various input formats to AI SDK V4 UI message format. This function accepts messages in multiple formats (strings, AI SDK V4/V5 messages, Mastra DB messages, etc.) and normalizes them to the AI SDK V4 `UIMessage` format, which is suitable for use with AI SDK UI components like `useChat()`. ## Usage example ```typescript import { toAISdkV4Messages } from "@mastra/ai-sdk"; import { useChat } from "ai/react"; // AI SDK V4 // Stored messages from your database, memory or API const storedMessages = [ { id: "1", role: "user", parts: [{ type: "text", text: "Hello" }] }, { id: "2", role: "assistant", parts: [{ type: "text", text: "Hi there!" }] } ]; export default function Chat() { const { messages } = useChat({ initialMessages: toAISdkV4Messages(storedMessages) }); return (
{messages.map((message) => (
{message.role}: {message.content}
))}
); } ``` ## Parameters **messages:** (`MessageListInput`): Messages to convert. Can be a string, array of strings, a single message object, or an array of message objects in any supported format. ## Returns Returns an array of AI SDK V4 `UIMessage` objects with the following structure: **id:** (`string`): Unique message identifier. **role:** (`'user' | 'assistant' | 'system'`): The role of the message sender. **content:** (`string`): Text content of the message. **parts:** (`UIMessagePart[]`): Array of UI parts including text, tool-invocation, file, reasoning, source, and step markers. **createdAt:** (`Date`): Message creation timestamp. **toolInvocations?:** (`ToolInvocation[]`): Array of tool invocations for assistant messages. **experimental\_attachments?:** (`Attachment[]`): File attachments on the message. **metadata?:** (`Record`): Custom metadata attached to the message. ## Examples ### Converting simple text messages ```typescript import { toAISdkV4Messages } from "@mastra/ai-sdk"; const messages = toAISdkV4Messages(["Hello", "How can I help you today?"]); // Returns array of UIMessage objects with user role and content string ``` ### Loading messages with Mastra client ```typescript import { MastraClient } from "@mastra/client-js"; import { toAISdkV4Messages } from "@mastra/ai-sdk"; const client = new MastraClient(); const { messages } = await client.listThreadMessages("thread-id", { agentId: "myAgent" }); const uiMessages = toAISdkV4Messages(messages); ```