Skip to main content

A simple CLI client for kyun.sh

Project description

Kyun CLI (Beta)

A command-line interface for using kyun.sh.

Note: This project is currently in beta.


Installation

The following assumes you are on Linux. Windows is not supported yet.

Install from PyPI (Recommended)

Install with pipx:

sudo apt install pipx
pipx ensurepath
pipx install kyuncli

# Now you can use Kyun CLI
kyun account login

# To upgrade
pipx upgrade kyuncli

# To uninstall
pipx uninstall kyuncli

Install from releases

Use the .whl link from Releases:

pipx install <link-to-release>

Build it yourself

If you prefer to build the package yourself:

sudo apt install pipx
pipx ensurepath

git clone https://git.kyun.sh/nthpyrodev/kyuncli.git
cd kyuncli
python3 -m venv .venv
source .venv/bin/activate
pip install build
python -m build
deactivate

# Install your locally built wheel
pipx install dist/kyuncli-*.whl

# Now you can use Kyun CLI
kyun account login

# To uninstall
pipx uninstall kyuncli

Installing in a virtual environment (for development)

git clone https://git.kyun.sh/nthpyrodev/kyuncli.git
cd kyuncli
python3 -m venv .venv
source .venv/bin/activate
pip install -e .

Shell Autocompletion (Linux)

Enable tab completion using:

echo 'eval "$(_KYUN_COMPLETE=bash_source kyun)"' >> ~/.bashrc
source ~/.bashrc

Usage

Account Management

# Create a new account
kyun account create

# Login to your account and create the API to use
kyun account login

# Switch between accounts
kyun account switch <hash>

# List all accounts
kyun account list

# Check balance
kyun account balance

# Remove an account (does not delete your account, just removes it locally)
kyun account remove <hash>

SSH Key Management

# List SSH keys
kyun account ssh list

# Add SSH key from file
kyun account ssh add --file ~/.ssh/id_rsa.pub --name "My Key"

# Add SSH key directly
kyun account ssh add --key "ssh-rsa AAAAB3..." --name "My Key"

# Rename SSH key
kyun account ssh rename <key_id> "New Name"

# Delete SSH key
kyun account ssh delete <key_id>

Contact Information Management

# Get contact information
kyun account contact get

# Update email address
kyun account contact update --email "your@email.com"

# Update Matrix ID
kyun account contact update --matrix "@user:matrix.org"

# Update both email and Matrix
kyun account contact update --email "your@email.com" --matrix "@user:matrix.org"

# Link Telegram account
kyun account contact telegram link --code "ABC123"

# Unlink Telegram account
kyun account contact telegram unlink

2FA/OTP Management

# Check if 2FA is enabled
kyun account otp status

# Enable 2FA (Also creates backup scratch token)
kyun account otp enable

# Disable 2FA
kyun account otp disable

danbo Management

# List all danbos
kyun danbo list

# Get detailed danbo info
kyun danbo get <danbo_id>

# Buy a new danbo
kyun danbo buy

# Rename a danbo
kyun danbo rename <danbo_id> "New Name"

# View danbo resource usage statistics
kyun danbo stats <danbo_id>

# View stats for last 60 minutes
kyun danbo stats <danbo_id> --minutes 60

# Delete a danbo (Irreversible)
kyun danbo manage delete <danbo_id>

# Cancel a danbo (deleted on next renewal)
kyun danbo manage cancel <danbo_id>

# Cancel a danbo with 2FA code
kyun danbo manage cancel <danbo_id>

danbo Power Management

# Start a danbo
kyun danbo power start <danbo_id>

# Stop a danbo
kyun danbo power stop <danbo_id>

# Reboot a danbo
kyun danbo power reboot <danbo_id>

# Graceful shutdown
kyun danbo power shutdown <danbo_id>

danbo Specs Management

# View current specs
kyun danbo get <danbo_id>

# Check max upgrade options
kyun danbo specs max-upgrade <danbo_id>

# Change specs
kyun danbo specs change <danbo_id>

danbo IP Management

# Show danbo information
kyun danbo get <danbo_id>

# Add IPv4
kyun danbo ip add <danbo_id>

# Remove IPv4
kyun danbo ip remove <danbo_id> <ip_address>

# Set primary IP
kyun danbo ip set-primary-ip <danbo_id> <ip_address>

# List reverse DNS entries for an IP
kyun danbo ip rdns list <danbo_id> <ip_address>

# Add reverse DNS entry
kyun danbo ip rdns add <danbo_id> <ip_address> <domain>

# Remove reverse DNS entry
kyun danbo ip rdns remove <danbo_id> <ip_address> <domain>

danbo SSH Management

# View authorized keys
kyun danbo ssh get-authorized <danbo_id>

# Set authorized keys from account (Replaces existing)
kyun danbo ssh set-authorized <danbo_id> --from-account

# Set authorized keys from file (Replaces existing)
kyun danbo ssh set-authorized <danbo_id> --file ~/.ssh/authorized_keys

# Add key to authorized keys
kyun danbo ssh add-to-authorized <danbo_id> --key "ssh-rsa AAAAB3..."

# Remove key from authorized keys
kyun danbo ssh remove-from-authorized <danbo_id> --key "ssh-rsa AAAAB3.."

# Get SSH host keys
kyun danbo ssh get-host-keys <danbo_id>

danbo Bandwidth Management

# Check current bandwidth limit
kyun danbo bandwidth get <danbo_id>

# Set bandwidth limit (--limit flag optional)
kyun danbo bandwidth set <danbo_id> --limit 100

# Clear bandwidth limit
kyun danbo bandwidth clear <danbo_id>

danbo OS Management

# Install an OS on a danbo
kyun danbo os install <danbo_id>

# Get the installed OS name
kyun danbo os get <danbo_id>

# Set the OS name
kyun danbo os set <danbo_id> "Debian 12 Bookworm"

danbo Subdomain Management

# List subdomains
kyun danbo subdomains list <danbo_id>

# Create subdomain
kyun danbo subdomains create <danbo_id> --name "subdomain" --domain "kyun.li" --ip "ip_address"

# Delete subdomain
kyun danbo subdomains delete <danbo_id> <subdomain_id>

danbo Brick Management

# List attached Bricks
kyun danbo bricks list <danbo_id>

# Attach Brick to danbo
kyun danbo bricks attach <danbo_id> <brick_id>

# Detach Brick from danbo
kyun danbo bricks detach <danbo_id> <brick_id>

Brick Storage Management

# List all Bricks
kyun brick list

# Get Brick details
kyun brick get <brick_id>

# Buy a new Brick
kyun brick buy

# Grow a Brick
kyun brick grow <brick_id>

# Check max growth
kyun brick max-grow <brick_id>

# Delete a Brick (Irreversible)
kyun brick delete <brick_id>

# Unsuspend a Brick
kyun brick unsuspend <brick_id>

Monero Deposit Management

# View exchange rates
kyun deposit rates

# List pending deposits
kyun deposit pending

# Create new deposit
kyun deposit create

# Get deposit info
kyun deposit get <deposit_id>

# Check deposit status
kyun deposit status <deposit_id>

Stripe Billing Management

# Add a payment method
kyun stripe addcard

# Don't open in browser automatically
kyun stripe addcard --url-only

# Show QR code
kyun stripe addcard --qr

# Stripe customer portal (general billing including invoices and payment methods)
kyun stripe portal

# Don't open in browser automatically
kyun stripe portal --url-only

# Show QR code
kyun stripe portal --qr

Support Chat

# List all chats
kyun chat list

# Start new chat
kyun chat start

# Start chat using ultra private mode
kyun chat start --private

# Open live chat session
kyun chat open <chat_id>

# Use commands inside live chat session:
# /help

# Delete chat
kyun chat delete <chat_id>

# Check online staff
kyun chat staff

# Enable ultra private mode
kyun chat privacy enable <chat_id>

# Disable ultra private mode
kyun chat privacy disable <chat_id>

Notifications

# Use --all to enable/disable for all accounts, or --hash to specify a specific account, otherwise defaults to currently active account.
# Just enabling a notification type will not allow it to run immediately, make sure you have run kyun notify cron install.
# No need to rerun kyun notify cron install after enabling/disabling notification type.

# Notify when a danbo is suspended
kyun notify danbo suspend enable

# Notify if balance is too low at specified hours ahead of a danbo renewal, default is one notification 72 hours in advance
kyun notify danbo renewal enable --hours-before 72 --hours-before 24

# Notify if balance is too low at specified hours ahead of a brick renewal, default is one notification 72 hours in advance
kyun notify brick renewal enable --hours-before 96 --hours-before 36

# Notify when a brick is suspended
kyun notify brick suspend enable

# Notify on new livechat message
kyun notify chat enable

# Change how many hours in advance of insufficient balance for renewal you are notified (replaces previous)
kyun notify danbo renewal hours 72 24

# Change how many hours in advance of insufficient balance for renewal you are notified (replaces previous)
kyun notify brick renewal hours 72

# Show which notification types are set for all accounts added to kyuncli
kyun notify status

# Manually run all enabled notification checks
kyun notify run

# Run notification checks every 5 minutes
kyun notify cron install

# Remove notification check entry from cron
kyun notify cron remove

Configuration

Config File Location

Account info is stored in a config file:

  • Linux: ~/.config/kyuncli/config.json
  • macOS: ~/Library/Application Support/kyuncli/config.json

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

kyuncli-0.3.0b1.tar.gz (53.5 kB view details)

Uploaded Source

Built Distribution

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

kyuncli-0.3.0b1-py3-none-any.whl (52.6 kB view details)

Uploaded Python 3

File details

Details for the file kyuncli-0.3.0b1.tar.gz.

File metadata

  • Download URL: kyuncli-0.3.0b1.tar.gz
  • Upload date:
  • Size: 53.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.13

File hashes

Hashes for kyuncli-0.3.0b1.tar.gz
Algorithm Hash digest
SHA256 d7c759fc57bee4424cf7c1e6fc56f04fc2f7d290d5fd07bae90e64a6526680b3
MD5 fd49e1583dc304df7ee59b384767d477
BLAKE2b-256 b6be733b24c67d876f70cd66498a3cabae30f0921c4a9424670e1413478c4e89

See more details on using hashes here.

File details

Details for the file kyuncli-0.3.0b1-py3-none-any.whl.

File metadata

  • Download URL: kyuncli-0.3.0b1-py3-none-any.whl
  • Upload date:
  • Size: 52.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.13

File hashes

Hashes for kyuncli-0.3.0b1-py3-none-any.whl
Algorithm Hash digest
SHA256 672df366515ab6ad61c380980144a04915623217d76f7053f0af3594748c3266
MD5 882f8715136116c283608029ff46e9dd
BLAKE2b-256 ecd0ee105907470e7dadfd8c4aba7759484bd459960f2e837e210dc449825d76

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