ai.post_prompt_url
The URL that the user defines to which to send status callbacks and reports.
| Name | Type | Default | Description | 
|---|---|---|---|
| post_prompt_urlOptional | string | - | The URL to which to send status callbacks and reports. Authentication can also be set in the url in the format of username:password@url. | 
Request Parameters for post_prompt_url
SignalWire will make a request to the post_prompt_url with the following parameters:
| Name | Type | Description | 
|---|---|---|
| action | string | Action that prompted this request. The value will be "post_conversation". | 
| ai_end_date | integer | Timestamp indicating when the AI session ended. | 
| ai_session_id | string | A unique identifier for the AI session. | 
| ai_start_date | integer | Timestamp indicating when the AI session started. | 
| app_name | string | Name of the application that originated the request. | 
| call_answer_date | integer | Timestamp indicating when the call was answered. | 
| call_end_date | integer | Timestamp indicating when the call ended. | 
| call_id | string | ID of the call. | 
| call_log | object | The complete log of the call, as a JSON object. | 
| call_log.content | string | Content of the call log entry. | 
| call_log.role | string | Role associated with the call log entry (e.g., "system", "assistant", "user"). | 
| call_start_date | integer | Timestamp indicating when the call started. | 
| caller_id_name | string | Name associated with the caller ID. | 
| caller_id_number | string | Number associated with the caller ID. | 
| content_disposition | string | Disposition of the content. | 
| content_type | string | Type of content. The value will be text/swaig. | 
| post_prompt_data | object | The answer from the AI agent to the post_prompt. The object contains the three following fields. | 
| post_prompt_data.parsed | object | If a JSON object is detected within the answer, it is parsed and provided here. | 
| post_prompt_data.raw | string | The raw data answer from the AI agent. | 
| post_prompt_data.substituted | string | The answer from the AI agent, excluding any JSON. | 
| project_id | string | ID of the Project. | 
| space_id | string | ID of the Space. | 
| SWMLVars | object | A collection of variables related to SWML. | 
| swaig_log | object | A log related to SWAIG functions. | 
| total_input_tokens | integer | Represents the total number of input tokens. | 
| total_output_tokens | integer | Represents the total number of output tokens. | 
| version | string | Version number. | 
Post Prompt Callback Request Example
Below is a json example of the callback request that is sent to the post_prompt_url:
{
  "total_output_tokens": 119,
  "caller_id_name": "[CALLER_NAME]",
  "SWMLVars": {
    "ai_result": "success",
    "answer_result": "success"
  },
  "call_start_date": 1694541295773508,
  "project_id": "[PROJECT_ID]",
  "call_log": [
    {
      "content": "[AI INITIAL PROMPT/INSTRUCTIONS]",
      "role": "system"
    },
    {
      "content": "[AI RESPONSE]",
      "role": "assistant"
    },
    {
      "content": "[USER RESPONSE]",
      "role": "user"
    }
  ],
  "ai_start_date": 1694541297950440,
  "call_answer_date": 1694541296799504,
  "version": "2.0",
  "content_disposition": "Conversation Log",
  "conversation_id": "[CONVERSATION_ID]",
  "space_id": "[SPACE_ID]",
  "app_name": "swml app",
  "swaig_log": [
    {
      "post_data": {
        "content_disposition": "SWAIG Function",
        "conversation_id": "[CONVERSATION_ID]",
        "space_id": "[SPACE_ID]",
        "meta_data_token": "[META_DATA_TOKEN]",
        "app_name": "swml app",
        "meta_data": {},
        "argument": {
          "raw": "{\n  \"target\": \"[TRANSFER_TARGET]\"\n}",
          "substituted": "",
          "parsed": [
            {
              "target": "[TRANSFER_TARGET]"
            }
          ]
        },
        "call_id": "[CALL_ID]",
        "content_type": "text/swaig",
        "ai_session_id": "[AI_SESSION_ID]",
        "caller_id_num": "[CALLER_NUMBER]",
        "caller_id_name": "[CALLER_NAME]",
        "project_id": "[PROJECT_ID]",
        "purpose": "Use to transfer to a target",
        "argument_desc": {
          "type": "object",
          "properties": {
            "target": {
              "description": "the target to transfer to",
              "type": "string"
            }
          }
        },
        "function": "transfer",
        "version": "2.0"
      },
      "command_name": "transfer",
      "epoch_time": 1694541334,
      "command_arg": "{\n  \"target\": \"[TRANSFER_TARGET]\"\n}",
      "url": "https://example.com/here",
      "post_response": {
        "action": [
          {
            "say": "This is a say message!"
          },
          {
            "SWML": {
              "sections": {
                "main": [
                  {
                    "connect": {
                      "to": "+1XXXXXXXXXX"
                    }
                  }
                ]
              },
              "version": "1.0.0"
            }
          },
          {
            "stop": true
          }
        ],
        "response": "transferred to [TRANSFER_TARGET], the call has ended"
      }
    }
  ],
  "total_input_tokens": 5627,
  "caller_id_num": "[CALLER_NUMBER]",
  "call_id": "[CALL_ID]",
  "call_end_date": 1694541335435503,
  "content_type": "text/swaig",
  "action": "post_conversation",
  "post_prompt_data": {
    "substituted": "[SUMMARY_MESSAGE_PLACEHOLDER]",
    "parsed": [],
    "raw": "[SUMMARY_MESSAGE_PLACEHOLDER]"
  },
  "ai_end_date": 1694541335425164,
  "ai_session_id": "[AI_SESSION_ID]"
}
Responding to Post Prompt Requests
The response to the callback request should be a JSON object with the following parameters:
{
  "response": "ok"
}