module DeviseTokenAuth::Url

def self.generate(url, params = {})

def self.generate(url, params = {})
  uri = URI(url)
  res = "#{uri.scheme}://#{uri.host}"
  res += ":#{uri.port}" if (uri.port && uri.port != 80 && uri.port != 443)
  res += uri.path.to_s if uri.path
  query = [uri.query, params.to_query].reject(&:blank?).join('&')
  res += "?#{query}"
  res += "##{uri.fragment}" if uri.fragment
  # repeat any query params after the fragment to deal with Angular eating any pre fragment query params, used
  # in the reset password redirect url
  res += "?#{query}" if uri.fragment
  res
end

def self.whitelisted?(url)

def self.whitelisted?(url)
  url.nil? || \
    !!DeviseTokenAuth.redirect_whitelist.find do |pattern|
      !!Wildcat.new(pattern).match(url)
    end
end