cartodb-4.29/app/controllers/api/application_controller.rb
2020-06-15 10:58:47 +08:00

48 lines
1.3 KiB
Ruby

require_relative '../../../lib/cartodb/stats/editor_apis'
class Api::ApplicationController < ApplicationController
protect_from_forgery with: :null_session
# Don't force org urls
skip_before_filter :ensure_org_url_if_org_user, :browser_is_html5_compliant?
skip_before_filter :verify_authenticity_token, if: :json_formatted_request?
before_filter :api_authorization_required
before_filter :ensure_account_has_been_activated
before_filter :setup_stats_instance
protected
def set_start_time
@time_start = Time.now
end
# dry up the jsonp output
def render_jsonp(obj, status = 200, options = {})
if callback_valid?
options.reverse_merge! :json => obj, :status => status, :callback => params[:callback]
else
options.reverse_merge! :json => { errors: { callback: "Invalid callback format" } }, :status => 400
end
render options
end
def setup_stats_instance
@stats_aggregator = CartoDB::Stats::EditorAPIs.instance
end
def valid_password_confirmation
unless current_user.valid_password_confirmation(params[:password_confirmation])
raise Carto::PasswordConfirmationError.new
end
end
private
def callback_valid?
# While only checks basic characters, represents most common use of JS function names
params[:callback].nil? || !!(params[:callback] =~ /\A[$a-z_][0-9a-z_$]*\z/i)
end
end