application_controller.rb 8.8 KB

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