Skip to main content

A Comprehensive Tool for Setting Up Virtual Machines.

Project description

🚀 VM Setup Tool

PyPI version Python versions

DocumentationPyPIGitHubContributingLicense

A modern, user-friendly solution for automating and managing virtual machine (VM) setup and configuration using Ansible.


✨ Features

  • Automated VM setup with Docker & Docker Compose
  • Cloud VM provisioning via SSH
  • Infrastructure Provisioning: Terraform integration for cloud providers (AWS, etc.)
  • Kubernetes Ready: One-click K3s cluster setup
  • Observability: Instant Prometheus & Grafana deployment
  • CI/CD Pipelines: Auto-generate GitHub Actions workflows
  • SSH key management and configuration
  • Simple Python API for integration
  • One-command version check: vm_tool --version

⚡️ Installation

Install the latest version from PyPI:

pip install vm-tool

🛠️ Usage Examples

🚀 Universal Deployment (CLI)

1. Generate CI/CD Pipeline

Bootstrap your project with a complete GitHub Actions workflow:

vm_tool generate-pipeline

2. Provision Infrastructure

Provision cloud resources using Terraform (requires Terraform installed):

vm_tool provision --provider aws --action apply --vars region=us-east-1

3. Setup Kubernetes (K3s)

Deploy a lightweight Kubernetes cluster to your servers:

vm_tool setup-k8s --inventory inventory.yml

4. Setup Observability

Deploy Prometheus and Grafana for instant monitoring:

vm_tool setup-monitoring --inventory inventory.yml

🐍 Python API Usage

Automated Local VM Setup

from vm_tool.runner import SetupRunner, SetupRunnerConfig

config = SetupRunnerConfig(
    github_username='your_github_username',
    github_token='your_github_token',
    github_project_url='your_github_project_url',
    github_branch='your_branch_name',
    docker_compose_file_path='path_to_your_docker_compose_file',
    dockerhub_username='your_dockerhub_username',
    dockerhub_password='your_dockerhub_password'
)

runner = SetupRunner(config)
runner.run_setup()

Cloud VM Setup (via SSH)

from vm_tool.runner import SetupRunner, SetupRunnerConfig, SSHConfig

config = SetupRunnerConfig(
    github_username='your_github_username',
    github_token='your_github_token',
    github_project_url='your_github_project_url',
    github_branch='your_branch_name',
    docker_compose_file_path='path_to_your_docker_compose_file',
    dockerhub_username='your_dockerhub_username',
    dockerhub_password='your_dockerhub_password'
)

runner = SetupRunner(config)

ssh_configs = [
    SSHConfig(
        ssh_username='your_ssh_username',
        ssh_password='your_ssh_password',
        ssh_hostname='your_ssh_hostname',
        ssh_identity_file='/path/to/your/ssh_key'  # Optional
    )
]

runner.run_cloud_setup(ssh_configs)

SSH Key Management

from vm_tool.ssh import SSHSetup

ssh_setup = SSHSetup(
    hostname='your_vm_hostname',
    username='your_vm_username',
    password='your_vm_password',
    email='your_email_for_ssh_key'
)

ssh_setup.setup()

🖥️ Command Line Version Check

Check your installed version at any time:

vm_tool --version

⚙️ Configuration Options

  • github_username: GitHub username (for private repos)
  • github_token: GitHub token (for private repos)
  • github_project_url: GitHub repository URL
  • github_branch: Branch to use (default: main)
  • docker_compose_file_path: Path to Docker Compose file (default: docker-compose.yml)
  • dockerhub_username: Docker Hub username (if login needed)
  • dockerhub_password: Docker Hub password (if login needed)

📚 Learn More

See the Official Documentation for complete guides. Visit the PyPI page for generic details, or the GitHub repository for code and issues.


Empower your infrastructure automation with VM Setup Tool – fast, reliable, and developer-friendly!

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

vm_tool-1.0.59.tar.gz (66.4 kB view details)

Uploaded Source

Built Distribution

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

vm_tool-1.0.59-py3-none-any.whl (84.0 kB view details)

Uploaded Python 3

File details

Details for the file vm_tool-1.0.59.tar.gz.

File metadata

  • Download URL: vm_tool-1.0.59.tar.gz
  • Upload date:
  • Size: 66.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for vm_tool-1.0.59.tar.gz
Algorithm Hash digest
SHA256 49c659e0a1c3af6641ad3a0bc1426f3b8c77e9582045ed3c129645bded915ee9
MD5 ead85a6b51a317fdae373048b44d0c27
BLAKE2b-256 1a09f9e94e91c92ad118c8c74c49d5b78ac1266bfe6fc4bc2d87d8450a430340

See more details on using hashes here.

Provenance

The following attestation bundles were made for vm_tool-1.0.59.tar.gz:

Publisher: publish.yml on thesunnysinha/vm_tool

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file vm_tool-1.0.59-py3-none-any.whl.

File metadata

  • Download URL: vm_tool-1.0.59-py3-none-any.whl
  • Upload date:
  • Size: 84.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for vm_tool-1.0.59-py3-none-any.whl
Algorithm Hash digest
SHA256 ff5be232a6477b1ed14df8aeb86262740e19f7ba7bdb05afe51cc50de0578fea
MD5 eb52d1b68c9d4beaeb6d5e3382189813
BLAKE2b-256 50be93ce96468fe5b008a29c57878647677b99a7bd8ba5cd3a7d0bd5a8cf53dc

See more details on using hashes here.

Provenance

The following attestation bundles were made for vm_tool-1.0.59-py3-none-any.whl:

Publisher: publish.yml on thesunnysinha/vm_tool

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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