class Attachment < ApplicationRecord include BaseModel include Publicable include Publishable include Lockable belongs_to :container, polymorphic: true, optional: true belongs_to :author, class_name: "User", foreign_key: :author_id belongs_to :course, foreign_key: :container_id, optional: true has_many :attachment_group_settings, :dependent => :destroy has_many :attachment_histories, -> { order(version: :desc) }, :dependent => :destroy # 二级目录 belongs_to :course_second_category, optional: true scope :by_filename_or_user_name, -> (keywords) { joins(:author).where("filename like :search or LOWER(concat(users.lastname, users.firstname)) LIKE :search", :search => "%#{keywords.split(" ").join('|')}%") unless keywords.blank? } scope :by_keywords, -> (keywords) { where("filename LIKE ?", "%#{keywords.split(" ").join('|')}%") unless keywords.blank? } scope :ordered, -> (opts = {}) { order("#{opts[:sort_type]} #{opts[:sort] == 1 ? 'asc': 'desc'}") } scope :by_course_second_category_id, -> (course_second_category_id = 0) { where(course_second_category_id: course_second_category_id) } scope :contains_only_course, -> { where(container_type: 'Course') } scope :contains_only_project, -> { where(container_type: 'Project') } scope :contains_course_and_project, -> { contains_only_course.or(contains_only_project) } scope :mine, -> (author_id) { where(author_id: author_id) } scope :simple_columns, -> { select(:id, :filename, :filesize, :created_on, :cloud_url, :author_id, :content_type, :container_type, :container_id) } scope :search_by_container, -> (ids) {where(container_id: ids)} scope :unified_setting, -> {where("unified_setting = ? ", 1)} scope :published, -> {where(is_publish: 1)} scope :no_link, -> {where(link: nil)} validates_length_of :description, maximum: 100, message: "不能超过100个字符" validates :link, format: { with: CustomRegexp::URL, message: "必须为网址超链接" }, allow_blank: true DCODES = %W(2 3 4 5 6 7 8 9 a b c f e f g h i j k l m n o p q r s t u v w x y z) def diskfile File.join(File.join(Rails.root, "files"), disk_directory.to_s, disk_filename.to_s) end def relative_path_filename File.join(disk_directory.to_s, disk_filename.to_s) end def title title = filename if container && container.is_a?(StudentWork) && author_id != User.current.id course = container&.homework_common&.course unless User.current.teacher_of_course?(course) title = "#{Time.now.strftime('%Y%m%d%H%M%S')}_#{DCODES.sample(8).join}" + File.extname(filename) end end title end def downloads_count downloads end def quotes_count quotes.nil? ? 0 : quotes end def self.associate_container(ids, container_id, container_type, attachtype=1) return false if ids.blank? || !ids.is_a?(Array) ids.each do |id| attachment = Attachment.find id attachment.update_attributes(container_id: container_id, container_type: container_type, attachtype: attachtype) end end # Returns an unsaved copy of the attachment def copy(attributes=nil) copy = self.class.new copy.attributes = self.attributes.dup.except("id", "downloads", "quotes") copy.attributes = attributes if attributes copy end def set_publish_time(publish_time) self.unified_setting = 1 if publish_time.blank? self.publish_time = Time.now self.is_publish = 1 else self.is_publish = publish_time.to_s > (format_time Time.now).to_s ? 0 : 1 self.publish_time = publish_time.to_s > (format_time Time.now).to_s ? publish_time : Time.now end end def set_course_group_publish_time(course, course_group_publish_times) self.unified_setting = 0 min_publish_time = "" course_group_publish_times.each do |obj| if obj && obj[:course_group_id] publish_time = obj[:publish_time] if !publish_time.blank? && publish_time < min_publish_time min_publish_time = publish_time elsif publish_time.blank? publish_time = Time.now end attachment_group_setting = self.attachment_group_settings.where(course_group_id: obj[:course_group_id], course_id: course.id).first if attachment_group_setting.present? attachment_group_setting.update_columns(publish_time: publish_time) else self.attachment_group_settings.create( :course_group_id => obj[:course_group_id], :course_id => course.id, :publish_time => publish_time ) end end end self.is_publish = min_publish_time > (format_time Time.now).to_s ? 0 : 1 self.publish_time = min_publish_time > (format_time Time.now).to_s ? min_publish_time : self.created_on end def become_history history = self.attachment_histories.first new_attachment_history = AttachmentHistory.new(self.attributes.except("id", "resource_bank_id", "unified_setting", "course_second_category_id", "delay_publish", "link").merge( attachment_id: self.id, version: history.nil? ? 1 : history.version + 1, )) new_attachment_history end def copy_attributes_from_new_attachment(new_attachment) self.attributes = new_attachment.attributes.dup.except("id","container_id","container_type","is_public","downloads", "quotes",'is_publish','publish_time', "delay_publish", "link") end def set_public(is_public) if is_public == true is_public = 1 elsif is_public == false is_public = 0 end end #判断是否为pdf文件 def is_pdf? is_pdf = false file_content_type = content_type file_ext_type = File.extname(filename).strip.downcase[1..-1] if (file_content_type.present? && file_content_type.downcase.include?("pdf")) || (file_ext_type.present? && file_ext_type.include?("pdf")) is_pdf = true end is_pdf end end