He implementado una estrategia personalizada de OmniAuth + un autenticador que extiende Auth::ManagedAuthenticator de Discourse.
Sin embargo, al probar esto en mi entorno de desarrollo, finalmente termino en esta pantalla, en lugar de iniciar sesión inmediatamente:
La información se rellena correctamente desde el hash de autenticación, pero no quiero que los usuarios puedan cambiar su nombre de usuario o nombre aquí. ¿Cómo debo modificar mi implementación o la configuración del foro para que esta pantalla se omita y la cuenta de usuario se cree inmediatamente (si no existe) y se inicie sesión?
Autenticador:
class MyAuthenticator < ::Auth::ManagedAuthenticator
def name
'my_authenticator'
end
def enabled?
true
end
def register_middleware(omniauth)
omniauth.provider name.to_sym, {}
end
end
Estrategia:
require 'omniauth'
...
class OmniAuth::Strategies::MyAuthenticator
include OmniAuth::Strategy
option :name, "my_authenticator"
...
def callback_phase
...
@user_id = ...
@username = ...
@avatar = ...
@email = ...
...
end
...
def auth_hash
{
provider: "my_authenticator",
uid: @user_id,
info: {
name: @username,
image: @avatar,
email: @email
},
extra: {}
}
end
end
OmniAuth.config.add_camelization('my_authenticator', 'MyAuthenticator')
plugin.rb:
before_auth do
...
auth_provider authenticator: MyAuthenticator.new()
...
end
