Skip to main content
POST
/
chat
/
completions
Create chat completion
const options = {
  method: 'POST',
  headers: {Authorization: 'Bearer <token>', 'Content-Type': 'application/json'},
  body: JSON.stringify({
    model: 'openai/gpt-5-nano',
    stream: false,
    messages: [{role: 'user', content: 'What is the current datetime in Europe/London?'}],
    tools: [{type: 'gateway:datetime', parameters: {timezone: 'Europe/London'}}],
    tool_choice: 'auto'
  })
};

fetch('https://api.phaseo.app/v1/chat/completions', options)
  .then(res => res.json())
  .then(res => console.log(res))
  .catch(err => console.error(err));
{
  "id": "<string>",
  "object": "<string>",
  "created": 123,
  "model": "<string>",
  "choices": [
    {
      "index": 123,
      "message": {
        "role": "system",
        "content": "<string>",
        "name": "<string>",
        "tool_calls": [
          {
            "id": "<string>",
            "type": "function",
            "function": {
              "name": "<string>",
              "arguments": "<string>",
              "description": "<string>",
              "parameters": {}
            }
          }
        ],
        "images": [
          {
            "type": "image_url",
            "image_url": {
              "url": "<string>"
            },
            "mime_type": "<string>"
          }
        ],
        "audios": [
          {
            "type": "audio_url",
            "audio_url": {
              "url": "<string>"
            },
            "mime_type": "<string>",
            "format": "wav"
          }
        ],
        "tool_call_id": "<string>"
      },
      "finish_reason": "stop"
    }
  ],
  "usage": {
    "prompt_tokens": 123,
    "completion_tokens": 123,
    "total_tokens": 123,
    "server_tool_use": {
      "datetime_requests": 1
    }
  }
}

Server tools

/v1/chat/completions supports regular function tools and one gateway-managed server tool:
  • gateway:datetime
Web-search tool types are temporarily disabled at the gateway request layer.

Datetime example

curl https://api.phaseo.app/v1/chat/completions \
  -H "Authorization: Bearer YOUR_API_KEY" \
  -H "Content-Type: application/json" \
  -d '{
    "model": "openai/gpt-5-nano",
    "stream": false,
    "messages": [
      { "role": "user", "content": "What is the current datetime in Europe/London?" }
    ],
    "tools": [
      {
        "type": "gateway:datetime",
        "parameters": { "timezone": "Europe/London" }
      }
    ],
    "tool_choice": "auto"
  }'
When a server tool is used, usage includes:
{
  "usage": {
    "prompt_tokens": 12,
    "completion_tokens": 34,
    "total_tokens": 46,
    "server_tool_use": {
      "datetime_requests": 1
    }
  }
}
Use stream: false when tools are present.

Authorizations

Authorization
string
header
required

Bearer token authentication

Body

application/json
model
string
required
messages
object[]
required
Minimum array length: 1
reasoning
object
frequency_penalty
number
Required range: -2 <= x <= 2
logit_bias
object
max_completion_tokens
integer
Required range: x >= 1
max_tokens
integer
Required range: x >= 1
metadata
object
presence_penalty
number
Required range: -2 <= x <= 2
seed
integer
Required range: -9223372036854776000 <= x <= 9223372036854776000
store
boolean
stream
boolean
default:false
stream_options
object
temperature
number
default:1
Required range: 0 <= x <= 2
tools
object[]

Tool definitions for model function calls and gateway server tools. The only built-in gateway server tool is gateway:datetime. Web-search tool types (for example web_search_preview) are temporarily disabled by the gateway.

max_tool_calls
integer
Required range: x >= 1
parallel_tool_calls
boolean
default:true
tool_choice

Tool selection strategy. gateway:datetime is accepted and rewritten by the gateway into an upstream function/tool target.

Available options:
auto,
none,
required,
gateway:datetime
logprobs
boolean
default:false
top_logprobs
integer
Required range: 0 <= x <= 20
top_p
number
Required range: 0 <= x <= 1
stop
response_format
modalities
enum<string>[]
Available options:
text,
image,
audio
image_config
object
usage
boolean
provider
object

Provider routing preferences for gateway selection.

provider_options
object

Optional provider-specific options.

user_id
string
user
string
service_tier
enum<string>
Available options:
auto,
default,
flex,
standard,
priority
prompt_cache_key
string | null
safety_identifier
string | null
meta
boolean
default:false
echo_upstream_request
boolean
debug
object

Gateway debug controls. These flags are never forwarded upstream.

Response

200 - application/json

Chat completion response

id
string
object
string
created
integer
model
string
choices
object[]
usage
object
Last modified on April 1, 2026