66 lines
3.0 KiB
Makefile
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
|