Skip to main content

Shared Chat Messages Endpoint

Overview

This endpoint retrieves messages from a shared chat conversation. It supports password protection and whitelist-based access control.

Request Details

HTTP Method

GET

Route

/api/shared/chats/[uuid]

Route Parameters

ParameterTypeRequiredDescription
uuidstringYesUnique identifier of the shared chat

Headers

HeaderValueRequiredDescription
Content-Typeapplication/jsonYesIndicates JSON request body
Cookieneptun-sessionNoSession authentication cookie

Query Parameters

No query parameters required.

Request Body

No request body required.

Response Format

Response Status Codes

Status CodeDescription
200Successfully retrieved chat messages
401Unauthorized (missing or invalid password)
403Forbidden (not on whitelist)
404Share not found
500Server error

Success Response (200 OK)

{
"chatMessages": [
{
"id": 123,
"content": "Hello world",
"role": "user",
"timestamp": "2024-03-20T10:30:00Z"
}
],
"shareInfo": {
"shareExists": true,
"shareIsPrivate": true,
"shareHasPassword": true,
"shareHasWhitelist": false
}
}

Error Responses

Not Found (404)

{
"statusCode": 404,
"statusMessage": "Not Found (share not found)",
"message": "The share does not exist.",
"data": {
"shareInfo": {
"shareExists": false,
"shareIsPrivate": false,
"shareHasPassword": false,
"shareHasWhitelist": false
}
}
}

Unauthorized (401)

{
"statusCode": 401,
"statusMessage": "Unauthorized (incorrect credentials)",
"message": "You are not authorized to view this chat.",
"data": {
"shareInfo": {
"shareExists": true,
"shareIsPrivate": true,
"shareHasPassword": true,
"shareHasWhitelist": false
}
}
}

TypeScript Interface

interface ChatMessage {
id: number
content: string
role: 'user' | 'assistant'
created_at: string
updated_at: string
}

interface ShareInfo {
shareExists: boolean
shareIsActive: boolean
shareIsPrivate: boolean
shareHasPassword: boolean
shareHasWhitelist: boolean
}

interface SharedChatResponse {
chatMessages: ChatMessage[]
shareInfo: ShareInfo
}

interface SharedChatError {
statusCode: number
statusMessage: string
message: string
data: {
shareInfo: ShareInfo
}
}

Python Model

from pydantic import BaseModel
from typing import List
from datetime import datetime

class ChatMessage(BaseModel):
id: int
content: str
role: Literal['user', 'assistant']
created_at: datetime
updated_at: datetime

class ShareInfo(BaseModel):
shareExists: bool
shareIsActive: bool
shareIsPrivate: bool
shareHasPassword: bool
shareHasWhitelist: bool

class SharedChatResponse(BaseModel):
chatMessages: List[ChatMessage]
shareInfo: ShareInfo

class SharedChatError(BaseModel):
statusCode: int
statusMessage: str
message: str
data: dict[str, ShareInfo]

Code Examples

cURL Example

curl -X GET "https://neptun-webui.vercel.app/api/shared/chats/your-uuid-here" \
-H "Cookie: neptun-session=your-session-cookie"

Python Example

from pydantic import BaseModel
import httpx
from typing import List
from datetime import datetime

async def get_shared_chat(
uuid: str,
session_cookie: str
) -> SharedChatResponse:
async with httpx.AsyncClient() as client:
response = await client.get(
f"https://neptun-webui.vercel.app/api/shared/chats/{uuid}",
cookies={"neptun-session": session_cookie}
)
response.raise_for_status()
return SharedChatResponse(**response.json())

TypeScript/JavaScript Example

async function getSharedChat(uuid: string): Promise<SharedChatResponse> {
const response = await fetch(
`https://neptun-webui.vercel.app/api/shared/chats/${uuid}`,
{
credentials: 'include', // Important for cookie handling
}
)

if (!response.ok) {
throw new Error(`HTTP error! status: ${response.status}`)
}

return await response.json() as SharedChatResponse
}

Notes

  • The endpoint supports both password-protected and whitelist-based access control
  • The shareInfo object provides information about the share's protection status
  • Session cookie is required for authentication if the share is protected
  • Error responses include detailed share information for better error handling