Namespace package for components, packages, and plugins within the Swarmauri framework.
Project description
Swarmauri SDK
The Swarmauri SDK offers a comprehensive suite of tools designed for building distributed, extensible systems using the Swarmauri framework.
Swarmauri Namespace Microkernel
The swarmauri package is implemented as a namespace microkernel. When the
package is imported it registers a custom importer that consults the interface
and plugin citizenship registries to locate actual implementations. This design
keeps the namespace lightweight while still allowing first-party and community
plugins to be discovered and loaded on demand. New resource kinds are declared
in interface_registry.py, then mapped to plugin modules via
plugin_citizenship_registry.py. For a deeper look at the import flow, see
docs/callflow.md.
Public Operator Surfaces
Swarmauri exposes three stable operator-facing surfaces:
-
Namespace imports (
swarmauri.<kind>)
The primary runtime surface is the namespace import path. Importing concrete operators through theswarmaurinamespace triggers the microkernel importer and resolves to the installed implementation. -
Registry contracts (
interface_registry.py)
The interface registry defines the accepted interface path for each resource kind. This is the canonical public contract that implementations must satisfy. -
Citizenship mappings (
plugin_citizenship_registry.py)
Citizenship maps each public interface path to a concrete plugin module that can be loaded. This is the public compatibility surface used to connect interface contracts to implementations.
Together these surfaces allow operators to use stable import paths while implementations evolve independently.
Native Dynamic Schemas and Serialization
Swarmauri treats dynamic, typed component serialization as a core runtime
strength. Registered component families use type discriminators and dynamic
unions so factories, HTTP APIs, queues, and persisted JSON payloads can restore
the concrete subclass that was serialized.
Every ComponentBase-derived component inherits JSON support from Pydantic and
YAML/TOML helpers from the Swarmauri base mixins. That means the same component
initialization can move through JSON, YAML, or TOML configuration files and dump
back to those formats while preserving concrete kin.
from typing import Literal
from pydantic import BaseModel
from swarmauri_base.ComponentBase import ComponentBase
from swarmauri_base.DynamicBase import SubclassUnion
@ComponentBase.register_model()
class RuntimeConnector(ComponentBase):
type: Literal["RuntimeConnector"] = "RuntimeConnector"
label: str
@ComponentBase.register_type(RuntimeConnector, "HttpRuntimeConnector")
class HttpRuntimeConnector(RuntimeConnector):
type: Literal["HttpRuntimeConnector"] = "HttpRuntimeConnector"
endpoint: str
class RuntimePayload(BaseModel):
connector: SubclassUnion[RuntimeConnector]
payload = RuntimePayload.model_validate(
{
"connector": {
"type": "HttpRuntimeConnector",
"label": "orders",
"endpoint": "https://api.example.test/orders",
}
}
)
assert isinstance(payload.connector, HttpRuntimeConnector)
Without this, applications usually fall back to untyped dictionaries or manual factory switches. With it, Swarmauri can publish JSON Schema for the available kin classes and hydrate concrete components from the same payloads used by APIs, databases, and configuration files.
Core
- Core Interfaces: Define the fundamental communication and data-sharing protocols between components in a Swarmauri-based system.
Standard
- Base Classes: Provide a foundation for constructing Swarmauri components, with standardized methods and properties.
- Mixins: Reusable code fragments designed to be integrated into various classes, offering shared functionality across different components.
- Concrete Classes: Ready-to-use, pre-implemented classes that fulfill standard system needs while adhering to Swarmauri principles. These classes are the first in line for ongoing support and maintenance, ensuring they remain stable, performant, and up to date with future SDK developments.
Community
- Third-Party Plug-in Integration: Concrete classes designed to extend the framework’s capabilities by utilizing third-party libraries and plugins.
- Open Source Contributions: A collaborative space for developers to contribute new components, plug-ins, and features.
Experimental
- In-Development Components: Early-stage features and components that push the boundaries of the Swarmauri framework, offering innovative solutions that are still in testing phases.
Features
- Polymorphism: Allows for dynamic behavior switching between components, enabling flexible, context-aware system behavior.
- Dynamic JSON Schemas: Updates discriminated-union schemas as registered component kin become available.
- Discriminated Unions: Provides a robust method for handling multiple possible object types in a type-safe manner.
- Serialization: Efficiently encode and decode component initializations across JSON, YAML, and TOML while preserving concrete
type. - Intensional and Extensional Programming: The microkernel continues to leverage both rule-based (intensional) patterns and set-based (extensional) plugin discovery, allowing you to build and manipulate complex data structures with ease.
Use Cases
- Modular Systems: Develop scalable, pluggable systems that can evolve over time by adding or modifying components without disrupting the entire ecosystem.
- Distributed Architectures: Build systems with distributed nodes that seamlessly communicate using the SDK’s standardized interfaces.
- Third-Party Integrations: Extend the system's capabilities by easily incorporating third-party tools, libraries, and services.
- Prototype and Experimentation: Test cutting-edge ideas using the experimental components in the SDK, while retaining the reliability of core and standard features for production systems.
Extension Surface
Swarmauri is designed to be extended by adding new resource kinds or new implementations for existing kinds.
For extension work:
- Add or update the interface contract in
swarmauri/interface_registry.py. - Register the concrete implementation in
swarmauri/plugin_citizenship_registry.py. - Ensure the implementation module can be imported and instantiated directly through its public class API.
- Validate import resolution against the call flow documented in
docs/callflow.md.
This extension surface keeps the microkernel small while allowing packages, plugins, and standards modules to participate in the same runtime model.
Authoring Guide
When authoring new Swarmauri components:
-
Define the interface first
Start from the interface contract and ensure your class adheres to the expected methods and typing. -
Implement concrete behavior in your package
Keep domain logic in the implementation package and keep the namespace microkernel declarations focused on discovery and routing. -
Register the implementation
Add citizenship entries so the namespace importer can resolve your class. -
Instantiate plugins directly in usage examples
Prefer direct class imports/instantiation in examples and integrations unless a manager abstraction is explicitly required. -
Document expected workflow
Include installation, minimal usage, and extension notes so users can adopt and extend the component safely.
Future Development
The Swarmauri SDK is an evolving platform, and the community is encouraged to contribute to its growth. Upcoming releases will focus on enhancing the framework's modularity, providing more advanced serialization methods, and expanding the community-driven component library.
Modules Overview
Importer
- importer.py: Handles the dynamic importing of modules and components within the Swarmauri framework.
Interface Registry
- interface_registry.py: Manages the registration and lookup of interfaces used for communication between different components.
Plugin Citizenship Registry
- plugin_citizenship_registry.py: Maintains a registry of plugins and their citizenship status within the Swarmauri ecosystem.
When introducing a new resource kind or class, remember to update both the
plugin_citizenship_registry.py and interface_registry.py so the framework can
discover and validate your additions.
Contributing
Contributions are welcome! If you'd like to add a new feature, fix a bug, or improve documentation, kindly go through the contributions guidelines first.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file swarmauri-0.9.1.dev3.tar.gz.
File metadata
- Download URL: swarmauri-0.9.1.dev3.tar.gz
- Upload date:
- Size: 29.8 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.11.15 {"installer":{"name":"uv","version":"0.11.15","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
f8b65343844b449da1132eeb73904df0f889e3f2f272af04c11fe461212a4823
|
|
| MD5 |
4e050679522e64c4583d5af49fed7d71
|
|
| BLAKE2b-256 |
21171cdba30855508ff39bce90bed07c0e91ddfcefe5060a23cae7b14440a688
|
File details
Details for the file swarmauri-0.9.1.dev3-py3-none-any.whl.
File metadata
- Download URL: swarmauri-0.9.1.dev3-py3-none-any.whl
- Upload date:
- Size: 28.1 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.11.15 {"installer":{"name":"uv","version":"0.11.15","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
209908c3e5442411d70d7c2bd2c171d94e6740de9d44d3eaeb688db6f69c5913
|
|
| MD5 |
b852f7717e9d9d8b1921fcb00cc476f5
|
|
| BLAKE2b-256 |
a6dc391a6bf869b5897dd2dc32b88cf31d5e10c028c0a20cc5c086be7f4e127a
|