Skip to main content

Cloudflare client library for kiarina namespace

Project description

kiarina-lib-cloudflare-auth

A Python library for Cloudflare authentication with configuration management using pydantic-settings-manager.

Features

  • Configuration Management: Use pydantic-settings-manager for flexible configuration
  • Type Safety: Full type hints and Pydantic validation
  • Secure Credential Handling: API tokens are protected using SecretStr
  • Multiple Configurations: Support for multiple named configurations (e.g., different accounts)
  • Environment Variable Support: Configure via environment variables with KIARINA_LIB_CLOUDFLARE_AUTH_ prefix

Installation

pip install kiarina-lib-cloudflare-auth

Quick Start

Basic Usage

from kiarina.lib.cloudflare.auth import CloudflareAuthSettings, settings_manager

# Configure Cloudflare authentication
settings_manager.user_config = {
    "default": {
        "account_id": "your-account-id",
        "api_token": "your-api-token"
    }
}

# Get settings
settings = settings_manager.settings
print(f"Account ID: {settings.account_id}")
print(f"API Token: {settings.api_token.get_secret_value()}")  # Access secret value

Environment Variable Configuration

Configure authentication using environment variables:

export KIARINA_LIB_CLOUDFLARE_AUTH_ACCOUNT_ID="your-account-id"
export KIARINA_LIB_CLOUDFLARE_AUTH_API_TOKEN="your-api-token"
from kiarina.lib.cloudflare.auth import settings_manager

# Settings are automatically loaded from environment variables
settings = settings_manager.settings
print(f"Account ID: {settings.account_id}")

Multiple Configurations

Manage multiple Cloudflare accounts:

from kiarina.lib.cloudflare.auth import settings_manager

# Configure multiple accounts
settings_manager.user_config = {
    "production": {
        "account_id": "prod-account-id",
        "api_token": "prod-api-token"
    },
    "staging": {
        "account_id": "staging-account-id",
        "api_token": "staging-api-token"
    }
}

# Switch between configurations
settings_manager.active_key = "production"
prod_settings = settings_manager.settings
print(f"Production Account: {prod_settings.account_id}")

settings_manager.active_key = "staging"
staging_settings = settings_manager.settings
print(f"Staging Account: {staging_settings.account_id}")

Configuration

This library uses pydantic-settings-manager for flexible configuration management.

CloudflareAuthSettings

The CloudflareAuthSettings class provides the following configuration fields:

Field Type Required Description
account_id str Yes Cloudflare account ID
api_token SecretStr Yes Cloudflare API token (masked in logs)

Environment Variables

All settings can be configured via environment variables with the KIARINA_LIB_CLOUDFLARE_AUTH_ prefix:

# Account ID
export KIARINA_LIB_CLOUDFLARE_AUTH_ACCOUNT_ID="your-account-id"

# API Token (will be automatically wrapped in SecretStr)
export KIARINA_LIB_CLOUDFLARE_AUTH_API_TOKEN="your-api-token"

Programmatic Configuration

from pydantic import SecretStr
from kiarina.lib.cloudflare.auth import CloudflareAuthSettings, settings_manager

# Direct settings object
settings = CloudflareAuthSettings(
    account_id="your-account-id",
    api_token=SecretStr("your-api-token")
)

# Via settings manager
settings_manager.user_config = {
    "default": {
        "account_id": "your-account-id",
        "api_token": "your-api-token"  # Automatically converted to SecretStr
    }
}

Runtime Overrides

from kiarina.lib.cloudflare.auth import settings_manager

# Override specific settings at runtime
settings_manager.cli_args = {
    "account_id": "override-account-id"
}

settings = settings_manager.settings
print(f"Account ID: {settings.account_id}")  # Uses overridden value

Security

API Token Protection

API tokens are stored using Pydantic's SecretStr type, which provides the following security benefits:

  • Masked in logs: Tokens are displayed as ********** in string representations
  • Prevents accidental exposure: Tokens won't appear in debug output or error messages
  • Explicit access required: Must use .get_secret_value() to access the actual token
from kiarina.lib.cloudflare.auth import settings_manager

settings = settings_manager.settings

# Token is masked in string representation
print(settings)  # api_token=SecretStr('**********')

# Explicit access to get the actual token
token = settings.api_token.get_secret_value()

API Reference

CloudflareAuthSettings

class CloudflareAuthSettings(BaseSettings):
    account_id: str
    api_token: SecretStr

Pydantic settings model for Cloudflare authentication.

Fields:

  • account_id (str): Cloudflare account ID
  • api_token (SecretStr): Cloudflare API token (protected)

settings_manager

settings_manager: SettingsManager[CloudflareAuthSettings]

Global settings manager instance for Cloudflare authentication.

Properties:

  • settings: Get the current active settings
  • user_config: Get/set user configuration
  • cli_args: Get/set CLI arguments for runtime overrides
  • active_key: Get/set active configuration key (for multi-config mode)

Methods:

  • clear(): Clear cached settings
  • get_settings_by_key(key: str): Get settings by specific key

Development

Prerequisites

  • Python 3.12+

Setup

# Clone the repository
git clone https://github.com/kiarina/kiarina-python.git
cd kiarina-python

# Setup development environment
mise run setup

Running Tests

# Run format, lint, type checks and tests
mise run package kiarina-lib-cloudflare-auth

# Coverage report
mise run package:test kiarina-lib-cloudflare-auth --coverage

Dependencies

License

This project is licensed under the MIT License - see the LICENSE file for details.

Contributing

This is a personal project, but contributions are welcome! Please feel free to submit issues or pull requests.

Related Projects

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

kiarina_lib_cloudflare_auth-1.6.0.tar.gz (4.4 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

kiarina_lib_cloudflare_auth-1.6.0-py3-none-any.whl (4.4 kB view details)

Uploaded Python 3

File details

Details for the file kiarina_lib_cloudflare_auth-1.6.0.tar.gz.

File metadata

File hashes

Hashes for kiarina_lib_cloudflare_auth-1.6.0.tar.gz
Algorithm Hash digest
SHA256 28e1f0d4d82f171ae7cb6ff8712e8824d3e72e67331487b481a707ccc6fb0f2e
MD5 4da01dae70501656a6d77645e6c16f3b
BLAKE2b-256 0275197e5eef21a814cb2e3f88d99c2f1b2f3b45f5c3c0d942da217e925d7b84

See more details on using hashes here.

File details

Details for the file kiarina_lib_cloudflare_auth-1.6.0-py3-none-any.whl.

File metadata

File hashes

Hashes for kiarina_lib_cloudflare_auth-1.6.0-py3-none-any.whl
Algorithm Hash digest
SHA256 c56a4e4817583d9a04c935264e4aea085331460ce38e566b711bec01aadfe2f0
MD5 2bc84135dab78e29c4252a65b9ca821b
BLAKE2b-256 608c8cca624938dbd207f4812a8de4b0856c9aa5c9b680c92c3542c059ae20ce

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page