Zum Hauptinhalt springen
POST
/
v3
/
organizations
/
{org_id}
/
sessions
Session erstellen
curl --request POST \
  --url https://api.devin.ai/v3/organizations/{org_id}/sessions \
  --header 'Authorization: Bearer <token>' \
  --header 'Content-Type: application/json' \
  --data '
{
  "prompt": "<string>",
  "advanced_mode": "analyze",
  "attachment_urls": [
    "<string>"
  ],
  "bypass_approval": true,
  "child_playbook_id": "<string>",
  "create_as_user_id": "<string>",
  "knowledge_ids": [
    "<string>"
  ],
  "max_acu_limit": 123,
  "playbook_id": "<string>",
  "repos": [
    "<string>"
  ],
  "secret_ids": [
    "<string>"
  ],
  "session_links": [
    "<string>"
  ],
  "session_secrets": [
    {
      "key": "<string>",
      "value": "<string>",
      "sensitive": true
    }
  ],
  "structured_output_schema": {},
  "tags": [
    "<string>"
  ],
  "title": "<string>"
}
'
{
  "acus_consumed": 123,
  "created_at": 123,
  "org_id": "<string>",
  "pull_requests": [
    {
      "pr_state": "<string>",
      "pr_url": "<string>"
    }
  ],
  "session_id": "<string>",
  "status": "new",
  "tags": [
    "<string>"
  ],
  "updated_at": 123,
  "url": "<string>",
  "child_session_ids": [
    "<string>"
  ],
  "is_advanced": false,
  "is_archived": false,
  "parent_session_id": "<string>",
  "playbook_id": "<string>",
  "service_user_id": "<string>",
  "status_detail": "working",
  "structured_output": {},
  "title": "<string>",
  "user_id": "<string>"
}

Berechtigungen

Erfordert einen Servicebenutzer mit der Berechtigung ManageOrgSessions auf Organisationsebene.

Zusätzliche Berechtigungen für erweiterte Funktionen

FunktionErforderliche Berechtigung
advanced_modeUseDevinExpert
create_as_user_idImpersonateOrgSessions

Erweiterter Modus

Der Parameter advanced_mode aktiviert spezielles Sitzungsverhalten für Automatisierungs-Workflows. Ist er aktiviert, verwendet die Sitzung die erweiterte Persona und der Prompt wird abhängig vom ausgewählten Modus angepasst.

Verfügbare Modi

ModusBeschreibungErforderliche Parameter
analyzeBestehende Devin-Sessions analysieren, um Erkenntnisse zu gewinnensession_links
createEin neues Playbook auf Basis einer Session-Analyse erstellenKeine (optional: session_links)
improveEin bestehendes Playbook auf Basis von Feedback verbessernchild_playbook_id
batchMehrere Devin-Sessions für eine Aufgabenliste startenchild_playbook_id
manageKnowledge verwaltenKeine

Optionen für den Batch-Modus

Wenn Sie den batch-Modus verwenden, können Sie optional bypass_approval auf true setzen, um den Genehmigungsschritt bei der Erstellung von Batch-Sitzungen zu überspringen. Das ist hilfreich für vollständig automatisierte Workflows, in denen Sitzungen ohne manuelle Genehmigung sofort gestartet werden sollen.

Nutzer-Impersonation

Der Parameter create_as_user_id ermöglicht das Erstellen einer Sitzung im Namen eines anderen Nutzers. Dafür ist Folgendes erforderlich:
  1. Der Servicebenutzer muss die Berechtigung ImpersonateOrgSessions haben
  2. Der Zielnutzer muss Mitglied der Organisation sein
  3. Der Zielnutzer muss die Berechtigung UseDevinSessions haben

Autorisierungen

Authorization
string
header
erforderlich

Servicebenutzer-Anmeldedaten (Präfix: cog_)

Body

application/json
prompt
string
erforderlich
advanced_mode
enum<string> | null
Verfügbare Optionen:
analyze,
create,
improve,
batch,
manage
attachment_urls
string<uri>[] | null
Required string length: 1 - 2083
bypass_approval
boolean | null
child_playbook_id
string | null
create_as_user_id
string | null
knowledge_ids
string[] | null
max_acu_limit
integer | null
playbook_id
string | null
repos
string[] | null
secret_ids
string[] | null
session_secrets
SessionSecretInput · object[] | null
structured_output_schema
Structured Output Schema · object

JSON-Schema (Draft 7) zur Validierung strukturierter Ausgaben. Max. 64 KB. Muss in sich abgeschlossen sein (keine externen $ref-Verweise).

tags
string[] | null
title
string | null

Antwort

Erfolgreiche Antwort

acus_consumed
number
erforderlich
created_at
integer
erforderlich
org_id
string
erforderlich
pull_requests
SessionPullRequest · object[]
erforderlich
session_id
string
erforderlich
status
enum<string>
erforderlich
Verfügbare Optionen:
new,
claimed,
running,
exit,
error,
suspended,
resuming
tags
string[]
erforderlich
updated_at
integer
erforderlich
url
string
erforderlich
child_session_ids
string[] | null
is_advanced
boolean
Standard:false
is_archived
boolean
Standard:false
parent_session_id
string | null
playbook_id
string | null
service_user_id
string | null
status_detail
enum<string> | null

Zusätzliche Details zum aktuellen Sitzungsstatus. Wenn der Status „running“ ist: „working“ (arbeitet aktiv), „waiting_for_user“ (wartet auf Benutzereingaben), „waiting_for_approval“ (wartet im Safe Mode auf die Genehmigung einer Aktion) oder „finished“ (Aufgabe abgeschlossen). Wenn der Status „suspended“ ist: der Grund für die Aussetzung, z. B. „inactivity“, „user_request“, „usage_limit_exceeded“, „out_of_credits“, „payment_declined“, „org_usage_limit_exceeded“ oder „error“. Wird nur bei GET-/List-Endpunkten gesetzt.

Verfügbare Optionen:
working,
waiting_for_user,
waiting_for_approval,
finished,
inactivity,
user_request,
usage_limit_exceeded,
out_of_credits,
payment_declined,
org_usage_limit_exceeded,
error
structured_output
Structured Output · object

Validierte strukturierte Ausgabe aus der Session. Wird nur bei GET-/LIST-Endpunkten befüllt.

title
string | null
user_id
string | null