]> git.openstreetmap.org Git - rails.git/blobdiff - app/controllers/export_controller.rb
Switch to using rails builtin content security policy support
[rails.git] / app / controllers / export_controller.rb
index b37810ca90df2f616ce58a418021ad96a1f90a90..cddc97b6883e13044601c5b4a3a24b1f84d83f74 100644 (file)
@@ -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