Files
dyncoll-dev/Makefile
2026-06-15 01:16:01 +02:00

66 lines
3.0 KiB
Makefile

# =============================================================================
# Makefile — workflow host/container condiviso (vedi CLAUDE.md §Workflow).
# Regola d'oro: chi scrive file lo fa come utente host (beppe). Mai mischiare
# node_modules musl(container) e glibc(host).
# - composer / npm -> HOST
# - artisan con servizi -> container MA come UID host (file beppe-owned)
# =============================================================================
UID := $(shell id -u)
GID := $(shell id -g)
DC := docker compose
EXEC := $(DC) exec -u $(UID):$(GID) backend
.DEFAULT_GOAL := help
.PHONY: help up down build logs composer be-install be-update artisan migrate import tinker fe-install fe-add fe-rebuild fe-dev fe-build permissions
help: ## Mostra questo aiuto
@grep -hE '^[a-zA-Z_-]+:.*?## ' $(MAKEFILE_LIST) | awk 'BEGIN{FS=":.*?## "}{printf " \033[36m%-14s\033[0m %s\n",$$1,$$2}'
## --- Stack ---
up: ## Avvia l'intero stack dev: Vite HMR + backend(serve) + db + redis + docs + mailpit
$(DC) up -d
down: ## Ferma lo stack
$(DC) down
build: ## Ricostruisce le immagini (con --pull per base aggiornate)
$(DC) build --pull
logs: ## Segue i log del backend
$(DC) logs -f backend
## --- Backend / PHP (composer sull'HOST) ---
composer: ## composer host (es: make composer c="require foo/bar")
composer -d backend $(c)
be-install: ## composer install (host)
composer -d backend install
be-update: ## composer update (host)
composer -d backend update
artisan: ## artisan nel container come utente host (es: make artisan c="migrate --seed")
$(EXEC) php artisan $(c)
migrate: ## php artisan migrate (container)
$(EXEC) php artisan migrate
import: ## ETL da v1 (container)
$(EXEC) php artisan v1:import
tinker: ## REPL artisan (container)
$(EXEC) php artisan tinker
## --- Frontend / Node ---
# In dev Vite gira NEL container (make up): HMR via bind-mount, node_modules musl
# nel volume anonimo. npm gira sull'HOST (package.json/lock + node_modules host per
# il type-check dell'IDE); poi si rigenera immagine + volume node_modules del container.
# AGGIUNGERE UNA LIBRERIA: make fe-add p="leaflet" && make fe-rebuild
fe-install: ## npm install host da package.json (package-lock + node_modules host per l'IDE)
cd frontend && npm install
fe-add: ## Aggiunge una dipendenza (host) — es: make fe-add p="leaflet" oppure p="-D nome"; poi make fe-rebuild
cd frontend && npm install $(p)
fe-rebuild: ## Rigenera immagine frontend E il volume node_modules del container (dopo modifiche a package.json)
$(DC) up -d --build --renew-anon-volumes frontend
fe-dev: ## ALTERNATIVA: vite dev server su host senza Docker (conflitto porta 5173 se lo stack è su)
cd frontend && npm run dev
fe-build: ## build di produzione su host (smoke test locale)
cd frontend && npm run build
## --- Manutenzione ---
permissions: ## Permessi storage scrivibili da php-fpm (www-data) — richiede sudo, una tantum
sudo chgrp -R www-data backend/storage backend/bootstrap/cache
sudo chmod -R g+ws backend/storage backend/bootstrap/cache