Skip to main content

AI agent knowledge management system using Wiki-based markdown storage

Project description

OutoWiki Documentation

OutoWiki is a wiki-based knowledge management system designed for AI agents. It provides a structured way to store, retrieve, and organize information that AI agents learn across interactions.

Overview

OutoWiki solves the problem of persistent memory for AI agents by organizing information in a familiar wiki structure. Instead of opaque databases, OutoWiki uses markdown documents organized in folders, making the knowledge human-readable and editable.

Architecture

┌─────────────────────────────────────────────────────────┐
│                      OutoWiki Facade                     │
│  (OutoWiki class - main entry point for all operations)  │
└─────────────────────┬───────────────────────────────────┘
                      │
         ┌────────────┼────────────┐
         │            │            │
    ┌────▼────┐  ┌────▼────┐  ┌────▼────┐
    │Recorder │  │Searcher │  │Internal │
    │ Module  │  │ Module  │  │ Agent   │
    └────┬────┘  └────┬────┘  └────┬────┘
         │            │            │
    ┌────▼────────────▼────────────▼────┐
    │           LLM Provider            │
    │   (OpenAI or Anthropic)          │
    └──────────────────────────────────┘

The system has three main components:

  • Recorder: Processes new content, determines document placement, manages backlinks
  • Searcher: Finds relevant documents using semantic search and intent analysis
  • Internal Agent: Handles complex operations like merge, split, and modify plans

Wiki Structure

OutoWiki organizes knowledge as markdown files in a folder hierarchy. When initialized, default category folders are created automatically:

wiki/
├── users/
│   └── {username}/
│       ├── profile.md
│       └── preferences/
│           └── {topic}.md
├── tools/
│   └── {toolname}/
│       ├── overview.md
│       └── usage.md
├── agent/
│   ├── identity/
│   ├── learning/
│   └── memory/
├── knowledge/
│   └── {domain}/
│       └── {subdomain}/
│           └── {topic}.md
├── history/
│   └── sessions/
│       └── {date}.md
└── unassigned/
    └── {documents}.md

Documents support backlinks using the [[Document Name]] syntax. When auto_backlinks is enabled, OutoWiki automatically updates related documents when new content references existing topics.

Quick Start

from outowiki import OutoWiki, WikiConfig

# Create configuration
config = WikiConfig(
    provider="openai",
    api_key="sk-...",        # Your OpenAI API key
    model="gpt-4",
    wiki_path="./my_wiki"    # Local wiki folder
)

# Initialize the wiki
wiki = OutoWiki(config)

# Record new information
result = wiki.record({
    "type": "conversation",
    "content": "User prefers Python for web development. Suggested Flask or Django."
})
print(f"Recorded: {result.success}")
print(f"Actions: {result.actions_taken}")

# Search for information
results = wiki.search("programming preferences")
print(f"Found: {results.paths}")

# Work with a specific document
doc = wiki.get_document("concepts/web-development.md")
print(f"Title: {doc.metadata.title}")
print(doc.content[:500])

Documentation

Getting Started

API Reference

Guides

License

Apache License 2.0 - see LICENSE file for details.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

outowiki-0.5.0.tar.gz (68.0 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

outowiki-0.5.0-py3-none-any.whl (44.4 kB view details)

Uploaded Python 3

File details

Details for the file outowiki-0.5.0.tar.gz.

File metadata

  • Download URL: outowiki-0.5.0.tar.gz
  • Upload date:
  • Size: 68.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for outowiki-0.5.0.tar.gz
Algorithm Hash digest
SHA256 4bdbafeea9d5858b2d978623d2ec0173413a191869dd36b4fc570b83ba1caa2a
MD5 897aaa269fca092725ff8ff1e45cc3b8
BLAKE2b-256 4393548af1d2ff409f66db71e751cb7fa17814c01b75cc9b6391428e5ec1b1a2

See more details on using hashes here.

Provenance

The following attestation bundles were made for outowiki-0.5.0.tar.gz:

Publisher: publish.yml on llaa33219/outowiki

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file outowiki-0.5.0-py3-none-any.whl.

File metadata

  • Download URL: outowiki-0.5.0-py3-none-any.whl
  • Upload date:
  • Size: 44.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for outowiki-0.5.0-py3-none-any.whl
Algorithm Hash digest
SHA256 ce60d61bbd933448f7eb5573f0984932c37b53e1be8e267abbb74076bc028130
MD5 d4e7838a3e2f2f34ea8ae2710a6383ac
BLAKE2b-256 d64cef736c158c89dd32d64e53a82f77a00d2705d699baebb316fbe1ca0c0e49

See more details on using hashes here.

Provenance

The following attestation bundles were made for outowiki-0.5.0-py3-none-any.whl:

Publisher: publish.yml on llaa33219/outowiki

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page