Metadata-Version: 2.4
Name: waldur-site-agent
Version: 0.9.2
Summary: Agent for integrating service provider's site with Waldur Mastermind.
Project-URL: Homepage, https://waldur.com
Project-URL: Documentation, https://docs.waldur.com
Author-email: OpenNode Team <info@opennodecloud.com>
License-Expression: MIT
License-File: LICENCE.md
Classifier: Intended Audience :: Developers
Classifier: License :: OSI Approved :: MIT License
Classifier: Operating System :: OS Independent
Requires-Python: <4.0,>=3.9
Requires-Dist: importlib-metadata>=8.7.0; python_full_version == '3.9.*'
Requires-Dist: pydantic>=2.0.0
Requires-Dist: pyyaml==6.0.1
Requires-Dist: requests==2.32.3
Requires-Dist: sentry-sdk==2.3.1
Requires-Dist: stomp-py<9,>=8.2.0
Requires-Dist: structlog>=25.4.0
Requires-Dist: waldur-api-client>=8.0.4
Description-Content-Type: text/markdown

# Waldur Site Agent

A stateless Python application that synchronizes data between Waldur Mastermind and service provider
backends. Manages account creation, usage reporting, and membership synchronization across different cluster
management systems.

## Architecture

The agent uses a **uv workspace architecture** with pluggable backends:

- **Core Package**: `waldur-site-agent` (base classes, common utilities)
- **Plugin Packages**: Standalone backend implementations
  - `waldur-site-agent-slurm`: SLURM clusters
  - `waldur-site-agent-moab`: MOAB clusters
  - `waldur-site-agent-mup`: MUP portal
  - `waldur-site-agent-okd`: OpenShift/OKD platforms
  - `waldur-site-agent-harbor`: Harbor registries
  - `waldur-site-agent-croit-s3`: Croit S3 storage
  - `waldur-site-agent-cscs-dwdi`: CSCS DWDI accounting
  - `waldur-site-agent-basic-username-management`: Username management

### Agent Modes

- `order_process`: Fetches orders from Waldur and manages backend resources
- `report`: Reports usage data from backend to Waldur
- `membership_sync`: Synchronizes user memberships
- `event_process`: Event-based processing using STOMP

## Usage

```bash
waldur_site_agent -m <mode> -c <config-file>
```

## Logging

The agent emits structured logs in JSON format to stdout. This applies to both the core
agent and CLI tools.

Example log entry:

```json
{"event": "Running agent in order_process mode", "level": "info", "logger": "waldur_site_agent.backend", "timestamp": "2026-02-03T14:02:35.551020+00:00"}
```

### CLI Arguments

- `-m`, `--mode`: Agent mode (`order_process`, `report`, `membership_sync`, `event_process`)
- `-c`, `--config-file`: Path to configuration file

### Environment Variables

- `WALDUR_SITE_AGENT_ORDER_PROCESS_PERIOD_MINUTES`: Order processing period (default: 5)
- `WALDUR_SITE_AGENT_REPORT_PERIOD_MINUTES`: Reporting period (default: 30)
- `WALDUR_SITE_AGENT_MEMBERSHIP_SYNC_PERIOD_MINUTES`: Membership sync period (default: 5)
- `SENTRY_ENVIRONMENT`: Sentry environment name

## Development

```bash
# Install dependencies
uv sync --all-packages

# Run tests
uv run pytest

# Format and lint code
pre-commit run --all-files

# Load components into Waldur
waldur_site_load_components -c <config-file>
```

## Documentation

- [Architecture & Plugin Development](docs/architecture.md)
- [Installation Guide](docs/installation.md)
- [Configuration Reference](docs/configuration.md)
- [Deployment Guide](docs/deployment.md)
- [Username Management](docs/offering-users.md)
- [SLURM Usage Reporting Setup](docs/slurm-usage-reporting-setup.md)

## Plugin Documentation

### Compute & HPC Plugins

- [SLURM Plugin](plugins/slurm/README.md) - SLURM cluster management
- [MOAB Plugin](plugins/moab/README.md) - MOAB cluster management
- [MUP Plugin](plugins/mup/README.md) - MUP portal integration

### Container & Cloud Plugins

- [OpenShift/OKD Plugin](plugins/okd/README.md) - OpenShift and OKD container platform management
- [Harbor Plugin](plugins/harbor/README.md) - Harbor container registry management

### Storage Plugins

- [Croit S3 Plugin](plugins/croit-s3/README.md) - Croit S3 storage management

### Accounting Plugins

- [CSCS DWDI Plugin](plugins/cscs-dwdi/README.md) - CSCS DWDI accounting integration

### Utility Plugins

- [Basic Username Management Plugin](plugins/basic_username_management/README.md) - Username generation and management

## License

MIT License - see [LICENCE](./LICENCE.md) file for details.
