class Mod < ActiveRecord::Base has_and_belongs_to_many :sixconfigs has_and_belongs_to_many :servers has_and_belongs_to_many :queryservers has_and_belongs_to_many :networks six_guid def real_name return unless self.name case RUBY_PLATFORM when /-mingw32$/, /-mswin32$/ self.name else self.name.downcase end end def installed? !self.version_local.empty? end def exists?(setting) return false unless setting.real_modpath && self.real_name File.exists?(File.join(setting.real_modpath, self.real_name)) end def remote end def rema "mods/show" end def read_version(path) return unless path && self.real_name cfg = File.join(path, self.real_name, '.rsync', '.repository.yml') if File.exists?(cfg) conf = YAML::load_file(cfg) if conf conf[:version] else nil end else nil end end def update_version(path) self.version_local = self.read_version(path).to_s end def update_skip_by_version(path) self.update_version(path) self.update_skip end def real_path(appsetting) if self.path self.path else appsetting.real_modpath end end def all_repositories if self.networks.empty? Repository.find(:all) else repos = [] self.networks.each { |net| repos += net.repositories unless net.disabled } repos end end def update_skip self.skip = if self.new_record?; true ; else; ((self.version == self.version_local) && !self.version.nil?); end end def to_updater_yml return unless self.real_name hash = Hash.new hash[:folder] = self.real_name hash[:repository] = [] hash[:skip] = self.skip # TODO: Enable once proper processing is implemented #hash[:path] = self.path hash[:disabled] = self.disabled hash[:priority] = self.priority name = self.real_name.clone name.gsub!("@", '') unless self.new_record? self.all_repositories.each do |rep| hash[:repository] << "#{rep.to_updater_yml}/rel/#{name.downcase}/." unless rep.disabled end end hash end def self.read_modfolders(setting) Dir.chdir setting.real_modpath.clone do Dir["@*"].each do |dir| next unless File.directory?(dir) m = Mod.find(:first, :conditions => "name LIKE '#{dir}'") unless m m = Mod.new :name => dir m.save end logger.debug "#{m.inspect}" end end end end