#!/usr/bin/env bash # Craig Jennings # # Prepares the docker environment telega.el uses for TDLib. # # Sequence: # - Verifies docker is installed and the daemon is responsive. # - Verifies the user can talk to docker without sudo (group membership). # - Pulls the telega-server image if a public one is configured (env var # `TELEGA_DOCKER_IMAGE'); otherwise prints the in-Emacs build command # (`M-x telega-server-build') for the user to run once. # # Does NOT handle Telegram account auth -- phone number + verification # code is interactive and runs inside `M-x telega' on first launch. # # Sourceable: only `main' runs when the script is executed directly, so # the helpers can be tested with bats. set -euo pipefail # Public image override. When set, the script pulls this image directly # instead of falling back to the in-Emacs build flow. Default empty so # the script doesn't assume an image name that may or may not exist # upstream. : "${TELEGA_DOCKER_IMAGE:=}" ensure_docker_installed() { if ! command -v docker >/dev/null 2>&1; then echo " ✗ docker not found on PATH" echo " install docker (https://docs.docker.com/get-docker/) and rerun" return 1 fi echo " ✓ docker present: $(command -v docker)" } ensure_docker_running() { if ! docker info >/dev/null 2>&1; then echo " ✗ cannot talk to the docker daemon" echo " start the daemon (e.g. 'sudo systemctl start docker') or" echo " add your user to the 'docker' group, then re-login and rerun" return 1 fi echo " ✓ docker daemon reachable" } pull_or_announce_image() { if [[ -z "$TELEGA_DOCKER_IMAGE" ]]; then cat <