Skip to main content Link Search Menu Expand Document (external link)

Prompt.ts overview

The Prompt module provides several data structures to simplify creating and combining prompts.

This module defines the complete structure of a conversation with a large language model, including messages, content parts, and provider-specific options. It supports rich content types like text, files, tool calls, and reasoning.

Example

import { Prompt } from "@effect/ai"

// Create a structured conversation
const conversation = Prompt.make([
  {
    role: "system",
    content: "You are a helpful assistant specialized in mathematics."
  },
  {
    role: "user",
    content: [
      {
        type: "text",
        text: "What is the derivative of x²?"
      }
    ]
  },
  {
    role: "assistant",
    content: [
      {
        type: "text",
        text: "The derivative of x² is 2x."
      }
    ]
  }
])

Example

import { Prompt } from "@effect/ai"

// Merge multiple prompts
const systemPrompt = Prompt.make([
  {
    role: "system",
    content: "You are a coding assistant."
  }
])

const userPrompt = Prompt.make("Help me write a function")

const combined = Prompt.merge(systemPrompt, userPrompt)

Since v1.0.0


Exports Grouped by Category


Combinators

appendSystem

Creates a new prompt from the specified prompt with the provided text content appended to the end of existing system message content.

If no system message exists in the specified prompt, the provided content will be used to create a system message.

Example

import { Prompt } from "@effect/ai"

const systemPrompt = Prompt.make([
  {
    role: "system",
    content: "You are a helpful assistant."
  }
])

const userPrompt = Prompt.make("Hello, world!")

const prompt = Prompt.merge(systemPrompt, userPrompt)

const replaced = Prompt.appendSystem(prompt, " You are an expert in programming.")

Signature

declare const appendSystem: { (content: string): (self: Prompt) => Prompt; (self: Prompt, content: string): Prompt }

Source

Since v1.0.0

merge

Merges a prompt with additional raw input by concatenating messages.

Creates a new prompt containing all messages from both the original prompt, and the provided raw input, maintaining the order of messages.

Example

import { Prompt } from "@effect/ai"

const systemPrompt = Prompt.make([
  {
    role: "system",
    content: "You are a helpful assistant."
  }
])

const merged = Prompt.merge(systemPrompt, "Hello, world!")

Signature

declare const merge: { (input: RawInput): (self: Prompt) => Prompt; (self: Prompt, input: RawInput): Prompt }

Source

Since v1.0.0

prependSystem

Creates a new prompt from the specified prompt with the provided text content prepended to the start of existing system message content.

If no system message exists in the specified prompt, the provided content will be used to create a system message.

Example

import { Prompt } from "@effect/ai"

const systemPrompt = Prompt.make([
  {
    role: "system",
    content: "You are an expert in programming."
  }
])

const userPrompt = Prompt.make("Hello, world!")

const prompt = Prompt.merge(systemPrompt, userPrompt)

const replaced = Prompt.prependSystem(prompt, "You are a helpful assistant. ")

Signature

declare const prependSystem: { (content: string): (self: Prompt) => Prompt; (self: Prompt, content: string): Prompt }

Source

Since v1.0.0

setSystem

Creates a new prompt from the specified prompt with the system message set to the specified text content.

NOTE: This method will remove and replace any previous system message from the prompt.

Example

import { Prompt } from "@effect/ai"

const systemPrompt = Prompt.make([
  {
    role: "system",
    content: "You are a helpful assistant."
  }
])

const userPrompt = Prompt.make("Hello, world!")

const prompt = Prompt.merge(systemPrompt, userPrompt)

const replaced = Prompt.setSystem(prompt, "You are an expert in programming")

Signature

declare const setSystem: { (content: string): (self: Prompt) => Prompt; (self: Prompt, content: string): Prompt }

Source

Since v1.0.0

Constructors

empty

An empty prompt with no messages.

Example

import { Prompt } from "@effect/ai"

const emptyPrompt = Prompt.empty
console.log(emptyPrompt.content) // []

Signature

declare const empty: Prompt

Source

Since v1.0.0

fromMessages

Creates a Prompt from an array of messages.

Example

import { Prompt } from "@effect/ai"

const messages: ReadonlyArray<Prompt.Message> = [
  Prompt.makeMessage("system", {
    content: "You are a coding assistant."
  }),
  Prompt.makeMessage("user", {
    content: [Prompt.makePart("text", { text: "Help me with TypeScript" })]
  })
]

const prompt = Prompt.fromMessages(messages)

Signature

declare const fromMessages: (messages: ReadonlyArray<Message>) => Prompt

Source

Since v1.0.0

fromResponseParts

Creates a Prompt from the response parts of a previous interaction with a large language model.

Converts streaming or non-streaming AI response parts into a structured prompt, typically for use in conversation history or further processing.

Example

import { Prompt, Response } from "@effect/ai"

const responseParts: ReadonlyArray<Response.AnyPart> = [
  Response.makePart("text", {
    text: "Hello there!"
  }),
  Response.makePart("tool-call", {
    id: "call_1",
    name: "get_time",
    params: {},
    providerExecuted: false
  }),
  Response.makePart("tool-result", {
    id: "call_1",
    name: "get_time",
    result: "10:30 AM",
    encodedResult: "10:30 AM",
    providerExecuted: false
  })
]

const prompt = Prompt.fromResponseParts(responseParts)
// Creates an assistant message with the response content

Signature

declare const fromResponseParts: (parts: ReadonlyArray<Response.AnyPart>) => Prompt

Source

Since v1.0.0

make

Creates a Prompt from an input.

This is the primary constructor for creating prompts, supporting multiple input formats for convenience and flexibility.

Example

import { Prompt } from "@effect/ai"

// From string - creates a user message
const textPrompt = Prompt.make("Hello, how are you?")

// From messages array
const structuredPrompt = Prompt.make([
  { role: "system", content: "You are a helpful assistant." },
  { role: "user", content: [{ type: "text", text: "Hi!" }] }
])

// From existing prompt
declare const existingPrompt: Prompt.Prompt
const copiedPrompt = Prompt.make(existingPrompt)

Signature

declare const make: (input: RawInput) => Prompt

Source

Since v1.0.0

makeMessage

Creates a new message with the specified role.

Example

import { Prompt } from "@effect/ai"

const textPart = Prompt.makePart("text", {
  text: "Hello, world!"
})

const filePart = Prompt.makeMessage("user", {
  content: [textPart]
})

Signature

declare const makeMessage: <const Role extends Message["role"]>(
  role: Role,
  params: Omit<Extract<Message, { role: Role }>, MessageTypeId | "role" | "options"> & {
    readonly options?: Extract<Message, { role: Role }>["options"]
  }
) => Extract<Message, { role: Role }>

Source

Since v1.0.0

makePart

Creates a new content part of the specified type.

Example

import { Prompt } from "@effect/ai"

const textPart = Prompt.makePart("text", {
  text: "Hello, world!"
})

const filePart = Prompt.makePart("file", {
  mediaType: "image/png",
  fileName: "screenshot.png",
  data: new Uint8Array([1, 2, 3])
})

Signature

declare const makePart: <const Type extends Part["type"]>(
  type: Type,
  params: Omit<Extract<Part, { type: Type }>, PartTypeId | "type" | "options"> & {
    readonly options?: Extract<Part, { type: Type }>["options"] | undefined
  }
) => Extract<Part, { type: Type }>

Source

Since v1.0.0

Guards

isMessage

Type guard to check if a value is a Message.

Signature

declare const isMessage: (u: unknown) => u is Message

Source

Since v1.0.0

isPart

Type guard to check if a value is a Part.

Signature

declare const isPart: (u: unknown) => u is Part

Source

Since v1.0.0

isPrompt

Type guard to check if a value is a Prompt.

Signature

declare const isPrompt: (u: unknown) => u is Prompt

Source

Since v1.0.0

Models

AssistantMessage (interface)

Message representing large language model assistant responses.

Example

import { Prompt } from "@effect/ai"

const assistantMessage: Prompt.AssistantMessage = Prompt.makeMessage("assistant", {
  content: [
    Prompt.makePart("text", {
      text: "The user is asking about the weather. I should use the weather tool."
    }),
    Prompt.makePart("tool-call", {
      id: "call_123",
      name: "get_weather",
      params: { city: "San Francisco" },
      providerExecuted: false
    }),
    Prompt.makePart("tool-result", {
      id: "call_123",
      name: "get_weather",
      result: { temperature: 72, condition: "sunny" }
    }),
    Prompt.makePart("text", {
      text: "The weather in San Francisco is currently 72°F and sunny."
    })
  ]
})

Signature

export interface AssistantMessage extends BaseMessage<"assistant", AssistantMessageOptions> {
  /**
   * Array of content parts that make up the assistant's response.
   */
  readonly content: ReadonlyArray<AssistantMessagePart>
}

Source

Since v1.0.0

AssistantMessageEncoded (interface)

Encoded representation of assistant messages for serialization.

Signature

export interface AssistantMessageEncoded extends BaseMessageEncoded<"assistant", AssistantMessageOptions> {
  readonly content: string | ReadonlyArray<AssistantMessagePartEncoded>
}

Source

Since v1.0.0

AssistantMessagePart (type alias)

Union type of content parts allowed in assistant messages.

Signature

type AssistantMessagePart = TextPart | FilePart | ReasoningPart | ToolCallPart | ToolResultPart

Source

Since v1.0.0

AssistantMessagePartEncoded (type alias)

Union type of encoded content parts for assistant messages.

Signature

type AssistantMessagePartEncoded =
  | TextPartEncoded
  | FilePartEncoded
  | ReasoningPartEncoded
  | ToolCallPartEncoded
  | ToolResultPartEncoded

Source

Since v1.0.0

BaseMessage (interface)

Base interface for all message types.

Provides common structure including role and provider options.

Signature

export interface BaseMessage<Role extends string, Options extends ProviderOptions> {
  readonly [MessageTypeId]: MessageTypeId
  /**
   * The role of the message participant.
   */
  readonly role: Role
  /**
   * Provider-specific options for this message.
   */
  readonly options: Options
}

Source

Since v1.0.0

BaseMessageEncoded (interface)

Base interface for encoded message types.

Signature

export interface BaseMessageEncoded<Role extends string, Options extends ProviderOptions> {
  /**
   * The role of the message participant.
   */
  readonly role: Role
  /**
   * Provider-specific options for this message.
   */
  readonly options?: Options | undefined
}

Source

Since v1.0.0

BasePart (interface)

Base interface for all content parts.

Provides common structure including type and provider options.

Signature

export interface BasePart<Type extends string, Options extends ProviderOptions> {
  readonly [PartTypeId]: PartTypeId
  /**
   * The type of this content part.
   */
  readonly type: Type
  /**
   * Provider-specific options for this part.
   */
  readonly options: Options
}

Source

Since v1.0.0

BasePartEncoded (interface)

Base interface for encoded content parts.

Signature

export interface BasePartEncoded<Type extends string, Options extends ProviderOptions> {
  /**
   * The type of this content part.
   */
  readonly type: Type
  /**
   * Provider-specific options for this part.
   */
  readonly options?: Options | undefined
}

Source

Since v1.0.0

FilePart (interface)

Content part representing a file attachment. Files can be provided as base64 strings of data, byte arrays, or URLs.

Supports various file types including images, documents, and binary data.

Example

import { Prompt } from "@effect/ai"

const imagePart: Prompt.FilePart = Prompt.makePart("file", {
  mediaType: "image/jpeg",
  fileName: "photo.jpg",
  data: "..."
})

const documentPart: Prompt.FilePart = Prompt.makePart("file", {
  mediaType: "application/pdf",
  fileName: "report.pdf",
  data: new Uint8Array([1, 2, 3])
})

Signature

export interface FilePart extends BasePart<"file", FilePartOptions> {
  /**
   * MIME type of the file (e.g., "image/jpeg", "application/pdf").
   */
  readonly mediaType: string
  /**
   * Optional filename for the file.
   */
  readonly fileName?: string | undefined
  /**
   * File data as base64 string of data, a byte array, or a URL.
   */
  readonly data: string | Uint8Array | URL
}

Source

Since v1.0.0

FilePartEncoded (interface)

Encoded representation of file parts for serialization.

Signature

export interface FilePartEncoded extends BasePartEncoded<"file", FilePartOptions> {
  /**
   * MIME type of the file (e.g., "image/jpeg", "application/pdf").
   */
  readonly mediaType: string
  /**
   * Optional filename for the file.
   */
  readonly fileName?: string | undefined
  /**
   * File data as base64 string of data, a byte array, or a URL.
   */
  readonly data: string | Uint8Array | URL
}

Source

Since v1.0.0

Message (type alias)

A type representing all possible message types in a conversation.

Signature

type Message = SystemMessage | UserMessage | AssistantMessage | ToolMessage

Source

Since v1.0.0

MessageEncoded (type alias)

A type representing all possible encoded message types for serialization.

Signature

type MessageEncoded = SystemMessageEncoded | UserMessageEncoded | AssistantMessageEncoded | ToolMessageEncoded

Source

Since v1.0.0

Part (type alias)

Union type representing all possible content parts within messages.

Parts are the building blocks of message content, supporting text, files, reasoning, tool calls, and tool results.

Signature

type Part = TextPart | ReasoningPart | FilePart | ToolCallPart | ToolResultPart

Source

Since v1.0.0

PartEncoded (type alias)

Encoded representation of a Part.

Signature

type PartEncoded =
  | TextPartEncoded
  | ReasoningPartEncoded
  | FilePartEncoded
  | ToolCallPartEncoded
  | ToolResultPartEncoded

Source

Since v1.0.0

Prompt (interface)

A Prompt contains a sequence of messages that form the context of a conversation with a large language model.

Signature

export interface Prompt extends Pipeable {
  readonly [TypeId]: TypeId
  /**
   * Array of messages that make up the conversation.
   */
  readonly content: ReadonlyArray<Message>
}

Source

Since v1.0.0

PromptEncoded (interface)

Encoded representation of prompts for serialization.

Signature

export interface PromptEncoded {
  /**
   * Array of messages that make up the conversation.
   */
  readonly content: ReadonlyArray<MessageEncoded>
}

Source

Since v1.0.0

ProviderOptions

Schema for provider-specific options which can be attached to both content parts and messages, enabling provider-specific behavior.

Provider-specific options are namespaced by provider and have the structure:

{
  "<provider-specific-key>": {
    // Provider-specific options
  }
}

Signature

declare const ProviderOptions: Schema.Record$<
  typeof Schema.String,
  Schema.UndefinedOr<Schema.Record$<typeof Schema.String, typeof Schema.Unknown>>
>

Source

Since v1.0.0

ProviderOptions (type alias)

Signature

type ProviderOptions = typeof ProviderOptions.Type

Source

Since v1.0.0

RawInput (type alias)

Raw input types that can be converted into a Prompt.

Supports various input formats for convenience, including simple strings, message arrays, response parts, and existing prompts.

Example

import { Prompt } from "@effect/ai"

// String input - creates a user message
const stringInput: Prompt.RawInput = "Hello, world!"

// Message array input
const messagesInput: Prompt.RawInput = [
  { role: "system", content: "You are helpful." },
  { role: "user", content: [{ type: "text", text: "Hi!" }] }
]

// Existing prompt
declare const existingPrompt: Prompt.Prompt
const promptInput: Prompt.RawInput = existingPrompt

Signature

type RawInput = string | Iterable<MessageEncoded> | Prompt

Source

Since v1.0.0

ReasoningPart (interface)

Content part representing reasoning or chain-of-thought.

Example

import { Prompt } from "@effect/ai"

const reasoningPart: Prompt.ReasoningPart = Prompt.makePart("reasoning", {
  text: "Let me think step by step: First I need to understand the user's question..."
})

Signature

export interface ReasoningPart extends BasePart<"reasoning", ReasoningPartOptions> {
  /**
   * The reasoning or thought process text.
   */
  readonly text: string
}

Source

Since v1.0.0

ReasoningPartEncoded (interface)

Encoded representation of reasoning parts for serialization.

Signature

export interface ReasoningPartEncoded extends BasePartEncoded<"reasoning", ReasoningPartOptions> {
  /**
   * The reasoning or thought process text.
   */
  readonly text: string
}

Source

Since v1.0.0

SystemMessage (interface)

Message representing system instructions or context.

Example

import { Prompt } from "@effect/ai"

const systemMessage: Prompt.SystemMessage = Prompt.makeMessage("system", {
  content: "You are a helpful assistant specialized in mathematics. " + "Always show your work step by step."
})

Signature

export interface SystemMessage extends BaseMessage<"system", SystemMessageOptions> {
  /**
   * The system instruction or context as plain text.
   */
  readonly content: string
}

Source

Since v1.0.0

SystemMessageEncoded (interface)

Encoded representation of system messages for serialization.

Signature

export interface SystemMessageEncoded extends BaseMessageEncoded<"system", SystemMessageOptions> {
  /**
   * The system instruction or context as plain text.
   */
  readonly content: string
}

Source

Since v1.0.0

TextPart (interface)

Content part representing plain text.

The most basic content type used for textual information in messages.

Example

import { Prompt } from "@effect/ai"

const textPart: Prompt.TextPart = Prompt.makePart("text", {
  text: "Hello, how can I help you today?"
})

Signature

export interface TextPart extends BasePart<"text", TextPartOptions> {
  /**
   * The text content.
   */
  readonly text: string
}

Source

Since v1.0.0

TextPartEncoded (interface)

Encoded representation of text parts for serialization.

Signature

export interface TextPartEncoded extends BasePartEncoded<"text", TextPartOptions> {
  /**
   * The text content.
   */
  readonly text: string
}

Source

Since v1.0.0

ToolCallPart (interface)

Content part representing a tool call request.

Example

import { Prompt } from "@effect/ai"

const toolCallPart: Prompt.ToolCallPart = Prompt.makePart("tool-call", {
  id: "call_123",
  name: "get_weather",
  params: { city: "San Francisco", units: "celsius" },
  providerExecuted: false
})

Signature

export interface ToolCallPart extends BasePart<"tool-call", ToolCallPartOptions> {
  /**
   * Unique identifier for this tool call.
   */
  readonly id: string
  /**
   * Name of the tool to invoke.
   */
  readonly name: string
  /**
   * Parameters to pass to the tool.
   */
  readonly params: unknown
  /**
   * Whether the tool was executed by the provider (true) or framework (false).
   */
  readonly providerExecuted: boolean
}

Source

Since v1.0.0

ToolCallPartEncoded (interface)

Encoded representation of tool call parts for serialization.

Signature

export interface ToolCallPartEncoded extends BasePartEncoded<"tool-call", ToolCallPartOptions> {
  /**
   * Unique identifier for this tool call.
   */
  readonly id: string
  /**
   * Name of the tool to invoke.
   */
  readonly name: string
  /**
   * Parameters to pass to the tool.
   */
  readonly params: unknown
  /**
   * Whether the tool was executed by the provider (true) or framework (false).
   */
  readonly providerExecuted?: boolean | undefined
}

Source

Since v1.0.0

ToolMessage (interface)

Message representing tool execution results.

Example

import { Prompt } from "@effect/ai"

const toolMessage: Prompt.ToolMessage = Prompt.makeMessage("tool", {
  content: [
    Prompt.makePart("tool-result", {
      id: "call_123",
      name: "search_web",
      result: {
        query: "TypeScript best practices",
        results: [
          { title: "TypeScript Handbook", url: "https://..." },
          { title: "Effective TypeScript", url: "https://..." }
        ]
      }
    })
  ]
})

Signature

export interface ToolMessage extends BaseMessage<"tool", ToolMessageOptions> {
  /**
   * Array of tool result parts.
   */
  readonly content: ReadonlyArray<ToolMessagePart>
}

Source

Since v1.0.0

ToolMessageEncoded (interface)

Encoded representation of tool messages for serialization.

Signature

export interface ToolMessageEncoded extends BaseMessageEncoded<"tool", ToolMessageOptions> {
  /**
   * Array of tool result parts.
   */
  readonly content: ReadonlyArray<ToolMessagePartEncoded>
}

Source

Since v1.0.0

ToolMessagePart (type alias)

Union type of content parts allowed in tool messages.

Signature

type ToolMessagePart = ToolResultPart

Source

Since v1.0.0

ToolMessagePartEncoded (type alias)

Union type of encoded content parts for tool messages.

Signature

type ToolMessagePartEncoded = ToolResultPartEncoded

Source

Since v1.0.0

ToolResultPart (interface)

Content part representing the result of a tool call.

Example

import { Prompt } from "@effect/ai"

const toolResultPart: Prompt.ToolResultPart = Prompt.makePart("tool-result", {
  id: "call_123",
  name: "get_weather",
  result: {
    temperature: 22,
    condition: "sunny",
    humidity: 65
  }
})

Signature

export interface ToolResultPart extends BasePart<"tool-result", ToolResultPartOptions> {
  /**
   * Unique identifier matching the original tool call.
   */
  readonly id: string
  /**
   * Name of the tool that was executed.
   */
  readonly name: string
  /**
   * The result returned by the tool execution.
   */
  readonly result: unknown
}

Source

Since v1.0.0

ToolResultPartEncoded (interface)

Encoded representation of tool result parts for serialization.

Signature

export interface ToolResultPartEncoded extends BasePartEncoded<"tool-result", ToolResultPartOptions> {
  /**
   * Unique identifier matching the original tool call.
   */
  readonly id: string
  /**
   * Name of the tool that was executed.
   */
  readonly name: string
  /**
   * The result returned by the tool execution.
   */
  readonly result: unknown
}

Source

Since v1.0.0

UserMessage (interface)

Message representing user input or questions.

Example

import { Prompt } from "@effect/ai"

const textUserMessage: Prompt.UserMessage = Prompt.makeMessage("user", {
  content: [
    Prompt.makePart("text", {
      text: "Can you analyze this image for me?"
    })
  ]
})

const multimodalUserMessage: Prompt.UserMessage = Prompt.makeMessage("user", {
  content: [
    Prompt.makePart("text", {
      text: "What do you see in this image?"
    }),
    Prompt.makePart("file", {
      mediaType: "image/jpeg",
      fileName: "vacation.jpg",
      data: "data:image/jpeg;base64,..."
    })
  ]
})

Signature

export interface UserMessage extends BaseMessage<"user", UserMessageOptions> {
  /**
   * Array of content parts that make up the user's message.
   */
  readonly content: ReadonlyArray<UserMessagePart>
}

Source

Since v1.0.0

UserMessageEncoded (interface)

Encoded representation of user messages for serialization.

Signature

export interface UserMessageEncoded extends BaseMessageEncoded<"user", UserMessageOptions> {
  /**
   * Array of content parts that make up the user's message.
   */
  readonly content: string | ReadonlyArray<UserMessagePartEncoded>
}

Source

Since v1.0.0

UserMessagePart (type alias)

Union type of content parts allowed in user messages.

Signature

type UserMessagePart = TextPart | FilePart

Source

Since v1.0.0

UserMessagePartEncoded (type alias)

Union type of encoded content parts for user messages.

Signature

type UserMessagePartEncoded = TextPartEncoded | FilePartEncoded

Source

Since v1.0.0

ProviderOptions

AssistantMessageOptions (interface)

Represents provider-specific options that can be associated with a AssistantMessage through module augmentation.

Signature

export interface AssistantMessageOptions extends ProviderOptions {}

Source

Since v1.0.0

FilePartOptions (interface)

Represents provider-specific options that can be associated with a FilePart through module augmentation.

Signature

export interface FilePartOptions extends ProviderOptions {}

Source

Since v1.0.0

ReasoningPartOptions (interface)

Represents provider-specific options that can be associated with a ReasoningPart through module augmentation.

Signature

export interface ReasoningPartOptions extends ProviderOptions {}

Source

Since v1.0.0

SystemMessageOptions (interface)

Represents provider-specific options that can be associated with a SystemMessage through module augmentation.

Signature

export interface SystemMessageOptions extends ProviderOptions {}

Source

Since v1.0.0

TextPartOptions (interface)

Represents provider-specific options that can be associated with a TextPart through module augmentation.

Signature

export interface TextPartOptions extends ProviderOptions {}

Source

Since v1.0.0

ToolCallPartOptions (interface)

Represents provider-specific options that can be associated with a ToolCallPart through module augmentation.

Signature

export interface ToolCallPartOptions extends ProviderOptions {}

Source

Since v1.0.0

ToolMessageOptions (interface)

Represents provider-specific options that can be associated with a ToolMessage through module augmentation.

Signature

export interface ToolMessageOptions extends ProviderOptions {}

Source

Since v1.0.0

ToolResultPartOptions (interface)

Represents provider-specific options that can be associated with a ToolResultPart through module augmentation.

Signature

export interface ToolResultPartOptions extends ProviderOptions {}

Source

Since v1.0.0

UserMessageOptions (interface)

Represents provider-specific options that can be associated with a UserMessage through module augmentation.

Signature

export interface UserMessageOptions extends ProviderOptions {}

Source

Since v1.0.0

Schemas

AssistantMessage

Schema for validation and encoding of assistant messages.

Signature

declare const AssistantMessage: Schema.Schema<AssistantMessage, AssistantMessageEncoded, never>

Source

Since v1.0.0

FilePart

Schema for validation and encoding of file parts.

Signature

declare const FilePart: Schema.Schema<FilePart, FilePartEncoded, never>

Source

Since v1.0.0

FromJson

Schema for parsing a Prompt from JSON strings.

Signature

declare const FromJson: Schema.transform<
  Schema.SchemaClass<unknown, string, never>,
  Schema.Schema<Prompt, PromptEncoded, never>
>

Source

Since v1.0.0

Message

Schema for validation and encoding of messages.

Signature

declare const Message: Schema.Schema<Message, MessageEncoded, never>

Source

Since v1.0.0

MessageContentFromString

Schema for decoding message content (i.e. an array containing a single TextPart) from a string.

Signature

declare const MessageContentFromString: Schema.Schema<readonly [TextPart, ...TextPart[]], string, never>

Source

Since v1.0.0

Prompt

Schema for validation and encoding of prompts.

Signature

declare const Prompt: Schema.Schema<Prompt, PromptEncoded, never>

Source

Since v1.0.0

PromptFromSelf (class)

Describes a schema that represents a Prompt instance.

Signature

declare class PromptFromSelf

Source

Since v1.0.0

ReasoningPart

Schema for validation and encoding of reasoning parts.

Signature

declare const ReasoningPart: Schema.Schema<ReasoningPart, ReasoningPartEncoded, never>

Source

Since v1.0.0

SystemMessage

Schema for validation and encoding of system messages.

Signature

declare const SystemMessage: Schema.Schema<SystemMessage, SystemMessageEncoded, never>

Source

Since v1.0.0

TextPart

Schema for validation and encoding of text parts.

Signature

declare const TextPart: Schema.Schema<TextPart, TextPartEncoded, never>

Source

Since v1.0.0

ToolCallPart

Schema for validation and encoding of tool call parts.

Signature

declare const ToolCallPart: Schema.Schema<ToolCallPart, ToolCallPartEncoded, never>

Source

Since v1.0.0

ToolMessage

Schema for validation and encoding of tool messages.

Signature

declare const ToolMessage: Schema.Schema<ToolMessage, ToolMessageEncoded, never>

Source

Since v1.0.0

ToolResultPart

Schema for validation and encoding of tool result parts.

Signature

declare const ToolResultPart: Schema.Schema<ToolResultPart, ToolResultPartEncoded, never>

Source

Since v1.0.0

UserMessage

Schema for validation and encoding of user messages.

Signature

declare const UserMessage: Schema.Schema<UserMessage, UserMessageEncoded, never>

Source

Since v1.0.0

Type Ids

MessageTypeId

Unique identifier for Message instances.

Signature

declare const MessageTypeId: "~effect/ai/Prompt/Message"

Source

Since v1.0.0

MessageTypeId (type alias)

Type-level representation of the Message identifier.

Signature

type MessageTypeId = typeof MessageTypeId

Source

Since v1.0.0

PartTypeId

Unique identifier for Part instances.

Signature

declare const PartTypeId: "~effect/ai/Prompt/Part"

Source

Since v1.0.0

PartTypeId (type alias)

Type-level representation of the Part identifier.

Signature

type PartTypeId = typeof PartTypeId

Source

Since v1.0.0

TypeId

Unique identifier for Prompt instances.

Signature

declare const TypeId: "~@effect/ai/Prompt"

Source

Since v1.0.0

TypeId (type alias)

Type-level representation of the Prompt identifier.

Signature

type TypeId = typeof TypeId

Source

Since v1.0.0