Metadata-Version: 2.4
Name: aitronos-cli
Version: 0.2.0
Summary: Unified CLI for managing all Aitronos services
Author-email: Aitronos Team <team@aitronos.com>
License: MIT
Project-URL: Homepage, https://aitronos.com
Project-URL: Documentation, https://docs.aitronos.com/cli
Project-URL: Repository, https://github.com/aitronos/cli
Project-URL: Issues, https://github.com/aitronos/cli/issues
Keywords: aitronos,cli,streamline,automation,ai,assistants
Classifier: Programming Language :: Python :: 3
Classifier: Programming Language :: Python :: 3.9
Classifier: Programming Language :: Python :: 3.10
Classifier: Programming Language :: Python :: 3.11
Classifier: Programming Language :: Python :: 3.12
Classifier: Programming Language :: Python :: 3.13
Classifier: License :: OSI Approved :: MIT License
Classifier: Operating System :: OS Independent
Classifier: Development Status :: 4 - Beta
Classifier: Intended Audience :: Developers
Classifier: Topic :: Software Development :: Libraries :: Python Modules
Requires-Python: >=3.9
Description-Content-Type: text/markdown
License-File: LICENSE
Requires-Dist: requests>=2.28.0
Requires-Dist: pyyaml>=6.0
Requires-Dist: simple-term-menu>=1.6.0
Requires-Dist: pyjwt>=2.8.0
Requires-Dist: python-dotenv>=1.0.0
Provides-Extra: dev
Requires-Dist: pytest>=7.0.0; extra == "dev"
Requires-Dist: pytest-cov>=4.0.0; extra == "dev"
Requires-Dist: coverage>=7.0.0; extra == "dev"
Requires-Dist: ruff>=0.1.0; extra == "dev"
Requires-Dist: bandit>=1.7.0; extra == "dev"
Requires-Dist: pip-audit>=2.6.0; extra == "dev"
Requires-Dist: simple-term-menu>=1.6.0; extra == "dev"
Dynamic: license-file

# Aitronos CLI

Unified command-line interface for managing all Aitronos services, including Streamline automations, AI assistants, and more.

## Installation

### Via pip (Recommended for Python developers)

```bash
pip install aitronos-cli
```

### Via Homebrew (Recommended for macOS/Linux)

```bash
# Add the Aitronos tap
brew tap aitronos/tap

# Install the CLI
brew install aitronos-cli
```

### Verify Installation

```bash
aitronos --version
```

## Quick Start

### 1. Authentication

Login to your Aitronos account:

```bash
aitronos auth login
```

### 2. Streamline Automations

Initialize a new Streamline project:

```bash
aitronos streamline init
```

Upload an automation:

```bash
aitronos streamline upload
```

Link a GitHub repository:

```bash
aitronos streamline link-repo
```

Execute an automation:

```bash
aitronos streamline execute <automation-id>
```

### 3. View Logs

```bash
aitronos streamline logs <automation-id>
```

## Features

- **Authentication**: Secure login with email verification
- **Streamline Automations**: Create, upload, and manage automations
- **GitHub Integration**: Link repositories for automatic syncing
- **Execution Management**: Run automations and view real-time logs
- **Template Support**: Initialize projects from templates
- **Interactive Menus**: User-friendly navigation with arrow keys

## Commands

### Authentication

- `aitronos auth login` - Login to your account
- `aitronos auth logout` - Logout from your account
- `aitronos auth status` - Check authentication status

### Streamline

- `aitronos streamline init` - Initialize a new project/repository
- `aitronos streamline upload` - Upload automation manually
- `aitronos streamline link-repo` - Link GitHub repository
- `aitronos streamline list` - List all automations
- `aitronos streamline execute <id>` - Execute an automation
- `aitronos streamline logs <id>` - View execution logs
- `aitronos streamline sync <id>` - Sync automation from GitHub
- `aitronos streamline delete <id>` - Delete an automation
- `aitronos streamline schedule <id>` - Set execution schedule
- `aitronos streamline remove-schedule <id>` - Remove schedule

## Configuration

The CLI stores configuration in `~/.aitronos/`:

- `config.yaml` - General configuration
- `auth.json` - Authentication tokens (never share this file)

## Development

### Setup Development Environment

```bash
# Clone repository
git clone https://github.com/Aitronos-Development/aitronos.cli.git
cd aitronos.cli

# Install UV (if not already installed)
# macOS/Linux:
curl -LsSf https://astral.sh/uv/install.sh | sh
# Or via Homebrew:
brew install uv

# Install dependencies
uv sync

# Install in editable mode for development
uv pip install -e .
```

### Running in Development Mode

#### Option 1: Direct Python Execution (Recommended for Testing)

```bash
# Run the CLI directly without installing
uv run python -m aitronos_cli.cli --help

# Test specific commands
uv run python -m aitronos_cli.cli auth login
uv run python -m aitronos_cli.cli streamline init
uv run python -m aitronos_cli.cli streamline list
```

#### Option 2: Editable Install (Recommended for Full Testing)

```bash
# Install in editable mode
uv pip install -e .

# Now you can use the CLI as if it were installed
aitronos --help
aitronos auth login
aitronos streamline init
```

#### Option 3: Using the Entry Point Script

```bash
# Run directly from the source
uv run aitronos --help
uv run aitronos auth status
```

### Testing Changes

```bash
# Make changes to the code
vim aitronos_cli/cli.py

# Test immediately (no reinstall needed with editable mode)
aitronos --version

# Or run directly
uv run python -m aitronos_cli.cli --version
```

### Running Tests

```bash
# Run all tests
uv run pytest tests/

# Run with coverage
uv run pytest tests/ --cov=aitronos_cli --cov-report=term

# Run specific test file
uv run pytest tests/test_auth.py

# Run tests in verbose mode
uv run pytest tests/ -v
```

### Code Quality

The project uses strict compliance checks:

```bash
# Run all compliance checks
./start-compliance.sh

# Run specific checks
uvx ruff check .              # Linting
uvx ruff format --check .     # Format check
uvx ruff format .             # Auto-format code
uvx bandit -r aitronos_cli/   # Security scan
uv run pytest tests/ --cov    # Tests with coverage
```

### Debugging Tips

```bash
# Enable verbose output
aitronos --verbose streamline list

# Check configuration
cat ~/.aitronos/config.yaml
cat ~/.aitronos/auth.json

# Test API connectivity
uv run python -c "from aitronos_cli.config import config; print(config.get_api_url())"

# Clear authentication (for testing login flow)
rm ~/.aitronos/auth.json
```

### Common Development Tasks

```bash
# Add a new dependency
uv add requests

# Add a development dependency
uv add --dev pytest

# Update dependencies
uv sync

# Check for outdated packages
uv pip list --outdated

# Run linting and auto-fix issues
uvx ruff check --fix .
```

## Contributing

1. Fork the repository
2. Create a feature branch (`git checkout -b feat/amazing-feature`)
3. Make your changes
4. Run tests and compliance checks
5. Commit your changes (`git commit -m 'feat: add amazing feature'`)
6. Push to the branch (`git push origin feat/amazing-feature`)
7. Open a Pull Request

### Branch Naming Conventions

- `feat/` - New features
- `fix/` - Bug fixes
- `docs/` - Documentation updates
- `refactor/` - Code refactoring
- `test/` - Test additions/improvements

## Documentation

- [Deployment Guide](docs/DEPLOYMENT.md) - How to deploy new versions
- [API Documentation](https://docs.aitronos.com/api) - Backend API reference
- [Compliance Guide](scripts/compliance/README.md) - Code quality standards

## Support

- **Documentation**: https://docs.aitronos.com
- **Issues**: https://github.com/Aitronos-Development/aitronos.cli/issues
- **Email**: support@aitronos.com

## License

MIT License - see [LICENSE](LICENSE) for details

## Changelog

See [CHANGELOG.md](CHANGELOG.md) for version history and changes.
