@robota-sdk/sessions
v2.0.9
Published
Session and chat management for Robota SDK - multi-session support with independent workspaces
Maintainers
Readme
@robota-sdk/sessions
Multi-session support with independent workspaces for AI agents
The sessions package provides a clean way to manage multiple independent AI agents across different workspaces. Think of it as a container that lets you run multiple AI conversations simultaneously while keeping them completely isolated from each other.
🎯 Core Purpose
The sessions package is designed for managing multiple independent AI agents in isolated workspaces:
- SessionManager: Manages multiple sessions (workspaces)
- ChatInstance: Simple wrapper around individual Robota agents
- Workspace Isolation: Each session operates in its own memory space
- Agent Switching: Easy switching between different AI agents
- Template Integration: Uses AgentFactory and AgentTemplates from the agents package
🚀 Quick Start
import { SessionManager } from '@robota-sdk/sessions';
import { OpenAIProvider } from '@robota-sdk/openai';
// Create a session manager
const sessionManager = new SessionManager({
maxSessions: 10,
maxChatsPerSession: 5,
enableWorkspaceIsolation: true,
});
// Create a session (workspace)
const sessionId = sessionManager.createSession({
name: 'Development Workspace',
userId: 'developer-123',
workspaceId: 'workspace-dev',
});
// Create an AI agent in the session
const chatId = await sessionManager.createChat(sessionId, {
name: 'Coding Assistant',
agentConfig: {
name: 'Coding Assistant',
aiProviders: [new OpenAIProvider({ apiKey: 'your-key' })],
defaultModel: {
provider: 'openai',
model: 'gpt-4',
systemMessage: 'You are a helpful coding assistant.',
},
},
});
// Switch to the agent and start chatting
sessionManager.switchChat(sessionId, chatId);
const chat = sessionManager.getChat(chatId);
const response = await chat.sendMessage('Hello! Can you help me with TypeScript?');📋 Key Features
1. Multiple Sessions (Workspaces)
Each session is an isolated workspace that can contain multiple AI agents:
// Create different workspaces for different purposes
const devSession = sessionManager.createSession({
name: 'Development',
workspaceId: 'workspace-dev',
});
const researchSession = sessionManager.createSession({
name: 'Research',
workspaceId: 'workspace-research',
});2. Multiple AI Agents per Session
Each session can have multiple specialized AI agents:
// Create specialized agents in the same session
const codingAssistant = await sessionManager.createChat(devSession, {
name: 'Coding Assistant',
agentConfig: { /* coding-focused config */ },
});
const reviewAssistant = await sessionManager.createChat(devSession, {
name: 'Code Review Assistant',
agentConfig: { /* review-focused config */ },
});3. Agent Switching
Easily switch between different agents within a session:
// Switch to coding assistant
sessionManager.switchChat(devSession, codingAssistant);
// Switch to review assistant
sessionManager.switchChat(devSession, reviewAssistant);4. Workspace Isolation
Each session operates independently with its own memory space:
// Agents in different sessions don't interfere with each other
const session1 = sessionManager.createSession({ workspaceId: 'workspace-1' });
const session2 = sessionManager.createSession({ workspaceId: 'workspace-2' });
// These agents are completely isolated
const agent1 = await sessionManager.createChat(session1, config);
const agent2 = await sessionManager.createChat(session2, config);🏗️ Architecture
The sessions package follows a clean, simplified architecture:
SessionManager
├── Session 1 (Workspace)
│ ├── ChatInstance 1 (Robota Agent)
│ ├── ChatInstance 2 (Robota Agent)
│ └── ChatInstance 3 (Robota Agent)
├── Session 2 (Workspace)
│ ├── ChatInstance 1 (Robota Agent)
│ └── ChatInstance 2 (Robota Agent)
└── Session 3 (Workspace)
└── ChatInstance 1 (Robota Agent)Key Components
- SessionManager: Container for multiple sessions
- ChatInstance: Simple wrapper around Robota agents
- TemplateManagerAdapter: Integrates with agents package templates
- Workspace Isolation: Each session has independent memory
🔧 API Reference
SessionManager
createSession(options)
Creates a new session (workspace). Throws an error if session limit is reached:
try {
const sessionId = sessionManager.createSession({
name: 'My Workspace',
userId: 'user-123',
workspaceId: 'workspace-abc',
});
} catch (error) {
// Handle session limit - implement your own cleanup policy
console.log('Session limit reached:', error.message);
// Example: Remove oldest session
const sessions = sessionManager.listSessions();
const oldest = sessions.reduce((prev, curr) =>
prev.createdAt < curr.createdAt ? prev : curr
);
sessionManager.deleteSession(oldest.id);
// Now create the new session
const sessionId = sessionManager.createSession(options);
}createChat(sessionId, options)
Creates a new AI agent in a session:
const chatId = await sessionManager.createChat(sessionId, {
name: 'Assistant',
agentConfig: {
name: 'Assistant',
aiProviders: [provider],
defaultModel: { provider: 'openai', model: 'gpt-4' },
},
});switchChat(sessionId, chatId)
Switches to a different agent in the session:
sessionManager.switchChat(sessionId, chatId);getChat(chatId)
Gets a chat instance for direct interaction:
const chat = sessionManager.getChat(chatId);
const response = await chat.sendMessage('Hello!');ChatInstance
sendMessage(content)
Sends a message to the AI agent:
const response = await chat.sendMessage('Help me with TypeScript');getHistory()
Gets the conversation history:
const messages = chat.getHistory();clearHistory()
Clears the conversation history:
chat.clearHistory();🎨 Use Cases
1. Multi-Purpose Development Environment
const devSession = sessionManager.createSession({ name: 'Development' });
// Create specialized agents
const coder = await sessionManager.createChat(devSession, { /* coding config */ });
const reviewer = await sessionManager.createChat(devSession, { /* review config */ });
const documenter = await sessionManager.createChat(devSession, { /* docs config */ });
// Switch between them as needed
sessionManager.switchChat(devSession, coder); // For coding
sessionManager.switchChat(devSession, reviewer); // For code review
sessionManager.switchChat(devSession, documenter); // For documentation2. Multi-User Support
// Create isolated workspaces for different users
const userASession = sessionManager.createSession({
userId: 'user-a',
workspaceId: 'workspace-a'
});
const userBSession = sessionManager.createSession({
userId: 'user-b',
workspaceId: 'workspace-b'
});
// Each user has their own isolated agents3. Project-Based Organization
// Create sessions for different projects
const project1 = sessionManager.createSession({ name: 'Project Alpha' });
const project2 = sessionManager.createSession({ name: 'Project Beta' });
// Each project has its own set of specialized agents🔗 Integration with Agents Package
The sessions package is built on top of the agents package:
- Robota: Each ChatInstance wraps a Robota agent
- AgentFactory: Used for creating agents with proper configuration
- AgentTemplates: Template system for creating specialized agents
- ConversationHistory: Leverages the agents package history management
🎯 What's NOT Included
The sessions package focuses on session management and does NOT include:
- ❌ Message editing/deletion (use agents package directly)
- ❌ Complex conversation history manipulation
- ❌ Advanced configuration tracking
- ❌ Built-in persistence (use agents ConversationHistoryPlugin)
📦 Installation
npm install @robota-sdk/sessions @robota-sdk/agents
# or
pnpm add @robota-sdk/sessions @robota-sdk/agents🤝 Contributing
This package is part of the Robota SDK monorepo. See the main repository for contribution guidelines.
📄 License
MIT - See LICENSE file for details.
