application_controller.rb 7.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285
  1. class ApplicationController < ActionController::Base
  2. # http_basic_authenticate_with :name => "test", :password => "ttt"
  3. helper_method :current_user,
  4. :authentication_check,
  5. :config_frontend,
  6. :user_data_full,
  7. :is_role,
  8. :model_create_render,
  9. :model_update_render,
  10. :model_restory_render,
  11. :mode_show_rendeder,
  12. :model_index_render
  13. before_filter :set_user
  14. before_filter :cors_preflight_check
  15. after_filter :set_access_control_headers
  16. after_filter :trigger_events
  17. # For all responses in this controller, return the CORS access control headers.
  18. def set_access_control_headers
  19. headers['Access-Control-Allow-Origin'] = '*'
  20. headers['Access-Control-Allow-Methods'] = 'POST, GET, PUT, DELETE, OPTIONS'
  21. headers['Access-Control-Max-Age'] = '1728000'
  22. headers['Access-Control-Allow-Headers'] = 'Content-Type, Depth, User-Agent, X-File-Size, X-Requested-With, If-Modified-Since, X-File-Name, Cache-Control'
  23. headers['Access-Control-Allow-Credentials'] = 'true'
  24. end
  25. # If this is a preflight OPTIONS request, then short-circuit the
  26. # request, return only the necessary headers and return an empty
  27. # text/plain.
  28. def cors_preflight_check
  29. if request.method == 'OPTIONS'
  30. headers['Access-Control-Allow-Origin'] = '*'
  31. headers['Access-Control-Allow-Methods'] = 'POST, GET, PUT, DELETE, OPTIONS'
  32. headers['Access-Control-Allow-Headers'] = 'Content-Type, Depth, User-Agent, X-File-Size, X-Requested-With, If-Modified-Since, X-File-Name, Cache-Control'
  33. headers['Access-Control-Max-Age'] = '1728000'
  34. headers['Access-Control-Allow-Credentials'] = 'true'
  35. render :text => '', :content_type => 'text/plain'
  36. return false
  37. end
  38. end
  39. private
  40. # execute events
  41. def trigger_events
  42. Observer::Ticket::Notification.transaction
  43. end
  44. # Finds the User with the ID stored in the session with the key
  45. # :current_user_id This is a common way to handle user login in
  46. # a Rails application; logging in sets the session value and
  47. # logging out removes it.
  48. def current_user
  49. return @_current_user if @_current_user
  50. return if !session[:user_id]
  51. @_current_user = 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. # Sets the current user into a named Thread location so that it can be accessed
  58. # by models and observers
  59. def set_user
  60. return if !current_user
  61. UserInfo.current_user_id = current_user.id
  62. end
  63. def authentication_check_only
  64. puts 'authentication_check'
  65. # puts params.inspect
  66. # check http basic auth
  67. authenticate_with_http_basic do |username, password|
  68. puts 'http basic auth check'
  69. userdata = User.lookup( :login => username )
  70. message = ''
  71. if !userdata
  72. message = 'authentication failed, user'
  73. else
  74. success = User.authenticate( username, password )
  75. if !success
  76. message = 'authentication failed, pw'
  77. end
  78. end
  79. # return auth ok
  80. if message == ''
  81. # set basic auth user to current user
  82. current_user_set(userdata)
  83. return {
  84. :auth => true
  85. }
  86. end
  87. # return auth not ok
  88. return {
  89. :auth => false,
  90. :message => message,
  91. }
  92. end
  93. # check logon session
  94. if params['logon_session']
  95. logon_session = ActiveRecord::SessionStore::Session.where( :session_id => params['logon_session'] ).first
  96. if logon_session
  97. userdata = User.find( logon_session.data[:user_id] )
  98. end
  99. # set logon session user to current user
  100. current_user_set(userdata)
  101. return {
  102. :auth => true
  103. }
  104. end
  105. # check sso
  106. if !session[:user_id]
  107. user = User.sso(params)
  108. # Log the authorizing user in.
  109. if user
  110. session[:user_id] = user.id
  111. end
  112. end
  113. # return auth not ok (no session exists)
  114. if !session[:user_id]
  115. puts 'no valid session, user_id'
  116. message = 'no valid session, user_id'
  117. return {
  118. :auth => false,
  119. :message => message,
  120. }
  121. end
  122. return {
  123. :auth => true
  124. }
  125. end
  126. def authentication_check
  127. result = authentication_check_only
  128. # return auth not ok
  129. if result[:auth] == false
  130. render(
  131. :json => {
  132. :error => result[:message],
  133. },
  134. :status => :unauthorized
  135. )
  136. return false
  137. end
  138. # return auth ok
  139. return true
  140. end
  141. def is_role( role_name )
  142. return false if !current_user
  143. return true if current_user.is_role( role_name )
  144. return false
  145. end
  146. def ticket_permission(ticket)
  147. return true if ticket.permission( :current_user => current_user )
  148. response_access_deny
  149. return false
  150. end
  151. def is_not_role( role_name )
  152. return false if is_role( role_name )
  153. response_access_deny()
  154. return true
  155. end
  156. def response_access_deny
  157. render(
  158. :json => {},
  159. :status => :unauthorized
  160. )
  161. return false
  162. end
  163. def log_view (object)
  164. RecentView.log( object, current_user )
  165. end
  166. def config_frontend
  167. # config
  168. config = {}
  169. Setting.select('name').where( :frontend => true ).each { |setting|
  170. config[setting.name] = Setting.get(setting.name)
  171. }
  172. return config
  173. end
  174. # model helper
  175. def model_create_render (object, params)
  176. begin
  177. # create object
  178. generic_object = object.new( object.param_cleanup(params) )
  179. # save object
  180. generic_object.save
  181. model_create_render_item(generic_object)
  182. rescue Exception => e
  183. logger.error e.message
  184. render :json => { :error => e.message }, :status => :unprocessable_entity
  185. end
  186. end
  187. def model_create_render_item (generic_object)
  188. render :json => generic_object, :status => :created
  189. end
  190. def model_update_render (object, params)
  191. begin
  192. # find object
  193. generic_object = object.find( params[:id] )
  194. # save object
  195. generic_object.update_attributes( object.param_cleanup(params) )
  196. model_update_render_item(generic_object)
  197. rescue Exception => e
  198. logger.error e.message
  199. render :json => { :error => e.message }, :status => :unprocessable_entity
  200. end
  201. end
  202. def model_update_render_item (generic_object)
  203. render :json => generic_object, :status => :ok
  204. end
  205. def model_destory_render (object, params)
  206. begin
  207. generic_object = object.find( params[:id] )
  208. generic_object.destroy
  209. model_destory_render_item()
  210. rescue Exception => e
  211. logger.error e.message
  212. render :json => { :error => e.message }, :status => :unprocessable_entity
  213. end
  214. end
  215. def model_destory_render_item ()
  216. render :json => {}, :status => :ok
  217. end
  218. def model_show_render (object, params)
  219. begin
  220. generic_object = object.find( params[:id] )
  221. model_show_render_item(generic_object)
  222. rescue Exception => e
  223. logger.error e.message
  224. render :json => { :error => e.message }, :status => :unprocessable_entity
  225. end
  226. end
  227. def model_show_render_item (generic_object)
  228. render :json => generic_object, :status => :ok
  229. end
  230. def model_index_render (object, params)
  231. begin
  232. generic_object = object.all
  233. model_index_render_result( generic_object )
  234. rescue Exception => e
  235. logger.error e.message
  236. render :json => { :error => e.message }, :status => :unprocessable_entity
  237. end
  238. end
  239. def model_index_render_result (generic_objects)
  240. render :json => generic_objects, :status => :ok
  241. end
  242. end