23

在我的 Rails 应用程序中,直接从视图访问设计配置变量的方法是什么?

我想config.allow_unconfirmed_access_for从 Devise 的:confirmable模块中展示。此变量在devise.rb初始化程序中设置:

Devise.setup do
  config.allow_unconfirmed_access_for = 3.days
end

谢谢!

4

3 回答 3

27

文件中的配置devise.rb会复制到您的 Devise 模型上,因此如果您的 Devise 资源是User,您应该能够通过User.allow_unconfirmed_access_for.

因此,在您的控制器上创建一个实例变量并将此值分配给它,然后您就可以在您的视图中显示它。

于 2012-06-28T02:36:34.953 回答
10

接受的答案不再正确。对于较新的设计版本,配置选项附加到主Devise模块,例如Devise.allow_unconfirmed_access_for.

于 2016-01-05T21:48:04.513 回答
3

这回答了一个类似的问题:

OmniAuth 配置存储在嵌套策略对象内的 omniauths_config 对象中

Devise.omniauth_configs

返回:

{:facebook=>
  #<Devise::OmniAuth::Config:0x007fa6db95aa68
  ....

然后通过符号访问:

Devise.omniauth_configs[:facebook].strategy

{"setup"=>true,
 "skip_info"=>false,
 "client_id"=>nil,
 "client_secret"=>nil,
 "client_options"=>{"site"=>"https://graph.facebook.com", "authorize_url"=>"https://www.facebook.com/dialog/oauth", "token_url"=>"/oauth/access_token"},
 "authorize_params"=>{},
 "authorize_options"=>[:scope, :display, :auth_type],
 "token_params"=>{"parse"=>:query},
 "token_options"=>[],
 "auth_token_params"=>{},
 "provider_ignores_state"=>false,
 "access_token_options"=>{"header_format"=>"OAuth %s", "param_name"=>"access_token"},
 "scope"=>"email,public_profile,publish_actions",
 "info_fields"=>"email, first_name, last_name",
 "name"=>"facebook"}
于 2017-03-28T17:10:36.413 回答