123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209 |
- # Copyright (C) 2013-2013 Zammad Foundation, http://zammad-foundation.org/
- require 'cache'
- require 'user_info'
- class ApplicationModel < ActiveRecord::Base
- self.abstract_class = true
- before_create :cache_delete, :fill_up_user_create
- before_update :cache_delete_before, :fill_up_user_update
- before_destroy :cache_delete_before
- after_create :cache_delete
- after_update :cache_delete
- after_destroy :cache_delete
- @@import_class_list = ['Ticket', 'Ticket::Article', 'History', 'Ticket::State', 'Ticket::Priority', 'Group', 'User' ]
- # for import of other objects, remove 'id'
- def self.attributes_protected_by_default
- if Setting.get('import_mode') && @@import_class_list.include?( self.name.to_s )
- ['type']
- else
- ['id','type']
- end
- end
- def self.param_cleanup(params)
- # only use object attributes
- data = {}
- self.new.attributes.each {|item|
- if params.has_key?(item[0])
- # puts 'use ' + item[0].to_s + '-' + params[item[0]].to_s
- data[item[0].to_sym] = params[item[0]]
- end
- }
- # we do want to set this via database
- self.param_validation(data)
- end
- def self.param_validation(data)
- # we do want to set this via database
- data.delete( :updated_at )
- data.delete( :created_at )
- data.delete( :updated_by_id )
- data.delete( :created_by_id )
- data
- end
- # set created_by_id & updated_by_id if not given based on UserInfo
- def fill_up_user_create
- if self.class.column_names.include? 'updated_by_id'
- if UserInfo.current_user_id
- if self.updated_by_id && self.updated_by_id != UserInfo.current_user_id
- puts "NOTICE create - self.updated_by_id is different: #{self.updated_by_id.to_s}/#{UserInfo.current_user_id.to_s}"
- end
- self.updated_by_id = UserInfo.current_user_id
- end
- end
- if self.class.column_names.include? 'created_by_id'
- if UserInfo.current_user_id
- if self.created_by_id && self.created_by_id != UserInfo.current_user_id
- puts "NOTICE create - self.created_by_id is different: #{self.created_by_id.to_s}/#{UserInfo.current_user_id.to_s}"
- end
- self.created_by_id = UserInfo.current_user_id
- end
- end
- end
- # set updated_by_id if not given based on UserInfo
- def fill_up_user_update
- return if !self.class.column_names.include? 'updated_by_id'
- if UserInfo.current_user_id
- self.updated_by_id = UserInfo.current_user_id
- end
- end
- def cache_update(o)
- # puts 'u ' + self.class.to_s
- if self.respond_to?('cache_delete') then self.cache_delete end
- # puts 'g ' + group.class.to_s
- if o.respond_to?('cache_delete') then o.cache_delete end
- end
- def cache_delete_before
- old_object = self.class.where( :id => self.id ).first
- if old_object
- old_object.cache_delete
- end
- self.cache_delete
- end
- def cache_delete
- key = self.class.to_s + '::' + self.id.to_s
- Cache.delete( key.to_s )
- key = self.class.to_s + ':f:' + self.id.to_s
- Cache.delete( key.to_s )
- if self[:name]
- key = self.class.to_s + '::' + self.name.to_s
- Cache.delete( key.to_s )
- key = self.class.to_s + ':f:' + self.name.to_s
- Cache.delete( key.to_s )
- end
- if self[:login]
- key = self.class.to_s + '::' + self.login.to_s
- Cache.delete( key.to_s )
- key = self.class.to_s + ':f:' + self.login.to_s
- Cache.delete( key.to_s )
- end
- end
- def self.cache_set(data_id, data, full = false)
- if !full
- key = self.to_s + '::' + data_id.to_s
- else
- key = self.to_s + ':f:' + data_id.to_s
- end
- Cache.write( key.to_s, data )
- end
- def self.cache_get(data_id, full = false)
- if !full
- key = self.to_s + '::' + data_id.to_s
- else
- key = self.to_s + ':f:' + data_id.to_s
- end
- Cache.get( key.to_s )
- end
- def self.lookup(data)
- if data[:id]
- # puts "GET- + #{self.to_s}.#{data[:id].to_s}"
- cache = self.cache_get( data[:id] )
- return cache if cache
- # puts "Fillup- + #{self.to_s}.#{data[:id].to_s}"
- record = self.where( :id => data[:id] ).first
- self.cache_set( data[:id], record )
- return record
- elsif data[:name]
- cache = self.cache_get( data[:name] )
- return cache if cache
- records = self.where( :name => data[:name] )
- records.each {|record|
- if record.name == data[:name]
- self.cache_set( data[:name], record )
- return record
- end
- }
- return
- elsif data[:login]
- cache = self.cache_get( data[:login] )
- return cache if cache
- records = self.where( :login => data[:login] )
- records.each {|record|
- if record.login == data[:login]
- self.cache_set( data[:login], record )
- return record
- end
- }
- return
- else
- raise "Need name, id or login for lookup()"
- end
- end
- def self.create_if_not_exists(data)
- if data[:id]
- record = self.where( :id => data[:id] ).first
- return record if record
- elsif data[:name]
- records = self.where( :name => data[:name] )
- records.each {|record|
- return record if record.name == data[:name]
- }
- elsif data[:login]
- records = self.where( :login => data[:login] )
- records.each {|record|
- return record if record.login == data[:login]
- }
- elsif data[:locale] && data[:source]
- records = self.where( :locale => data[:locale], :source => data[:source] )
- records.each {|record|
- return record if record.source == data[:source]
- }
- end
- self.create(data)
- end
- def self.create_or_update(data)
- if data[:name]
- records = self.where( :name => data[:name] )
- records.each {|record|
- if record.name == data[:name]
- record.update_attributes( data )
- return record
- end
- }
- record = self.new( data )
- record.save
- return record
- else
- raise "Need name for create_or_update()"
- end
- end
- end
|