X-Git-Url: https://git.openstreetmap.org/rails.git/blobdiff_plain/3d0ca940d26bdc23aa791178b01b816185c5a086..044febd3aae31713ff60938333766c45c788e62d:/app/controllers/application.rb diff --git a/app/controllers/application.rb b/app/controllers/application.rb index 082c5cf65..64eb2180f 100644 --- a/app/controllers/application.rb +++ b/app/controllers/application.rb @@ -113,8 +113,9 @@ class ApplicationController < ActionController::Base ex.record.errors.each { |attr,msg| message << "#{attr}: #{msg} (#{ex.record[attr].inspect})" } report_error message, :bad_request rescue OSM::APIError => ex - render_opts = ex.render_opts - report_error render_opts[:text], render_opts[:status] + report_error ex.message, ex.status + rescue Exception => ex + report_error "#{ex.class}: #{ex.message}", :internal_server_error end end @@ -126,6 +127,12 @@ class ApplicationController < ActionController::Base raise OSM::APIBadMethodError.new(method) unless ok end + def api_call_timeout + Timeout::timeout(APP_CONFIG['api_timeout'], OSM::APITimeoutError) do + yield + end + end + private # extract authorisation credentials from headers, returns user = nil if none