wikiops-sdk is the public SDK for the WikiOps ecosystem.
It defines the shared language used by the WikiOps host, documentation plugins, and document providers. The package is intentionally small and focused: it provides portable domain models, public extension contracts, and compatibility rules, but it does not implement orchestration, a CLI, concrete providers, or concrete plugins.
- Provider-agnostic domain models for documentation planning and application.
- Public protocols and Pydantic models for plugins and providers.
- Compatibility helpers for SDK, plugin, provider, and Python runtime versions.
- A strict automated test suite that validates the public SDK behavior.
- A dedicated
docs/directory with conceptual guides and API reference material.
- The WikiOps host application.
- A CLI.
- A scheduler or orchestrator.
- Provider implementations such as Azure DevOps Wiki or Confluence.
- Documentation plugin implementations.
In the intended ecosystem, the relationship is:
plugin -> sdk <- host
provider -> sdk <- host
The SDK is the stable contract layer in the middle.
WikiOps treats documentation as code. The long-term goal is to automate how Markdown-based documentation is read, transformed, generated, and persisted across multiple wiki systems while keeping business logic, provider infrastructure, and orchestration decoupled.
This SDK gives all participants a common model for concepts such as:
DocumentRefDocumentChangeSetExecutionContextProviderCapabilityApplyResult
src/wikiops_sdk/
compat.py
contracts/
domain/
docs/
tests/
Start here depending on your role:
- New to the project:
docs/index.md - Need the architectural model:
docs/architecture.md - Need the core concepts:
docs/concepts.md - Need compatibility rules:
docs/compatibility.md - Writing a plugin:
docs/guides/write-a-plugin.md - Writing a provider:
docs/guides/write-a-provider.md - Planning change sets:
docs/guides/planning-changes.md - Need API reference:
docs/api/index.md - Need SDK constraints and caveats:
docs/reference/constraints.md
For plugin authors:
docs/getting-started.mddocs/concepts.mddocs/guides/write-a-plugin.mddocs/api/contracts.mddocs/api/domain.md
For provider authors:
docs/getting-started.mddocs/concepts.mddocs/guides/write-a-provider.mddocs/api/contracts.mddocs/api/domain.md
For host authors:
The top-level package mainly exposes compatibility helpers:
from wikiops_sdk import ensure_plugin_api_compatibleContracts and domain models are intentionally imported from subpackages:
from wikiops_sdk.contracts import DocumentationPlugin, DocumentProvider, PluginManifest
from wikiops_sdk.domain import ChangeSet, DocumentRef, ExecutionContextThis repository documents the SDK only. The WikiOps host application should maintain its own documentation for orchestration, runtime loading, command-line workflows, and deployment concerns.
The current SDK implementation is intentionally narrow and precise:
- Markdown is the only built-in content format.
- The current operation model supports create, update, and create-child flows.
- Compatibility defaults to a
same_majorpolicy. - The SDK is designed to be provider-agnostic and orchestration-agnostic.
The repository ships with a strict test suite and coverage thresholds.
poetry install --with tests
poetry run pytestThe tests also serve as executable examples of the current public API.