Skip to content

Managing ACME Servers

This guide covers managing ACME server configurations after initial setup, including modifying settings, monitoring usage, and decommissioning servers.


Viewing ACME Servers

Navigate to AdminACME Servers to see all ACME server configurations for your tenant. The list displays:

  • Name — The server's display name
  • Status — Active or Inactive
  • Accounts — Number of registered accounts
  • Orders — Total orders processed
  • Certificates — Total certificates issued

Select a server to view details and modify settings.


Server Settings

General Settings

Setting Description Can Modify
Name Display name Yes
Description Optional description Yes
Status Active or Inactive Yes
UUID Unique identifier (part of directory URL) No

Certificate Settings

Setting Description Can Modify
Intermediate Certificate PKI intermediate used for signing Yes (affects new certificates only)
Default Validity (days) Default certificate lifetime (1–825) Yes
Maximum Validity (days) Maximum certificate lifetime Yes
Default Algorithm Key algorithm (e.g., ec-384) Yes
Default Digest Digest algorithm (e.g., sha384) Yes

Directory Metadata

These settings are surfaced in the ACME directory response:

Setting Description
Terms of Service URL Link to your certificate policy
Website URL Link to documentation or support
CAA Identities Certificate Authority Authorization identities

Activating and Deactivating Servers

Deactivating a Server

Setting a server to Inactive immediately stops it from processing new requests:

  • The directory endpoint returns an error
  • New account registrations are rejected
  • New orders cannot be created
  • Existing certificates remain valid until their expiry

To deactivate:

  1. Navigate to the server's detail page
  2. Set Status to Inactive
  3. Save changes

Note: Deactivating a server does not revoke existing certificates or invalidate existing accounts. Clients with valid certificates will continue to operate until renewal time, at which point they will fail if the server remains inactive.

Reactivating a Server

Set Status to Active to resume operations. Existing accounts and their domain bindings remain intact.


Changing the Intermediate Certificate

You can change which intermediate certificate signs new certificates:

  1. Navigate to the server's detail page
  2. Select a new Intermediate Certificate from the dropdown
  3. Save changes

Important: This affects only certificates issued after the change. Existing certificates retain their original chain. If you are rotating your PKI, ensure clients trust both the old and new intermediates during the transition period.


Validity Period Settings

Default Validity

The default certificate lifetime used when: - The ACME client does not specify notBefore or notAfter in the order - The requested validity exceeds the maximum

Maximum Validity

The hard limit for certificate lifetime. Orders requesting a longer validity are capped to this value. The maximum allowed by the platform is 825 days (approximately 27 months), aligning with CA/Browser Forum guidelines.

Recommendations

Environment Default Validity Maximum Validity
Production 90 days 365 days
Development/Testing 30 days 90 days
High-security 30 days 90 days

Shorter validity periods reduce the impact of key compromise and encourage automation.


Rate Limits

The ACME server configuration includes optional rate limit settings:

Setting Description
Orders per account per hour Maximum new orders an account can create per hour
Certificates per domain per week Maximum certificates for a single domain per week

Note: Rate limits are configured but not currently enforced. They are reserved for future implementation.


Viewing Orders and Certificates

From the server detail page, you can view:

Orders Tab

Lists all orders placed against this server:

  • Order ID — Unique identifier
  • Account — The requesting account
  • Status — pending, ready, processing, valid, or invalid
  • Domains — Requested identifiers
  • Created — Order timestamp
  • Expires — Order expiry time

Certificates Tab

Lists all certificates issued by this server:

  • Serial Number
  • Common Name
  • Subject Alternative Names
  • Validity Period
  • Algorithm
  • Status — Valid, Expired, or Revoked

Audit Logging

All ACME operations are logged to the platform's audit log:

Event Description
acme.account_created New account registration
acme.order_created New certificate order
acme.order_finalized CSR submitted for signing
acme.certificate_issued Certificate successfully issued
acme.authorization_failed Domain authorization denied

Navigate to AdminAudit Log and filter by event type to review ACME activity.


Deleting an ACME Server

An ACME server configuration can only be deleted if it has no associated accounts. To delete:

  1. Deactivate the server
  2. Delete all accounts (or wait for them to naturally expire if applicable)
  3. Navigate to the server detail page
  4. Select Delete

Warning: Deleting a server removes all configuration. The UUID is not reused. Any ACME clients configured to use this server's directory URL will fail.


Multiple ACME Servers

You can create multiple ACME server configurations for different purposes:

Use Case Configuration
Environment separation Separate servers for dev, staging, production
Different validity policies Shorter validity for external certificates, longer for internal
Different PKI hierarchies Different intermediate certificates for different purposes
Organisational separation Different servers for different business units

Each server has an independent URL namespace, account space, and configuration.


Directory Endpoint

The directory URL is the entry point for ACME clients:

https://your-region.zaita.com/acme/{server-uuid}/directory

A GET or POST request to this URL returns:

{
  "newNonce": "https://.../acme/{uuid}/new-nonce",
  "newAccount": "https://.../acme/{uuid}/new-account",
  "newOrder": "https://.../acme/{uuid}/new-order",
  "revokeCert": "https://.../acme/{uuid}/revoke-cert",
  "keyChange": "https://.../acme/{uuid}/key-change",
  "meta": {
    "termsOfService": "https://example.com/tos",
    "website": "https://example.com",
    "caaIdentities": ["example.com"],
    "externalAccountRequired": true
  }
}

Next Steps