Skip to content

Just some scripts for playing around with Proxmox, written for POSIX sh.

License

Notifications You must be signed in to change notification settings

bnnanet/proxmox-sh

 
 

Repository files navigation

Scripts to quickly deploy LXCs with Proxmox and expose them with Caddy.

Table of Contents

  • Install
  • Configure
    • env-switch
  • Usage
    • proxmox-add (to create an LXC)
    • caddy-add (to expose LXC via TLS/HTTPS)
  • Generate an API Token
  • Grant Permissions to an API Token
  • Beta scripts

Install

  1. Clone to ~/.local/opt/proxmox-sh/

    mkdir -p ~/.local/opt/
    git clone https://github.com/therootcompany/proxmox-sh.git ~/.local/opt/proxmox-sh
  2. Add to PATH

    echo 'export PATH="$HOME/.local/opt/proxmox-sh/bin:$PATH"' >> ~/.config/envman/PATH.env
    export PATH="$HOME/.local/opt/proxmox-sh/bin:$PATH"
  3. Initialize configs

    proxmox-sh-init

How to Configure ENVs

Use env-switch to set the current profile for the scripts:

env-switch 'proxmox-sh' 'profile-1'
env-switch 'caddy-sh' 'profile-1'

See also:

How to Create LXCs

proxmox-create
USAGE
    proxmox-create <hostname> [ssh-pubkey-file-url-or-string]

EXAMPLE
    proxmox-create 'example1.1101.c.bnna.net' ~/.ssh/id_rsa.pub

DEFAULT SSH KEYS (only key comments are shown, for brevity)
    [email protected]
    [email protected]
    [email protected]

See also: ~/.local/opt/proxmox-sh/bin/proxmox-create

How to expose LXCs via Proxy:

caddy-add
USAGE
    caddy-add <internal-ip> <domain> [--to-port=80] [--tls]

EXAMPLES
    caddy-add 192.168.0.103 pve1.example.com --to-port 8006 --tls
    caddy-add 192.168.0.103 lxc103.example.com --to-port 80
    caddy-add 192.168.0.103 lxc103.example.com

IMPORTANT
    BAD:  caddy run --config ./caddy.json # Will NOT persist!
    GOOD: caddy run --resume

See also: ~/.local/opt/proxmox-sh/bin/caddy-add

How to Get an API Token

Datacenter => Permissions => API Tokens

Note: Privilege Separation means that the API token must have its own permissions - it will not inherit from its owner.

How to Grant an API Token Permissions

Datacenter => Permissions

Visually, the Permissions link looks like a folder for a menu, but it's actually its own page.

Beta Scripts

USAGE
    provision-lxc <hostname> [ssh-pubkey-or-file-or-url]

EXAMPLE
    provision-lxc demo.example.com 'https://example.com/authorized_keys'

See also: provision-lxc

About

Just some scripts for playing around with Proxmox, written for POSIX sh.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Shell 100.0%