AcmeX
AcmeX is a modular, enterprise-grade ACME v2 (RFC 8555) client and server ecosystem written in Rust. It is designed for high performance, reliability, and extensibility, supporting various DNS providers, storage backends, and cryptographic libraries. AcmeX enables automated certificate lifecycle management with advanced features like OCSP verification, multi-provider DNS-01 challenges, and a RESTful management API.
🏗 Architecture
AcmeX follows a layered design to ensure separation of concerns and ease of maintenance:
- Application Layer: CLI and REST API (Axum-based) entry points for user interaction.
- Orchestration Layer: High-level workflow management for provisioning, validation, and renewal processes.
- Scheduling Layer: Task execution and concurrency management for asynchronous operations.
- Protocol Layer: Low-level ACME implementation (JWS, Nonce management, Directory handling).
- Storage Tier: Pluggable backends (File, Redis, Memory, Encrypted) for persistence.
- Certificate Tier: Chain verification, CSR generation, and OCSP status checking for security.
🚀 Key Features
- Full ACME v2 Support: Complete implementation of RFC 8555, including all challenge types and account management.
- Asynchronous Execution: Non-blocking task polling for long-running operations, ensuring responsiveness.
- Multiple Challenge Types: Support for
HTTP-01,DNS-01, andTLS-ALPN-01challenges. - Extensive DNS Support: Built-in providers for Cloudflare, AWS Route53, Alibaba Cloud, Azure, Google Cloud, Huawei, Tencent, and more.
- Flexible Storage: Support for local files, Redis, and encrypted storage backends.
- Multi-CA Support: Integration with Let's Encrypt, Google CA, ZeroSSL, and custom ACME servers.
- Observability: Integrated metrics (Prometheus), structured logging (Tracing), and OpenTelemetry support.
- Security First: Memory safety via Rust,
zeroizefor sensitive data, and RFC 7807 error reporting. - CLI and API: Command-line interface and RESTful API for easy integration and management.
- Feature Gates: Optional dependencies for DNS providers, storage backends, and crypto libraries to keep the core lightweight.
🛠 Installation
Add AcmeX to your Cargo.toml:
[]
= "0.8.0"
Feature Flags
Enable optional features as needed:
[]
= "0.8.0"
= ["dns-cloudflare", "redis", "cli"]
Available features:
- Crypto:
aws-lc-rs(default),ring-crypto - Storage:
redis - DNS Providers:
dns-cloudflare,dns-route53,dns-alibaba,dns-azure,dns-google,dns-huawei,dns-tencent, etc. - CAs:
google-ca,zerossl-ca - Other:
metrics,cli
📖 Quick Start
Basic Certificate Issuance
use *;
async
Running the API Server
# Build and run the server
Example acmex.toml:
[]
= "0.0.0.0"
= 8080
= "your-secret-api-key"
[]
= "file"
= "./data"
[]
= "https://acme-v02.api.letsencrypt.org/directory"
= "admin@example.com"
🛠 Development
Prerequisites
- Rust 1.92+
- Docker (for Redis testing)
Building
Running Tests
Examples
Explore the examples/ directory for more usage patterns:
📄 Documentation
Detailed documentation is available in the docs directory:
- Architecture Overview
- DNS Providers Guide
- API Implementation
- Observability Guide
- V0.8.0 Release Notes
API documentation: docs.rs/acmex
🤝 Contributing
We welcome contributions! Please see our Contributing Guide for details on how to get started.
Reporting Issues
- GitHub Issues
- For security issues, please email housemecn@gmail.com
📜 License
Licensed under either of:
- Apache License, Version 2.0 (LICENSE-APACHE or http://www.apache.org/licenses/LICENSE-2.0)
- MIT license (LICENSE-MIT or http://opensource.org/licenses/MIT)
at your option.