Skip to main content

plugin manager for hivemind-core

Project description

HiveMind Plugin Manager

Full documentation: docs/README.mdGetting Started | Concepts | API Reference | Contributing

The HiveMind Plugin Manager (HPM) is a system for discovering, managing, and loading plugins within the HiveMind ecosystem. It supports various plugin types, including databases, network protocols, agent protocols, and binary data handlers. HPM allows for dynamic integration of these plugins to enhance the functionality of HiveMind agents, offering a flexible and extensible architecture.

Features

  • Plugin Discovery: Easily find and load plugins of different types, including:

    • Database Plugins: Supports various database types such as JSON, SQLite, and Redis.
    • Agent Protocol Plugins: Integrates agent protocols like OVOS and Persona, enabling seamless communication between HiveMind agents.
    • Network Protocol Plugins: Enables network protocols such as WebSockets for distributed communication.
    • Binary Data Handler Plugins: Handle binary data communication, like audio data over HiveMind.
  • Plugin Loading: Dynamically load specific plugins by name, type, or from available entry points.

  • Factories for Plugin Instantiation: Factories for creating instances of each plugin type (database, agent protocol, network protocol, binary protocol) based on user configurations.

Installation

pip install hivemind-plugin-manager

Usage

The following example demonstrates how to discover and load plugins, along with creating instances using the provided factories.

Discovering Plugins

Use the find_plugins function to discover all available plugins for a specific type:

from hivemind_plugin_manager import find_plugins, HiveMindPluginTypes

# Find all database plugins
database_plugins = find_plugins(HiveMindPluginTypes.DATABASE)
print(database_plugins)

# Find all agent protocol plugins
agent_protocol_plugins = find_plugins(HiveMindPluginTypes.AGENT_PROTOCOL)
print(agent_protocol_plugins)

Creating Plugin Instances

Each plugin type has a corresponding factory class that allows for creating plugin instances with the required configuration.

Database Plugin Factory

from hivemind_plugin_manager import DatabaseFactory

# Create an instance of a database plugin
db_instance = DatabaseFactory.create("hivemind-redis-db-plugin", password="Password1!", host="192.168.1.11", port=6789)

Agent Protocol Factory

from hivemind_plugin_manager import AgentProtocolFactory

# Create an agent protocol instance
agent_protocol_instance = AgentProtocolFactory.create("hivemind-ovos-agent-plugin")

Network Protocol Factory

from hivemind_plugin_manager import NetworkProtocolFactory

# Create a network protocol instance
network_protocol_instance = NetworkProtocolFactory.create("hivemind-websocket-plugin")

Binary Data Handler Protocol Factory

from hivemind_plugin_manager import BinaryDataHandlerProtocolFactory

# Create a binary data handler protocol instance
binary_data_handler_instance = BinaryDataHandlerProtocolFactory.create("hivemind-audio-binary-protocol-plugin")

Plugin Types

HiveMind Plugin Manager

1. Database Plugins

Supports multiple database systems, such as:

  • JSON Database: Stores data in a JSON format.
  • SQLite Database: Uses SQLite for local database storage.
  • Redis Database: Uses Redis for distributed caching and storage.

2. Agent Protocol Plugins

Supports communication protocols for agents, such as:

  • OVOS Protocol: For interaction with OVOS-based agents.
  • Persona Protocol: For interaction with the Persona framework.

3. Network Protocol Plugins

Enables network communication protocols, such as:

  • WebSocket Protocol: For real-time, bidirectional communication over WebSockets.

4. Binary Data Handler Protocol Plugins

Handles communication of binary data types, like audio, using specialized protocols.

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

hivemind_plugin_manager-0.7.1a2.tar.gz (28.5 kB view details)

Uploaded Source

Built Distribution

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

hivemind_plugin_manager-0.7.1a2-py3-none-any.whl (21.9 kB view details)

Uploaded Python 3

File details

Details for the file hivemind_plugin_manager-0.7.1a2.tar.gz.

File metadata

File hashes

Hashes for hivemind_plugin_manager-0.7.1a2.tar.gz
Algorithm Hash digest
SHA256 ed9d26c79396dfcfaf63f63b91cefcf9fe21c26888e8b49752ac1b54bfcf4461
MD5 2f934bb068468480a26c692ec5115ce3
BLAKE2b-256 26a1419503f65a011b2bda46c26b4d02e291e4e70c1532b0a413eed95ef24f33

See more details on using hashes here.

File details

Details for the file hivemind_plugin_manager-0.7.1a2-py3-none-any.whl.

File metadata

File hashes

Hashes for hivemind_plugin_manager-0.7.1a2-py3-none-any.whl
Algorithm Hash digest
SHA256 92a98e006df8b936b482e67f97e993fdd35c207052349d5f8e56f27b080f181a
MD5 7f478c0ae1419b1a0906ed39a643321c
BLAKE2b-256 26bf7545921032933b48b113c3d02b749d7fd55b53091807d45ba1a2e1791bb8

See more details on using hashes here.

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