application_controller.rb 7.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282
  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. 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. @_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 is_not_role( role_name )
  144. return false if is_role( role_name )
  145. response_access_deny()
  146. return true
  147. end
  148. def response_access_deny
  149. render(
  150. :json => {},
  151. :status => :unauthorized
  152. )
  153. return false
  154. end
  155. def log_view (object)
  156. History.log_view( object, current_user )
  157. end
  158. def config_frontend
  159. # config
  160. config = {}
  161. Setting.select('name').where( :frontend => true ).each { |setting|
  162. config[setting.name] = Setting.get(setting.name)
  163. }
  164. return config
  165. end
  166. # model helper
  167. def model_create_render (object, params)
  168. begin
  169. # create object
  170. generic_object = object.new( object.param_cleanup(params) )
  171. # set created_by_id and updated_by_id
  172. generic_object.created_by_id = current_user.id
  173. generic_object.updated_by_id = current_user.id
  174. # save object
  175. generic_object.save
  176. model_create_render_item(generic_object)
  177. rescue Exception => e
  178. logger.error e.message
  179. render :json => { :error => e.message }, :status => :unprocessable_entity
  180. end
  181. end
  182. def model_create_render_item (generic_object)
  183. render :json => generic_object, :status => :created
  184. end
  185. def model_update_render (object, params)
  186. begin
  187. # find object
  188. generic_object = object.find( params[:id] )
  189. # set created_by_id and updated_by_id
  190. params['updated_by_id'] = current_user.id
  191. # save object
  192. generic_object.update_attributes( object.param_cleanup(params) )
  193. model_update_render_item(generic_object)
  194. rescue Exception => e
  195. logger.error e.message
  196. render :json => { :error => e.message }, :status => :unprocessable_entity
  197. end
  198. end
  199. def model_update_render_item (generic_object)
  200. render :json => generic_object, :status => :ok
  201. end
  202. def model_destory_render (object, params)
  203. begin
  204. generic_object = object.find( params[:id] )
  205. generic_object.destroy
  206. model_destory_render_item()
  207. rescue Exception => e
  208. logger.error e.message
  209. render :json => { :error => e.message }, :status => :unprocessable_entity
  210. end
  211. end
  212. def model_destory_render_item ()
  213. render :json => {}, :status => :ok
  214. end
  215. def model_show_render (object, params)
  216. begin
  217. generic_object = object.find( params[:id] )
  218. model_show_render_item(generic_object)
  219. rescue Exception => e
  220. logger.error e.message
  221. render :json => { :error => e.message }, :status => :unprocessable_entity
  222. end
  223. end
  224. def model_show_render_item (generic_object)
  225. render :json => generic_object, :status => :ok
  226. end
  227. def model_index_render (object, params)
  228. begin
  229. generic_object = object.all
  230. model_index_render_result( generic_object )
  231. rescue Exception => e
  232. logger.error e.message
  233. render :json => { :error => e.message }, :status => :unprocessable_entity
  234. end
  235. end
  236. def model_index_render_result (generic_objects)
  237. render :json => generic_objects, :status => :ok
  238. end
  239. end