application_controller.rb 7.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276
  1. class ApplicationController < ActionController::Base
  2. include UserInfo
  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. before_filter :set_user
  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'
  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'
  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. Ticket::Observer::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. @_current_user ||= session[:user_id] &&
  51. User.find_by_id( session[:user_id] )
  52. end
  53. def current_user_set(user)
  54. @_current_user = user
  55. set_user
  56. end
  57. def authentication_check_only
  58. puts 'authentication_check'
  59. # puts params.inspect
  60. # check http basic auth
  61. authenticate_with_http_basic do |user, password|
  62. puts 'http basic auth check'
  63. userdata = User.where( :login => user ).first
  64. message = ''
  65. if !userdata
  66. message = 'authentication failed, user'
  67. else
  68. if password != userdata.password
  69. message = 'authentication failed, pw'
  70. end
  71. end
  72. # return auth ok
  73. if message == ''
  74. # remember last login
  75. userdata.update_last_login
  76. # set basic auth user to current user
  77. current_user_set(userdata)
  78. return {
  79. :auth => true
  80. }
  81. end
  82. # return auth not ok
  83. return {
  84. :auth => false,
  85. :message => message,
  86. }
  87. end
  88. # check logon session
  89. if params['logon_session']
  90. logon_session = ActiveRecord::SessionStore::Session.where( :session_id => params['logon_session'] ).first
  91. if logon_session
  92. userdata = User.find( logon_session.data[:user_id] )
  93. end
  94. # set logon session user to current user
  95. current_user_set(userdata)
  96. return {
  97. :auth => true
  98. }
  99. end
  100. # return auth not ok (no session exists)
  101. if !session[:user_id]
  102. message = 'no valid session, user_id'
  103. return {
  104. :auth => false,
  105. :message => message,
  106. }
  107. end
  108. return {
  109. :auth => true
  110. }
  111. end
  112. def authentication_check
  113. result = authentication_check_only
  114. # return auth not ok
  115. if result[:auth] == false
  116. render(
  117. :json => {
  118. :error => result[:message],
  119. },
  120. :status => :unauthorized
  121. )
  122. return false
  123. end
  124. # return auth ok
  125. return true
  126. end
  127. # Sets the current user into a named Thread location so that it can be accessed
  128. # by models and observers
  129. def set_user
  130. return if !current_user
  131. UserInfo.current_user_id = current_user.id
  132. end
  133. def is_role( role_name )
  134. return false if !current_user
  135. return true if current_user.is_role( role_name )
  136. return false
  137. end
  138. def ticket_permission(ticket)
  139. return true if ticket.permission( :current_user => current_user )
  140. response_access_deny
  141. return false
  142. end
  143. def response_access_deny
  144. render(
  145. :json => {},
  146. :status => :unauthorized
  147. )
  148. return false
  149. end
  150. def log_view (object)
  151. History.log_view( object, current_user )
  152. end
  153. def config_frontend
  154. # config
  155. config = {}
  156. Setting.select('name').where( :frontend => true ).each { |setting|
  157. config[setting.name] = Setting.get(setting.name)
  158. }
  159. return config
  160. end
  161. # model helper
  162. def model_create_render (object, params)
  163. begin
  164. # create object
  165. generic_object = object.new( object.param_cleanup(params) )
  166. # set created_by_id and updated_by_id
  167. generic_object.created_by_id = current_user.id
  168. generic_object.updated_by_id = current_user.id
  169. # save object
  170. generic_object.save
  171. model_create_render_item(generic_object)
  172. rescue Exception => e
  173. logger.error e.message
  174. render :json => { :error => e.message }, :status => :unprocessable_entity
  175. end
  176. end
  177. def model_create_render_item (generic_object)
  178. render :json => generic_object, :status => :created
  179. end
  180. def model_update_render (object, params)
  181. begin
  182. # find object
  183. generic_object = object.find( params[:id] )
  184. # set created_by_id and updated_by_id
  185. params['updated_by_id'] = current_user.id
  186. # save object
  187. generic_object.update_attributes( object.param_cleanup(params) )
  188. model_update_render_item(generic_object)
  189. rescue Exception => e
  190. logger.error e.message
  191. render :json => { :error => e.message }, :status => :unprocessable_entity
  192. end
  193. end
  194. def model_update_render_item (generic_object)
  195. render :json => generic_object, :status => :ok
  196. end
  197. def model_destory_render (object, params)
  198. begin
  199. generic_object = object.find( params[:id] )
  200. generic_object.destroy
  201. model_destory_render_item()
  202. rescue Exception => e
  203. logger.error e.message
  204. render :json => { :error => e.message }, :status => :unprocessable_entity
  205. end
  206. end
  207. def model_destory_render_item ()
  208. render :json => {}, :status => :ok
  209. end
  210. def model_show_render (object, params)
  211. begin
  212. generic_object = object.find( params[:id] )
  213. model_show_render_item(generic_object)
  214. rescue Exception => e
  215. logger.error e.message
  216. render :json => { :error => e.message }, :status => :unprocessable_entity
  217. end
  218. end
  219. def model_show_render_item (generic_object)
  220. render :json => generic_object, :status => :ok
  221. end
  222. def model_index_render (object, params)
  223. begin
  224. generic_object = object.all
  225. model_index_render_result( generic_object )
  226. rescue Exception => e
  227. logger.error e.message
  228. render :json => { :error => e.message }, :status => :unprocessable_entity
  229. end
  230. end
  231. def model_index_render_result (generic_objects)
  232. render :json => generic_objects, :status => :ok
  233. end
  234. end