Skip to main content

HoxCore - A meta-manager for organizational objects (projects, missions, activities, programs)

Project description

HoxCore

Hoxcore

What is HoxCore?

HoxCore is a meta-manager — a low-level tool that centralizes the core metadata of organizational objects into a single, unified registry. Rather than managing execution or visualization directly, HoxCore acts as the foundational layer that independent software can build upon.

Organizational Object Types

HoxCore handles four categories of objects:

Type Orientation Description
Projects Goal-oriented Has a defined finalization point; decoupled from execution
Missions Event-oriented Linked to execution; tied to a specific occurrence or execution window
Activities Action-oriented No definite end; represents indefinite, ongoing progression
Programs Container Groups and organizes Projects, Missions, and/or Activities

Design Philosophy

HoxCore is intentionally minimal and low-level. It owns the metadata — everything else is up to you. Independent tools can be built on top of HoxCore for visualization, reporting, dashboards, or richer management interfaces, all reading from the same single source of truth.

Installation

From PyPI

pip install hoxcore

For Development

# Clone the repository
git clone https://github.com/SDEscobedo/hoxcore
cd hoxcore

# Create a virtual environment (optional but recommended)
python -m venv venv
source venv/bin/activate  # On Windows: venv\Scripts\activate

# Install in development mode
pip install -e .

Usage

$ hxc [command] [options]

Available Commands

  • command1: Example command
  • command2: Another example command

Examples

# Get help
$ hxc --help

# Get version information
$ hxc --version

# Get command-specific help
$ hxc command1 --help

# Execute commands
$ hxc command1 --option value
$ hxc command2 --flag input-value

MCP Server (Model Context Protocol)

HoxCore includes a built-in MCP server that exposes registry functionality to LLMs through a standardized interface. This allows AI assistants (like Claude) to interact with your HoxCore registries directly.

Starting the Server

# Start with the default or configured registry
hxc-mcp

# Start with a specific registry path
hxc-mcp --registry /path/to/your/registry

# Specify transport (currently only stdio is supported)
hxc-mcp --transport stdio

You can also start the server programmatically:

from hxc.mcp.server import create_server

server = create_server(registry_path="/path/to/registry")
server.run_stdio()

Connecting to Claude (or other MCP-compatible clients)

Add HoxCore to your MCP client configuration. For Claude Desktop, update your claude_desktop_config.json:

{
  "mcpServers": {
    "hoxcore": {
      "command": "hxc-mcp",
      "args": ["--registry", "/path/to/your/registry"]
    }
  }
}

Available Tools

The MCP server exposes four tools that an LLM can call:

Tool Description
list_entities List entities in the registry, with optional filters for type, status, tags, category, and parent
get_entity Retrieve a specific entity by its ID or UID
search_entities Full-text search across entity titles and descriptions
get_entity_property Fetch a specific property from an entity, with support for list indexing and key filtering

Available Resources

Resources are accessible via hxc:// URIs:

URI Description
hxc://entity/{identifier} A specific entity by ID or UID (YAML)
hxc://entities/{type} All entities of a given type (JSON)
hxc://hierarchy/{identifier} Entity hierarchy and relationships (JSON)
hxc://registry/stats Registry statistics and overview (JSON)
hxc://search?q={query} Search results for a query (JSON)

Extending the Server

You can register custom tools, resources, and prompts at runtime:

from hxc.mcp.server import create_server

server = create_server()

# Register a custom tool
def my_tool(registry_path=None, **kwargs):
    """My custom tool description."""
    return {"result": "..."}

server.register_tool("my_tool", my_tool)

# Register a custom prompt
server.register_prompt({
    "name": "my_prompt",
    "description": "A helpful prompt template",
    "arguments": [
        {"name": "context", "description": "Context for the prompt", "required": True}
    ]
})

server.run_stdio()

Development

Project Structure

project/
├── LICENSE
├── README.md
├── pyproject.toml
├── setup.py
├── src/
│   └── hxc/
│       ├── __init__.py
│       ├── cli.py
│       ├── commands/
│       │   ├── __init__.py
│       │   ├── base.py
│       │   ├── command1.py
│       │   └── command2.py
│       ├── core/
│       │   ├── __init__.py
│       │   └── config.py
│       ├── mcp/
│       │   ├── __init__.py
│       │   ├── server.py
│       │   ├── tools.py
│       │   ├── resources.py
│       │   └── prompts.py
│       └── utils/
│           ├── __init__.py
│           └── helpers.py
└── tests/
    ├── __init__.py
    ├── conftest.py
    ├── test_cli.py
    └── commands/
        ├── __init__.py
        ├── test_command1.py
        └── test_command2.py

Adding New Commands

To add a new command to the CLI:

  1. Create a new file in src/hxc/commands/ (e.g., mycommand.py)
  2. Define a class that inherits from BaseCommand
  3. Use the @register_command decorator to register it
  4. Implement register_subparser and execute methods

Example:

from hxc.commands import register_command
from hxc.commands.base import BaseCommand

@register_command
class MyCommand(BaseCommand):
    name = "mycommand"
    help = "My custom command"
    
    @classmethod
    def register_subparser(cls, subparsers):
        parser = super().register_subparser(subparsers)
        parser.add_argument('--myflag', help='My flag')
        return parser
    
    @classmethod
    def execute(cls, args):
        # Implement command logic here
        return 0

Running Tests

Make sure you have development dependencies installed:

pip install -e ".[dev]"

Run the tests:

# Run all tests
pytest

# Run with coverage
pytest --cov=hxc

# Run specific tests
pytest tests/test_cli.py

Important Test Setup

The project uses a src/ layout for better package organization. Make sure you have a conftest.py file in your tests directory with the following content to ensure tests can import the package correctly:

# tests/conftest.py
import os
import sys
from pathlib import Path

# Add the src directory to the Python path
src_path = Path(__file__).parent.parent / "src"
sys.path.insert(0, str(src_path))

Distribution

Building the package

python -m build

Publishing to PyPI

python -m twine upload dist/*

License

MIT

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

hoxcore-0.1.1.tar.gz (42.4 kB view details)

Uploaded Source

Built Distribution

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

hoxcore-0.1.1-py3-none-any.whl (56.0 kB view details)

Uploaded Python 3

File details

Details for the file hoxcore-0.1.1.tar.gz.

File metadata

  • Download URL: hoxcore-0.1.1.tar.gz
  • Upload date:
  • Size: 42.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for hoxcore-0.1.1.tar.gz
Algorithm Hash digest
SHA256 67db0363ca39448540e4f3d80516d511bc27f9425bcbcef621dc6be06f01ece9
MD5 38d7711d46514c873490ae8105d67d10
BLAKE2b-256 1b2e609a9449fb02c64f62b8b11c7b8d12fc1f0c70cb0663ff1fe5ffa15364b2

See more details on using hashes here.

Provenance

The following attestation bundles were made for hoxcore-0.1.1.tar.gz:

Publisher: publish.yml on SDEscobedo/hoxcore

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

File details

Details for the file hoxcore-0.1.1-py3-none-any.whl.

File metadata

  • Download URL: hoxcore-0.1.1-py3-none-any.whl
  • Upload date:
  • Size: 56.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for hoxcore-0.1.1-py3-none-any.whl
Algorithm Hash digest
SHA256 985f8844e1ed119039a751e11d0ea3b6655513ccf0cd2da7965c335ed1f5dbb6
MD5 b0f0293156b01e58a7a2bb25488d1cd1
BLAKE2b-256 5ff24d6db25d06d609720173cf76e41c69459b252dfcda3ffa32c77e728563fb

See more details on using hashes here.

Provenance

The following attestation bundles were made for hoxcore-0.1.1-py3-none-any.whl:

Publisher: publish.yml on SDEscobedo/hoxcore

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