We use cookies to enhance your experience and measure how the site performs. Choose "Essential Only" to disable analytics. Read our Privacy Policy.

    Odeus Docs

    Agent Update API

    Update an existing agent programmatically

    Agent Update API

    Update an existing agent programmatically

    ⚠️ Using our API via a dedicated deployment? Just replace api.odeus.ai with your deployment's base URL: <deployment-url>/api/public

    This is the new Agents API with native Vercel AI SDK compatibility. If you're using the legacy Assistants API, see the migration guide.

    Updates an existing agent in your workspace. Only the fields you provide will be updated, allowing for partial updates without affecting other configuration.

    Updates are applied to the agent's draft only. The active (published) version remains unchanged until the agent is published from the Odeus UI.

    Requires an API key with the AGENT_API scope and access to the agent you want to update.

    Update Behavior

    The update endpoint uses partial update semantics with specific behavior for different field types:

    • Partial updates - Only fields provided in the request are updated; omitted fields remain unchanged
    • Array fields replace - actions, inputFields, conversationStarters, and attachments completely replace existing values when provided
    • Empty arrays - Send [] to remove all actions/fields/attachments
    • Null handling - Send null for emoji to clear it. For description and instruction, send an empty string "" to clear them
    • Unchanged fields - Fields not included in the request retain their current values

    Request Parameters

    Set any of the parameters below to overwrite the agent's current settings. Fields you omit stay unchanged. Only agentId is required.

    ParameterTypeRequiredDescription
    agentIdstringYesUUID of the agent to update
    namestringNoAgent name (1-80 characters)
    descriptionstringNoDescription (max 500 chars, "" to clear)
    emojistringNoEmoji icon (max 16 chars, null to clear)
    instructionstringNoSystem prompt (max 40000 chars, "" to clear)
    modelstringNoModel identifier (deployment name from the Models API)
    creativitynumberNoTemperature between 0 and 1
    conversationStartersstring[]NoSuggested prompts, max 20, each 1-255 chars (replaces existing)
    actionsarrayNoActions (replaces existing)
    inputFieldsarrayNoForm fields (replaces existing)
    attachmentsstring[]NoAttachment UUIDs (replaces existing)
    webSearchbooleanNoEnable web search
    imageGenerationbooleanNoEnable image generation
    dataAnalystbooleanNoEnable code interpreter
    inputTypestringNoInput type: "PROMPT" or "STRUCTURED"
    canvasbooleanNoEnable canvas
    extendedThinkingbooleanNoEnable extended thinking mode

    Array fields (actions, inputFields, conversationStarters, attachments) are replaced entirely, not merged. Always provide the complete desired array, including any existing items you want to keep.

    Actions Configuration

    Each action in the actions array should contain:

    • actionId (required) - UUID of the action from an enabled integration
    • requiresConfirmation (optional) - Whether to require user confirmation before executing (default: true)

    Input Fields Configuration

    For inputFields array structure, see the Create Agent API documentation.

    Examples

    Updating Basic Properties

    const axios = require("axios");
    
    async function updateAgentName() {
      const response = await axios.patch(
        "https://api.odeus.ai/agent/v1/update",
        {
          agentId: "550e8400-e29b-41d4-a716-446655440000",
          name: "Advanced Document Analyzer",
          description: "Analyzes documents with enhanced capabilities",
          creativity: 0.7
        },
        {
          headers: {
            Authorization: "Bearer YOUR_API_KEY",
            "Content-Type": "application/json"
          }
        }
      );
    
      console.log("Agent updated:", response.data.message);
    }
    

    Validation Rules

    The API enforces several validation rules:

    • Agent access - Your API key must have access to the agent
    • Workspace match - Agent must belong to the same workspace as your API key
    • Model - If provided, must be in your workspace's active models list
    • Actions - If provided, must belong to integrations enabled in your workspace
    • Attachments - If provided, must exist in your workspace and not be deleted
    • Name - If provided, must be between 1-80 characters
    • Description - If provided, maximum 500 characters
    • Instruction - If provided, maximum 40000 characters
    • Creativity - If provided, must be between 0 and 1

    Response Format

    Success Response (200 OK)

    {
      status: "success";
      message: "Agent updated successfully";
      agent: {
        id: string;
        name: string;
        description: string;
        instruction: string;
        emojiIcon: string;
        model: string;
        temperature: number;
        conversationStarters: string[];
        inputType: "PROMPT" | "STRUCTURED";
        webSearchEnabled: boolean;
        imageGenerationEnabled: boolean;
        codeInterpreterEnabled: boolean;
        canvasEnabled: boolean;
        extendedThinking: boolean;
        actions: Array<{
          actionId: string;
          requiresConfirmation: boolean;
        }>;
        inputFields: Array<{
          slug: string;
          type: string;
          label: string;
          description: string;
          required: boolean;
          order: number;
          options: string[];
          fileTypes: string[] | null;
          emailDomain: string | null;
        }>;
        attachments: string[];
        createdAt: string;
        updatedAt: string;
      };
    }
    

    Error Handling

    try {
      const response = await axios.patch('https://api.odeus.ai/agent/v1/update', ...);
    } catch (error) {
      if (error.response) {
        switch (error.response.status) {
          case 400:
            console.error('Invalid parameters or resource not found:', error.response.data.message);
            break;
          case 401:
            console.error('Invalid or missing API key');
            break;
          case 403:
            console.error('Insufficient permissions - no access to this agent');
            break;
          case 404:
            console.error('Agent not found or API key does not have access');
            break;
          case 429:
            console.error('Rate limit exceeded');
            break;
          case 500:
            console.error('Server error');
            break;
        }
      }
    }
    

    Best Practices

    Preserving existing values: When updating array fields like actions or attachments, always include existing items you want to keep, as the entire array is replaced.

    1. Fetch before update - If you need to preserve existing array values, fetch the current agent configuration first
    2. Incremental updates - Update only the fields that need to change
    3. Validate attachments - Ensure attachment UUIDs are valid before including them
    4. Test actions - Verify actions belong to enabled integrations before updating
    5. Handle errors gracefully - Implement proper error handling for validation failures

    Odeus intentionally blocks browser-origin requests to protect your API key and ensure your applications remain secure. For more information, please see our guide on API Key Best Practices.

    OpenAPI

    openapi: 3.0.0
    info:
      title: Odeus API
      version: 3.0.0
    servers:
      - url: https://api.odeus.ai
    security:
      - bearerAuth: []
    paths:
      /agent/v1/update:
        patch:
          tags:
            - Agent Build
          summary: Updates an existing agent
          description: Updates an existing agent in your workspace.
          operationId: updateAgentV2
          requestBody:
            required: true
            content:
              application/json:
                schema:
                  allOf:
                    - type: object
                      required:
                        - agentId
                      properties:
                        agentId:
                          type: string
                          format: uuid
                    - $ref: '#/components/schemas/Assistant'
          responses:
            '200':
              description: Agent updated successfully
    components:
      schemas:
        Assistant:
          type: object
          required:
            - name
            - instructions
          properties:
            name:
              type: string
              maxLength: 64
            description:
              type: string
              maxLength: 256
            instructions:
              type: string
              maxLength: 16384
            temperature:
              type: number
              minimum: 0
              maximum: 1
            model:
              type: string
              maxLength: 64
            capabilities:
              type: object
              properties:
                webSearch:
                  type: boolean
                dataAnalyst:
                  type: boolean
                imageGeneration:
                  type: boolean
            actions:
              type: array
              items: fcf0fd67-fd0e-4a00-b735-68e73c7eacb2
            vectorDb:
              type: array
              items: f0c033f7-804b-4122-8a48-a9c1f45fd570
            knowledgeFolderIds:
              type: array
              items:
                type: string
            attachmentIds:
              type: array
              items:
                type: string
                format: uuid
              description: Array of UUID strings identifying attachments for this message
      securitySchemes:
        bearerAuth:
          type: http
          scheme: bearer
          bearerFormat: API Key
          description: API key as Bearer token. Format "Bearer YOUR_API_KEY"