Skip to main content
Mastra 1.0 is available 🎉 Read announcement

MessageHistory

The MessageHistory is a hybrid processor that handles both retrieval and persistence of message history. On input, it fetches historical messages from storage and prepends them to the conversation. On output, it persists new messages to storage.

Usage example
Direct link to Usage example

import { MessageHistory } from "@mastra/core/processors";

const processor = new MessageHistory({
storage: memoryStorage,
lastMessages: 50,
});

Constructor parameters
Direct link to Constructor parameters

options:

MessageHistoryOptions
Configuration options for the message history processor

Options
Direct link to Options

storage:

MemoryStorage
Storage instance for retrieving and persisting messages

lastMessages?:

number
Maximum number of historical messages to retrieve. If not specified, retrieves all messages

Returns
Direct link to Returns

id:

string
Processor identifier set to 'message-history'

name:

string
Processor display name set to 'MessageHistory'

processInput:

(args: { messages: MastraDBMessage[]; messageList: MessageList; abort: (reason?: string) => never; tracingContext?: TracingContext; requestContext?: RequestContext }) => Promise<MessageList | MastraDBMessage[]>
Fetches historical messages from storage and adds them to the message list

processOutputResult:

(args: { messages: MastraDBMessage[]; messageList: MessageList; abort: (reason?: string) => never; tracingContext?: TracingContext; requestContext?: RequestContext }) => Promise<MessageList>
Persists new messages (user input and assistant response) to storage, excluding system messages

Extended usage example
Direct link to Extended usage example

src/mastra/agents/memory-agent.ts
import { Agent } from "@mastra/core/agent";
import { MessageHistory } from "@mastra/core/processors";
import { PostgresStorage } from "@mastra/pg";

const storage = new PostgresStorage({
connectionString: process.env.DATABASE_URL,
});

export const agent = new Agent({
name: "memory-agent",
instructions: "You are a helpful assistant with conversation memory",
model: "openai:gpt-4o",
inputProcessors: [
new MessageHistory({
storage,
lastMessages: 100,
}),
],
outputProcessors: [
new MessageHistory({
storage,
}),
],
});

Behavior
Direct link to Behavior

Input processing
Direct link to Input processing

  1. Retrieves threadId from the request context
  2. Fetches historical messages from storage (ordered by creation date, descending)
  3. Filters out system messages (they should not be stored in the database)
  4. Merges historical messages with incoming messages, avoiding duplicates by ID
  5. Adds historical messages with source: 'memory' tag

Output processing
Direct link to Output processing

  1. Retrieves threadId from the request context
  2. Skips persistence if readOnly is set in memory config
  3. Filters out incomplete tool calls from messages
  4. Persists new user input and assistant response messages to storage
  5. Updates the thread's updatedAt timestamp