]> git.openstreetmap.org Git - rails.git/blobdiff - app/controllers/export_controller.rb
Merge remote-tracking branch 'upstream/pull/2115'
[rails.git] / app / controllers / export_controller.rb
index a773d4b72d2c177cadad071b0de2a77777f3f8f0..18ac15c101b47feeb1b518eb12a26a4b1dfe52e9 100644 (file)
@@ -1,25 +1,28 @@
 class ExportController < ApplicationController
 class ExportController < ApplicationController
-  def start
-  end
+  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
   def finish
-    bbox = BoundingBox.new(params[:minlon], params[:minlat], params[:maxlon], params[:maxlat])
+    bbox = BoundingBox.from_lon_lat_params(params)
     format = params[:format]
 
     if format == "osm"
     format = params[:format]
 
     if format == "osm"
-      redirect_to "http://api.openstreetmap.org/api/#{API_VERSION}/map?bbox=#{bbox}"
+      # redirect to API map get
+      redirect_to :controller => "api", :action => "map", :bbox => bbox
+
     elsif format == "mapnik"
     elsif format == "mapnik"
+      # redirect to a special 'export' cgi script
       format = params[:mapnik_format]
       scale = params[:mapnik_scale]
 
       format = params[:mapnik_format]
       scale = params[:mapnik_scale]
 
-      redirect_to "http://tile.openstreetmap.org/cgi-bin/export?bbox=#{bbox}&scale=#{scale}&format=#{format}"
-    elsif format == "osmarender"
-      format = params[:osmarender_format]
-      zoom = params[:osmarender_zoom].to_i
-      width = bbox.slippy_width(zoom).to_i
-      height = bbox.slippy_height(zoom).to_i
-
-      redirect_to "http://tah.openstreetmap.org/MapOf/index.php?long=#{bbox.centre_lon}&lat=#{bbox.centre_lat}&z=#{zoom}&w=#{width}&h=#{height}&format=#{format}"
+      redirect_to "https://render.openstreetmap.org/cgi-bin/export?bbox=#{bbox}&scale=#{scale}&format=#{format}"
     end
   end
     end
   end
+
+  def embed; end
 end
 end