class StylesheetCache < ActiveRecord::Base self.table_name = 'stylesheet_cache' MAX_TO_KEEP = 50 def self.add(target,digest,content) return false if where(target: target, digest: digest).exists? success = create(target: target, digest: digest, content: content) count = StylesheetCache.count if count > MAX_TO_KEEP remove_lower = StylesheetCache .where(target: target) .limit(MAX_TO_KEEP) .order('id desc') .pluck(:id) .last exec_sql("DELETE FROM stylesheet_cache where id < :id", id: remove_lower) end success rescue ActiveRecord::RecordNotUnique false end end # == Schema Information # # Table name: stylesheet_cache # # id :integer not null, primary key # target :string not null # digest :string not null # content :text not null # created_at :datetime # updated_at :datetime # # Indexes # # index_stylesheet_cache_on_target_and_digest (target,digest) UNIQUE #