An open API service indexing awesome lists of open source software.

https://github.com/greysquirr3l/shadowforge

Production-grade quantum-resistant steganography toolkit in Go. Implements 7 image/audio/text techniques, Kyber-1024 and Dilithium3, Reed-Solomon error correction, and 4 distribution patterns via a full CLI, following Clean Architecture (DDD + CQRS).
https://github.com/greysquirr3l/shadowforge

audio-processing clean-architecture cli cqrs cryptography ddd dilithium go image-processing kyber post-quantum-cryptography pqc reed-solomon security steganography

Last synced: 5 months ago
JSON representation

Production-grade quantum-resistant steganography toolkit in Go. Implements 7 image/audio/text techniques, Kyber-1024 and Dilithium3, Reed-Solomon error correction, and 4 distribution patterns via a full CLI, following Clean Architecture (DDD + CQRS).

Awesome Lists containing this project

README

          

# Shadowforge

![Shadowforge Logo](docs/assets/shadowforge-logo.png)

> **"Forge secrets in the shadows, shield them from quantum eyes"**

[![Go Version](https://img.shields.io/badge/Go-1.21+-00ADD8?style=flat&logo=go)](https://go.dev/)
[![License](https://img.shields.io/badge/License-Apache%202.0-blue.svg)](LICENSE)
[![Status](https://img.shields.io/badge/Status-v0.7.6-brightgreen.svg)](https://github.com/greysquirr3l/shadowforge/releases)
[![Build](https://img.shields.io/badge/Build-Passing-success.svg)](https://github.com/greysquirr3l/shadowforge)
[![Coverage](https://img.shields.io/badge/Coverage-66%25+-brightgreen.svg)](https://github.com/greysquirr3l/shadowforge)
[![Lines of Code](https://img.shields.io/badge/Lines-60K+-blue.svg)](https://github.com/greysquirr3l/shadowforge)
[![Go Code](https://img.shields.io/badge/Go%20Code-42K+-00ADD8.svg)](https://github.com/greysquirr3l/shadowforge)

**Shadowforge** is a production-grade quantum-resistant steganography tool that combines
NIST-approved post-quantum cryptography, Reed-Solomon error correction, and multiple
steganographic techniques. Built with Domain-Driven Design (DDD) and Command Query
Responsibility Segregation (CQRS) patterns.

## ๐ŸŽฏ Project Vision

Shadowforge provides military-grade data hiding with post-quantum security, designed to
withstand both current and future cryptographic attacks. The system supports multiple
distribution patterns, from simple one-to-one embedding to complex distributed networks
with `K-of-N` threshold recovery.

## โญ Key Features

### Post-Quantum Cryptography

- **Kyber-1024** (NIST-approved KEM) for encryption
- **Dilithium3** (NIST-approved) for digital signatures
- Constant-time operations to prevent timing attacks
- Secure memory handling with automatic key zeroing

### Reed-Solomon Error Correction

- Configurable data/parity shard ratios
- K-of-N threshold recovery (need only K shards from N total)
- Corruption detection and automatic recovery
- Up to 50% redundancy for maximum fault tolerance

### Steganography Techniques (7/7 Complete)

- **Image**: LSB (PNG/BMP), DCT (JPEG), Palette (GIF/PNG) โœ…
- **Audio**: Phase encoding (DSSS), Echo hiding, LSB audio โœ…
- **Text**: Zero-width characters (Unicode ZWSP/ZWJ) โœ…
- Capacity-aware embedding with statistical analysis โœ…

### Distribution Patterns

- **One-to-One**: Traditional steganography (1 payload โ†’ 1 cover)
- **One-to-Many**: Distributed secret splitting (1 payload โ†’ N covers)
- **Many-to-One**: Batch embedding (N payloads โ†’ 1 cover)
- **Many-to-Many**: Complex distribution matrix (N payloads โ†’ M covers)

### Archive Support

- ZIP, TAR, TAR.GZ format support
- Archive-to-archive workflows
- Nested archive handling
- Automatic format detection

## ๐Ÿ“ˆ Project Statistics

- **Total Lines**: 60,322 (44,174 code, 6,654 comments, 9,494 blanks)
- **Go Code**: 41,671 lines across 185 files
- **Comment Ratio**: 13% (5,385 comment lines)
- **Languages**: Go (primary), Python, Shell, Markdown, Makefile
- **Bounded Contexts**: 8 (Crypto, Error Correction, Stego, Media, Analysis, Distribution, Reconstruction, Archive)
- **Implementation Files**: 185+ Go files
- **Test Files**: 50+ comprehensive test suites
- **Test Coverage**: 85%+ (90%+ for crypto operations)
- **Distribution Patterns**: 4 (all operational)
- **Steganography Techniques**: 7/7 (100% complete)
- **CLI Binary Size**: 8.2MB (fully self-contained)
- **Shell Completions**: Bash, Fish, Zsh (all commands covered)

## ๐Ÿ—๏ธ Architecture

Shadowforge follows **Clean Architecture** principles with clear separation of concerns:

```text
โ”Œโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”
โ”‚ Interface Layer (CLI/API) โ”‚
โ”‚ โ”œโ”€ Cobra CLI commands โ”‚
โ”‚ โ””โ”€ Echo REST API endpoints โ”‚
โ”œโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ค
โ”‚ Application Layer (CQRS) โ”‚
โ”‚ โ”œโ”€ Command Handlers โ”‚
โ”‚ โ”œโ”€ Query Handlers โ”‚
โ”‚ โ””โ”€ Application Services โ”‚
โ”œโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ค
โ”‚ Domain Layer (8 Bounded Contexts) โ”‚
โ”‚ โ”œโ”€ Cryptography โ”‚
โ”‚ โ”œโ”€ Error Correction โ”‚
โ”‚ โ”œโ”€ Steganography โ”‚
โ”‚ โ”œโ”€ Media Processing โ”‚
โ”‚ โ”œโ”€ Security Analysis โ”‚
โ”‚ โ”œโ”€ Distribution โ”‚
โ”‚ โ”œโ”€ Reconstruction โ”‚
โ”‚ โ””โ”€ Archive โ”‚
โ”œโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ค
โ”‚ Infrastructure Layer โ”‚
โ”‚ โ”œโ”€ CIRCL PQC integration โ”‚
โ”‚ โ”œโ”€ Reed-Solomon implementation โ”‚
โ”‚ โ”œโ”€ File I/O and media processing โ”‚
โ”‚ โ””โ”€ External service adapters โ”‚
โ””โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”˜
```

## ๐Ÿ› ๏ธ Technology Stack

| Category | Technology |
|----------|-----------|
| **Language** | Go 1.21+ |
| **Architecture** | DDD + CQRS + Clean Architecture |
| **PQC** | [cloudflare/circl](https://github.com/cloudflare/circl) |
| **Error Correction** | [klauspost/reedsolomon](https://github.com/klauspost/reedsolomon) |
| **CLI** | [spf13/cobra](https://github.com/spf13/cobra) |
| **API** | [labstack/echo](https://github.com/labstack/echo) |
| **Testing** | [stretchr/testify](https://github.com/stretchr/testify), [golang/mock](https://github.com/golang/mock) |
| **Logging** | log/slog (stdlib) |

## ๏ฟฝ Visual Comparison: Original vs Steganographic Image

See the power of steganography - these images look identical to the human eye, yet
one contains encrypted quantum-resistant data:

Original Image


Original Image


Clean cover media - no hidden data

Stego Image


Steganographic Image


Visually identical - contains encrypted payload

### ๐Ÿ” What's Hidden Inside the Stego Image?

The steganographic image contains multiple layers of protection:

**Layer 1: Post-Quantum Encryption** (Kyber-1024)

- Encrypted payload protected against quantum computer attacks
- NIST-approved cryptographic standard
- 256-bit shared secret key

**Layer 2: Digital Signature** (Dilithium3)

- Cryptographic proof of authenticity
- Tamper detection mechanism
- Post-quantum signature scheme

**Layer 3: Reed-Solomon Error Correction**

- Configurable redundancy (typically 30-50%)
- Automatic corruption detection and repair
- Graceful degradation with partial data recovery

**Layer 4: Steganographic Embedding**

- LSB (Least Significant Bit) technique for PNG images
- Imperceptible modifications to pixel values
- Statistical distribution preserved to avoid detection

### ๐Ÿ“Š Technical Details

| Metric | Original | Stego Image | Change |
|--------|----------|-------------|--------|
| **File Size** | ~770 KB | ~770 KB | <0.1% |
| **Visual Appearance** | Natural landscape | Identical | 0% (imperceptible) |
| **Pixel Modifications** | 0 pixels | ~2.3% pixels | LSB changes only |
| **Hidden Payload** | None | ~35 bytes | Encrypted data |
| **Error Correction** | None | 30% redundancy | Reed-Solomon parity |
| **Detectability** | N/A | Chi-square: -13 dB | Statistically undetectable |

### ๐Ÿ›ก๏ธ Security Properties

- **Encryption**: Payload encrypted with Kyber-1024 (quantum-resistant)
- **Integrity**: Dilithium3 digital signature ensures authenticity
- **Resilience**: Reed-Solomon allows recovery even with 30% data loss
- **Stealth**: Embedding preserves statistical properties of original image
- **Capacity**: ~0.1% of cover image size used (minimal detection risk)

**Note**: The modifications are made to the least significant bits of pixel color values,
making them invisible to human perception while maintaining the image's statistical properties
to evade steganalysis detection.

## ๐Ÿ“š Documentation

**๐ŸŒ Web Documentation**: [greysquirr3l.github.io/shadowforge](https://greysquirr3l.github.io/shadowforge/)

Complete documentation available in [`docs/public/cli/`](docs/public/cli/):

**Getting Started:**

- [Installation](docs/public/cli/installation.md)
- [Getting Started Guide](docs/public/cli/getting-started.md)
- [Quick Reference](docs/public/cli/quick-reference.md)

**Commands:**

- [Complete reference for all 8 command categories](docs/public/cli/commands/README.md)

**Guides:**

- [Advanced Usage](docs/public/cli/guides/advanced.md)
- [Security Hardening](docs/public/cli/guides/security.md)

**Reference:**

- [Glossary](docs/public/cli/glossary.md)
- [Use Cases](docs/public/cli/use-cases.md)
- [FAQ](docs/public/cli/faq.md)

**Help:**

- [Best Practices](docs/public/cli/best-practices.md)
- [Troubleshooting](docs/public/cli/troubleshooting.md)
- [Security](docs/public/cli/security.md)

## ๐Ÿ“ฆ Installation

**Status**: CLI application is fully functional with 7 production-ready steganography
techniques and all 4 distribution patterns.

### Homebrew (macOS/Linux)

```bash
brew tap greysquirr3l/shadowforge
brew install shadowforge
```

### Download Binary

Download pre-built binaries from [GitHub Releases](https://github.com/greysquirr3l/shadowforge/releases/latest):

- macOS (Intel): `shadowforge_*_darwin_amd64.tar.gz`
- macOS (Apple Silicon): `shadowforge_*_darwin_arm64.tar.gz`
- Linux (x64): `shadowforge_*_linux_amd64.tar.gz`
- Linux (ARM64): `shadowforge_*_linux_arm64.tar.gz`

```bash
# Example: Install on macOS Apple Silicon
VERSION=0.7.6
curl -L -O https://github.com/greysquirr3l/shadowforge/releases/download/v${VERSION}/shadowforge_${VERSION}_darwin_arm64.tar.gz
tar -xzf shadowforge_${VERSION}_darwin_arm64.tar.gz
sudo mv shadowforge_${VERSION}_darwin_arm64/shadowforge /usr/local/bin/
shadowforge version
```

### From Source

**Prerequisites**: Go 1.21 or higher, Git

### Build from Source

```bash
# Clone the repository
git clone https://github.com/greysquirr3l/shadowforge.git
cd shadowforge

# Install dependencies
go mod download

# Build the CLI
make build

# Run tests
make test

# Optional: Install shell completions
# Bash
sudo cp scripts/completion/shadowforge.bash /etc/bash_completion.d/shadowforge

# Fish
cp scripts/completion/shadowforge.fish ~/.config/fish/completions/shadowforge.fish

# Zsh
cp scripts/completion/shadowforge.zsh ~/.zsh/completion/_shadowforge
# Add to ~/.zshrc: fpath=(~/.zsh/completion $fpath)
```

## ๐Ÿš€ Quick Start

### CLI Usage (Available Now)

The CLI is **fully functional** with real backend integration:

```bash
# Build the CLI
make build
# Or: go build -o bin/shadowforge ./cmd/cli
```

### Current CLI Commands

```bash
# Generate PQC key pair
shadowforge keygen --algorithm kyber1024 --output keys/

# Encrypt and embed (one-to-one)
shadowforge embed \
--input secret.txt \
--cover image.png \
--output stego.png \
--key keys/public.key

# Distributed embedding (one-to-many with K-of-N recovery)
shadowforge embed-distributed \
--input document.pdf \
--covers covers/*.png \
--data-shards 10 \
--parity-shards 5 \
--output-archive stego-bundle.zip

# Extract from stego media
shadowforge extract \
--input stego.png \
--key keys/private.key \
--output recovered.txt

# Analyze capacity
shadowforge analyze capacity --cover image.png --technique lsb

# Forensic watermarking (PNG directories)
# Works for KaTeX formula PNGs, or PDF pages rendered to PNG.
# Note: encryption + signature are enabled by default.
shadowforge watermark embed \
--recipient "Jane Smith " \
--gpg-key ./keys/jane-key.pub \
--input-dir ./formulas \
--output-dir ./watermarked \
--receipt ./watermark-receipt.md

# Extract (decrypt) the watermark (requires the same receipt)
shadowforge watermark extract \
--input-dir ./watermarked \
--output ./recovered-watermark.json \
--receipt ./watermark-receipt.md

# Verify authenticity + expected values (requires receipt)
shadowforge watermark verify \
--input-dir ./watermarked \
--expected-recipient "Jane Smith" \
--gpg-key ./keys/jane-key.pub \
--receipt ./watermark-receipt.md
```

### Forensic Watermarking (Receipts)

Shadowforge can embed a **forensic watermark** across a directory of PNG images.
If your source is a PDF, the intended workflow is: render PDF pages to PNG โ†’ watermark the PNGs โ†’ rebuild the PDF.
By default, watermark payloads are:

- **Encrypted** (Kyber-1024 + symmetric encryption)
- **Signed** (Dilithium3)
- **Distributed** across images with Reed-Solomon error correction

When encryption is enabled (default), pass `--receipt` during `watermark embed` to write a
Markdown receipt containing the per-watermark decryption key material.

- Treat the receipt like a **private key**.
- Without the receipt, you **cannot decrypt** or fully verify encrypted watermarks later.

For complete details and troubleshooting, see `internal/domain/watermark/README.md`.

### Planned API Usage

> Note: The REST API server is a future item. Weโ€™re prioritizing a CLI-first release and
have temporarily deferred API work until after distribution prep. Releases are manual-only
for now; the endpoints below illustrate the forthcoming server.

```bash
# Start API server
shadowforge-api --port 8080

# Embed via REST API
curl -X POST http://localhost:8080/api/v1/embed \
-H "Content-Type: application/json" \
-d '{
"payload": "base64_encoded_data",
"cover": "base64_encoded_image",
"algorithm": "kyber1024",
"technique": "lsb"
}'
```

## ๐Ÿ“Š Development Status

### Current Version: **v0.7.6** (December 2025)

### Current Phase: **Phase 5 Complete โ€” CLI Production Ready**

| Phase | Status | Description |
|-------|--------|-------------|
| **Phase 1** | โœ… Complete | Foundation (DDD+CQRS architecture, 83 files) |
| **Phase 2** | โœ… Complete | Core Domain (Crypto, Error Correction, Media) |
| **Phase 3** | โœ… Complete | Steganography Techniques (all 7/7 production-ready) |
| **Phase 4** | โœ… Complete | Distribution Patterns (all 4 patterns operational) |
| **Phase 5** | โœ… Complete | CLI Application (fully functional, 8.2MB binary) |
| **Phase 6** | โณ Future Item | REST API Server (Echo framework, deferred) |
| **Phase 7** | โณ Planned | Security Hardening (audit, penetration testing) |
| **Phase 8** | ๐Ÿšง In Progress | CI/CD prep (manual-only release workflow), Homebrew formula/docs |
| **Phase 9** | โณ Planned | Production Readiness (final hardening and deployment) |

Note: API is deferred; focus is on finalizing CI/CD and Homebrew distribution with manual-only releases.

### Recent Achievements (December 2025)

**Phase 3 - Steganography Techniques (100% Complete - 7/7)**:

- โœ… **LSB Image** (PNG/BMP) - 235 lines, 15 tests, 100% data integrity
- โœ… **DCT JPEG** - 294 lines + jpegdct, 19 tests, 100% data integrity
- โœ… **Zero-Width Text** - 400+ lines, 15 tests, 100% data integrity
- โœ… **Palette** (GIF/PNG) - 560 lines, 20+ tests, 100% data integrity
- โœ… **LSB Audio** (WAV) - 350 lines, 12 tests, 100% data integrity
- โœ… **Phase Encoding** (WAV) - 466 lines, 10 tests, DSSS with adaptive alpha
- โœ… **Echo Hiding** (WAV) - 421 lines, 10 tests, autocorrelation-based

**Phase 4 - Distribution Patterns (100% Complete)**:

- โœ… One-to-One pattern (traditional steganography)
- โœ… One-to-Many pattern (distributed K-of-N secret splitting)
- โœ… Many-to-One pattern (batch aggregation)
- โœ… Many-to-Many pattern (matrix distribution with 4 modes)
- โœ… 2,978 lines of implementation code
- โœ… 13/13 integration tests passing (100% coverage)
- โœ… Worker pool architecture for parallel processing
- โœ… HMAC-protected manifest serialization

**Phase 5 - CLI Application (100% Complete)**:

- โœ… Fully functional CLI (`bin/shadowforge` 8.2MB)
- โœ… Real backend integration (no simulation)
- โœ… Commands: embed, extract, analyze, keygen, formats, archive
- โœ… All 7 steganography techniques operational
- โœ… All 4 distribution patterns working

## ๐Ÿงช Testing

Shadowforge follows strict testing standards:

- **Domain Logic**: 85%+ coverage required
- **Cryptographic Operations**: 90%+ coverage required
- **Command/Query Handlers**: 80%+ coverage required
- **Race Detection**: All tests run with `-race` flag
- **Table-Driven Tests**: Comprehensive scenario coverage

```bash
# Run all tests
go test -v -race ./...

# Run tests with coverage
go test -v -race -cover ./...

# Run specific domain tests
go test -v -race ./internal/domain/crypto/

# Generate coverage report
go test -coverprofile=coverage.out ./...
go tool cover -html=coverage.out
```

## ๐Ÿ”’ Security

### Security-First Principles

- โœ… Constant-time cryptographic operations
- โœ… Automatic key zeroing after use
- โœ… No panic/recover in production code
- โœ… All errors handled explicitly
- โœ… Input validation on all boundaries
- โœ… Secure random number generation (crypto/rand)
- โœ… Statistical analysis for detectability

### Cryptographic Standards

- **NIST Post-Quantum Standards** (Kyber-1024, Dilithium3)
- **Argon2id** for password-based key derivation
- **AES-256-GCM** for symmetric encryption
- **SHA3/SHAKE** for hashing and extendable output

### Security Audit Status

โš ๏ธ **Pre-Production**: This software has NOT been externally security audited. While it
uses production-grade cryptography (NIST PQC standards) and has comprehensive test coverage,
do not use in production environments until Phase 7 (Security Hardening) is complete.

**Current Security Measures**:

- โœ… 90%+ test coverage for cryptographic operations
- โœ… All tests pass with race detector
- โœ… Constant-time operations for crypto
- โœ… Secure memory handling (auto key zeroing)
- โš ๏ธ External audit pending (Phase 7)

## ๐Ÿ“š Documentation

## ๐Ÿค Contributing

Contributions are welcome! Please follow these guidelines:

1. Read the [Go Instructions](.github/instructions/go.instructions.md)
2. Follow Clean Architecture boundaries
3. Maintain 80%+ test coverage
4. Run `go fmt`, `go vet`, and `golangci-lint`
5. All tests must pass with `-race` flag
6. Document security-critical code thoroughly

### Development Workflow

```bash
# Create feature branch
git checkout -b feature/your-feature-name

# Make changes and test
go test -v -race ./...

# Format and lint
go fmt ./...
go vet ./...
golangci-lint run

# Commit with conventional commits
git commit -m "feat(domain): add new bounded context"

# Push and create PR
git push origin feature/your-feature-name
```

## ๐ŸŽฏ Roadmap

### โœ… Completed (December 2025)

- โœ… **Phase 1-4**: Foundation, Core Domain, Steganography, Distribution
- โœ… **Phase 5**: CLI Application (fully functional)
- โœ… All 4 distribution patterns operational
- โœ… 5/7 steganography techniques production-ready
- โœ… Comprehensive test coverage (31/31 tests passing)

### ๐Ÿš€ Next: Phase 6 - REST API Server (Q1 2026)

- Full-featured REST API
- Async operation support
- WebSocket progress updates

### Phase 7: Security Hardening (Q2 2026)

- External security audit
- Penetration testing
- Production hardening

### Phase 8: Testing & Documentation (Q3 2026)

- E2E test suite
- Performance benchmarks
- Complete user documentation

### Phase 9: Production Release (Q3 2026)

- CI/CD pipeline
- Multi-platform releases
- Docker images

## ๐Ÿ“„ License

Apache License 2.0 - See [LICENSE](LICENSE) for details.

## โš ๏ธ Disclaimer

This software is provided "as is" without warranty of any kind. The developers are not
responsible for any misuse of this software. Shadowforge is designed for legitimate privacy
and security purposes only. Always comply with applicable laws and regulations.

## ๐Ÿ”— Links

- **Website**:
- **GitHub**:
- **Documentation**: [docs/public/cli/](https://greysquirr3l.github.io/shadowforge/cli/)
- **Issues**:
- **Releases**:

---

**Built with ๐ŸŒฎ and quantum-resistant cryptography**

*Last Updated: December 2025*