Erro de login ao tentar usar Discourse como provedor de identidade (SSO, DiscourseConnect)

Estou tentando seguir este post: Use Discourse as an identity provider (SSO, DiscourseConnect) usando código Python. O código Python abaixo imprime um URL que - até onde posso ver - deveria estar corretamente assinado para acessar https://forum.embeetle.com/session/sso_provider na minha instância Discourse, mas, em vez disso, mostra apenas o texto “Login Error”.

Não há erro nos logs em https://forum.embeetle.com/logs, então não tenho ideia de como resolver isso. Isso significa que a assinatura está incorreta? Alguma outra sugestão?

A propósito, não se preocupe: mudarei o segredo SSO assim que este problema for resolvido.

import secrets
import base64
import urllib.parse
import hmac
import hashlib

forum_url = 'https://forum.embeetle.com'
target_url = 'https://embeetle.com/#account'
sso_secret = b'JCLSVcqbAnEPXz2p2xBY'

nonce = secrets.token_urlsafe()
payload = f'nonce={nonce}&return_sso_url={target_url}'
payload_base64 = base64.b64encode(payload.encode('utf-8')).decode()
payload_for_url = urllib.parse.quote(payload_base64)
signature = hmac.new(
    sso_secret, payload_for_url.encode('utf-8'), hashlib.sha256
).hexdigest()

print(f'{forum_url}/session/sso_provider?sso={payload_for_url}&sig={signature}')

Este código gera um link como o do comando curl abaixo:

johan@morla:~/sa\> curl 'https://forum.embeetle.com/session/sso_provider?sso=bm9uY2U9bExhRUZjRGFVd0NrNTFkMEVOeGc5dUtKZ0kwNHZNYng5VkpFR0RqRUg0OCZyZXR1cm5fc3NvX3VybD1odHRwczovL2VtYmVldGxlLmNvbS8jYWNjb3VudA%3D%3D&sig=70e647a1baad2e09ef6cdc6d87fae70bc27c6823369be20fd1b11ea536180343'
Login Errorjohan@morla:~/sa\> 

Aqui está uma captura de tela das configurações no site:

O que está errado, ou como posso depurar isso?

Um passo adiante: se eu ativar o registro detalhado para DiscourseConnect, recebo um erro nos logs:

image

Log detalhado do SSO: Erro de análise de assinatura Assinatura inválida para a carga útil sso: bm9uY2U9YklKeEU1WWw2OFhjSkJydGlwSU15UTRZeVlMeWd6ZzQyUU9mOFo0SWF5QSZyZXR1cm5fc3NvX3VybD1odHRwczovL2VtYmVldGxlLmNvbS8jYWNjb3VudA= 

Um ponto notável é que a carga útil mencionada no log não está codificada em URL (note o ‘=’ no final) e está faltando o segundo ‘=’ dos dados codificados em URL (note o %3D repetido no final da carga útil original).

Entendido: a assinatura HMAC-SHA256 deve ser calculada a partir dos dados codificados em base64, e não dos dados codificados em URL. Portanto, o código correto é:

import secrets
import base64
import urllib.parse
import hmac
import hashlib

forum_url = 'https://forum.embeetle.com'
target_url = 'https://embeetle.com/#account'
sso_secret = b'JCLSVcqbAnEPXz2p2xBY'

nonce = secrets.token_urlsafe()
payload = f'nonce={nonce}&return_sso_url={target_url}'
payload_base64 = base64.b64encode(payload.encode('utf-8')).decode()
payload_for_url = urllib.parse.quote(payload_base64)

signature = hmac.new(
    sso_secret, payload_base64.encode('utf-8'), hashlib.sha256
).hexdigest()

print(f'{forum_url}/session/sso_provider?sso={payload_for_url}&sig={signature}')

Agora para o restante do trabalho: lidar com o redirecionamento, verificar o nonce, etc. A continuar…

1 curtida

This topic was automatically closed 30 days after the last reply. New replies are no longer allowed.