multimodal/tarko/agent-server/README.md
Standard server implementation for deploying Tarko AI Agents as HTTP/WebSocket services.
Agent Server transforms any Tarko agent into a scalable web service with session management, real-time streaming, workspace isolation, and persistent storage.
npm install @tarko/agent-server
import { AgentServer } from '@tarko/agent-server';
const server = new AgentServer({
appConfig: {
agent: 'my-agent',
workspace: './workspace',
server: { port: 3000 },
model: {
provider: 'openai',
id: 'gpt-4'
}
}
});
await server.start();
console.log('Agent server running on port 3000');
Create isolated agent sessions with persistent state and workspace isolation.
Support both real-time streaming responses and traditional request-response patterns.
Choose from memory, file, or sqlite storage backends for session persistence.
Real-time bidirectional communication with automatic session reconnection.
Secure file access with session-scoped workspace management.
Built-in analytics and monitoring integration for production deployments.
Generate shareable session links with workspace asset uploading.
āāāāāāāāāāāāāāāāāāā āāāāāāāāāāāāāāāāāāāā āāāāāāāāāāāāāāāāāāā
ā HTTP Client ā ā WebSocket ā ā Agent Core ā
ā āāāāāŗā Client āāāāāŗā ā
āāāāāāāāāāāāāāāāāāā āāāāāāāāāāāāāāāāāāāā āāāāāāāāāāāāāāāāāāā
ā ā ā
ā¼ ā¼ ā¼
āāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāā
ā AgentServer ā
āāāāāāāāāāāāāāāāāāā¬āāāāāāāāāāāāāāāāāāāā¬āāāāāāāāāāāāāāāāāāāāāāāāāāāā¤
ā Session Mgmt ā EventStreamBridge ā Storage Provider ā
ā ā ā ā
ā ⢠Create ā ⢠Real-time ā ⢠Memory/File/SQLite ā
ā ⢠Update ā ⢠Event filtering ā ⢠Session persistence ā
ā ⢠Delete ā ⢠Client sync ā ⢠Event streaming ā
ā ⢠Restore ā ā ā
āāāāāāāāāāāāāāāāāāā“āāāāāāāāāāāāāāāāāāāā“āāāāāāāāāāāāāāāāāāāāāāāāāāāā
POST /api/v1/sessions/create
Response: { sessionId: string }
GET /api/v1/sessions
Response: { sessions: SessionItemInfo[] }
GET /api/v1/sessions/details?sessionId={id}
Response: { session: SessionItemInfo & { active: boolean } }
POST /api/v1/sessions/query
Content-Type: application/json
{
"sessionId": "session_123",
"query": "What files are in my workspace?"
}
Response: { result: string }
POST /api/v1/sessions/query/stream
Content-Type: application/json
{
"sessionId": "session_123",
"query": "Generate a detailed report"
}
Response: Server-Sent Events stream
POST /api/v1/oneshot/query
Content-Type: application/json
{
"query": "Quick analysis",
"sessionName": "Analysis Session",
"sessionTags": ["analysis", "quick"]
}
Response: { sessionId: string, result: string }
POST /api/v1/sessions/abort
Content-Type: application/json
{ "sessionId": "session_123" }
POST /api/v1/sessions/update
Content-Type: application/json
{
"sessionId": "session_123",
"name": "Updated Session Name",
"tags": ["updated", "important"]
}
POST /api/v1/sessions/delete
Content-Type: application/json
{ "sessionId": "session_123" }
const socket = io('http://localhost:3000');
// Join a session
socket.emit('join-session', { sessionId: 'session_123' });
// Send query
socket.emit('send-query', {
sessionId: 'session_123',
query: 'Hello agent'
});
// Listen for agent events
socket.on('agent-event', (event) => {
console.log('Agent event:', event);
});
const server = new AgentServer({
appConfig: {
agent: 'my-agent', // Agent implementation
workspace: './workspace', // Workspace directory
server: {
port: 3000, // Server port
exclusive: false, // Single session mode
storage: {
type: 'sqlite', // Storage backend
path: './sessions.db' // Storage path
}
},
model: {
provider: 'openai', // Model provider
id: 'gpt-4', // Model ID
}
}
});
storage: { type: 'memory' }
storage: {
type: 'file',
path: './data/sessions' // Directory for session files
}
storage: {
type: 'sqlite',
path: './sessions.db' // SQLite database file
}
appConfig: {
agio: {
provider: 'https://agio.example.com/api/events'
}
}
appConfig: {
share: {
provider: 'https://share.example.com/api/upload'
},
webui: {
type: 'static',
staticPath: './dist/webui'
}
}
FROM node:18-alpine
WORKDIR /app
COPY package*.json ./
RUN npm ci --only=production
COPY . .
EXPOSE 3000
CMD ["node", "dist/server.js"]
PORT=3000
WORKSPACE_PATH=/app/workspace
STORAGE_TYPE=sqlite
STORAGE_PATH=/app/data/sessions.db
MODEL_PROVIDER=openai
MODEL_ID=gpt-4
OPENAI_API_KEY=your-api-key
GET /api/v1/system/health
Response:
{
"status": "healthy",
"version": "0.3.0",
"uptime": 3600,
"sessions": {
"active": 5,
"total": 127
},
"storage": {
"type": "sqlite",
"path": "/app/data/sessions.db"
}
}
Limit server to handle one session at a time:
server: { exclusive: true }
Access session workspace files:
GET /api/v1/sessions/workspace/files?sessionId=session_123&path=/images
Restore sessions from storage:
POST /api/v1/sessions/restore
Content-Type: application/json
{ "sessionId": "session_123" }
Sessions can override default model settings:
POST /api/v1/sessions/update
Content-Type: application/json
{
"sessionId": "session_123",
"metadata": {
"modelConfig": {
"provider": "anthropic",
"modelId": "claude-3-opus"
}
}
}
All API endpoints return structured error responses:
{
"error": "Session not found",
"code": "SESSION_NOT_FOUND",
"message": "Session session_123 does not exist",
"details": {
"sessionId": "session_123",
"timestamp": 1704067200000
}
}
# Create session
curl -X POST http://localhost:3000/api/v1/sessions/create
# ā {"sessionId":"abc123"}
# Send query
curl -X POST http://localhost:3000/api/v1/sessions/query \
-H "Content-Type: application/json" \
-d '{"sessionId":"abc123","query":"Hello!"}'
# Stream query
curl -X POST http://localhost:3000/api/v1/sessions/query/stream \
-H "Content-Type: application/json" \
-d '{"sessionId":"abc123","query":"Tell me a story"}'
import io from 'socket.io-client';
const socket = io('http://localhost:3000');
socket.emit('join-session', { sessionId: 'abc123' });
socket.emit('send-query', {
sessionId: 'abc123',
query: 'What can you help me with?'
});
socket.on('agent-event', (event) => {
if (event.type === 'assistant_message') {
console.log('Agent response:', event.content);
}
});
Port already in use
lsof -ti:3000 | xargs kill -9
Storage permission errors
chmod 755 ./data
chown -R node:node ./data
Agent resolution failed
appConfig: {
logLevel: LogLevel.DEBUG
}
Enable request logging:
app.use(express.logger('combined'));
Apache-2.0