render :action => "new"
elsif current_user.auth_provider.present?
# Verify external authenticator before moving on
- session[:new_user] = current_user.attributes.slice("email", "display_name", "pass_crypt")
+ session[:new_user] = current_user.slice("email", "display_name", "pass_crypt", "pass_crypt_confirmation")
redirect_to auth_url(current_user.auth_provider, current_user.auth_uid), :status => :temporary_redirect
else
# Save the user record
- session[:new_user] = current_user.attributes.slice("email", "display_name", "pass_crypt")
+ session[:new_user] = current_user.slice("email", "display_name", "pass_crypt", "pass_crypt_confirmation")
redirect_to :action => :terms
end
end
when "openid"
uid.match(%r{https://www.google.com/accounts/o8/id?(.*)}) ||
uid.match(%r{https://me.yahoo.com/(.*)})
- when "google", "facebook", "microsoft"
+ when "google", "facebook", "microsoft", "github", "wikipedia"
true
else
false
def welcome_options
uri = URI(session[:referer]) if session[:referer].present?
- welcome_options = {}
- welcome_options["oauth_return_url"] = uri&.to_s if uri&.path == oauth_authorization_path
+
+ return { "oauth_return_url" => uri&.to_s } if uri&.path == oauth_authorization_path
begin
%r{map=(.*)/(.*)/(.*)}.match(uri.fragment) do |m|
editor = Rack::Utils.parse_query(uri.query).slice("editor")
- welcome_options = { "zoom" => m[1],
- "lat" => m[2],
- "lon" => m[3] }.merge(editor).merge(welcome_options)
+ return { "zoom" => m[1], "lat" => m[2], "lon" => m[3] }.merge(editor)
end
rescue StandardError
# Use default
end
- welcome_options
end
##
domain_mx_servers(domain)
end
+ return true if Acl.allow_account_creation(request.remote_ip, :domain => domain, :mx => mx_servers)
+
blocked = Acl.no_account_creation(request.remote_ip, :domain => domain, :mx => mx_servers)
blocked ||= SIGNUP_IP_LIMITER && !SIGNUP_IP_LIMITER.allow?(request.remote_ip)