application_controller.rb 9.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350
  1. # Copyright (C) 2012-2014 Zammad Foundation, http://zammad-foundation.org/
  2. class ApplicationController < ActionController::Base
  3. # http_basic_authenticate_with :name => "test", :password => "ttt"
  4. helper_method :current_user,
  5. :authentication_check,
  6. :config_frontend,
  7. :is_role,
  8. :model_create_render,
  9. :model_update_render,
  10. :model_restory_render,
  11. :mode_show_rendeder,
  12. :model_index_render
  13. skip_before_filter :verify_authenticity_token
  14. before_filter :set_user, :session_update
  15. before_filter :cors_preflight_check
  16. after_filter :set_access_control_headers
  17. after_filter :trigger_events
  18. # For all responses in this controller, return the CORS access control headers.
  19. def set_access_control_headers
  20. headers['Access-Control-Allow-Origin'] = '*'
  21. headers['Access-Control-Allow-Methods'] = 'POST, GET, PUT, DELETE, OPTIONS'
  22. headers['Access-Control-Max-Age'] = '1728000'
  23. headers['Access-Control-Allow-Headers'] = 'Content-Type, Depth, User-Agent, X-File-Size, X-Requested-With, If-Modified-Since, X-File-Name, Cache-Control, Accept-Language'
  24. headers['Access-Control-Allow-Credentials'] = 'true'
  25. end
  26. # If this is a preflight OPTIONS request, then short-circuit the
  27. # request, return only the necessary headers and return an empty
  28. # text/plain.
  29. def cors_preflight_check
  30. if request.method == 'OPTIONS'
  31. headers['Access-Control-Allow-Origin'] = '*'
  32. headers['Access-Control-Allow-Methods'] = 'POST, GET, PUT, DELETE, OPTIONS'
  33. headers['Access-Control-Allow-Headers'] = 'Content-Type, Depth, User-Agent, X-File-Size, X-Requested-With, If-Modified-Since, X-File-Name, Cache-Control, Accept-Language'
  34. headers['Access-Control-Max-Age'] = '1728000'
  35. headers['Access-Control-Allow-Credentials'] = 'true'
  36. render :text => '', :content_type => 'text/plain'
  37. return false
  38. end
  39. end
  40. private
  41. # execute events
  42. def trigger_events
  43. Observer::Ticket::Notification.transaction
  44. end
  45. # Finds the User with the ID stored in the session with the key
  46. # :current_user_id This is a common way to handle user login in
  47. # a Rails application; logging in sets the session value and
  48. # logging out removes it.
  49. def current_user
  50. return @_current_user if @_current_user
  51. return if !session[:user_id]
  52. @_current_user = User.find( session[:user_id] )
  53. end
  54. def current_user_set(user)
  55. session[:user_id] = user.id
  56. @_current_user = user
  57. set_user
  58. end
  59. # Sets the current user into a named Thread location so that it can be accessed
  60. # by models and observers
  61. def set_user
  62. return if !current_user
  63. UserInfo.current_user_id = current_user.id
  64. end
  65. # update session updated_at
  66. def session_update
  67. #sleep 0.6
  68. # on many paralell requests, session got reinitialised if Time. is used, as workaround use DateTime.
  69. #session[:ping] = Time.now.utc.iso8601
  70. session[:ping] = DateTime.now.iso8601
  71. # check if remote ip need to be updated
  72. if !session[:remote_id] || session[:remote_id] != request.remote_ip
  73. session[:remote_id] = request.remote_ip
  74. session[:geo] = GeoIp.location( request.remote_ip )
  75. end
  76. # fill user agent
  77. if !session[:user_agent]
  78. session[:user_agent] = request.env['HTTP_USER_AGENT']
  79. end
  80. end
  81. def authentication_check_only
  82. #puts 'authentication_check'
  83. session[:request_type] = 1
  84. #puts params.inspect
  85. #puts session.inspect
  86. #puts cookies.inspect
  87. # check http basic auth
  88. authenticate_with_http_basic do |username, password|
  89. #puts 'http basic auth check'
  90. session[:request_type] = 2
  91. userdata = User.authenticate( username, password )
  92. message = ''
  93. if !userdata
  94. message = 'authentication failed'
  95. end
  96. # return auth ok
  97. if message == ''
  98. # remember user
  99. session[:user_id] = userdata.id
  100. # set basic auth user to current user
  101. current_user_set(userdata)
  102. return {
  103. :auth => true
  104. }
  105. end
  106. # return auth not ok
  107. return {
  108. :auth => false,
  109. :message => message,
  110. }
  111. end
  112. # check logon session
  113. if params['logon_session']
  114. logon_session = ActiveRecord::SessionStore::Session.where( :session_id => params['logon_session'] ).first
  115. if logon_session
  116. userdata = User.find( logon_session.data[:user_id] )
  117. end
  118. session[:request_type] = 3
  119. # set logon session user to current user
  120. current_user_set(userdata)
  121. return {
  122. :auth => true
  123. }
  124. end
  125. # check sso
  126. if !session[:user_id]
  127. user = User.sso(params)
  128. # Log the authorizing user in.
  129. if user
  130. session[:user_id] = user.id
  131. end
  132. end
  133. # return auth not ok (no session exists)
  134. if !session[:user_id]
  135. puts 'no valid session, user_id'
  136. message = 'no valid session, user_id'
  137. return {
  138. :auth => false,
  139. :message => message,
  140. }
  141. end
  142. return {
  143. :auth => true
  144. }
  145. end
  146. def authentication_check
  147. result = authentication_check_only
  148. # return auth not ok
  149. if result[:auth] == false
  150. render(
  151. :json => {
  152. :error => result[:message],
  153. },
  154. :status => :unauthorized
  155. )
  156. return false
  157. end
  158. # return auth ok
  159. return true
  160. end
  161. def is_role( role_name )
  162. return false if !current_user
  163. return true if current_user.is_role( role_name )
  164. return false
  165. end
  166. def ticket_permission(ticket)
  167. return true if ticket.permission( :current_user => current_user )
  168. response_access_deny
  169. return false
  170. end
  171. def is_not_role( role_name )
  172. deny_if_not_role( role_name )
  173. end
  174. def deny_if_not_role( role_name )
  175. return false if is_role( role_name )
  176. response_access_deny
  177. return true
  178. end
  179. def response_access_deny
  180. render(
  181. :json => {},
  182. :status => :unauthorized
  183. )
  184. return false
  185. end
  186. def config_frontend
  187. # config
  188. config = {}
  189. Setting.select('name').where( :frontend => true ).each { |setting|
  190. config[setting.name] = Setting.get(setting.name)
  191. }
  192. # get all time zones
  193. config['timezones'] = {}
  194. TZInfo::Timezone.all.each { |t|
  195. # ignore the following time zones
  196. next if t.name =~ /^GMT/
  197. next if t.name =~ /^Etc/
  198. next if t.name =~ /^MET/
  199. next if t.name =~ /^MST/
  200. next if t.name =~ /^ROC/
  201. next if t.name =~ /^ROK/
  202. diff = t.current_period.utc_total_offset / 60 /60
  203. config['timezones'][ t.name ] = diff
  204. }
  205. return config
  206. end
  207. # model helper
  208. def model_create_render (object, params)
  209. begin
  210. # create object
  211. generic_object = object.new( object.param_cleanup( params[object.to_app_model_url] ) )
  212. # save object
  213. generic_object.save!
  214. # set relations
  215. generic_object.param_set_associations( params )
  216. model_create_render_item(generic_object)
  217. rescue Exception => e
  218. puts e.message.inspect
  219. logger.error e.message
  220. logger.error e.backtrace.inspect
  221. render :json => { :error => e.message }, :status => :unprocessable_entity
  222. end
  223. end
  224. def model_create_render_item (generic_object)
  225. render :json => generic_object.attributes_with_associations, :status => :created
  226. end
  227. def model_update_render (object, params)
  228. begin
  229. # find object
  230. generic_object = object.find( params[:id] )
  231. # save object
  232. generic_object.update_attributes!( object.param_cleanup( params[object.to_app_model_url] ) )
  233. # set relations
  234. generic_object.param_set_associations( params )
  235. model_update_render_item( generic_object )
  236. rescue Exception => e
  237. logger.error e.message
  238. logger.error e.backtrace.inspect
  239. render :json => { :error => e.message }, :status => :unprocessable_entity
  240. end
  241. end
  242. def model_update_render_item (generic_object)
  243. render :json => generic_object.attributes_with_associations, :status => :ok
  244. end
  245. def model_destory_render (object, params)
  246. begin
  247. generic_object = object.find( params[:id] )
  248. generic_object.destroy
  249. model_destory_render_item()
  250. rescue Exception => e
  251. logger.error e.message
  252. logger.error e.backtrace.inspect
  253. render :json => { :error => e.message }, :status => :unprocessable_entity
  254. end
  255. end
  256. def model_destory_render_item ()
  257. render :json => {}, :status => :ok
  258. end
  259. def model_show_render (object, params)
  260. begin
  261. if params[:full]
  262. generic_object_full = object.full( params[:id] )
  263. render :json => generic_object_full, :status => :ok
  264. return
  265. end
  266. generic_object = object.find( params[:id] )
  267. model_show_render_item(generic_object)
  268. rescue Exception => e
  269. logger.error e.message
  270. logger.error e.backtrace.inspect
  271. render :json => { :error => e.message }, :status => :unprocessable_entity
  272. end
  273. end
  274. def model_show_render_item (generic_object)
  275. render :json => generic_object.attributes_with_associations, :status => :ok
  276. end
  277. def model_index_render (object, params)
  278. begin
  279. generic_objects = object.all
  280. model_index_render_result( generic_objects )
  281. rescue Exception => e
  282. logger.error e.message
  283. logger.error e.backtrace.inspect
  284. render :json => { :error => e.message }, :status => :unprocessable_entity
  285. end
  286. end
  287. def model_index_render_result (generic_objects)
  288. render :json => generic_objects, :status => :ok
  289. end
  290. end