Skip to main content

DevOps CLI — workspace sync (GDrive, git, GPG, systemd timers) + GitLab/Bitwarden tooling

Project description

lnp-devopscli

DevOps CLI for workspace sync (Google Drive + git + GPG + systemd timers) and GitLab/Bitwarden tooling.

Install

Via PyPI (recommended)

pipx install lnp-devopscli
# or
pip install --user lnp-devopscli

Provides two equivalent commands: devopscli and dc.

From source

git clone https://gitlab.com/lnp-consulting-ti/devops/devops-cli.git ~/bin/devops-cli
cd ~/bin/devops-cli && make setup

Bootstrap on a new PC

For a full workspace bootstrap (rclone + GPG + git-crypt + 10 repos + systemd timers), use the public bootstrap launcher:

bash <(curl -fsSL https://gitlab.com/-/snippets/6003334/raw/main/bootstrap.sh)

See MIGRATION-RUNBOOK.md for the complete migration procedure.

Commands

devopscli ws sync             # full bidirectional sync (pull → git → push)
devopscli ws push             # sync local → GDrive (13 categories)
devopscli ws pull             # sync GDrive → local
devopscli ws doctor           # health check (deps, configs, timers, repos)
devopscli ws ai-sync          # git pull/commit/push for ai_workspaces
devopscli ws repos-sync       # git pull/commit/push for repos_sync
devopscli ws gpg-backup       # export GPG key + encrypt + send to GDrive
devopscli ws gpg-restore      # download GPG key from GDrive + decrypt + import
devopscli ws install-timers   # install systemd user timers (replaces cron)
devopscli ws uninstall-timers # remove systemd timers

See devopscli ws --help for the full list.

Security

The CLI is open source but never accesses your data without your credentials:

  • Google OAuth protects access to your GDrive (rclone config)
  • GPG passphrase protects the GPG key backup
  • git-crypt protects .env files inside synced repos
  • GitLab/SSH keys protect access to private repositories

Anyone can pip install the CLI — but without your credentials, they cannot access your data.

Configuration

Edit ~/bin/config.yaml (synced via ws push step 7):

ai_workspaces:
  - name: "workspace-personal"
    path: "~/workspace-personal"
    clone_url: "git@gitlab.com:user/repo.git"
    remote: "origin"
    branch: "main"
    auto_commit: true
    commit_message: "chore(auto-sync): snapshot via ws ai-sync"

repos_sync:
  - name: "devops-cli"
    path: "~/bin/devops-cli"
    clone_url: "git@gitlab.com:lnp-consulting-ti/devops/devops-cli.git"
    remote: "origin"
    branch: "main"
    auto_commit: true
    commit_message: "chore(auto-sync): snapshot via ws repos-sync"

Release

To publish a new version to PyPI:

# 1. Bump version in pyproject.toml
git commit -am "chore(release): v1.0.1"

# 2. Tag and push
git tag v1.0.1
git push origin main v1.0.1

The GitLab CI pipeline auto-publishes when a tag matches v*.*.*.

Setup once: add PYPI_TOKEN to GitLab CI/CD Variables (Settings > CI/CD).

License

MIT

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

lnp_devopscli-1.0.0.tar.gz (23.7 kB view details)

Uploaded Source

Built Distribution

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

lnp_devopscli-1.0.0-py3-none-any.whl (24.3 kB view details)

Uploaded Python 3

File details

Details for the file lnp_devopscli-1.0.0.tar.gz.

File metadata

  • Download URL: lnp_devopscli-1.0.0.tar.gz
  • Upload date:
  • Size: 23.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.13

File hashes

Hashes for lnp_devopscli-1.0.0.tar.gz
Algorithm Hash digest
SHA256 3f847aa5d4a3c54356e1a19f83ba758a0ac26faeaf4cbb44340f93c341c32cb8
MD5 0917d2183a92c15d4d81762ffd54bbde
BLAKE2b-256 3f1e8259264899f72d9ab37215ff3c10f6ed92c01e9289fee9d4dbe5cc6b6b0b

See more details on using hashes here.

File details

Details for the file lnp_devopscli-1.0.0-py3-none-any.whl.

File metadata

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

File hashes

Hashes for lnp_devopscli-1.0.0-py3-none-any.whl
Algorithm Hash digest
SHA256 3b0f82c0bf2c5d20416cd24bc8df05ec820ecd34f2928cd6a8fe662ea4cb1aba
MD5 d288a2c12d4f1df6ac0ff17cce4562c1
BLAKE2b-256 a6e832bfb3e8fe2de6b42af8aac8d182ac6a617f46c53e4a4b6cf033e3d9e285

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