Files
Docker-Chevereto/Makefile
Rodolfo Berrios 3e38ce2fad fix feedback
2024-02-16 16:48:00 -03:00

266 lines
7.2 KiB
Makefile

#!make
SYSTEM ?= ubuntu/22.04
ENV_FILE = ./.env
DOMAIN ?= localhost
NAMESPACE ?= chevereto
NAMESPACE_FILE = ./namespace/${NAMESPACE}
NAMESPACE_FILE_EXISTS = false
CHEVERETO_LICENSE_KEY ?= ""
ifneq ("$(wildcard ${NAMESPACE_FILE})","")
NAMESPACE_FILE_EXISTS = true
include ${NAMESPACE_FILE}
export $(shell sed 's/=.*//' ${NAMESPACE_FILE})
endif
ifneq ("$(wildcard ${ENV_FILE})","")
include ${ENV_FILE}
export $(shell sed 's/=.*//' ${ENV_FILE})
endif
SOURCE ?= ~/git/chevereto/v4
TARGET ?= default# default|dev
VERSION ?= 4.0
PHP ?= 8.2
EDITION ?= $(shell [ "${CHEVERETO_LICENSE_KEY}" = "" ] && echo free || echo pro)
DOCKER_USER ?= www-data
HOSTNAME ?= localhost
HOSTNAME_PATH ?= /
PROTOCOL ?= https
SERVICE ?= php
ENCRYPTION_KEY ?=
EMAIL_HTTPS ?= mail@yourdomain.tld
DB_PORT ?= 8836
HTTP_PORT ?= 80
HTTPS_PORT ?= 443
PORT = $(shell [ "${PROTOCOL}" = "http" ] && echo \${HTTP_PORT} || echo \${HTTPS_PORT})
HTTPS = $(shell [ "${PROTOCOL}" = "http" ] && echo 0 || echo 1)
HTTPS_CERT = https/$(shell [ -f "https/cert.pem" ] && echo || echo dummy/)cert.pem
HTTPS_KEY = https/$(shell [ -f "https/key.pem" ] && echo || echo dummy/)key.pem
URL_BARE = ${PROTOCOL}://${HOSTNAME}${HOSTNAME_PATH}
URL_PORT = ${PROTOCOL}://${HOSTNAME}:${PORT}${HOSTNAME_PATH}
URL = $(shell [ "${PORT}" = 80 -o "${PORT}" = 443 ] && echo ${URL_BARE} || echo ${URL_PORT})
PROJECT = ${NAMESPACE}_chevereto$(shell [ ! "${TARGET}" = "default" ] && echo -\${TARGET})
CONTAINER_BASENAME = ${PROJECT}-${VERSION}
IMAGE_EDITION_FREE_BASE = ghcr.io/chevereto/chevereto
IMAGE_NAME = chevereto$(shell [ ! "${TARGET}" = "default" ] && echo -\${TARGET})
IMAGE ?= $(shell [ "${EDITION}" = "free" ] && echo \${IMAGE_EDITION_FREE_BASE} || echo \${IMAGE_NAME}):${VERSION}
COMPOSE ?= docker-compose
COMPOSE_TARGET = ${COMPOSE}.yml
COMPOSE_SAMPLE = $(shell [ "${TARGET}" = "default" ] && echo default || echo dev).yml
COMPOSE_FILE = $(shell [ -f \${COMPOSE_TARGET} ] && echo \${COMPOSE_TARGET} || echo \${COMPOSE_SAMPLE})
FEEDBACK = $(shell echo 👉 \${TARGET} \${CONTAINER_BASENAME} @\${NAMESPACE_FILE} V\${VERSION} \(\${DOCKER_USER}\))
FEEDBACK_SHORT = $(shell echo 👉 \${TARGET} V\${VERSION} \(\${DOCKER_USER}\))
CHEVERETO_LICENSE ?= $(shell stty -echo; read -p "Chevereto V4 License key (for paid edition): 🔑" license; stty echo; echo $$license)
DOCKER_COMPOSE = $(shell echo @CONTAINER_BASENAME=\${CONTAINER_BASENAME} \
SOURCE=\${SOURCE} \
DB_PORT=\${DB_PORT} \
HTTP_PORT=\${HTTP_PORT} \
HTTPS_PORT=\${HTTPS_PORT} \
HTTPS_CERT=\${HTTPS_CERT} \
HTTPS_KEY=\${HTTPS_KEY} \
HTTPS=\${HTTPS} \
IMAGE=\${IMAGE} \
VERSION=\${VERSION} \
HOSTNAME=\${HOSTNAME} \
HOSTNAME_PATH=\${HOSTNAME_PATH} \
URL=\${URL} \
docker compose -p \${PROJECT} -f \${COMPOSE_FILE})
# Informational
feedback:
@./scripts/chevereto/logo.sh
@echo "${FEEDBACK}"
feedback--short:
@echo "${FEEDBACK_SHORT}"
feedback--compose: feedback--image
@echo "🐋 ${COMPOSE_FILE}"
feedback--url:
@echo "Protocol ${PROTOCOL} (:${PORT})"
@echo "@URL ${URL}"
feedback--image:
@echo "📦 ${IMAGE} (BASE ${IMAGE_NAME})"
feedback--volumes:
@echo "${PROJECT}_database"
@echo "${PROJECT}_storage"
feedback--namespace:
@echo "$(shell [ "${NAMESPACE_FILE_EXISTS}" = "true" ] && echo "✅" || echo "❌") ${NAMESPACE_FILE}"
@echo "🔑 ${ENCRYPTION_KEY}"
@echo "🌎 ${HOSTNAME}"
# Docker
image: feedback--image feedback--short
@CHEVERETO_LICENSE_KEY=${CHEVERETO_LICENSE_KEY} \
VERSION=${VERSION} \
IMAGE_NAME=${IMAGE_NAME} \
./scripts/system/chevereto.sh \
docker build . \
--cache-from ${IMAGE_EDITION_FREE_BASE}:${VERSION} \
--network host \
-f Dockerfile
image-custom: feedback--image feedback--short
@mkdir -p chevereto
echo "* Building custom image ${IMAGE}"
@docker build . \
--cache-from ${IMAGE_EDITION_FREE_BASE}:${VERSION}\
--network host \
--build-arg PHP=${PHP} \
-f Dockerfile \
-t ${IMAGE}
volume-cp:
@docker run --rm -it -v ${VOLUME_FROM}:/from -v ${VOLUME_TO}:/to alpine ash -c "cd /from ; cp -av . /to"
volume-rm:
@docker volume rm ${VOLUME}
# Logs
log: feedback
@docker logs -f ${CONTAINER_BASENAME}_${SERVICE}
log-access: feedback
@docker logs ${CONTAINER_BASENAME}_${SERVICE} -f 2>/dev/null
log-error: feedback
@docker logs ${CONTAINER_BASENAME}_${SERVICE} -f 1>/dev/null
# Tools
bash: feedback
@docker exec -it --user ${DOCKER_USER} \
${CONTAINER_BASENAME}_${SERVICE} \
bash
exec: feedback
@docker exec -it --user ${DOCKER_USER} \
${CONTAINER_BASENAME}_${SERVICE} \
${COMMAND}
run: feedback
@docker exec -it \
${CONTAINER_BASENAME}_${SERVICE} \
bash /var/scripts/${SCRIPT}.sh
cron:
@./scripts/system/cron.sh
cron--run:
@./scripts/system/cron--run.sh
cloudflare:
@./scripts/system/cloudflare.sh
cloudflare--create:
@NAMESPACE_FILE=${NAMESPACE_FILE} ./scripts/system/cloudflare--create.sh
cloudflare--delete:
@./scripts/system/cloudflare--delete.sh
encryption-key:
@openssl rand -base64 32
install-docker:
@SYSTEM=${SYSTEM} \
./scripts/os/${SYSTEM}/install-docker.sh
.PHONY: namespace
namespace:
@chmod +x ./scripts/system/namespace.sh
@NAMESPACE=${NAMESPACE} \
NAMESPACE_EXISTS=${NAMESPACE_EXISTS} \
NAMESPACE_FILE=${NAMESPACE_FILE} \
HOSTNAME=${HOSTNAME} \
ENCRYPTION_KEY=${ENCRYPTION_KEY} \
./scripts/system/namespace.sh
.PHONY: env
env:
@chmod +x ./scripts/system/env.sh
@ENV_FILE=${ENV_FILE} ./scripts/system/env.sh
setup: cron proxy
# Docker compose
up: feedback--compose feedback--url
${DOCKER_COMPOSE} up
up-d: feedback--compose feedback--url
${DOCKER_COMPOSE} up -d
stop: feedback--compose
${DOCKER_COMPOSE} stop
start: feedback--compose
${DOCKER_COMPOSE} start
restart: feedback--compose
${DOCKER_COMPOSE} restart
down: feedback--compose
${DOCKER_COMPOSE} down
down--volumes: feedback--compose
${DOCKER_COMPOSE} down --volumes
# Instances
.PHONY: deploy
deploy:
@./scripts/system/deploy.sh
update: feedback--compose feedback--url
@./scripts/system/update.sh
destroy: feedback--compose cloudflare--delete
${DOCKER_COMPOSE} down --volumes
@rm namespace/${NAMESPACE}
install: feedback--short
docker exec -it --user ${DOCKER_USER} \
${CONTAINER_BASENAME}_${SERVICE} \
app/bin/legacy -C install -u "${ADMIN_USER}" -e "${ADMIN_EMAIL}" -x "${ADMIN_PASSWORD}"
# nginx-proxy
proxy:
@docker network create nginx-proxy || true
@docker run \
--detach \
--name nginx-proxy \
--net nginx-proxy \
--publish 80:80 \
--publish 443:443 \
--restart=always \
--volume certs:/etc/nginx/certs \
--volume vhost:/etc/nginx/vhost.d \
--volume html:/usr/share/nginx/html \
--mount type=bind,source=/var/run/docker.sock,target=/tmp/docker.sock,readonly \
--mount type=bind,source=${PWD}/nginx/chevereto.conf,target=/etc/nginx/conf.d/chevereto.conf,readonly \
--mount type=bind,source=${PWD}/nginx/cloudflare.conf,target=/etc/nginx/conf.d/cloudflare.conf,readonly \
nginxproxy/nginx-proxy
@docker run \
--detach \
--name nginx-proxy-acme \
--restart=always \
--volumes-from nginx-proxy \
--volume acme:/etc/acme.sh \
--mount type=bind,source=/var/run/docker.sock,target=/var/run/docker.sock,readonly \
--env "DEFAULT_EMAIL=${EMAIL_HTTPS}" \
nginxproxy/acme-companion
proxy--view:
@docker exec nginx-proxy cat /etc/nginx/conf.d/default.conf
proxy--remove:
@docker container rm -f nginx-proxy nginx-proxy-acme || true
@docker network rm nginx-proxy || true