API Reference¶
LLM API¶
Completions¶
An ordinary request¶
POST /v1/chat/completions
Content-Type: application/json
Authorization: Bearer br_xxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
{
"model": "claude-3-sonnet",
"messages": [
{
"role": "user",
"content": "ping"
}
],
"stream": true,
"temperature": 1,
"max_tokens": 4096
}
Including a picture in the request¶
POST /v1/chat/completions
Content-Type: application/json
Authorization: Bearer br_xxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
{
"model": "claude-3-sonnet",
"messages": [
{
"role": "user",
"content": [
{
"type":"text":
"text":"Describe this picture."
},
{
"type": "image_url",
"image_url": {
"url": "data:image/webp;base64,...."
}
}
]
}
]
}
- image url can be a base64 string or a http(s) url.
Including a docuement in the request¶
POST /v1/chat/completions
Content-Type: application/json
Authorization: Bearer br_xxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
{
"model": "claude-3-sonnet",
"messages": [
{
"role": "user",
"content": [
{
"type":"text":
"text":"Describe this document."
},
{
"type":"doc",
"doc": {
"name": "xxx",
"format": "pdf",
"size": 900,
"source": {
"bytes": {
0:35,1:35,2:37,...
}
}
}
}
]
}
]
}
Function calling (tool use)¶
POST /v1/chat/completions
Content-Type: application/json
Authorization: Bearer br_xxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
{
"model": "claude-3-sonnet",
"tools": [
{
"type": "function",
"function": {
"name": "bookFlight",
"description": "Book a flight",
"parameters": {
"type": "object",
"departure": {
"type": "string",
"description": "departure airport"
},
"arrival": {
"type": "string",
"description": "arrival airport"
},
"departureDate": {
"type": "string",
"description": "departure time"
}
},
"required": [
"departure",
"arrival",
"departureDate"
]
}
}
],
"tool_choice": "auto",
"messages": [
{
"role": "system",
"content": "You are an experienced business ticket agent, and your role is to help corporate customers purchase tickets. Current time: 2024-11-13T08:13:17.778Z."
},
{
"role": "user",
"content": "I would like to book a ticket to New York tomorrow.\n Required parameters are:\n\n \ndeparture: \narrival: \ndepartureDate: \n\n"
}
]
}
Embeddings¶
POST {{hostLocal}}/v1/embeddings
Content-Type: application/json
Authorization: Bearer br_xxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
{
"model": "your-embedding-model",
"input": "Hello world."
}
List models¶
Admin API¶
API key¶
Create an api key¶
POST /admin/api-key/apply
Content-Type: application/json
Authorization: Bearer br_xxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
{
"name": "jack",
"group_id": 1,
"role": "user",
"email": "",
"month_quota": 1.00
}
Create an api key with admin role¶
POST /admin/api-key/apply
Content-Type: application/json
Authorization: Bearer br_xxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
{
"name": "rob",
"group_id": 1,
"role": "admin",
"email": ""
}
Update and api key’s info¶
POST /admin/api-key/update
Content-Type: application/json
Authorization: Bearer br_xxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
{
"id": 2,
"name": "jack",
"month_quota": 10.00
}
Recharge up an API key¶
POST /admin/api-key/recharge
Content-Type: application/json
Authorization: Bearer br_xxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
{
"api_key": "br-xxxxxxxxxxxxxxx",
"balance": 0.23
}
Recharge history¶
List api keys¶
GET /admin/api-key/list?q=&name=&group_id=&role=&limit=10&offset=
Authorization: Bearer br_xxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
Delete an api key¶
POST /admin/api-key/delete
Content-Type: application/json
Authorization: Bearer br_xxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
{
"id": 1
}
Model¶
List models¶
Create a model¶
POST /admin/model/save
Content-Type: application/json
Authorization: Bearer br_xxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
{
"name": "xxxx",
"group_id": 1,
"multiple": false,
"config": "{\"modelId\": \"somevalue\"}",
"provider": "bedrock-converse",
"price_in": 1,
"price_out":3
}
Update a model¶
POST /admin/model/save
Content-Type: application/json
Authorization: Bearer br_xxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
{
"id": 1,
"name": "xxxx",
"group_id": 1,
"multiple": false,
"config": "{\"modelId\": \"somevalue\"}",
"provider": "bedrock-converse",
"price_in": 1,
"price_out":3
}
Delete a model¶
POST /admin/model/delete
Content-Type: application/json
Authorization: Bearer br_xxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
{
"id": 1
}
Webhook¶
List webhook¶
GET /admin/bot/feishu/list?q=&limit=10&offset=
Authorization: Bearer br_xxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
Create a webhook¶
POST /admin/bot/feishu/save
Content-Type: application/json
Authorization: Bearer br_xxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
{
"name": "xxxx",
"config": "{\"appId\": \"cli_xxxxx\", \"apiKey\": \"br-xxxxx\", \"modelId\": \"claude-3-sonnet\", \"appSecret\": \"xxxxx\" }",
"provider": "bedrock-converse"
}
Update a webhook¶
POST /admin/bot/feishu/save
Content-Type: application/json
Authorization: Bearer br_xxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
{
"appId": "cli_xxxxx",
"apiKey": "br-xxxxx",
"modelId": "claude-3-sonnet",
"appSecret": "xxxxx"
}
Delete a webhook¶
POST /admin/bot/feishu/delete
Content-Type: application/json
Authorization: Bearer br_xxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
{
"id": 1
}
Group¶
List groups¶
Delete a group¶
POST /admin/group/delete
Content-Type: application/json
Authorization: Bearer br_xxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
{
"id": 1
}
Model Authorization¶
- List models of a group
- Authorize the model to a group
- Deauthorize the model from a group
- List models of an api key
- Authorize the model to an api key
- Deauthorize the model from an api key
Chat records¶
List sessions¶
GET /admin/session/list?q=&limit=10&offset=&key_id=
Authorization: Bearer br_xxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
List threads / histories
GET /admin/thread/list?q=&limit=10&offset=&key_id=&session_id=
Authorization: Bearer br_xxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
User API¶
My sessions¶
My session detail¶
My threads / histories¶
GET /user/thread/list?q=&limit=10&offset=&session_id=
Authorization: Bearer br_xxxxxxxxxxxxxxxxxxxxxxxxxxxxxx