Skip to content

JarbasHiveMind/HiveMind-core

Repository files navigation

Ask DeepWiki

HiveMind Core

HiveMind is a flexible protocol that facilitates communication and collaboration among devices and AI agents within a unified network. It enables lightweight devices, called satellites, to connect to a central hub, with customizable permissions and centralized control.

HiveMind also supports hierarchical hub-to-hub connections, creating powerful, scalable smart environments.

Initially developed as part of the OpenVoiceOS (OVOS) ecosystem, HiveMind is adaptable to various AI backend systems.

For more details and demonstrations, check our YouTube channel.



🌟 Key Features

  • Modular Design: Easily extend functionality with plugins for different protocols and behaviors.
  • Protocol Flexibility: Use HiveMind with different network, agent, and binary protocols.
  • Customizable Database Options: Support for JSON, SQLite, and Redis.
  • Centralized Control: Manage and monitor devices from a single hub.
  • Fine-Grained Permissions: Control access to skills, intents, and message types for each satellite.
  • Multi-Agent Support: Integrate various AI assistants, such as OpenVoiceOS or LLMs.

🔌 Modular Design with Plugins

HiveMind is designed to be modular, allowing you to customize its behavior through plugins managed by the HiveMind Plugin Manager.

  • Transport Mechanism 🚚: The protocol does not specify how messages are transported; this is implemented via network protocol plugins (e.g., Websockets, HTTP).
  • Payload Handling 🤖 : The protocol does not dictate who handles the messages; this is implemebted via agent protocol plugins (e.g., OVOS, Persona).
  • Message Format 📦: The protocol supports JSON data modeled after the Message structure from OVOS and binary data; what happens to the received binary data is implemented via binary data protocol plugins (e.g., process incoming audio).
  • Database: 🗃️ how client credentials are stored is implemented via database plugins (e.g., JSON, SQLite, Redis).

📖 Protocol Configuration

HiveMind Core now supports a configuration file, making it easier for users to define server settings and reduce the need for complex command-line arguments.

💡 The configuration file is stored at ~/.config/hivemind-core/server.json

The default configuration

{
  "agent_protocol": {
    "module": "hivemind-ovos-agent-plugin",
    "hivemind-ovos-agent-plugin": {
      "host": "127.0.0.1",
      "port": 8181
    }
  },
  "binary_protocol": {
    "module": null
  },
  "network_protocol": {
    "hivemind-websocket-plugin": {
      "host": "0.0.0.0",
      "port": 5678
    },
    "hivemind-http-plugin": {
      "host": "0.0.0.0",
      "port": 5679
    }
  },
  "policy": {
    "chain": [
      {"module": "hivemind-ovos-agent-policy"}
    ]
  },
  "database": {
    "module": "hivemind-sqlite-db-plugin",
    "hivemind-sqlite-db-plugin": {
      "name": "clients",
      "subfolder": "hivemind-core"
    }
  }
}

Default backend: fresh installs use SQLite (transactional, concurrency-safe, stdlib). An existing JSON deployment (a clients.json already on disk) keeps using JSON so upgrades never strand the credentials store. Move an existing store with hivemind-core migrate-db --to sqlite (also supports --from/--to for JSON ⇄ SQLite ⇄ Redis).

Policy Admission Chain

Every inbound message passes through an ordered policy admission chain before reaching the agent bus. See issue #85 for the full spec.

How it works:

  1. MessageTypeACLPolicy is always prepended to the chain and cannot be removed by configuration. It enforces the per-client allowed_types whitelist: if message.msg_type is not in the client's allowed_types, the message is denied. Client.is_admin is informational and gives no admission bypass — admins are subject to the whitelist like any other client. — hivemind_core/policy.py:174
  2. Configured plugins in policy.chain run after MessageTypeACLPolicy, in order. Each plugin can deny the message or contribute mutations applied before the next plugin runs.
  3. The chain is always fail-closed. Any unhandled exception in a policy becomes Verdict.deny("policy_error", ...). There is no operator knob to override this. — hivemind_core/policy.py:36
  4. If the chain fails to build at startup, a DenyAllPolicy fallback is installed, rejecting every message with code="policy_chain_unavailable" until configuration is fixed. — hivemind_core/policy.py:151

Denied messages receive a hive.policy.denied BUS response with payload:

{
  "denied_type": "<msg_type or 'binary'>",
  "code": "<verdict code>",
  "reason": "<human-readable reason>",
  "data": {}
}

handle_inject_agent_msg runs policy_chain.review() then policy_chain.observe() for every accepted message. handle_binary_message runs policy_chain.review_binary(). — hivemind_core/protocol.py:908, hivemind_core/protocol.py:457

ACL model — whitelist-only, deny-by-default:

  • allowed_types is the only ACL field on HiveMindClientConnection. There is no message blacklist. — hivemind_core/protocol.py:92
  • A freshly created client (via add-client) has an empty allowed_types list and will be denied all messages until the operator explicitly grants types with allow-msg. This applies to admin clients too — Client.is_admin is informational only and gives no admission bypass.

To grant a message type:

$ hivemind-core allow-msg "recognizer_loop:utterance" 1
$ hivemind-core allow-msg "speak" 1

Removing a type (mutates allowed_types; not deprecated):

$ hivemind-core blacklist-msg "speak" 1

Skill and intent filtering are OVOS-specific concerns handled by OVOSAgentPolicy (shipped with hivemind-ovos-agent-plugin, the default agent_protocol). The CLI commands blacklist-skill, allow-skill, blacklist-intent, and allow-intent manage the skill_blacklist / intent_blacklist lists in Client.metadata, which OVOSAgentPolicy injects into the OVOS session. They take effect only when that policy is configured in policy.chain. For any other policy-relevant key, use set-metadata to write arbitrary Client.metadata. — hivemind_core/scripts.py

On-disk migration of legacy blacklist fields. Database backends (e.g. hivemind-sqlite-database, hivemind-redis-database) implement the new AbstractDB.migrate(from_version) hook from hivemind-plugin-manager and run a one-shot v1 → v2 migration on first open. The migration folds any legacy top-level intent_blacklist / skill_blacklist / message_blacklist storage (SQLite columns, JSON keys, Redis hash fields) into each row's metadata dict via setdefault (explicit metadata wins), then clears the legacy storage. Backends track their schema version natively (SQLite PRAGMA user_version, Redis sentinel key) so the migration runs exactly once per database. Third-party backends that do not override migrate() keep working — the property shims on Client ensure read-path code is agnostic to on-disk shape.

To add additional policies, extend the policy.chain list with plugin module names:

"policy": {
  "chain": [
    {"module": "hivemind-ovos-agent-policy"},
    {"module": "hivemind-intent-quota-policy", "config": {"limit": 100}}
  ]
}

Drop hivemind-ovos-agent-policy from the list only if you are running a non-OVOS agent backend.


🛰️ Quick Start

To get started, HiveMind Core provides a command-line interface (CLI) for managing clients, permissions, and connections.

Installation

pip install hivemind-core

Adding a Satellite

Add credentials for each satellite device:

$ hivemind-core add-client --db-backend sqlite 
Database backend: SQLiteDB
Credentials added to database!

Node ID: 3
Friendly Name: HiveMind-Node-2
Access Key: 42caf3d2405075fb9e7a4e1ff44e4c4f
Password: 5ae486f7f1c26bd4645bd052e4af3ea3
Encryption Key: f46351c54f61a715
WARNING: Encryption Key is deprecated, only use if your client does not support password

NOTE: You will need to provide this information on the client devices to connect.

Running the Server

Start the HiveMind Core server to accept connections:

$ hivemind-core listen

🛠️ Commands Overview

HiveMind Core CLI supports the following commands:

$ hivemind-core --help
Usage: hivemind-core [OPTIONS] COMMAND [ARGS]...

Options:
  --help  Show this message and exit.

Commands:
  add-client           add credentials for a client
  allow-msg            allow a message type to be sent from a client
  blacklist-msg        remove a message type from a client's allowed list
  allow-escalate       allow ESCALATE messages from a client
  blacklist-escalate   deny ESCALATE messages from a client
  allow-propagate      allow PROPAGATE messages from a client
  blacklist-propagate  deny PROPAGATE messages from a client
  delete-client        remove credentials for a client
  list-clients         list clients and credentials
  listen               start listening for HiveMind connections
  make-admin           grant administrator privileges to a client
  revoke-admin         revoke administrator privileges from a client
  rename-client        rename a client in the database
  allow-intent         remove an intent from a client's blacklist (OVOS-policy)
  allow-skill          remove a skill from a client's blacklist (OVOS-policy)
  blacklist-intent     blacklist an intent for a client (OVOS-policy)
  blacklist-skill      blacklist a skill for a client (OVOS-policy)
  set-metadata         set arbitrary metadata on a client (read by policy plugins)

For detailed help on each command, use --help (e.g., hivemind-core add-client --help).

💡 Tip: if you don't specify the numeric client_id in your commands you will be prompted for it interactively

Click for more details

add-client

Add credentials for a new client that will connect to the HiveMind instance.

$ hivemind-core add-client --name "satellite_1" --access-key "mykey123" --password "mypass"
  • When to use:
    Use this command when setting up a new HiveMind client (e.g., Raspberry Pi, IoT device). Provide credentials for secure communication with the server.
  • Optional metadata: Admins can attach plugin-specific client context with --metadata:
hivemind-core add-client --name "satellite_1" --metadata '{"account_id":"acct_123","device_type":"satellite"}'

list-clients

List all registered clients and their credentials.

$ hivemind-core list-clients
  • When to use:
    Use this command to view or inspect all registered clients, helpful for debugging or managing devices connected to HiveMind.

rename-client

Rename a registered client.

$ hivemind-core rename-client "new name" 1
  • When to use:
    Use this command when you need to change the name of an existing client in the database.

delete-client

Remove a registered client from the HiveMind instance.

$ hivemind-core delete-client 1
  • When to use:
    Use this command to revoke a client’s access, for example, when a device is lost, no longer in use, or compromised.

allow-msg

Grant a specific message type to a client’s allowed_types whitelist. New clients have an empty whitelist and are denied all messages until at least one type is granted.

$ hivemind-core allow-msg "recognizer_loop:utterance" 1
$ hivemind-core allow-msg "speak" 1
  • When to use:
    Use this command after add-client to grant the message types the client needs. Without any allow-msg calls the client is effectively locked out (deny-by-default).

blacklist-msg

Revoke specific message types from being allowed to be sent by a client.

$ hivemind-core blacklist-msg "speak"
  • When to use:
    Use this command to prevent specific message types from being sent by a client, adding a layer of control over communication.

blacklist-skill / allow-skill / blacklist-intent / allow-intent (OVOS-policy)

Skill and intent filtering is an OVOS-specific concern handled by OVOSAgentPolicy (shipped with hivemind-ovos-agent-plugin). These commands manage the skill_blacklist / intent_blacklist lists in Client.metadata; OVOSAgentPolicy injects them into the OVOS session. They take effect only when that policy is configured in policy.chain. — hivemind_core/scripts.py

$ hivemind-core blacklist-skill "skill-weather" 1   # writes Client.metadata["skill_blacklist"]
$ hivemind-core allow-skill "skill-weather" 1
$ hivemind-core blacklist-intent "intent.check_weather" 1  # writes Client.metadata["intent_blacklist"]
$ hivemind-core allow-intent "intent.check_weather" 1

set-metadata

Set arbitrary Client.metadata on an existing client. Metadata keys are consumed by policy plugins — OVOSAgentPolicy reads skill_blacklist / intent_blacklist; other policies read their own keys. Merge a JSON object, set a single entry, or remove a key:

$ hivemind-core set-metadata 1 --metadata '{"tier":"pro","region":"eu"}'   # merge
$ hivemind-core set-metadata 1 --key skill_blacklist --value '["skill-weather"]'
$ hivemind-core set-metadata 1 --key tier --value pro    # non-JSON value kept as a string
$ hivemind-core set-metadata 1 --unset region            # remove a key

listen

Start the HiveMind instance to listen for client connections.

$ hivemind-core listen
  • When to use:
    Use this command to start the HiveMind instance, enabling it to accept connections from clients (e.g., satellite devices). Configure the host, port, and security options as needed.


🧩 Plugins Overview

Category Plugin Description
Network Protocol hivemind-websocket-protocol Provides WebSocket-based communication for Hivemind, enabling real-time data exchange.
hivemind-http-protocol Provides HTTP-based communication for Hivemind, ideal for when a persistent connected is undesirable/not-possible
Binary Protocol hivemind-audio-binary-protocol Listens for incoming audio and processes it using the ovos-plugin-manager, enabling seamless interaction between Hivemind and audio input systems.
Agent Protocol OpenVoiceOS Integration with OpenVoiceOS, facilitated by ovos-bus-client, enabling seamless communication with OVOS systems.
Persona LLM (Large Language Model) integration provided by ovos-persona, works with all OpenAI server compatible projects.
Database hivemind-sqlite-database SQLite-based database solution for managing local data within Hivemind applications.
hivemind-redis-database Redis integration for scalable, in-memory database solutions with fast data access.
hivemind-json-database A JSON-based database plugin provided by json-database, offering lightweight storage and retrieval using JSON format.

💬 Clients Overview

Category Client Description
Satellites Voice Satellite Standalone OVOS local audio stack for Hivemind.
Voice Relay Lightweight audio satellite, STT/TTS processed server side, requires hivemind-audio-binary-protocol.
Mic Satellite Only VAD runs on device, audio streamed and fully processed server side, requires hivemind-audio-binary-protocol.
Web Chat Client-side browser Hivemind connection for web-based communication.
Bridges Mattermost Bridge Bridge for talking to Hivemind via Mattermost
Matrix Bridge Bridge for talking to Hivemind via Matrix
DeltaChat Bridge Bridge for talking to Hivemind via DeltaChat

🚀 Next Steps


⚖️ License

HiveMind-core is licensed under the Apache License 2.0, matching the rest of the HiveMind ecosystem.

💡 Releases ≤ hivemind-core 3.4.0 were Apache-2.0. The 4.x series shipped under AGPL-3.0 as a short-lived experiment; from this release forward HiveMind-core returns to Apache-2.0. Previously published 3.x and 4.x releases on PyPI remain under the licence they were published with.

Trademark

The names HiveMind, HiveMind-core, HiveMind Protocol, the HiveMind logos, and any "HiveMind Compatible / Powered by HiveMind" marks are protected trademarks and are not licensed under Apache-2.0 (see Apache-2.0 §6). See TRADEMARK-USAGE.md for the brand-use policy. A no-cost trademark grant is available for nonprofits, academic projects, and OSI-licensed downstreams.

Supporting the project

If your organisation depends on HiveMind-core in production, consider sponsoring the project, contracting paid support / custom integrations, or commissioning proprietary skills. Contact: jarbasai@mailfence.com.


🤝 Contributing

HiveMind-core welcomes external contributions. Inbound code is licensed under Apache-2.0 by default (per Apache-2.0 §5 — no separate CLA needed).

  • Bugs & features — open an issue on GitHub.
  • Pull requests — target the dev branch. Keep changes focused; follow existing code style.
  • DiscussionMatrix chat.

About

Central HiveMind hub server: connects satellite devices and AI agents to an OVOS instance over an encrypted mesh protocol

Topics

Resources

License

Stars

Watchers

Forks

Sponsor this project

Packages

 
 
 

Contributors

Languages