Metadata-Version: 2.4
Name: kubed
Version: 2.4.0
Summary: One small layout file instead of heavy discovery — agent-friendly infra index for Kubernetes, Docker, Terraform, Helm plus shell completions
Home-page: https://cmds.daleyarborough.com
Author: Dale Yarborough
Author-email: Dale Yarborough <daleyarborough@gmail.com>
License: MIT
Project-URL: Homepage, https://cmds.daleyarborough.com
Project-URL: Repository, https://github.com/dalefrieswthat/kubed.git
Classifier: Development Status :: 5 - Production/Stable
Classifier: Intended Audience :: Developers
Classifier: License :: OSI Approved :: MIT License
Classifier: Operating System :: OS Independent
Classifier: Programming Language :: Python :: 3
Classifier: Programming Language :: Python :: 3.6
Classifier: Programming Language :: Python :: 3.7
Classifier: Programming Language :: Python :: 3.8
Classifier: Programming Language :: Python :: 3.9
Classifier: Programming Language :: Python :: 3.10
Classifier: Programming Language :: Python :: 3.11
Classifier: Topic :: Software Development :: Libraries :: Python Modules
Requires-Python: >=3.6
Description-Content-Type: text/markdown
Requires-Dist: click
Requires-Dist: rich
Requires-Dist: pyyaml
Requires-Dist: requests
Requires-Dist: docker
Requires-Dist: kubernetes
Requires-Dist: helm
Dynamic: author
Dynamic: home-page
Dynamic: requires-python

# Kubed

**One small context file instead of heavy discovery.**

CLI and context tooling for Kubernetes, Docker, Terraform, and Helm. Kubed writes a single `.kubed/layout.json` that captures your entire infra layout—Dockerfiles, Terraform, Helm charts, K8s resources, project structure, and cross-repo shared infra. Agents can read that one file (~1,500 tokens) instead of running 10+ discovery commands whose output can reach 50,000+ tokens. Fewer context tokens, faster answers.

| Without Kubed | With Kubed |
|---------------|------------|
| 50,000+ tokens (discovery output) | ~1,500 tokens (one file) |
| 10+ tool calls | 1 file read |
| Repeated discovery | Snapshot-based |

- **Docs:** [cmds.daleyarborough.com](https://cmds.daleyarborough.com)
- **Layout index:** `kubed layout capture` writes `.kubed/layout.json`; `kubed layout show` prints it. Schema: [docs/LAYOUT_SCHEMA.md](docs/LAYOUT_SCHEMA.md).
- **Reducing tokens in Cursor:** [docs/reducing-token-usage.md](docs/reducing-token-usage.md) — use the layout instead of discovery, read one section when possible, narrow @-mentions.

## Installation (Python package)

```bash
pip install kubed
kubed-setup
```

Non-interactive: `kubed-setup --force-yes`. See [cmds.daleyarborough.com](https://cmds.daleyarborough.com) for full docs.

## Layout commands (Go binary)

Build the binary (requires Go 1.21+):

```bash
make build   # outputs build/kubed
# or: go build -o build/kubed ./cmd/kubed
```

- **`kubed layout capture`** — Index infra paths, project structure, shared infra, and (optionally) K8s resources; write `.kubed/layout.json`. Optional: `--all-namespaces`.
- **`kubed layout show`** — Print `layout.json` to stdout.

### Learned cache (accumulated knowledge)

- **`kubed learned show`** — Print `.kubed/learned.json` (facts, paths, deps, patterns accumulated across sessions).
- **`kubed learned summary`** — Quick summary: "3 facts, 2 paths, 5 deps, 1 patterns".
- **`kubed learned add-fact "fact" [--category=X] [--source=Y]`** — Add a discovered fact.
- **`kubed learned add-path "/path" "description" [--tags=a,b]`** — Add an important path.
- **`kubed learned add-dep "name" [--kind=X] [--version=Y]`** — Add a dependency.

Agents read `learned.json` first to avoid re-discovering the same things. When the agent learns something useful (architecture, dependencies, patterns), it persists it so future sessions benefit.

*This repo does not use Kubernetes; we validate layout with `make test` (fixture-based agent-query tests).*

## Development: test before pushing

Run **`make verify`** before pushing to main (same idea as Kubernetes: only working, quality code).

```bash
make verify   # runs go vet + tests (unit + agent-query tests)
make test     # tests only
make build    # build binary
make help     # list targets
```

Tests include **agent-query tests**: given a layout fixture, they assert that the data passed to an agent/LLM answers questions like "what workloads exist?", "what does service X select?", "what configmaps does deployment Y use?". See `internal/layout/query_test.go`.

---

# Kubed Documentation (site)

This is the documentation website for the Kubed CLI tool, built with Jekyll and Tailwind CSS.

## Setup

### Prerequisites

- Ruby 2.7+ with Bundler
- Node.js 14+ with npm

### Installation

1. Install Ruby dependencies:

```bash
bundle install
```

2. Install Node.js dependencies:

```bash
npm install
```

### Development

To run the site locally with live reload:

```bash
npm run dev
```

You can then access the site at http://localhost:4000

### Building for Production

```bash
npm run build:css
bundle exec jekyll build
```

The site will be generated in the `_site` directory.

### Content

- `index.md`: The home page
- `/docker/`, `/kubernetes/`, `/terraform/`, `/helm/`: Tool-specific documentation
- `installation.md`: Installation instructions

---

## License

MIT. See the LICENSE file for details.

## Contributing

Contributions are welcome. Please open an issue or submit a pull request.

## Contact

[cmds.daleyarborough.com](https://cmds.daleyarborough.com) · daleyarborough@gmail.com
