Skip to main content

Snowflake Key Pair Rotation Tool for Hevo Data destinations

Project description

Snowflake Key Pair Rotation Tool

PyPI version Python 3.8+ License: MIT

Automates Snowflake key-pair authentication setup and rotation with Hevo Data destinations.

Installation

From PyPI (Recommended)

pip install sf-rotation

From GitHub

pip install git+https://github.com/Legolasan/sf_rotation.git

From Source

git clone https://github.com/Legolasan/sf_rotation.git
cd sf_rotation
pip install .

Development Mode

git clone https://github.com/Legolasan/sf_rotation.git
cd sf_rotation
pip install -e .

Configuration

  1. Create a config file based on the example:
mkdir -p config
curl -o config/config.yaml https://raw.githubusercontent.com/Legolasan/sf_rotation/main/config/config.yaml.example
  1. Edit config/config.yaml with your credentials:
  • Snowflake account URL, admin credentials, target user
  • Hevo API credentials and destination details
  • Key encryption preferences

Usage

Command Line Interface

After installation, the sf-rotation command is available:

# Initial setup (creates new Hevo destination, saves destination_id to config)
sf-rotation setup --config config/config.yaml

# Update keys for existing destination (requires destination_id in config)
sf-rotation update-keys --config config/config.yaml

# Key rotation (for ongoing key rotations)
sf-rotation rotate --config config/config.yaml

# Snowflake-only setup (no Hevo integration)
sf-rotation snowflake-only --config config/config.yaml

# With encrypted private key
sf-rotation setup --config config/config.yaml --encrypted

Commands Overview

Command Description Hevo Integration
setup Initial setup - creates new Hevo destination Creates new
update-keys Update keys for existing Hevo destination Updates existing
rotate Rotate keys with zero-downtime (repeatable) Updates existing
snowflake-only Set up Snowflake keys only (no Hevo) None

Tip: Run rotate as many times as needed - it automatically alternates between Snowflake key slots.

As Python Module

python -m sf_rotation setup --config config/config.yaml
python -m sf_rotation rotate --config config/config.yaml
python -m sf_rotation snowflake-only --config config/config.yaml

Programmatic Usage

from sf_rotation import KeyGenerator, SnowflakeClient, HevoClient

# Generate keys (returns: private_key_path, public_key_path, backup_path)
generator = KeyGenerator(output_directory="./keys")
private_key_path, public_key_path, backup_path = generator.generate_key_pair(
    key_name="rsa_key",
    encrypted=False
)

# Connect to Snowflake
sf_client = SnowflakeClient(
    account_url="your_account.snowflakecomputing.com",
    username="admin",
    password="password"
)

# Set public key for user
public_key = generator.read_public_key(public_key_path)
formatted_key = generator.format_public_key_for_snowflake(public_key)
sf_client.set_rsa_public_key("target_user", formatted_key)

# Create Hevo destination
hevo = HevoClient(
    base_url="https://us.hevodata.com",
    username="hevo_user",
    password="hevo_pass"
)
private_key = generator.read_private_key(private_key_path)
hevo.create_destination(
    name="my_snowflake",
    account_url="your_account.snowflakecomputing.com",
    warehouse="WAREHOUSE",
    database_name="DATABASE",
    database_user="target_user",
    private_key=private_key
)

Features

  • Generate RSA 2048-bit key pairs (encrypted or non-encrypted)
  • Configure Snowflake users with RSA public keys
  • Create/update Hevo Data destinations with key-pair authentication
  • Seamless key rotation with automatic backup
  • CLI and programmatic interfaces

Process Flow

Setup Mode (New Destination)

  1. Generate RSA key pair
  2. Connect to Snowflake (username/password)
  3. Set RSA_PUBLIC_KEY for target user
  4. Create Hevo destination with private key
  5. Auto-save destination_id to config file

Update-Keys Mode (Existing Destination)

  1. Verify destination_id exists in config
  2. Generate RSA key pair
  3. Connect to Snowflake and set public key
  4. Update existing Hevo destination with private key

Rotate Mode (Key Rotation - Repeatable)

  1. Backup existing keys
  2. Generate new key pair
  3. Detect current key slot (RSA_PUBLIC_KEY or RSA_PUBLIC_KEY_2)
  4. Set new key in the alternate slot (zero-downtime)
  5. Update Hevo destination with new private key
  6. Unset the old key slot

Note: Rotation alternates between slots, allowing unlimited rotations without conflicts.

Snowflake-Only Mode (No Hevo)

  1. Generate RSA key pair
  2. Connect to Snowflake (username/password)
  3. Set RSA_PUBLIC_KEY for target user
  4. Does NOT interact with Hevo APIs

Use Case: Configure Snowflake key-pair auth when you manage Hevo separately or don't use Hevo at all.

Project Structure

sf_rotation/
├── src/sf_rotation/
│   ├── __init__.py           # Package exports
│   ├── main.py               # CLI entry point
│   ├── key_generator.py      # OpenSSL key generation
│   ├── snowflake_client.py   # Snowflake connection/key management
│   ├── hevo_client.py        # Hevo API client
│   └── utils.py              # Helper functions
├── config/
│   └── config.yaml.example   # Configuration template
├── pyproject.toml            # Package configuration
├── README.md
└── WORKFLOW.md               # Detailed workflow documentation

Requirements

  • Python 3.8+
  • OpenSSL (for key generation)
  • Snowflake account with admin access
  • Hevo Data account with API access

Security Notes

  • Private keys are stored with 600 permissions
  • Keys directory is gitignored
  • Config files with credentials are gitignored
  • Passphrase prompted at runtime (not stored in config)

License

MIT License - see LICENSE file for details.

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

sf_rotation-1.3.0.tar.gz (22.7 kB view details)

Uploaded Source

Built Distribution

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

sf_rotation-1.3.0-py3-none-any.whl (22.7 kB view details)

Uploaded Python 3

File details

Details for the file sf_rotation-1.3.0.tar.gz.

File metadata

  • Download URL: sf_rotation-1.3.0.tar.gz
  • Upload date:
  • Size: 22.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.13.2

File hashes

Hashes for sf_rotation-1.3.0.tar.gz
Algorithm Hash digest
SHA256 3d493eaad7b8c2f8ed6bfffa51b60004392a1a2a6b9d17b84241c7f1aec3e7ea
MD5 f05fbdec65f427a9d97344af67ef36c3
BLAKE2b-256 4540f9483420fb51303e997ef8875f5a59f3fee2dffacaab4c6d2a5b66107e70

See more details on using hashes here.

File details

Details for the file sf_rotation-1.3.0-py3-none-any.whl.

File metadata

  • Download URL: sf_rotation-1.3.0-py3-none-any.whl
  • Upload date:
  • Size: 22.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.13.2

File hashes

Hashes for sf_rotation-1.3.0-py3-none-any.whl
Algorithm Hash digest
SHA256 8392a04ca7305c5e86670e2f262664364d822e3edcf9b5103f1aa441a48239d5
MD5 7dfdb13a397f4f291f02ad8b1374beec
BLAKE2b-256 edf0c6bb63f343a5f4504385c35eda03fa35cc70dd572eadc33b285c3f4b0d32

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