使用 devise_token_auth 和 active_model_serializers 解决多个用户模型的问题?

2024-01-07

多个用户模型(User、Admin 和 Master)与 devise_token_auth 的组合在使用非“User”模型(Admin 和 Master)登录时无法成功设置响应标头(uid、token 等);然而,用户模型是有效的。

原因看起来是 active_model_serializers/lib/action_controller/serialization.rb:18 中的默认serialization_scope (:current_user)。

有没有办法设置serialization_scope,或者我需要覆盖控制器吗?

环境:

  • 轨道 4.2.6
  • 自动化管理系统10.3
  • devise_token_auth 1.38

我当前的工作是在重写的控制器中设置范围,如下所示。这感觉很脆弱,但它有效

class Overrides::Master::SessionsController < DeviseTokenAuth::SessionsController

  protected
    def render_create_success
      render json: {
       data: resource_data(resource_json: @resource.token_validation_response)
      }, scope: :current_master
    end
end
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

使用 devise_token_auth 和 active_model_serializers 解决多个用户模型的问题? 的相关文章

随机推荐