]> git.openstreetmap.org Git - rails.git/blobdiff - app/controllers/export_controller.rb
Merge pull request #2485 from mmd-osm/patch/json2
[rails.git] / app / controllers / export_controller.rb
index 9b8d878f2c999724bf0575c42bba052a6d0d1582..50aa2a3c96f43838467568b2085c4aa2036fa059 100644 (file)
@@ -1,9 +1,32 @@
 class ExportController < ApplicationController
-  def start
-    render :update do |page|
-      page.replace_html :sidebar_title, 'Export'
-      page.replace_html :sidebar_content, :partial => 'start'
-      page.call "openSidebar"
+  before_action :authorize_web
+  before_action :set_locale
+  before_action :update_totp, :only => [:finish]
+  authorize_resource :class => false
+
+  caches_page :embed
+
+  # 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 :controller => "api/map", :action => "index", :bbox => bbox
+
+    elsif format == "mapnik"
+      # redirect to a special 'export' cgi script
+      format = params[:mapnik_format]
+      scale = params[:mapnik_scale]
+
+      redirect_to "https://render.openstreetmap.org/cgi-bin/export?bbox=#{bbox}&scale=#{scale}&format=#{format}"
     end
   end
+
+  def embed
+    append_content_security_policy_directives(
+      :frame_ancestors => %w[*]
+    )
+  end
 end