X-Git-Url: https://git.openstreetmap.org/rails.git/blobdiff_plain/c8f26592a74e776b9827ed68ccc1ee345ff52408..b5cc4449a6502ee5868f8e85bceb90ef202e5f98:/app/controllers/export_controller.rb diff --git a/app/controllers/export_controller.rb b/app/controllers/export_controller.rb index fa7944516..94851de96 100644 --- a/app/controllers/export_controller.rb +++ b/app/controllers/export_controller.rb @@ -1,6 +1,8 @@ class ExportController < ApplicationController before_action :authorize_web before_action :set_locale + before_action :update_totp, :only => [:finish] + authorize_resource :class => false caches_page :embed @@ -9,18 +11,23 @@ class ExportController < ApplicationController bbox = BoundingBox.from_lon_lat_params(params) format = params[:format] - if format == "osm" + case format + when "osm" # redirect to API map get - redirect_to "http://api.openstreetmap.org/api/#{API_VERSION}/map?bbox=#{bbox}" + redirect_to :controller => "api/map", :action => "index", :bbox => bbox - elsif format == "mapnik" + 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 + append_content_security_policy_directives( + :frame_ancestors => %w[*] + ) + end end