apt-ostree/docs/README.md
robojerk 75f5d2fc05
Some checks failed
Build apt-ostree Package / Build apt-ostree Package (push) Failing after 2m12s
Test apt-ostree Build / Test apt-ostree Build (with existing libostree) (push) Failing after 2m36s
Getting ready to move out of heavy alpha development. Created ci/cd
2025-07-22 04:43:43 +00:00

433 lines
No EOL
12 KiB
Markdown

# apt-ostree Documentation
## Overview
apt-ostree is a Debian/Ubuntu equivalent of rpm-ostree, providing a hybrid image/package system that combines the strengths of APT package management with OSTree's atomic, immutable deployment model.
## Current Status (December 2024)
### ✅ **MAJOR MILESTONES ACHIEVED**
#### **1. Architecture Foundation - COMPLETE**
-**Daemon-Client Architecture**: Proper rpm-ostree-style daemon-client model implemented
-**D-Bus Communication**: Full D-Bus integration with fallback mechanisms
-**Systemd Services**: Core daemon service with proper integration
-**Security Model**: Privileged operations isolated in daemon
#### **2. CLI Compatibility - 100% COMPLETE**
-**All 21 rpm-ostree Commands**: Fully implemented with identical interfaces
-**Command Architecture**: Proper daemon-based commands with client fallback
-**Option Parsing**: Complete CLI option compatibility
-**Output Formatting**: JSON and text output matching rpm-ostree
#### **3. Core Functionality - WORKING**
-**Package Management**: Real APT integration with DEB package handling
-**OSTree Integration**: Atomic commit creation and deployment management
-**Bubblewrap Sandboxing**: Complete script execution sandboxing
-**Transaction Management**: Atomic operations with rollback support
#### **4. OCI Integration - COMPLETE**
-**Container Image Generation**: `apt-ostree compose build-chunked-oci`
-**Base Image Resolution**: Pull from OCI registries
-**Bootc Compatibility**: Generate bootc-compatible images with proper labels
-**Registry Integration**: Push/pull from container registries
#### **5. Real OSTree Environment Testing - COMPLETE**
-**OSTree Repository Operations**: Initialize, commit, checkout working
-**Package Operations**: List, search, install simulation working
-**OCI Image Generation**: From real OSTree commits working
-**Bootc-Compatible Images**: Proper OCI structure with bootc labels
-**Deployment Simulation**: Checkout and deployment management working
-**Rollback Simulation**: Rollback point creation and management working
-**System Upgrade Simulation**: Upgrade workflow working
### 🔄 **CURRENT DEVELOPMENT PHASE**
#### **End-to-End Workflow Testing**
-**Complete Aurora-Style Workflow**: From package installation to OCI deployment
-**Real OSTree Environment**: Working with actual OSTree repositories
-**OCI Image Validation**: Image generation and inspection working
-**Bootc Integration**: Compatible image generation working
### 🎯 **NEXT PRIORITIES**
#### **1. Production Readiness (HIGHEST PRIORITY)**
- [ ] **Performance Optimization**: Optimize package operations for large sets
- [ ] **Error Handling**: Comprehensive error scenarios and recovery
- [ ] **Documentation**: Complete user guides and API documentation
- [ ] **Packaging**: Debian/Ubuntu package creation
#### **2. Real Package Installation Testing**
- [ ] **Root Package Installation**: Test with actual `apt-get install`
- [ ] **Large Package Sets**: Performance testing with real packages
- [ ] **Dependency Resolution**: Complex package dependency handling
- [ ] **Transaction Rollback**: Real rollback testing
#### **3. Bootc Integration Validation**
- [ ] **Bootc Image Validation**: Test generated images with bootc
- [ ] **Deployment Testing**: Real bootc deployment workflow
- [ ] **Update Workflow**: Test bootc update process
- [ ] **Rollback Testing**: Test bootc rollback functionality
## Architecture
### Daemon-Client Model
```
┌─────────────────┐ D-Bus ┌─────────────────┐
│ apt-ostree │ ──────────► │ apt-ostreed │
│ (Client) │ │ (Daemon) │
└─────────────────┘ └─────────────────┘
│ │
│ Fallback │
▼ │
┌─────────────────┐ │
│ AptOstreeSystem │ │
│ (Client-only) │ │
└─────────────────┘ │
┌─────────────────┐
│ OSTree/APT │
│ Operations │
└─────────────────┘
```
### Key Components
#### **Client (`apt-ostree`)**
- Command-line interface
- Option parsing and validation
- D-Bus communication with daemon
- Fallback to client-only operations
#### **Daemon (`apt-ostreed`)**
- Privileged operations
- Transaction management
- OSTree repository operations
- APT package management
#### **D-Bus Interface**
- `org.aptostree.dev.Daemon`
- Method-based communication
- Transaction monitoring
- Progress reporting
## Installation
### Prerequisites
- Rust toolchain (1.70+)
- OSTree development libraries
- APT development libraries
- Bubblewrap (for sandboxing)
### Build and Install
```bash
# Clone repository
git clone https://github.com/your-org/apt-ostree.git
cd apt-ostree
# Build
cargo build --release
# Install
sudo ./apt-ostree-complete-fix.sh
```
### Verify Installation
```bash
# Test daemon communication
sudo apt-ostree daemon-ping
# Test command fallback
apt-ostree status
# Test full workflow
sudo apt-ostree install package-name
```
## Bootc Integration
### Why Bootc?
Bootc is essential for the **Aurora-style workflow** - a modern approach to system deployment that treats operating systems as container images. This enables:
- **Container-native deployments**: Deploy systems like containers
- **Atomic updates**: Transactional system updates with rollback
- **Immutable infrastructure**: Predictable, reproducible deployments
- **Cloud-native workflows**: Integration with container registries and CI/CD
### Installing Bootc
Bootc is available as a Debian package from the Forgejo repository:
```bash
# Add the Forgejo repository
curl -fsSL https://git.raines.xyz/api/packages/robojerk/debian/repository.key | sudo gpg --dearmor -o /usr/share/keyrings/forgejo-robojerk.gpg
echo "deb [signed-by=/usr/share/keyrings/forgejo-robojerk.gpg] https://git.raines.xyz/api/packages/robojerk/debian noble main" | sudo tee /etc/apt/sources.list.d/forgejo-robojerk.list
# Update package lists
sudo apt update
# Install libostree 2025.2-1 packages (required dependency)
sudo apt install -y libostree-dev=2025.2-1~noble1 libostree-1-1=2025.2-1~noble1
# Install bootc
sudo apt install -y bootc
```
### Aurora-Style Workflow with apt-ostree
The complete Aurora-style workflow combines apt-ostree and bootc:
```bash
# 1. Create OSTree commit with apt-ostree
sudo apt-ostree install nginx apache2
# 2. Build OCI image from commit
apt-ostree compose build-chunked-oci --rootfs /var/lib/apt-ostree/repo --output my-system:latest --bootc
# 3. Deploy with bootc
bootc install oci:my-system:latest
# 4. Boot into new deployment
bootc status
```
### Bootc Package Repository
The bootc package is maintained in a separate repository:
- **Repository**: [bootc-deb](https://git.raines.xyz/robojerk/bootc-deb)
- **Package**: [bootc 1.5.1-1~noble1](https://git.raines.xyz/robojerk/-/packages/debian/bootc/1.5.1-1~noble1)
- **Dependencies**: libostree-1-1 (>= 2025.2), systemd, podman|docker.io, skopeo
## Usage
### Basic Commands
```bash
# System status
apt-ostree status
# Install packages
sudo apt-ostree install nginx apache2
# System upgrade
sudo apt-ostree upgrade
# Rollback deployment
sudo apt-ostree rollback
# Search packages
apt-ostree search web-server
# List installed packages
apt-ostree list
```
### Advanced Commands
```bash
# Deploy specific commit
sudo apt-ostree deploy <commit-hash>
# Apply changes live
sudo apt-ostree apply-live
# Manage kernel arguments
sudo apt-ostree kargs --append "console=ttyS0"
# Package overrides
sudo apt-ostree override replace package-name=version
# Database operations
apt-ostree db diff commit1 commit2
```
### Compose Commands
```bash
# Create deployment from base
apt-ostree compose create --base ubuntu:24.04 --packages nginx
# Build OCI image
apt-ostree compose build-chunked-oci --source my-deployment --output my-image:latest
# Build bootc-compatible OCI image
apt-ostree compose build-chunked-oci --rootfs /var/lib/apt-ostree/repo --output my-system:latest --bootc
# List available bases
apt-ostree compose list
```
## Development
### Project Structure
```
src/
├── main.rs # CLI application
├── lib.rs # Library interface
├── daemon_client.rs # D-Bus client library
├── system.rs # System integration
├── apt.rs # APT package management
├── ostree.rs # OSTree operations
├── oci.rs # OCI image operations
├── bubblewrap_sandbox.rs # Script sandboxing
├── package_manager.rs # High-level package operations
└── bin/
└── apt-ostreed.rs # D-Bus daemon
```
### Building
```bash
# Development build
cargo build
# Release build
cargo build --release
# Run tests
cargo test
# Run specific binary
cargo run --bin apt-ostree -- --help
cargo run --bin apt-ostreed
```
### Testing
```bash
# Test architecture
./test-architecture.sh
# Test daemon communication
sudo apt-ostree daemon-ping
# Test command fallback
apt-ostree status
# Test OCI image generation
./test-aurora-style-workflow.sh
```
## Contributing
### Development Setup
1. Install Rust toolchain
2. Install system dependencies
3. Clone repository
4. Run `cargo build` to verify setup
### Code Style
- Follow Rust conventions
- Use `cargo fmt` for formatting
- Use `cargo clippy` for linting
- Write tests for new functionality
### Testing Guidelines
- Unit tests for all modules
- Integration tests for workflows
- Architecture tests for daemon communication
- Performance tests for critical paths
## Roadmap
### Short Term (Next 2-4 weeks)
- [ ] Real OSTree environment testing
- [ ] Performance optimization
- [ ] Comprehensive error handling
### Medium Term (Next 2-3 months)
- [ ] Production deployment testing
- [ ] Advanced features (multi-arch, security)
- [ ] Documentation and user guides
- [ ] Package distribution
### Long Term (Next 6-12 months)
- [ ] Enterprise features
- [ ] Cloud integration
- [ ] Advanced security features
- [ ] Community adoption
## Troubleshooting
### Common Issues
#### Daemon Not Starting
```bash
# Check daemon status
sudo systemctl status apt-ostreed
# View logs
sudo journalctl -u apt-ostreed -f
# Restart daemon
sudo systemctl restart apt-ostreed
```
#### D-Bus Communication Issues
```bash
# Test D-Bus connection
sudo apt-ostree daemon-ping
# Check D-Bus policy
sudo cat /etc/dbus-1/system.d/org.aptostree.dev.conf
# Reload D-Bus
sudo systemctl reload dbus
```
#### Permission Issues
```bash
# Check user permissions
id
# Verify sudo access
sudo -l
# Check file permissions
ls -la /usr/libexec/apt-ostreed
```
#### Bootc Integration Issues
```bash
# Verify bootc installation
bootc --help
# Check libostree version
dpkg -l | grep libostree
# Test OCI image compatibility
skopeo inspect oci:my-system:latest
```
## Support
### Getting Help
- Check this documentation
- Review troubleshooting section
- Search existing issues
- Create new issue with details
### Reporting Bugs
- Include system information
- Provide error messages
- Describe steps to reproduce
- Include relevant logs
### Feature Requests
- Describe use case
- Explain expected behavior
- Provide examples
- Consider implementation complexity
## License
This project is licensed under the same terms as rpm-ostree. See LICENSE file for details.
## Acknowledgments
- rpm-ostree project for architecture inspiration
- OSTree project for deployment technology
- Debian/Ubuntu communities for package management
- Rust community for excellent tooling
- Bootc project for Aurora-style workflow integration