Comptabilite (Super Admin) : - ComptabiliteController avec 7 exports CSV/JSON compatibles SAGE (journal ventes, grand livre, FEC, balance agee, reglements, commissions Stripe 1.5%+0.25E, couts services) - Export PDF via ComptaPdf (FPDF) avec bloc legal pre-rempli, tableau pagine, champ signature DocuSeal - Signature electronique DocuSeal + callback + envoi email signe avec template dedie (compta_export_signed.html.twig) - Rapport financier public (RapportFinancierPdf) : recettes par service, depenses (Stripe, infra, prestataires), bilan excedent/deficit - Codes comptables clients EC-XXXX (plus de 411xxx) Prestataires (Super Admin) : - Entite Prestataire (raisonSociale, siret, email, phone, adresse) - Entite FacturePrestataire (numFacture, montantHt, montantTtc, year, month, isPaid, PDF via Vich) - CRUD complet avec recherche SIRET via proxy API data.gouv.fr - Commande cron app:reminder:factures-prestataire (5 du mois) - Factures prestataires integrees dans export couts services - Sidebar Super Admin : entree Prestataires + Comptabilite Stats (/admin/stats) : - Cout prestataire dynamique depuis FacturePrestataire - Fusion Infra + Prestataire en "Cout de fonctionnement" - Commission Stripe corrigee (1.5% + 0.25E par transaction) Divers : - DocuSealService::sendComptaForSignature() + getApi() - Customer::generateCodeComptable() format EC-XXXX-XXXXX - Protection double prefixe EC- a la creation client - Bouton regenerer PDF cache quand advert state=accepted - Modals sans script inline (data-modal-open/close dans app.js) Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
282 lines
6.8 KiB
YAML
282 lines
6.8 KiB
YAML
services:
|
|
php:
|
|
build:
|
|
context: ./docker/php/dev
|
|
dockerfile: Dockerfile
|
|
container_name: crm_siteconseil_php
|
|
restart: unless-stopped
|
|
group_add:
|
|
- "${DOCKER_GID:-989}"
|
|
volumes:
|
|
- .:/app
|
|
- /var/run/docker.sock:/var/run/docker.sock:ro
|
|
ports:
|
|
- "9000:9000"
|
|
depends_on:
|
|
pgbouncer:
|
|
condition: service_healthy
|
|
redis:
|
|
condition: service_healthy
|
|
|
|
database:
|
|
image: postgres:16-alpine
|
|
container_name: crm_siteconseil_database
|
|
environment:
|
|
POSTGRES_USER: app
|
|
POSTGRES_PASSWORD: secret
|
|
POSTGRES_DB: crm_siteconseil
|
|
ports:
|
|
- "5432:5432"
|
|
volumes:
|
|
- db-data:/var/lib/postgresql/data
|
|
- ./docker/dovecot/init-esymail.sql:/docker-entrypoint-initdb.d/02-init-esymail.sql:ro
|
|
healthcheck:
|
|
test: ["CMD-SHELL", "pg_isready -U app -d crm_siteconseil"]
|
|
interval: 5s
|
|
timeout: 5s
|
|
retries: 5
|
|
|
|
pgbouncer:
|
|
image: edoburu/pgbouncer
|
|
container_name: crm_siteconseil_pgbouncer
|
|
volumes:
|
|
- ./docker/pgsql/pgbouncer-dev.ini:/etc/pgbouncer/pgbouncer.ini:ro
|
|
- ./docker/pgsql/userlist-dev.txt:/etc/pgbouncer/userlist.txt:ro
|
|
ports:
|
|
- "6432:6432"
|
|
depends_on:
|
|
database:
|
|
condition: service_healthy
|
|
healthcheck:
|
|
test: ["CMD-SHELL", "pg_isready -h 127.0.0.1 -p 6432 -U app"]
|
|
interval: 5s
|
|
timeout: 5s
|
|
retries: 5
|
|
|
|
redis:
|
|
image: redis:7-alpine
|
|
container_name: crm_siteconseil_redis
|
|
command: redis-server --requirepass crm_siteconseil
|
|
ports:
|
|
- "6379:6379"
|
|
volumes:
|
|
- redis-data:/data
|
|
healthcheck:
|
|
test: ["CMD", "redis-cli", "-a", "crm_siteconseil", "ping"]
|
|
interval: 5s
|
|
timeout: 5s
|
|
retries: 5
|
|
|
|
caddy:
|
|
image: caddy:2-alpine
|
|
container_name: crm_siteconseil_caddy
|
|
ports:
|
|
- "8000:80"
|
|
volumes:
|
|
- ./docker/caddy/Caddyfile:/etc/caddy/Caddyfile
|
|
- .:/app
|
|
depends_on:
|
|
- php
|
|
|
|
messenger:
|
|
build:
|
|
context: ./docker/php/dev
|
|
dockerfile: Dockerfile
|
|
container_name: crm_siteconseil_messenger
|
|
command: php bin/console messenger:consume async -vv
|
|
restart: unless-stopped
|
|
volumes:
|
|
- .:/app
|
|
depends_on:
|
|
pgbouncer:
|
|
condition: service_healthy
|
|
redis:
|
|
condition: service_healthy
|
|
meilisearch:
|
|
condition: service_started
|
|
|
|
bun:
|
|
image: oven/bun:alpine
|
|
container_name: crm_siteconseil_bun
|
|
working_dir: /app
|
|
volumes:
|
|
- .:/app
|
|
- bun-modules:/app/node_modules
|
|
command: sh -c "bun install && bun run dev"
|
|
ports:
|
|
- "5173:5173"
|
|
|
|
mailpit:
|
|
image: axllent/mailpit
|
|
container_name: crm_siteconseil_mailpit
|
|
ports:
|
|
- "1025:1025"
|
|
- "8025:8025"
|
|
|
|
vault:
|
|
image: hashicorp/vault:latest
|
|
container_name: crm_siteconseil_vault
|
|
cap_add:
|
|
- IPC_LOCK
|
|
environment:
|
|
VAULT_DEV_ROOT_TOKEN_ID: crm_siteconseil
|
|
VAULT_DEV_LISTEN_ADDRESS: 0.0.0.0:8200
|
|
ports:
|
|
- "8200:8200"
|
|
volumes:
|
|
- vault-data:/vault/file
|
|
|
|
ngrok:
|
|
image: ngrok/ngrok:latest
|
|
container_name: crm_siteconseil_ngrok
|
|
command: http caddy:80 --log stdout
|
|
environment:
|
|
NGROK_AUTHTOKEN: GXtZtKtRxRF5TFV5pCKD_25f1ALUyQQ9LkyQJgv1dr
|
|
ports:
|
|
- "4040:4040"
|
|
depends_on:
|
|
- caddy
|
|
|
|
ngrok-sync:
|
|
image: curlimages/curl:latest
|
|
container_name: crm_siteconseil_ngrok_sync
|
|
user: "0:0"
|
|
volumes:
|
|
- .:/app
|
|
- ./docker/ngrok/sync.sh:/sync.sh
|
|
depends_on:
|
|
- ngrok
|
|
entrypoint: sh /sync.sh
|
|
|
|
meilisearch:
|
|
image: getmeili/meilisearch:latest
|
|
container_name: crm_siteconseil_meilisearch
|
|
environment:
|
|
MEILI_MASTER_KEY: crm_siteconseil
|
|
MEILI_ENV: development
|
|
ports:
|
|
- "7700:7700"
|
|
volumes:
|
|
- meilisearch-data:/meili_data
|
|
|
|
cron:
|
|
build:
|
|
context: ./docker/cron
|
|
dockerfile: Dockerfile
|
|
container_name: crm_siteconseil_cron
|
|
restart: unless-stopped
|
|
group_add:
|
|
- "${DOCKER_GID:-989}"
|
|
volumes:
|
|
- .:/app
|
|
- /var/run/docker.sock:/var/run/docker.sock:ro
|
|
depends_on:
|
|
pgbouncer:
|
|
condition: service_healthy
|
|
redis:
|
|
condition: service_healthy
|
|
|
|
redisinsight:
|
|
image: redis/redisinsight:latest
|
|
container_name: crm_siteconseil_redisinsight
|
|
ports:
|
|
- "5540:5540"
|
|
depends_on:
|
|
redis:
|
|
condition: service_healthy
|
|
|
|
postfix:
|
|
image: boky/postfix:latest
|
|
container_name: crm_siteconseil_postfix
|
|
restart: unless-stopped
|
|
hostname: mail.e-cosplay.local
|
|
environment:
|
|
ALLOWED_SENDER_DOMAINS: e-cosplay.fr e-cosplay.local
|
|
RELAYHOST: "[mailpit]:1025"
|
|
POSTFIX_myhostname: mail.e-cosplay.local
|
|
POSTFIX_mydestination: e-cosplay.local, localhost
|
|
POSTFIX_mynetworks: "10.0.0.0/8 172.16.0.0/12 192.168.0.0/16"
|
|
POSTFIX_smtpd_milters: "inet:rspamd:11332"
|
|
POSTFIX_non_smtpd_milters: "inet:rspamd:11332"
|
|
POSTFIX_milter_protocol: "6"
|
|
POSTFIX_milter_default_action: "accept"
|
|
POSTFIX_smtp_tls_security_level: "none"
|
|
volumes:
|
|
- postfix-data:/var/spool/postfix
|
|
depends_on:
|
|
rspamd:
|
|
condition: service_started
|
|
mailpit:
|
|
condition: service_started
|
|
healthcheck:
|
|
test: ["CMD-SHELL", "postfix status || exit 1"]
|
|
interval: 10s
|
|
timeout: 5s
|
|
retries: 5
|
|
|
|
rspamd:
|
|
image: rspamd/rspamd:latest
|
|
container_name: crm_siteconseil_rspamd
|
|
restart: unless-stopped
|
|
volumes:
|
|
- rspamd-data:/var/lib/rspamd
|
|
depends_on:
|
|
clamav:
|
|
condition: service_healthy
|
|
environment:
|
|
- CLAMAV_HOST=clamav
|
|
|
|
clamav:
|
|
image: clamav/clamav:stable
|
|
container_name: crm_siteconseil_clamav
|
|
restart: unless-stopped
|
|
volumes:
|
|
- clamav-data:/var/lib/clamav
|
|
healthcheck:
|
|
test: ["CMD-SHELL", "clamdcheck || echo 0"]
|
|
interval: 30s
|
|
timeout: 10s
|
|
retries: 5
|
|
start_period: 120s
|
|
|
|
dovecot:
|
|
build:
|
|
context: ./docker/dovecot
|
|
dockerfile: Dockerfile
|
|
container_name: crm_siteconseil_dovecot
|
|
restart: unless-stopped
|
|
volumes:
|
|
- dovecot-mail:/var/mail/vhosts
|
|
- dovecot-logs:/var/log/dovecot
|
|
depends_on:
|
|
database:
|
|
condition: service_healthy
|
|
|
|
fail2ban:
|
|
image: crazymax/fail2ban:latest
|
|
container_name: crm_siteconseil_fail2ban
|
|
restart: unless-stopped
|
|
cap_add:
|
|
- NET_ADMIN
|
|
- NET_RAW
|
|
network_mode: host
|
|
volumes:
|
|
- ./docker/fail2ban/jail.local:/etc/fail2ban/jail.local:ro
|
|
- ./docker/fail2ban/filter.d/dovecot.conf:/etc/fail2ban/filter.d/dovecot.conf:ro
|
|
- fail2ban-data:/var/lib/fail2ban
|
|
- dovecot-logs:/var/log/dovecot:ro
|
|
|
|
volumes:
|
|
db-data:
|
|
redis-data:
|
|
bun-modules:
|
|
vault-data:
|
|
meilisearch-data:
|
|
libretranslate-data:
|
|
postfix-data:
|
|
rspamd-data:
|
|
clamav-data:
|
|
fail2ban-data:
|
|
dovecot-mail:
|
|
dovecot-logs:
|