Files
Docker-Chevereto/Makefile
Rodolfo Berrios 175489dd68 wip https
2022-10-17 10:22:01 -03:00

145 lines
3.7 KiB
Makefile

SOURCE ?= ~/git/chevereto/v4
TARGET ?= prod# prod|dev
VERSION ?= 4.0
PHP ?= 8.1
DOCKER_USER ?= www-data
HOSTNAME ?= localhost
HOSTNAME_PATH ?= /
PROTOCOL ?= http
NAMESPACE ?= chevereto
SERVICE ?= php
PORT_HTTP ?= 8420
PORT_HTTPS ?= 8430
PORT = $(shell [[ \${PROTOCOL} == "http" ]] && echo \${PORT_HTTP} || echo \${PORT_HTTPS})
HTTPS = $(shell [[ \${PROTOCOL} == "http" ]] && echo 0 || echo 1)
URL = ${PROTOCOL}://${HOSTNAME}:${PORT}/
PROJECT = $(shell [[ \${TARGET} == "prod" ]] && echo \${NAMESPACE}_chevereto || echo \${NAMESPACE}_chevereto-${TARGET})
CONTAINER_BASENAME ?= ${NAMESPACE}_chevereto-${VERSION}
TAG_BASENAME ?= ${NAMESPACE}_chevereto:${VERSION}
COMPOSE ?= docker-compose
PROJECT_COMPOSE = ${COMPOSE}.yml
COMPOSE_SAMPLE = default.yml
COMPOSE_FILE = $(shell [[ -f \${PROJECT_COMPOSE} ]] && echo \${PROJECT_COMPOSE} || echo \${COMPOSE_SAMPLE})
FEEDBACK = $(shell echo 👉 \${TARGET} V\${VERSION} \${NAMESPACE} [PHP \${PHP}] \(\${DOCKER_USER}\))
FEEDBACK_SHORT = $(shell echo 👉 \${TARGET} V\${VERSION} [PHP \${PHP}] \(\${DOCKER_USER}\))
LICENSE ?= $(shell stty -echo; read -p "Chevereto V4 License key: 🔑" license; stty echo; echo $$license)
DOCKER_COMPOSE = $(shell echo @CONTAINER_BASENAME=\${CONTAINER_BASENAME} \
PORT_HTTP=\${PORT_HTTP} \
PORT_HTTPS=\${PORT_HTTPS} \
HTTPS=\${HTTPS} \
TAG_BASENAME=\${TAG_BASENAME} \
VERSION=\${VERSION} \
HOSTNAME=\${HOSTNAME} \
HOSTNAME_PATH=\${HOSTNAME_PATH} \
URL=\${URL} \
docker compose -p \${PROJECT} -f \${COMPOSE_FILE})
feedback:
@./scripts/logo.sh
@echo "${FEEDBACK}"
feedback--short:
@echo "${FEEDBACK_SHORT}"
feedback--compose:
@echo "🐋 ${COMPOSE_FILE}"
feedback--url:
@echo "🌎 ${URL}"
feedback--volumes:
@echo "${PROJECT}_database"
@echo "${PROJECT}_assets"
@echo "${PROJECT}_storage"
# Docker
image: feedback--short
@chmod +x ./scripts/chevereto.sh
@LICENSE=${LICENSE} \
VERSION=${VERSION} \
./scripts/chevereto.sh
@echo "* Building PHP image"
@docker build . \
-f Dockerfile \
-t ${TAG_BASENAME}_php
image-custom: feedback--short
@echo "* Building PHP image"
@docker build . \
-f Dockerfile \
-t ${TAG_BASENAME}_php
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}
bash: feedback
@docker exec -it --user ${DOCKER_USER} \
${CONTAINER_BASENAME}_${SERVICE} \
bash
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
# docker compose
up: feedback feedback--compose feedback--url
${DOCKER_COMPOSE} up
up-d: feedback feedback--compose feedback--url
${DOCKER_COMPOSE} up -d
stop: feedback feedback--compose
${DOCKER_COMPOSE} stop
start: feedback feedback--compose
${DOCKER_COMPOSE} start
restart: feedback feedback--compose
${DOCKER_COMPOSE} restart
down: feedback feedback--compose
${DOCKER_COMPOSE} down
down--volumes: feedback feedback--compose
${DOCKER_COMPOSE} down --volumes
# tools
certbot:
@echo "🔐 Generating certificate"
@HOSTNAME=${HOSTNAME} \
docker container run \
-it \
--rm \
-v ${PWD}/letsencrypt/certs:/etc/letsencrypt \
-v ${PWD}/letsencrypt/data:/data/letsencrypt \
certbot/certbot certonly \
--webroot \
--webroot-path=/data/letsencrypt \
-d ${HOSTNAME} \
--dry-run \
&& cp ${PWD}/letsencrypt/certs/live/${HOSTNAME}/fullchain.pem ${PWD}/https/cert.pem \
&& cp ${PWD}/letsencrypt/certs/live/${HOSTNAME}/privkey.pem ${PWD}/https/key.pem
cert-self:
@echo "🔐 Generating self-signed certificate"
@cd ${PWD}/https \
&& openssl req -newkey rsa:2048 -new -nodes -x509 -days 3650 -keyout key.pem -out cert.pem