HoxCore - A meta-manager for organizational objects (projects, missions, activities, programs)
Project description
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
HoxCore manages your projects using a simple file-based system. It operates on a Registry (a directory on your disk) that holds various Entities (Programs, Projects, Missions, or Actions) stored as individual files. This mental model allows you to maintain full control over your data while using simple CLI commands to organize your workflow.
Available Commands
| Command | Description |
|---|---|
init |
Initialize a new registry |
create |
Create a new entity (project, program, mission, action) |
list |
List entities with optional filters |
show |
Show full details of a specific entity |
get |
Get a specific property from an entity |
edit |
Edit properties of an entity |
delete |
Delete an entity from the registry |
validate |
Validate registry integrity |
registry |
Manage registry location |
mcp |
Start the MCP server for LLM access |
Quick Start Guide
1. Initialize a Registry
Set up your first registry to start storing entities.
# Initialize a registry in the current directory
hxc init
# Initialize in a specific directory
hxc init ~/my-registry
# Initialize without git integration
hxc init --no-git
2. Create Entities
Add projects, programs, missions, or actions to your registry.
# Create a basic project
hxc create project "My First Project"
# Create a project with a description, tags, and due date
hxc create project "API Redesign" --description "Redesign the public API" --tags backend api --due-date 2025-06-01
# Create a program (container for projects)
hxc create program "Q2 Initiatives"
# Create a mission (execution-oriented, time-bound)
hxc create mission "Deploy v2.0"
# Create an action (ongoing, no end date)
hxc create action "Monitor system health"
3. List and Inspect
View your registry content and drill down into details.
# List all projects
hxc list project
# List all entities in the registry
hxc list all
# Filter by status or tag
hxc list project --status active
hxc list project --tag backend
# Show full details of a specific entity
hxc show <uid>
# Get a specific property
hxc get <uid> status
4. Edit and Delete
Update or remove entities as your tasks progress.
# Change status or add a tag
hxc edit <uid> --set-status completed
hxc edit <uid> --add-tag backend
# Set a new due date
hxc edit <uid> --set-due-date 2025-06-01
# Delete an entity (prompts for confirmation)
hxc delete <uid>
# Delete immediately without prompt
hxc delete <uid> --force
Getting Help
If you need more information about a specific command or general flags:
# General help
hxc --help
# Command-specific help
hxc create --help
hxc list --help
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:
- Create a new file in
src/hxc/commands/(e.g.,mycommand.py) - Define a class that inherits from
BaseCommand - Use the
@register_commanddecorator to register it - Implement
register_subparserandexecutemethods
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
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 hoxcore-0.1.2.tar.gz.
File metadata
- Download URL: hoxcore-0.1.2.tar.gz
- Upload date:
- Size: 44.4 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
068c1e14e3d7d5790dc3fb64490000a88d637e5968fa15c345a4f453fa7d2d2d
|
|
| MD5 |
555b100a2b2f6c290015d5f4079e4339
|
|
| BLAKE2b-256 |
1510e85d5fd5581afd184bd21159c39d404d1880a51693cd522dcc105b367bd0
|
Provenance
The following attestation bundles were made for hoxcore-0.1.2.tar.gz:
Publisher:
publish.yml on SDEscobedo/hoxcore
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
hoxcore-0.1.2.tar.gz -
Subject digest:
068c1e14e3d7d5790dc3fb64490000a88d637e5968fa15c345a4f453fa7d2d2d - Sigstore transparency entry: 1042615816
- Sigstore integration time:
-
Permalink:
SDEscobedo/hoxcore@a7250cdd5b1a14e8fc2677c01aa1e082b08faa99 -
Branch / Tag:
refs/heads/master - Owner: https://github.com/SDEscobedo
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@a7250cdd5b1a14e8fc2677c01aa1e082b08faa99 -
Trigger Event:
push
-
Statement type:
File details
Details for the file hoxcore-0.1.2-py3-none-any.whl.
File metadata
- Download URL: hoxcore-0.1.2-py3-none-any.whl
- Upload date:
- Size: 56.9 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
6fabaf37240237dd98376694983a606f875506168b6834dca66d84e4414b8aea
|
|
| MD5 |
7498490d503f234fc5c0453d23067d4d
|
|
| BLAKE2b-256 |
c530dc5892bb8d5f658ffe8b5c69cac068f3a2ef3bf8de0e325ee0c69c45ceb1
|
Provenance
The following attestation bundles were made for hoxcore-0.1.2-py3-none-any.whl:
Publisher:
publish.yml on SDEscobedo/hoxcore
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
hoxcore-0.1.2-py3-none-any.whl -
Subject digest:
6fabaf37240237dd98376694983a606f875506168b6834dca66d84e4414b8aea - Sigstore transparency entry: 1042615818
- Sigstore integration time:
-
Permalink:
SDEscobedo/hoxcore@a7250cdd5b1a14e8fc2677c01aa1e082b08faa99 -
Branch / Tag:
refs/heads/master - Owner: https://github.com/SDEscobedo
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@a7250cdd5b1a14e8fc2677c01aa1e082b08faa99 -
Trigger Event:
push
-
Statement type: