Sessions manage conversation state, track context usage, and extract long-term memories.
Create a new session.
Parameters
| Parameter | Type | Required | Default | Description |
|---|---|---|---|---|
| session_id | str | No | None | Session ID. Creates new session with auto-generated ID if None |
Python SDK (Embedded / HTTP)
# Create new session (auto-generated ID)
session = client.session()
print(f"Session URI: {session.uri}")HTTP API
POST /api/v1/sessions
curl -X POST http://localhost:1933/api/v1/sessions \
-H "Content-Type: application/json" \
-H "X-API-Key: your-key"CLI
openviking session newResponse
{
"status": "ok",
"result": {
"session_id": "a1b2c3d4",
"user": "alice"
},
"time": 0.1
}List all sessions.
Python SDK (Embedded / HTTP)
sessions = client.ls("viking://session/")
for s in sessions:
print(f"{s['name']}")HTTP API
GET /api/v1/sessions
curl -X GET http://localhost:1933/api/v1/sessions \
-H "X-API-Key: your-key"CLI
openviking session listResponse
{
"status": "ok",
"result": [
{"session_id": "a1b2c3d4", "user": "alice"},
{"session_id": "e5f6g7h8", "user": "bob"}
],
"time": 0.1
}Get session details.
Parameters
| Parameter | Type | Required | Default | Description |
|---|---|---|---|---|
| session_id | str | Yes | - | Session ID |
Python SDK (Embedded / HTTP)
# Load existing session
session = client.session(session_id="a1b2c3d4")
session.load()
print(f"Loaded {len(session.messages)} messages")HTTP API
GET /api/v1/sessions/{session_id}
curl -X GET http://localhost:1933/api/v1/sessions/a1b2c3d4 \
-H "X-API-Key: your-key"CLI
openviking session get a1b2c3d4Response
{
"status": "ok",
"result": {
"session_id": "a1b2c3d4",
"user": "alice",
"message_count": 5
},
"time": 0.1
}Delete a session.
Parameters
| Parameter | Type | Required | Default | Description |
|---|---|---|---|---|
| session_id | str | Yes | - | Session ID to delete |
Python SDK (Embedded / HTTP)
client.rm("viking://session/a1b2c3d4/", recursive=True)HTTP API
DELETE /api/v1/sessions/{session_id}
curl -X DELETE http://localhost:1933/api/v1/sessions/a1b2c3d4 \
-H "X-API-Key: your-key"CLI
openviking session delete a1b2c3d4Response
{
"status": "ok",
"result": {
"session_id": "a1b2c3d4"
},
"time": 0.1
}Add a message to the session.
Parameters
| Parameter | Type | Required | Default | Description |
|---|---|---|---|---|
| role | str | Yes | - | Message role: "user" or "assistant" |
| parts | List[Part] | Conditional | - | List of message parts (Required for Python SDK; Optional for HTTP API, mutually exclusive with content) |
| content | str | Conditional | - | Message text content (HTTP API simple mode, mutually exclusive with parts) |
Note: HTTP API supports two modes:
- Simple mode: Use
contentstring (backward compatible)- Parts mode: Use
partsarray (full Part support)If both
contentandpartsare provided,partstakes precedence.
Part Types (Python SDK)
from openviking.message import TextPart, ContextPart, ToolPart
# Text content
TextPart(text="Hello, how can I help?")
# Context reference
ContextPart(
uri="viking://resources/docs/auth/",
context_type="resource", # "resource", "memory", or "skill"
abstract="Authentication guide..."
)
# Tool call
ToolPart(
tool_id="call_123",
tool_name="search_web",
skill_uri="viking://skills/search-web/",
tool_input={"query": "OAuth best practices"},
tool_output="",
tool_status="pending" # "pending", "running", "completed", "error"
)Python SDK (Embedded / HTTP)
from openviking.message import TextPart
session = client.session()
# Add user message
session.add_message("user", [
TextPart(text="How do I authenticate users?")
])
# Add assistant response
session.add_message("assistant", [
TextPart(text="You can use OAuth 2.0 for authentication...")
])HTTP API
POST /api/v1/sessions/{session_id}/messages
Simple Mode (Backward Compatible)
# Add user message
curl -X POST http://localhost:1933/api/v1/sessions/a1b2c3d4/messages \
-H "Content-Type: application/json" \
-H "X-API-Key: your-key" \
-d '{
"role": "user",
"content": "How do I authenticate users?"
}'Parts Mode (Full Part Support)
# Add assistant message with context reference
curl -X POST http://localhost:1933/api/v1/sessions/a1b2c3d4/messages \
-H "Content-Type: application/json" \
-H "X-API-Key: your-key" \
-d '{
"role": "assistant",
"parts": [
{"type": "text", "text": "Based on the authentication guide..."},
{"type": "context", "uri": "viking://resources/docs/auth/", "context_type": "resource", "abstract": "Auth guide"}
]
}'
# Add assistant message with tool call
curl -X POST http://localhost:1933/api/v1/sessions/a1b2c3d4/messages \
-H "Content-Type: application/json" \
-H "X-API-Key: your-key" \
-d '{
"role": "assistant",
"parts": [
{"type": "text", "text": "Let me search for that..."},
{"type": "tool", "tool_id": "call_123", "tool_name": "search_web", "tool_input": {"query": "OAuth"}, "tool_status": "completed", "tool_output": "Results..."}
]
}'CLI
openviking session add-message a1b2c3d4 --role user --content "How do I authenticate users?"Response
{
"status": "ok",
"result": {
"session_id": "a1b2c3d4",
"message_count": 2
},
"time": 0.1
}Commit a session by archiving messages and extracting memories.
Parameters
| Parameter | Type | Required | Default | Description |
|---|---|---|---|---|
| session_id | str | Yes | - | Session ID to commit |
Python SDK (Embedded / HTTP)
session = client.session(session_id="a1b2c3d4")
session.load()
# Commit archives messages and extracts memories
result = session.commit()
print(f"Status: {result['status']}")
print(f"Memories extracted: {result['memories_extracted']}")HTTP API
POST /api/v1/sessions/{session_id}/commit
curl -X POST http://localhost:1933/api/v1/sessions/a1b2c3d4/commit \
-H "Content-Type: application/json" \
-H "X-API-Key: your-key"CLI
openviking session commit a1b2c3d4Response
{
"status": "ok",
"result": {
"session_id": "a1b2c3d4",
"status": "committed",
"archived": true
},
"time": 0.1
}| Property | Type | Description |
|---|---|---|
| uri | str | Session Viking URI (viking://session/{session_id}/) |
| messages | List[Message] | Current messages in the session |
| stats | SessionStats | Session statistics |
| summary | str | Compression summary |
| usage_records | List[Usage] | Context and skill usage records |
viking://session/{session_id}/
+-- .abstract.md # L0: Session overview
+-- .overview.md # L1: Key decisions
+-- messages.jsonl # Current messages
+-- tools/ # Tool executions
| +-- {tool_id}/
| +-- tool.json
+-- .meta.json # Metadata
+-- .relations.json # Related contexts
+-- history/ # Archived history
+-- archive_001/
| +-- messages.jsonl
| +-- .abstract.md
| +-- .overview.md
+-- archive_002/
| Category | Location | Description |
|---|---|---|
| profile | user/memories/.overview.md |
User profile information |
| preferences | user/memories/preferences/ |
User preferences by topic |
| entities | user/memories/entities/ |
Important entities (people, projects) |
| events | user/memories/events/ |
Significant events |
| cases | agent/memories/cases/ |
Problem-solution cases |
| patterns | agent/memories/patterns/ |
Interaction patterns |
Python SDK (Embedded / HTTP)
import openviking as ov
from openviking.message import TextPart, ContextPart
# Initialize client
client = ov.OpenViking(path="./my_data")
client.initialize()
# Create new session
session = client.session()
# Add user message
session.add_message("user", [
TextPart(text="How do I configure embedding?")
])
# Search with session context
results = client.search("embedding configuration", session=session)
# Add assistant response with context reference
session.add_message("assistant", [
TextPart(text="Based on the documentation, you can configure embedding..."),
ContextPart(
uri=results.resources[0].uri,
context_type="resource",
abstract=results.resources[0].abstract
)
])
# Track actually used contexts
session.used(contexts=[results.resources[0].uri])
# Commit session (archive messages, extract memories)
result = session.commit()
print(f"Memories extracted: {result['memories_extracted']}")
client.close()HTTP API
# Step 1: Create session
curl -X POST http://localhost:1933/api/v1/sessions \
-H "Content-Type: application/json" \
-H "X-API-Key: your-key"
# Returns: {"status": "ok", "result": {"session_id": "a1b2c3d4"}}
# Step 2: Add user message
curl -X POST http://localhost:1933/api/v1/sessions/a1b2c3d4/messages \
-H "Content-Type: application/json" \
-H "X-API-Key: your-key" \
-d '{"role": "user", "content": "How do I configure embedding?"}'
# Step 3: Search with session context
curl -X POST http://localhost:1933/api/v1/search/search \
-H "Content-Type: application/json" \
-H "X-API-Key: your-key" \
-d '{"query": "embedding configuration", "session_id": "a1b2c3d4"}'
# Step 4: Add assistant message
curl -X POST http://localhost:1933/api/v1/sessions/a1b2c3d4/messages \
-H "Content-Type: application/json" \
-H "X-API-Key: your-key" \
-d '{"role": "assistant", "content": "Based on the documentation, you can configure embedding..."}'
# Step 5: Commit session
curl -X POST http://localhost:1933/api/v1/sessions/a1b2c3d4/commit \
-H "Content-Type: application/json" \
-H "X-API-Key: your-key"# Commit after significant interactions
if len(session.messages) > 10:
session.commit()# Only mark contexts that were actually helpful
if context_was_useful:
session.used(contexts=[ctx.uri])# Better search results with conversation context
results = client.search(query, session=session)# Always load when resuming an existing session
session = client.session(session_id="existing-id")
session.load()- Context Types - Memory types
- Retrieval - Search with session
- Resources - Resource management