Files
Docker-Chevereto/Makefile

266 lines
7.3 KiB
Makefile
Raw Normal View History

2022-11-05 19:10:02 -03:00
#!make
2022-11-16 15:11:57 -03:00
SYSTEM ?= ubuntu/22.04
2023-01-11 20:21:52 -03:00
ENV_FILE = ./.env
2024-02-06 11:59:30 -03:00
DOMAIN ?= localhost
2022-11-05 19:10:02 -03:00
NAMESPACE ?= chevereto
NAMESPACE_FILE = ./namespace/${NAMESPACE}
2022-11-05 19:30:40 -03:00
NAMESPACE_FILE_EXISTS = false
2022-11-05 19:10:02 -03:00
ifneq ("$(wildcard ${NAMESPACE_FILE})","")
2022-11-05 19:30:40 -03:00
NAMESPACE_FILE_EXISTS = true
2022-11-05 19:10:02 -03:00
include ${NAMESPACE_FILE}
export $(shell sed 's/=.*//' ${NAMESPACE_FILE})
endif
2023-01-11 20:21:52 -03:00
ifneq ("$(wildcard ${ENV_FILE})","")
include ${ENV_FILE}
export $(shell sed 's/=.*//' ${ENV_FILE})
endif
SOURCE ?= ~/git/chevereto/v4
2022-11-17 13:51:40 -03:00
TARGET ?= default# default|dev
2022-04-01 16:04:53 -03:00
VERSION ?= 4.0
2023-01-02 13:12:44 -03:00
PHP ?= 8.2
2022-11-29 13:51:17 -03:00
EDITION ?= pro
2022-04-01 16:04:53 -03:00
DOCKER_USER ?= www-data
2022-10-06 15:31:11 -03:00
HOSTNAME ?= localhost
HOSTNAME_PATH ?= /
2022-11-06 17:21:31 -03:00
PROTOCOL ?= https
2022-04-03 21:56:25 -04:00
SERVICE ?= php
2022-11-05 15:50:43 -03:00
ENCRYPTION_KEY ?=
EMAIL_HTTPS ?= mail@yourdomain.tld
2022-11-13 19:28:50 -03:00
DB_PORT ?= 8836
2022-10-17 16:16:44 -03:00
HTTP_PORT ?= 80
HTTPS_PORT ?= 443
PORT = $(shell [ "${PROTOCOL}" = "http" ] && echo \${HTTP_PORT} || echo \${HTTPS_PORT})
2022-10-17 15:22:07 -03:00
HTTPS = $(shell [ "${PROTOCOL}" = "http" ] && echo 0 || echo 1)
2022-10-17 16:16:44 -03:00
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
2022-11-10 11:43:57 -03:00
URL_BARE = ${PROTOCOL}://${HOSTNAME}${HOSTNAME_PATH}
2022-11-05 15:50:43 -03:00
URL_PORT = ${PROTOCOL}://${HOSTNAME}:${PORT}${HOSTNAME_PATH}
2022-11-10 11:43:57 -03:00
URL = $(shell [ "${PORT}" = 80 -o "${PORT}" = 443 ] && echo ${URL_BARE} || echo ${URL_PORT})
2022-11-28 19:18:32 -03:00
PROJECT = ${NAMESPACE}_chevereto$(shell [ ! "${TARGET}" = "default" ] && echo -\${TARGET})
2022-10-17 19:48:55 -03:00
CONTAINER_BASENAME = ${PROJECT}-${VERSION}
2022-11-29 13:51:17 -03:00
IMAGE_EDITION_FREE_BASE = ghcr.io/chevereto/chevereto
2023-01-12 09:19:35 -03:00
IMAGE_NAME = chevereto$(shell [ ! "${TARGET}" = "default" ] && echo -\${TARGET})
IMAGE ?= $(shell [ "${EDITION}" = "free" ] && echo \${IMAGE_EDITION_FREE_BASE} || echo \${IMAGE_NAME}):${VERSION}
COMPOSE ?= docker-compose
2022-11-28 19:18:32 -03:00
COMPOSE_TARGET = ${COMPOSE}.yml
2022-11-17 13:51:40 -03:00
COMPOSE_SAMPLE = $(shell [ "${TARGET}" = "default" ] && echo default || echo dev).yml
2022-11-28 19:18:32 -03:00
COMPOSE_FILE = $(shell [ -f \${COMPOSE_TARGET} ] && echo \${COMPOSE_TARGET} || echo \${COMPOSE_SAMPLE})
2023-01-02 13:12:44 -03:00
FEEDBACK = $(shell echo 👉 \${TARGET} \${CONTAINER_BASENAME} @\${NAMESPACE_FILE} V\${VERSION} \(\${DOCKER_USER}\))
2022-12-17 18:01:24 -03:00
FEEDBACK_SHORT = $(shell echo 👉 \${TARGET} V\${VERSION} \(\${DOCKER_USER}\))
2024-02-14 12:31:08 -03:00
CHEVERETO_LICENSE ?= $(shell stty -echo; read -p "Chevereto V4 License key (if any): 🔑" license; stty echo; echo $$license)
2022-11-16 15:11:57 -03:00
DOCKER_COMPOSE = $(shell echo @CONTAINER_BASENAME=\${CONTAINER_BASENAME} \
2022-10-17 19:48:55 -03:00
SOURCE=\${SOURCE} \
2022-11-13 19:28:50 -03:00
DB_PORT=\${DB_PORT} \
2022-10-17 16:16:44 -03:00
HTTP_PORT=\${HTTP_PORT} \
HTTPS_PORT=\${HTTPS_PORT} \
2022-10-17 10:37:15 -03:00
HTTPS_CERT=\${HTTPS_CERT} \
HTTPS_KEY=\${HTTPS_KEY} \
2022-10-17 10:22:01 -03:00
HTTPS=\${HTTPS} \
2022-11-29 13:51:17 -03:00
IMAGE=\${IMAGE} \
2022-10-17 10:22:01 -03:00
VERSION=\${VERSION} \
HOSTNAME=\${HOSTNAME} \
HOSTNAME_PATH=\${HOSTNAME_PATH} \
URL=\${URL} \
docker compose -p \${PROJECT} -f \${COMPOSE_FILE})
2022-10-07 14:22:07 -03:00
2022-10-17 19:48:55 -03:00
# Informational
2022-10-06 15:31:11 -03:00
feedback:
2022-11-16 14:51:23 -03:00
@./scripts/chevereto/logo.sh
2022-04-01 16:04:53 -03:00
@echo "${FEEDBACK}"
2022-10-06 15:31:11 -03:00
feedback--short:
@echo "${FEEDBACK_SHORT}"
2022-12-17 18:01:24 -03:00
feedback--compose: feedback--image
2022-10-07 14:22:07 -03:00
@echo "🐋 ${COMPOSE_FILE}"
feedback--url:
2024-02-04 15:12:55 -03:00
@echo "Protocol ${PROTOCOL} (:${PORT})"
@echo "@URL ${URL}"
2022-11-08 15:37:03 -03:00
feedback--image:
2023-01-12 09:19:35 -03:00
@echo "📦 ${IMAGE} (BASE ${IMAGE_NAME})"
2022-11-08 15:37:03 -03:00
feedback--volumes:
@echo "${PROJECT}_database"
@echo "${PROJECT}_storage"
2022-11-05 19:30:40 -03:00
feedback--namespace:
@echo "$(shell [ "${NAMESPACE_FILE_EXISTS}" = "true" ] && echo "✅" || echo "❌") ${NAMESPACE_FILE}"
@echo "🔑 ${ENCRYPTION_KEY}"
@echo "🌎 ${HOSTNAME}"
2022-04-01 16:04:53 -03:00
# Docker
2022-11-19 11:04:13 -03:00
image: feedback--image feedback--short
2024-02-14 12:31:08 -03:00
@CHEVERETO_LICENSE=${CHEVERETO_LICENSE} \
2022-04-03 19:35:44 -04:00
VERSION=${VERSION} \
2023-01-12 09:19:35 -03:00
IMAGE_NAME=${IMAGE_NAME} \
2022-11-19 11:02:54 -03:00
./scripts/system/chevereto.sh \
docker build . \
2022-11-29 13:51:17 -03:00
--cache-from ${IMAGE_EDITION_FREE_BASE}:${VERSION} \
2022-10-17 13:25:36 -03:00
--network host \
2022-11-19 11:02:54 -03:00
-f Dockerfile
2022-04-03 19:35:44 -04:00
2022-11-08 15:37:03 -03:00
image-custom: feedback--image feedback--short
2022-10-17 19:48:55 -03:00
@mkdir -p chevereto
2022-11-29 13:51:17 -03:00
echo "* Building custom image ${IMAGE}"
2022-04-03 19:35:44 -04:00
@docker build . \
2022-12-17 18:01:24 -03:00
--cache-from ${IMAGE_EDITION_FREE_BASE}:${VERSION}\
2022-10-17 19:48:55 -03:00
--network host \
2023-01-02 13:12:44 -03:00
--build-arg PHP=${PHP} \
-f Dockerfile \
2022-11-29 13:51:17 -03:00
-t ${IMAGE}
2022-04-01 16:04:53 -03:00
volume-cp:
2022-10-17 10:22:01 -03:00
@docker run --rm -it -v ${VOLUME_FROM}:/from -v ${VOLUME_TO}:/to alpine ash -c "cd /from ; cp -av . /to"
volume-rm:
2022-10-17 10:22:01 -03:00
@docker volume rm ${VOLUME}
2022-09-08 13:40:50 -04:00
2022-10-17 19:48:55 -03:00
# Logs
2022-04-01 16:04:53 -03:00
2022-10-17 10:22:01 -03:00
log: feedback
@docker logs -f ${CONTAINER_BASENAME}_${SERVICE}
2022-10-06 15:31:11 -03:00
log-access: feedback
2022-04-01 16:04:53 -03:00
@docker logs ${CONTAINER_BASENAME}_${SERVICE} -f 2>/dev/null
2022-10-06 15:31:11 -03:00
log-error: feedback
2022-04-01 16:04:53 -03:00
@docker logs ${CONTAINER_BASENAME}_${SERVICE} -f 1>/dev/null
2022-10-17 19:48:55 -03:00
# Tools
bash: feedback
@docker exec -it --user ${DOCKER_USER} \
${CONTAINER_BASENAME}_${SERVICE} \
bash
2022-11-09 16:20:24 -03:00
exec: feedback
@docker exec -it --user ${DOCKER_USER} \
${CONTAINER_BASENAME}_${SERVICE} \
${COMMAND}
2022-10-17 19:48:55 -03:00
run: feedback
@docker exec -it \
${CONTAINER_BASENAME}_${SERVICE} \
bash /var/scripts/${SCRIPT}.sh
2022-11-08 07:17:30 -03:00
cron:
2022-11-16 21:08:03 -03:00
@./scripts/system/cron.sh
2022-11-08 07:17:30 -03:00
2022-11-16 14:51:23 -03:00
cron--run:
@./scripts/system/cron--run.sh
2022-11-08 07:17:30 -03:00
cloudflare:
2022-11-16 14:51:23 -03:00
@./scripts/system/cloudflare.sh
2022-11-08 07:17:30 -03:00
2023-01-11 20:21:52 -03:00
cloudflare--create:
2023-01-13 08:58:34 -03:00
@./scripts/system/cloudflare--create.sh | (printf "CLOUDFLARE_IDENTIFIER=" && cat) >> ${NAMESPACE_FILE}
2023-01-11 20:21:52 -03:00
cloudflare--delete:
@./scripts/system/cloudflare--delete.sh
2022-11-05 19:10:02 -03:00
encryption-key:
@openssl rand -base64 32
2022-11-16 15:11:57 -03:00
install-docker:
@SYSTEM=${SYSTEM} \
./scripts/os/${SYSTEM}/install-docker.sh
2022-11-05 19:10:02 -03:00
.PHONY: namespace
namespace:
2022-11-16 14:51:23 -03:00
@chmod +x ./scripts/system/namespace.sh
2022-11-05 19:10:02 -03:00
@NAMESPACE=${NAMESPACE} \
NAMESPACE_EXISTS=${NAMESPACE_EXISTS} \
NAMESPACE_FILE=${NAMESPACE_FILE} \
HOSTNAME=${HOSTNAME} \
ENCRYPTION_KEY=${ENCRYPTION_KEY} \
2022-11-16 14:51:23 -03:00
./scripts/system/namespace.sh
2022-11-05 19:10:02 -03:00
2022-10-17 19:48:55 -03:00
# Docker compose
2022-04-01 16:04:53 -03:00
up: feedback feedback--compose feedback--url
${DOCKER_COMPOSE} up
2022-04-01 16:04:53 -03:00
up-d: feedback feedback--compose feedback--url
${DOCKER_COMPOSE} up -d
2022-04-01 16:04:53 -03:00
2022-10-07 14:22:07 -03:00
stop: feedback feedback--compose
${DOCKER_COMPOSE} stop
start: feedback feedback--compose
${DOCKER_COMPOSE} start
restart: feedback feedback--compose
${DOCKER_COMPOSE} restart
2022-04-01 16:04:53 -03:00
2022-10-07 14:22:07 -03:00
down: feedback feedback--compose
${DOCKER_COMPOSE} down
2022-04-01 16:04:53 -03:00
2022-10-07 14:22:07 -03:00
down--volumes: feedback feedback--compose
${DOCKER_COMPOSE} down --volumes
2022-10-17 10:22:01 -03:00
2023-01-13 08:58:34 -03:00
# Instances
2023-01-13 09:23:13 -03:00
spawn: feedback feedback--compose feedback--url cloudflare--create up-d
2023-01-13 09:16:03 -03:00
2024-02-14 10:15:23 -03:00
.PHONY: deploy
2024-02-14 10:07:10 -03:00
deploy: feedback feedback--compose feedback--url
@./scripts/system/deploy.sh
update: feedback feedback--compose feedback--url
@./scripts/system/update.sh
2023-01-13 08:58:34 -03:00
destroy: feedback feedback--compose cloudflare--delete
2023-01-11 20:21:52 -03:00
${DOCKER_COMPOSE} down --volumes
@rm namespace/${NAMESPACE}
2024-02-04 15:12:55 -03:00
# Provisioning
2024-02-04 15:31:40 -03:00
provision: feedback--short
2024-02-04 15:12:55 -03:00
make namespace HOSTNAME="${NAMESPACE}.${DOMAIN}"
make spawn NAMESPACE=${NAMESPACE}
2024-02-04 15:31:40 -03:00
install: feedback--short
2024-02-04 15:12:55 -03:00
docker exec -it --user ${DOCKER_USER} \
${CONTAINER_BASENAME}_${SERVICE} \
app/bin/legacy -C install -u "${ADMIN_USER}" -e "${ADMIN_EMAIL}" -x "${ADMIN_PASSWORD}"
2022-11-03 19:15:26 -03:00
# nginx-proxy
proxy:
@docker network create nginx-proxy || true
2022-11-16 21:08:03 -03:00
@docker run \
2022-11-03 19:15:26 -03:00
--detach \
--name nginx-proxy \
--net nginx-proxy \
--publish 80:80 \
--publish 443:443 \
2022-11-17 13:52:55 -03:00
--restart=always \
2022-11-03 19:15:26 -03:00
--volume certs:/etc/nginx/certs \
--volume vhost:/etc/nginx/vhost.d \
--volume html:/usr/share/nginx/html \
2022-11-14 13:44:41 -03:00
--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 \
2022-11-03 19:15:26 -03:00
nginxproxy/nginx-proxy
2022-11-16 21:08:03 -03:00
@docker run \
2022-11-03 19:15:26 -03:00
--detach \
--name nginx-proxy-acme \
2022-11-17 13:52:55 -03:00
--restart=always \
2022-11-03 19:15:26 -03:00
--volumes-from nginx-proxy \
--volume acme:/etc/acme.sh \
2022-11-14 19:21:05 -03:00
--mount type=bind,source=/var/run/docker.sock,target=/var/run/docker.sock,readonly \
2022-11-05 15:50:43 -03:00
--env "DEFAULT_EMAIL=${EMAIL_HTTPS}" \
2022-11-03 19:15:26 -03:00
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
2022-11-07 15:29:15 -03:00
@docker network rm nginx-proxy || true
2022-11-03 19:15:26 -03:00