Archive messages and extract long-term memories from a session
curl --request POST \
--url https://api.example.com/api/v1/sessions/{session_id}/commit \
--header 'Content-Type: application/json' \
--header 'X-API-Key: <x-api-key>' \
--data '
{
"profile": {},
"preferences": {},
"entities": {},
"events": {},
"cases": {},
"patterns": {}
}
'{
"status": "<string>",
"result": {
"session_id": "<string>",
"status": "<string>",
"archived": true,
"memories_extracted": 123,
"active_count_updated": 123,
"stats": {
"total_turns": 123,
"contexts_used": 123,
"skills_used": 123,
"memories_extracted": 123
}
},
"time": 123
}Commit a session to archive its messages and extract long-term memories. This operation:Documentation Index
Fetch the complete documentation index at: https://mintlify.com/volcengine/OpenViking/llms.txt
Use this file to discover all available pages before exploring further.
history/archive_N/application/jsonok or error)committed)curl -X POST http://localhost:1933/api/v1/sessions/a1b2c3d4/commit \
-H "Content-Type: application/json" \
-H "X-API-Key: your-api-key"
{
"status": "ok",
"result": {
"session_id": "a1b2c3d4",
"status": "committed",
"archived": true,
"memories_extracted": 3,
"active_count_updated": 2,
"stats": {
"total_turns": 5,
"contexts_used": 2,
"skills_used": 1,
"memories_extracted": 3
}
},
"time": 2.5
}
viking://user/{user}/memories/profile.mdUser profile information (name, role, background, expertise)Merge strategy: Always merged into single profile.md fileviking://user/{user}/memories/preferences/User preferences organized by topic (coding style, communication style, tool preferences)Merge strategy: Merged by topic when similarviking://user/{user}/memories/entities/Important entities (people, projects, organizations, concepts)Merge strategy: Merged when referring to same entityviking://user/{user}/memories/events/Significant events (decisions, milestones, incidents)Merge strategy: Created as separate events, not mergedviking://agent/{agent}/memories/cases/Problem-solution pairs (specific bugs fixed, issues resolved)Merge strategy: Created as separate cases, not mergedviking://agent/{agent}/memories/patterns/Reusable patterns (workflows, processes, interaction patterns)Merge strategy: Merged when similar patterns detected# L0: Abstract (.abstract.md)
One-sentence summary for quick scanning
# L1: Overview (.overview.md)
Medium-detail description with key points
# L2: Content (file.md)
Full narrative with complete context and details
viking://session/{user_space}/{session_id}/history/
├── archive_001/
│ ├── messages.jsonl # Archived messages
│ ├── .abstract.md # L0: Archive summary
│ └── .overview.md # L1: Archive overview
├── archive_002/
│ ├── messages.jsonl
│ ├── .abstract.md
│ └── .overview.md
└── ...
session = client.session(session_id="a1b2c3d4")
session.load()
# Check token usage
if session.stats.total_tokens > 8000:
result = session.commit()
print(f"Auto-committed: {result['memories_extracted']} memories extracted")
# After completing a task
if task_completed:
session.commit()
# End of conversation
if user_says_goodbye:
session.commit()
# After significant interaction
if session.stats.total_turns >= 10:
session.commit()
import openviking as ov
from openviking.message import TextPart, ContextPart
# Initialize
client = ov.OpenViking(path="./my_data")
client.initialize()
# Create session
session = client.session()
print(f"Session: {session.session_id}")
# Conversation turn 1
session.add_message("user", [
TextPart(text="How do I add a new resource?")
])
results = client.search("add resource", session=session)
session.add_message("assistant", [
TextPart(text="You can use client.add_resource()..."),
ContextPart(
uri=results.resources[0].uri,
context_type="resource",
abstract="Resource management guide"
)
])
session.used(contexts=[results.resources[0].uri])
# Conversation turn 2
session.add_message("user", [
TextPart(text="What about indexing?")
])
results = client.search("indexing", session=session)
session.add_message("assistant", [
TextPart(text="Indexing happens automatically..."),
ContextPart(
uri=results.resources[0].uri,
context_type="resource",
abstract="Indexing documentation"
)
])
session.used(contexts=[results.resources[0].uri])
# Commit at end of conversation
result = session.commit()
print(f"\nCommit Results:")
print(f" Archived: {result['archived']}")
print(f" Memories extracted: {result['memories_extracted']}")
print(f" Stats: {result['stats']}")
# Session is now cleared and ready for next conversation
print(f"\nActive messages after commit: {len(session.messages)}")
client.close()
# Search for context
results = client.search(query, session=session)
# Add message
session.add_message("assistant", [...])
# IMPORTANT: Track what was actually used
session.used(contexts=[results.resources[0].uri])
# Commit will use this to update active_count
session.commit()
# Good: Commit every 10-15 turns
if session.stats.total_turns >= 10:
session.commit()
# Good: Commit when context is high
if session.stats.total_tokens > 8000:
session.commit()
# Avoid: Never committing (loses memory)
# Avoid: Committing too frequently (inefficient)
result = session.commit()
if result['memories_extracted'] == 0:
print("Warning: No memories extracted")
# Maybe conversation wasn't meaningful enough
if result['archived']:
print(f"Archived {len(session.messages)} messages")
curl --request POST \
--url https://api.example.com/api/v1/sessions/{session_id}/commit \
--header 'Content-Type: application/json' \
--header 'X-API-Key: <x-api-key>' \
--data '
{
"profile": {},
"preferences": {},
"entities": {},
"events": {},
"cases": {},
"patterns": {}
}
'{
"status": "<string>",
"result": {
"session_id": "<string>",
"status": "<string>",
"archived": true,
"memories_extracted": 123,
"active_count_updated": 123,
"stats": {
"total_turns": 123,
"contexts_used": 123,
"skills_used": 123,
"memories_extracted": 123
}
},
"time": 123
}