Integração Ghost Discourse

Estou enfrentando dificuldades para estabelecer uma integração entre o Ghost e o Discourse.

O Discourse está na versão: 2.8.0.beta1, rodando em Docker no Ubuntu, sem nginx.

Estou usando o Traefik em um sistema independente atrás de um único roteador IP, em uma LAN doméstica com NAT. O Traefik permite roteamento HTTP/HTTPS.

O Traefik está configurado com um arquivo traefik_dynamic.toml em vez de labels do Docker. Não há uma rede Docker compartilhada. (Se alguém estiver interessado na configuração do Traefik, por favor, me avise — ele funciona muito bem como um proxy reverso).

O Ghost também está na versão mais recente (4.6.4) e roda em um host separado (ambos os hosts são VMs Ubuntu, VERSÃO=“20.04.2 LTS (Focal Fossa)”, rodando no Proxmox).

Segui as diversas páginas de tutorial disponíveis no site da documentação do Ghost e no fórum do Discourse.

As Ferramentas de Desenvolvedor do Firefox indicam que a página retorna o seguinte código-fonte:

<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>

Mas nenhum comentário real é retornado. Posso ver que meu host do Discourse retorna o embed.js, mas nada aparece na página. (Desculpe, não sou uma pessoa da área de desenvolvimento web).

Parece que o script está sendo carregado, mas não retorna nada.

É uma instalação nova do Discourse e ainda está no modo de treinamento (bootstrap mode). Então, há quase nenhum tópico ainda.

O arquivo app.yml está anexado abaixo.

As configurações do host incorporado estão corretas, acredito, com o usuário administrador do Discourse como nome de usuário para criação de tópicos; a lista de permissões de caminho está atualmente como “”.

Criei uma categoria chamada “testing” e ela foi adicionada à opção “Postar na categoria”.

Também adicionei DISCOURSE_ENABLE_CORS: true ao app.yml porque isso pode ajudar. Adicionei o proxy e http://ghost.mydomain e http://ghost.mydomain às origens CORS.

Alguém consegue oferecer conselhos sobre como posso depurar isso?

app.yml:
#
templates:
  - "templates/postgres.template.yml"
  - "templates/redis.template.yml"
  - "templates/web.template.yml"
  - "templates/web.ratelimited.template.yml"
## Descomente estas duas linhas se quiser adicionar o Lets Encrypt (https)
#  - "templates/web.ssl.template.yml"
#  - "templates/web.letsencrypt.ssl.template.yml"

## Quais portas TCP/IP este contêiner deve expor?
## Se quiser que o Discourse compartilhe uma porta com outro servidor web, como Apache ou nginx,
## consulte https://meta.discourse.org/t/17247 para detalhes
expose:
  - "8081:80"   # http
    #  - "443:443" # https

params:
  db_default_text_search_config: "pg_catalog.english"

  ## Defina db_shared_buffers para no máximo 25% da memória total.
  ## Será definido automaticamente pelo bootstrap com base na RAM detectada, ou você pode sobrescrever
  db_shared_buffers: "2048MB"

  ## pode melhorar o desempenho de ordenação, mas aumenta o uso de memória por conexão
  #db_work_mem: "40MB"

  ## Qual revisão do Git este contêiner deve usar? (padrão: 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

  ## Quantas requisições web simultâneas são suportadas? Depende de memória e núcleos de CPU.
  ## Será definido automaticamente pelo bootstrap com base nos CPUs detectados, ou você pode sobrescrever
  UNICORN_WORKERS: 2

  ## TODO: O nome de domínio ao qual esta instância do Discourse responderá
  ## Obrigatório. O Discourse não funcionará com um número IP puro.
  DISCOURSE_HOSTNAME: mydiscoursehost.mydomain

  ## Descomente se quiser que o contêiner seja iniciado com o mesmo
  ## nome de host (opção -h) especificado acima (padrão "$hostname-$config")
  #DOCKER_USE_HOSTNAME: true

  ## TODO: Lista de e-mails separados por vírgula que serão feitos administradores e desenvolvedores
  ## no cadastro inicial, exemplo 'user1@example.com,user2@example.com'
  DISCOURSE_DEVELOPER_EMAILS: 'myemailaddress@mydomain'

  ## TODO: O servidor SMTP usado para validar novas contas e enviar notificações
  ## ENDEREÇO SMTP, nome de usuário e senha são obrigatórios
  # AVISO: o caractere '#' na senha do SMTP pode causar problemas!
  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           # (opcional, padrão true)
  DISCOURSE_SMTP_DOMAIN: mydomain
  DISCOURSE_NOTIFICATION_EMAIL: noreply@mydomain

  ## Se você adicionou o modelo Lets Encrypt, descomente abaixo para obter um certificado SSL gratuito
  #  LETSENCRYPT_ACCOUNT_EMAIL: notused

  ## O endereço CDN http ou https para esta instância do Discourse (configurado para buscar)
  ## consulte https://meta.discourse.org/t/14857 para detalhes
  #DISCOURSE_CDN_URL: https://discourse-cdn.example.com
 
  ## A chave de endereço IP do Maxmind para pesquisa de geolocalização
  ## consulte https://meta.discourse.org/t/-/137387/23 para detalhes
  #DISCOURSE_MAXMIND_LICENSE_KEY: 1234567890123456

## O contêiner Docker é sem estado; todos os dados são armazenados em /shared
volumes:
  - volume:
      host: /var/discourse/shared/standalone
      guest: /shared
  - volume:
      host: /var/discourse/shared/standalone/log/var-log
      guest: /var/log

## Plugins vão aqui
## consulte https://meta.discourse.org/t/19157 para detalhes
hooks:
  after_code:
    - exec:
        cd: $home/plugins
        cmd:
          - git clone https://github.com/discourse/docker_manager.git

## Quaisquer comandos personalizados para executar após a construção
run:
  - exec: echo "Início dos comandos personalizados"
  ## Se quiser definir o endereço de e-mail 'De' para seu primeiro registro, descomente e altere:
  ## Após receber o primeiro e-mail de cadastro, recomente a linha. Só precisa ser executado uma vez.
  #- exec: rails r "SiteSetting.notification_email='info@unconfigured.discourse.org'"
  - exec: echo "Fim dos comandos personalizados"