Ghost Discourse Integration

Ich habe große Schwierigkeiten, eine Integration zwischen Ghost und Discourse einzurichten.

Discourse ist: 2.8.0.beta1, Docker auf Ubuntu – ohne Nginx.

Ich verwende Traefik auf einem eigenständigen System hinter einem einzelnen IP-Router in einem NAT-geschützten Heim-LAN. Traefik ermöglicht HTTP/HTTPS-Routing.

Traefik ist mit einer traefik_dynamic.toml konfiguriert und nicht über Docker-Labels. Es gibt kein gemeinsames Docker-Netzwerk. (Falls jemand an der Traefik-Konfiguration interessiert ist – bitte melden Sie sich – sie funktioniert als Reverse-Proxy sehr gut).

Ghost ist ebenfalls die neueste Version (4.6.4) und läuft auf einem separaten Host (beide Hosts sind Ubuntu-VMs – VERSION=“20.04.2 LTS (Focal Fossa)”, laufen auf Proxmox).

Ich habe die verschiedenen Tutorial-Seiten befolgt, die auf der Ghost-Dokumentationsseite und im Discourse-Forum verfügbar sind.

Die Firefox-Webentwickler-Tools zeigen an, dass die Seite folgenden Quellcode zurückgibt:

<div class="comment container small">

<div class="discourse-comments"></div>
    <script type="text/javascript">
     if (window.location.pathname.indexOf('/p/') < 0) {
      DiscourseEmbed = { discourseUrl: 'https://discourse.mydomain/', discourseEmbedUrl: 'https://ghost.mydomain/testing-new-stuff/' };

  (function() {
    var d = document.createElement('script'); d.type = 'text/javascript'; d.async = true;
    d.src = DiscourseEmbed.discourseUrl + 'javascripts/embed.js';
    (document.getElementsByTagName('head')[0] || document.getElementsByTagName('body')[0]).appendChild(d);
  })();
}
</script>
</div>

Es werden jedoch keine tatsächlichen Kommentare zurückgegeben. Ich kann sehen, dass mein Discourse-Host embed.js zurückgibt, aber auf der Seite kommt nichts an. (Entschuldigung, ich bin kein Webentwickler).

Es scheint also, dass das Skript durchkommt, aber nichts zurückgibt.

Es ist eine neue Discourse-Installation und befindet sich noch in der Lernphase (Bootstrap-Modus). Es gibt also kaum Themen.

Die app.yml ist unten angehängt.

Die eingebetteten Host-Einstellungen sind meiner Meinung nach korrekt, mit dem Discourse-Administratorbenutzernamen für die Themenerstellung; die Pfad-Whitelist ist derzeit “”.

Ich habe eine Kategorie namens „testing“ erstellt und diese zu „Post to category“ hinzugefügt.

Außerdem habe ich DISCOURSE_ENABLE_CORS: true zu app.yml hinzugefügt, da dies helfen könnte. Ich habe den Proxy sowie http://ghost.mydomain und http://ghost.mydomain zu den CORS-Ursprüngen hinzugefügt.

Kann mir jemand Rat geben, wie man dies debuggen kann?

app.yml:
#
templates:
  - "templates/postgres.template.yml"
  - "templates/redis.template.yml"
  - "templates/web.template.yml"
  - "templates/web.ratelimited.template.yml"
## Diese beiden Zeilen kommentieren Sie aus, wenn Sie Lets Encrypt (https) hinzufügen möchten
#  - "templates/web.ssl.template.yml"
#  - "templates/web.letsencrypt.ssl.template.yml"

## Welche TCP/IP-Ports sollte dieser Container exponieren?
## Wenn Sie möchten, dass Discourse einen Port mit einem anderen Webserver wie Apache oder nginx teilt,
## siehe https://meta.discourse.org/t/17247 für Details
expose:
  - "8081:80"   # http
    #  - "443:443" # https

params:
  db_default_text_search_config: "pg_catalog.english"

  ## Setzen Sie db_shared_buffers auf maximal 25 % des Gesamtspeichers.
  ## wird automatisch vom Bootstrap basierend auf dem erkannten RAM gesetzt, oder Sie können es überschreiben
  db_shared_buffers: "2048MB"

  ## Kann die Sortierleistung verbessern, erhöht aber die Speichernutzung pro Verbindung
  #db_work_mem: "40MB"

  ## Welche Git-Revision soll dieser Container verwenden? (Standard: 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

  DISCOURSE_ENABLE_CORS: true

  ## Wie viele gleichzeitige Webanfragen werden unterstützt? Hängt von Speicher und CPU-Kernen ab.
  ## wird automatisch vom Bootstrap basierend auf den erkannten CPUs gesetzt, oder Sie können es überschreiben
  UNICORN_WORKERS: 2

  ## TODO: Der Domainname, auf den diese Discourse-Instanz antworten soll
  ## Erforderlich. Discourse funktioniert nicht mit einer bloßen IP-Nummer.
  DISCOURSE_HOSTNAME: mydiscoursehost.mydomain

  ## Kommentieren Sie dies aus, wenn Sie möchten, dass der Container mit demselben
  ## Hostnamen (-h-Option) wie oben angegeben gestartet wird (Standard: "$hostname-$config")
  #DOCKER_USE_HOSTNAME: true

  ## TODO: Liste der durch Komma getrennten E-Mails, die bei der ersten Anmeldung zu Administratoren und Entwicklern werden
  ## Beispiel 'user1@example.com,user2@example.com'
  DISCOURSE_DEVELOPER_EMAILS: 'myemailaddress@mydomain'

  ## TODO: Der SMTP-Mailserver, der zur Validierung neuer Konten und zum Senden von Benachrichtigungen verwendet wird
  ## SMTP-Adresse, Benutzername und Passwort sind erforderlich
  ## WARNUNG: Das Zeichen '#' im SMTP-Passwort kann Probleme verursachen!
  DISCOURSE_SMTP_ADDRESS: smtp.mailgun.org
  DISCOURSE_SMTP_PORT: 587
  DISCOURSE_SMTP_USER_NAME: postmaster@mydomain
  DISCOURSE_SMTP_PASSWORD: "mypostmasterpassword7"
  #DISCOURSE_SMTP_ENABLE_START_TLS: true           # (optional, Standard true)
  DISCOURSE_SMTP_DOMAIN: mydomain
  DISCOURSE_NOTIFICATION_EMAIL: noreply@mydomain

  ## Wenn Sie die Lets-Encrypt-Vorlage hinzugefügt haben, kommentieren Sie unten aus, um ein kostenloses SSL-Zertifikat zu erhalten
  #  LETSENCRYPT_ACCOUNT_EMAIL: notused

  ## Die HTTP- oder HTTPS-CDN-Adresse für diese Discourse-Instanz (konfiguriert zum Abrufen)
  ## siehe https://meta.discourse.org/t/14857 für Details
  #DISCOURSE_CDN_URL: https://discourse-cdn.example.com
 
  ## Der MaxMind-Geolokalisierungs-IP-Schlüssel für die IP-Adresssuche
  ## siehe https://meta.discourse.org/t/-/137387/23 für Details
  #DISCOURSE_MAXMIND_LICENSE_KEY: 1234567890123456

## Der Docker-Container ist zustandslos; alle Daten werden in /shared gespeichert
volumes:
  - volume:
      host: /var/discourse/shared/standalone
      guest: /shared
  - volume:
      host: /var/discourse/shared/standalone/log/var-log
      guest: /var/log

## Plugins gehen hier
## siehe https://meta.discourse.org/t/19157 für Details
hooks:
  after_code:
    - exec:
        cd: $home/plugins
        cmd:
          - git clone https://github.com/discourse/docker_manager.git

## Beliebige benutzerdefinierte Befehle, die nach dem Build ausgeführt werden sollen
run:
  - exec: echo "Beginning of custom commands"
  ## Wenn Sie die 'From'-E-Mail-Adresse für Ihre erste Registrierung festlegen möchten, kommentieren Sie dies aus und ändern Sie:
  ## Nach Erhalt der ersten Anmelde-E-Mail diesen Kommentar wieder entfernen. Es muss nur einmal ausgeführt werden.
  #- exec: rails r "SiteSetting.notification_email='info@unconfigured.discourse.org'"
  - exec: echo "End of custom commands"