123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338 |
- # Copyright (C) 2012-2013 Zammad Foundation, http://zammad-foundation.org/
- class ApplicationController < ActionController::Base
- # http_basic_authenticate_with :name => "test", :password => "ttt"
- helper_method :current_user,
- :authentication_check,
- :config_frontend,
- :user_data_full,
- :is_role,
- :model_create_render,
- :model_update_render,
- :model_restory_render,
- :mode_show_rendeder,
- :model_index_render
- skip_filter :verify_authenticity_token
- before_filter :log_request, :set_user, :session_update
- before_filter :cors_preflight_check
- after_filter :set_access_control_headers
- after_filter :trigger_events
- # For all responses in this controller, return the CORS access control headers.
- def set_access_control_headers
- headers['Access-Control-Allow-Origin'] = '*'
- headers['Access-Control-Allow-Methods'] = 'POST, GET, PUT, DELETE, OPTIONS'
- headers['Access-Control-Max-Age'] = '1728000'
- 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'
- headers['Access-Control-Allow-Credentials'] = 'true'
- end
- # If this is a preflight OPTIONS request, then short-circuit the
- # request, return only the necessary headers and return an empty
- # text/plain.
- def cors_preflight_check
- if request.method == 'OPTIONS'
- headers['Access-Control-Allow-Origin'] = '*'
- headers['Access-Control-Allow-Methods'] = 'POST, GET, PUT, DELETE, OPTIONS'
- 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'
- headers['Access-Control-Max-Age'] = '1728000'
- headers['Access-Control-Allow-Credentials'] = 'true'
- render :text => '', :content_type => 'text/plain'
- return false
- end
- end
- private
- # execute events
- def trigger_events
- Observer::Ticket::Notification.transaction
- end
- def log_request
- puts Time.now().to_s + ' ' + request.original_fullpath.to_s
- end
- # Finds the User with the ID stored in the session with the key
- # :current_user_id This is a common way to handle user login in
- # a Rails application; logging in sets the session value and
- # logging out removes it.
- def current_user
- return @_current_user if @_current_user
- return if !session[:user_id]
- @_current_user = User.find( session[:user_id] )
- end
- def current_user_set(user)
- @_current_user = user
- set_user
- end
- # Sets the current user into a named Thread location so that it can be accessed
- # by models and observers
- def set_user
- return if !current_user
- UserInfo.current_user_id = current_user.id
- end
- # update session updated_at
- def session_update
- # on many paralell requests, session got reinitialised if Time. is used, as workaround use DateTime.
- #session[:ping] = Time.now.utc.iso8601
- session[:ping] = DateTime.now.iso8601
- # check if remote ip need to be updated
- if !session[:remote_id] || session[:remote_id] != request.remote_ip
- session[:remote_id] = request.remote_ip
- session[:geo] = GeoIp.location( request.remote_ip )
- end
- # fill user agent
- if !session[:user_agent]
- session[:user_agent] = request.env['HTTP_USER_AGENT']
- end
- end
- def authentication_check_only
- puts 'authentication_check'
- session[:request_type] = 1
- #puts params.inspect
- #puts session.inspect
- #puts cookies.inspect
- # check http basic auth
- authenticate_with_http_basic do |username, password|
- puts 'http basic auth check'
- session[:request_type] = 2
- userdata = User.authenticate( username, password )
- message = ''
- if !userdata
- message = 'authentication failed'
- end
- # return auth ok
- if message == ''
- # remember user
- session[:user_id] = userdata.id
- # set basic auth user to current user
- current_user_set(userdata)
- return {
- :auth => true
- }
- end
- # return auth not ok
- return {
- :auth => false,
- :message => message,
- }
- end
- # check logon session
- if params['logon_session']
- logon_session = ActiveRecord::SessionStore::Session.where( :session_id => params['logon_session'] ).first
- if logon_session
- userdata = User.find( logon_session.data[:user_id] )
- end
- session[:request_type] = 3
- # set logon session user to current user
- current_user_set(userdata)
- return {
- :auth => true
- }
- end
- # check sso
- if !session[:user_id]
- user = User.sso(params)
- # Log the authorizing user in.
- if user
- session[:user_id] = user.id
- end
- end
- # return auth not ok (no session exists)
- if !session[:user_id]
- puts 'no valid session, user_id'
- message = 'no valid session, user_id'
- return {
- :auth => false,
- :message => message,
- }
- end
- return {
- :auth => true
- }
- end
- def authentication_check
- result = authentication_check_only
- # return auth not ok
- if result[:auth] == false
- render(
- :json => {
- :error => result[:message],
- },
- :status => :unauthorized
- )
- return false
- end
- # return auth ok
- return true
- end
- def is_role( role_name )
- return false if !current_user
- return true if current_user.is_role( role_name )
- return false
- end
- def ticket_permission(ticket)
- return true if ticket.permission( :current_user => current_user )
- response_access_deny
- return false
- end
- def is_not_role( role_name )
- deny_if_not_role( role_name )
- end
- def deny_if_not_role( role_name )
- return false if is_role( role_name )
- response_access_deny
- return true
- end
- def response_access_deny
- render(
- :json => {},
- :status => :unauthorized
- )
- return false
- end
- def log_view (object)
- RecentView.log( object, current_user )
- end
- def config_frontend
- # config
- config = {}
- Setting.select('name').where( :frontend => true ).each { |setting|
- config[setting.name] = Setting.get(setting.name)
- }
- # get all time zones
- config['timezones'] = {}
- TZInfo::Timezone.all.each { |t|
- # ignore the following time zones
- next if t.name =~ /^GMT/
- next if t.name =~ /^Etc/
- next if t.name =~ /^MET/
- next if t.name =~ /^MST/
- next if t.name =~ /^ROC/
- next if t.name =~ /^ROK/
- diff = t.current_period.utc_total_offset / 60 /60
- config['timezones'][ t.name ] = diff
- }
- return config
- end
- # model helper
- def model_create_render (object, params)
- begin
- # create object
- generic_object = object.new( object.param_cleanup(params) )
- # save object
- generic_object.save!
- model_create_render_item(generic_object)
- rescue Exception => e
- puts e.message.inspect
- logger.error e.message
- render :json => { :error => e.message }, :status => :unprocessable_entity
- end
- end
- def model_create_render_item (generic_object)
- render :json => generic_object, :status => :created
- end
- def model_update_render (object, params)
- begin
- # find object
- generic_object = object.find( params[:id] )
- # save object
- generic_object.update_attributes!( object.param_cleanup(params) )
- model_update_render_item(generic_object)
- rescue Exception => e
- logger.error e.message
- render :json => { :error => e.message }, :status => :unprocessable_entity
- end
- end
- def model_update_render_item (generic_object)
- render :json => generic_object, :status => :ok
- end
- def model_destory_render (object, params)
- begin
- generic_object = object.find( params[:id] )
- generic_object.destroy
- model_destory_render_item()
- rescue Exception => e
- logger.error e.message
- render :json => { :error => e.message }, :status => :unprocessable_entity
- end
- end
- def model_destory_render_item ()
- render :json => {}, :status => :ok
- end
- def model_show_render (object, params)
- begin
- generic_object = object.find( params[:id] )
- model_show_render_item(generic_object)
- rescue Exception => e
- logger.error e.message
- render :json => { :error => e.message }, :status => :unprocessable_entity
- end
- end
- def model_show_render_item (generic_object)
- render :json => generic_object, :status => :ok
- end
- def model_index_render (object, params)
- begin
- generic_object = object.all
- model_index_render_result( generic_object )
- rescue Exception => e
- logger.error e.message
- render :json => { :error => e.message }, :status => :unprocessable_entity
- end
- end
- def model_index_render_result (generic_objects)
- render :json => generic_objects, :status => :ok
- end
- end
|