application_controller.rb 7.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274
  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. render(
  141. :json => {},
  142. :status => :unauthorized
  143. )
  144. return false
  145. end
  146. def log_view (object)
  147. history_type = History::Type.where( :name => 'viewed' ).first
  148. if !history_type || !history_type.id
  149. history_type = History::Type.create(
  150. :name => 'viewed'
  151. )
  152. end
  153. history_object = History::Object.where( :name => object.class.name ).first
  154. if !history_object || !history_object.id
  155. history_object = History::Object.create(
  156. :name => object.class.name
  157. )
  158. end
  159. History.create(
  160. :o_id => object.id,
  161. :history_type_id => history_type.id,
  162. :history_object_id => history_object.id,
  163. :created_by_id => current_user.id
  164. )
  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. # set created_by_id and updated_by_id
  180. generic_object.created_by_id = current_user.id
  181. generic_object.updated_by_id = current_user.id
  182. # save object
  183. generic_object.save
  184. render :json => generic_object, :status => :created
  185. rescue Exception => e
  186. logger.error e.message
  187. render :json => { :error => e.message }, :status => :unprocessable_entity
  188. end
  189. end
  190. def model_update_render (object, params)
  191. begin
  192. # find object
  193. generic_object = object.find( params[:id] )
  194. # set created_by_id and updated_by_id
  195. params['updated_by_id'] = current_user.id
  196. # save object
  197. generic_object.update_attributes( object.param_cleanup(params) )
  198. render :json => generic_object, :status => :ok
  199. rescue Exception => e
  200. logger.error e.message
  201. render :json => { :error => e.message }, :status => :unprocessable_entity
  202. end
  203. end
  204. def model_destory_render (object, params)
  205. begin
  206. generic_object = object.find( params[:id] )
  207. generic_object.destroy
  208. head :ok
  209. rescue Exception => e
  210. logger.error e.message
  211. render :json => { :error => e.message }, :status => :unprocessable_entity
  212. end
  213. end
  214. def model_show_render (object, params)
  215. begin
  216. generic_object = object.find( params[:id] )
  217. render :json => generic_object, :status => :ok
  218. rescue Exception => e
  219. logger.error e.message
  220. render :json => { :error => e.message }, :status => :unprocessable_entity
  221. end
  222. end
  223. def model_index_render (object, params)
  224. begin
  225. generic_object = object.all
  226. render :json => generic_object, :status => :ok
  227. rescue Exception => e
  228. logger.error e.message
  229. render :json => { :error => e.message }, :status => :unprocessable_entity
  230. end
  231. end
  232. end