Je suis en train de vérifier et de modifier le fichier app.yml. J’ai effacé les journaux au préalable. Je vais tenter d’envoyer des e-mails et je vous tiendrai informé.
EDIT
Ainsi, en effaçant les journaux et en envoyant des e-mails à Gmail ou à mon propre domaine, aucune erreur ne s’affiche. Je reçois des e-mails sur Gmail mais aucun sur mon domaine.
Les journaux de MailGun indiquent essentiellement ceci :
{
"recipient": "me@mydomain",
"id": "SCBCSJxDSqupdU9Da29rRw",
"envelope": {
"sender": "postmaster@mg.mydomain",
"targets": "me@mydomain",
"transport": "smtp",
"sending-ip": "192.168.0.1"
},
"timestamp": 1697462206.8430145,
"user-variables": {},
"message": {
"headers": {
"from": "Discourse Test Forum <postmaster@mg.mydomain>",
"message-id": "9d3b190d-bcbd-4378-8eb6-fc90cd57fe35@discourse.mydomain",
"to": "me@mydomain",
"subject": "[Discourse Test Forum] Email Deliverability Test"
},
"attachments": [],
"size": 4546
},
"storage": {
"region": "us-west1",
"key": "BAABAQUOTl3y4PtvsqlN5Z2OvaxXslLlZA",
"env": "production",
"url": "https://storage-us-west1.api.mailgun.net/v3/domains/mg.mydomain/messages/BAABAQUOTl3y4PtvsqlN5Z2OvaxXslLlZA"
},
"reason": "generic",
"delivery-status": {
"enhanced-code": "",
"mx-host": "mydomain",
"description": "",
"certificate-verified": true,
"attempt-no": 1,
"code": 550,
"message": "Verification failed for <bounce+674b6a.be6180c-me=mydomain@mg.mydomain>\nThe mail server does not recognize bounce+674b6a.be6180c-me=mydomain@mg.mydomain as a valid sender.\nSender verify failed",
"session-seconds": 40.878,
"tls": true
},
"campaigns": [],
"severity": "permanent",
"tags": [],
"recipient-domain": "mydomain",
"flags": {
"is-routed": false,
"is-authenticated": true,
"is-test-mode": false,
"is-system-test": false
},
"log-level": "error",
"event": "failed"
}
Je ne reçois ceci que lorsque j’essaie sur mon propre domaine. Si j’essaie sur n’importe quel autre domaine, cela fonctionne, qu’il s’agisse d’un e-mail gratuit ou non.
Voici les paramètres actuels dans app.yml :
## voici le modèle de conteneur Docker autonome tout-en-un
##
## Après avoir effectué des modifications dans ce fichier, vous DEVEZ reconstruire
## /var/discourse/launcher rebuild app
##
## SOYEZ TRÈS PRUDENT LORS DE LA MODIFICATION !
## LES FICHIERS YAML SONT EXTRÊMEMENT SENSIBLES AUX ERREURS D'ESPACEMENT OU D'ALIGNEMENT !
## visitez http://www.yamllint.com/ pour valider ce fichier si nécessaire
templates:
- "templates/postgres.template.yml"
- "templates/redis.template.yml"
- "templates/web.template.yml"
## Décommentez la ligne suivante pour activer l'écoute IPv6
#- "templates/web.ipv6.template.yml"
- "templates/web.ratelimited.template.yml"
## Décommentez ces deux lignes si vous souhaitez ajouter Lets Encrypt (https)
- "templates/web.ssl.template.yml"
- "templates/web.letsencrypt.ssl.template.yml"
## quels ports TCP/IP ce conteneur doit-il exposer ?
## Si vous souhaitez que Discourse partage un port avec un autre serveur web comme Apache ou nginx,
## consultez https://meta.discourse.org/t/17247 pour plus de détails
expose:
- "80:80" # http
- "443:443" # https
params:
db_default_text_search_config: "pg_catalog.english"
## Définissez db_shared_buffers à un maximum de 25 % de la mémoire totale.
## sera défini automatiquement par bootstrap en fonction de la RAM détectée, ou vous pouvez le remplacer
db_shared_buffers: "2048MB"
## peut améliorer les performances de tri, mais augmente l'utilisation de la mémoire par connexion
#db_work_mem: "40MB"
## Quelle révision Git ce conteneur doit-il utiliser ? (par défaut : tests-passed)
#version: tests-passed
env:
LC_ALL: en_US.UTF-8
LANG: en_US.UTF-8
LANGUAGE: en_US.UTF-8
# DISCOURSE_DEFAULT_LOCALE: en
## Combien de requêtes web simultanées sont prises en charge ? Dépend de la mémoire et des cœurs CPU.
## sera défini automatiquement par bootstrap en fonction des CPU détectés, ou vous pouvez le remplacer
UNICORN_WORKERS: 8
## TODO : Le nom de domaine auquel cette instance Discourse répondra
## Obligatoire. Discourse ne fonctionnera pas avec un simple numéro IP.
DISCOURSE_HOSTNAME: mydomain
## Décommentez si vous souhaitez que le conteneur soit démarré avec le même
## nom d'hôte (-h option) que celui spécifié ci-dessus (par défaut "$hostname-$config")
#DOCKER_USE_HOSTNAME: true
## TODO : Liste des e-mails séparés par des virgules qui seront faits administrateurs et développeurs
## lors de la première inscription, par exemple 'user1@example.com,user2@example.com'
DISCOURSE_DEVELOPER_EMAILS: 'me@mydomain'
## TODO : Le serveur de messagerie SMTP utilisé pour valider les nouveaux comptes et envoyer des notifications
# ADRESSE SMTP, nom d'utilisateur et mot de passe sont requis
# ATTENTION le caractère '#' dans le mot de passe SMTP peut causer des problèmes !
DISCOURSE_SMTP_ADDRESS: smtp.mailgun.org
DISCOURSE_SMTP_PORT: 587
DISCOURSE_SMTP_USER_NAME: postmaster@mg.mydomain
DISCOURSE_SMTP_PASSWORD: "mailgunpassword"
#DISCOURSE_SMTP_ENABLE_START_TLS: true # (facultatif, par défaut true)
#DISCOURSE_SMTP_FORCE_TLS: true
DISCOURSE_SMTP_DOMAIN: mydomain
DISCOURSE_NOTIFICATION_EMAIL: postmaster@mg.mydomain
## Si vous avez ajouté le modèle Lets Encrypt, décommentez ci-dessous pour obtenir un certificat SSL gratuit
LETSENCRYPT_ACCOUNT_EMAIL: freemailaccount
## L'adresse CDN http ou https pour cette instance Discourse (configurée pour tirer)
## consultez https://meta.discourse.org/t/14857 pour plus de détails
#DISCOURSE_CDN_URL: https://discourse-cdn.example.com
## La clé d'adresse IP de géolocalisation maxmind pour la recherche d'adresses IP
## consultez https://meta.discourse.org/t/-/137387/23 pour plus de détails
#DISCOURSE_MAXMIND_LICENSE_KEY: 1234567890123456
## Le conteneur Docker est sans état ; toutes les données sont stockées dans /shared
volumes:
- volume:
host: /var/discourse/shared/standalone
guest: /shared
- volume:
host: /var/discourse/shared/standalone/log/var-log
guest: /var/log
## Les plugins vont ici
## consultez https://meta.discourse.org/t/19157 pour plus de détails
hooks:
after_code:
- exec:
cd: $home/plugins
cmd:
- git clone https://github.com/discourse/docker_manager.git
- git clone https://github.com/discourse/discourse-spoiler-alert.git
- git clone https://github.com/discourse/discourse-solved.git
- git clone https://github.com/discourse/discourse-docs.git
## Toutes les commandes personnalisées à exécuter après la construction
run:
- exec: echo "Début des commandes personnalisées"
## Si vous souhaitez définir l'adresse e-mail 'De' pour votre première inscription, décommentez et modifiez :
## Après avoir reçu le premier e-mail d'inscription, re-commentez la ligne. Elle ne doit s'exécuter qu'une seule fois.
#- exec: rails r "SiteSetting.notification_email='info@unconfigured.discourse.org'"
- exec: echo "Fin des commandes personnalisées"
Les seules modifications apportées à ceci seraient :
DISCOURSE_SMTP_ADDRESS: smtp.mydomain
DISCOURSE_SMTP_PORT: 587
DISCOURSE_SMTP_USER_NAME: email@mydomain
DISCOURSE_SMTP_PASSWORD: "mydomainmailpassword"
#DISCOURSE_SMTP_ENABLE_START_TLS: true # (facultatif, par défaut true)
#DISCOURSE_SMTP_FORCE_TLS: true
DISCOURSE_SMTP_DOMAIN: mydomain
DISCOURSE_NOTIFICATION_EMAIL: email@mydomain
Une fois que j’aurai une réponse de quelqu’un, je ferai ces modifications et vérifierai à nouveau les journaux. Ou alors… peut-être que je le fais tout simplement - je poste les journaux - et j’attends une réponse. Cela ne devrait pas prendre trop de temps. On verra.