X-Git-Url: https://git.openstreetmap.org./rails.git/blobdiff_plain/dae2c209d9e7eba8f3d1fda6d3d6a09a2c12ec00..a90302aecf579ca29fa5ea0b1e9d03f81b8bbde4:/app/controllers/export_controller.rb?ds=inline diff --git a/app/controllers/export_controller.rb b/app/controllers/export_controller.rb index b37810ca9..cddc97b68 100644 --- a/app/controllers/export_controller.rb +++ b/app/controllers/export_controller.rb @@ -1,31 +1,33 @@ class ExportController < ApplicationController + before_action :authorize_web + before_action :set_locale + before_action :update_totp, :only => [:finish] + authorize_resource :class => false - before_filter :authorize_web - before_filter :set_locale + content_security_policy(:only => :embed) do |policy| + policy.frame_ancestors("*") + end caches_page :embed - def start - end - - #When the user clicks 'Export' we redirect to a URL which generates the export download + # When the user clicks 'Export' we redirect to a URL which generates the export download def finish bbox = BoundingBox.from_lon_lat_params(params) format = params[:format] - if format == "osm" - #redirect to API map get - redirect_to "http://api.openstreetmap.org/api/#{API_VERSION}/map?bbox=#{bbox}" + case format + when "osm" + # redirect to API map get + redirect_to :controller => "api/map", :action => "index", :bbox => bbox - elsif format == "mapnik" - #redirect to a special 'export' cgi script + when "mapnik" + # redirect to a special 'export' cgi script format = params[:mapnik_format] scale = params[:mapnik_scale] - redirect_to "http://render.openstreetmap.org/cgi-bin/export?bbox=#{bbox}&scale=#{scale}&format=#{format}" + redirect_to "https://render.openstreetmap.org/cgi-bin/export?bbox=#{bbox}&scale=#{scale}&format=#{format}", :allow_other_host => true end end - def embed - end + def embed; end end