mirror of
https://github.com/neocities/neocities.git
synced 2025-04-24 09:12:35 +02:00
28 lines
1.1 KiB
Ruby
28 lines
1.1 KiB
Ruby
class Tag < Sequel::Model
|
|
NAME_LENGTH_MAX = 25
|
|
NAME_WORDS_MAX = 1
|
|
many_to_many :sites
|
|
|
|
def before_create
|
|
super
|
|
values[:name] = self.class.clean_name values[:name]
|
|
end
|
|
|
|
def self.clean_name(name)
|
|
name.downcase.strip
|
|
end
|
|
|
|
def self.create_unless_exists(name)
|
|
name = clean_name name
|
|
return nil if name == '' || name.nil?
|
|
dataset.filter(name: name).first || create(name: name)
|
|
end
|
|
|
|
def self.autocomplete(name, limit=3)
|
|
DB["select tags.name,count(*) as c from sites_tags inner join tags on tags.id=sites_tags.tag_id inner join sites on sites.id=sites_tags.site_id where is_deleted='f' and is_banned='f' and is_crashing='f' and site_changed='t' and tags.is_nsfw='f' and tags.name != '' and tags.name LIKE ? group by tags.name having count(*) > 1 order by c desc LIMIT ?", name+'%', limit].all
|
|
end
|
|
|
|
def self.popular_names(limit=10)
|
|
DB["select tags.name,count(*) as c from sites_tags inner join tags on tags.id=sites_tags.tag_id where tags.name != '' and tags.is_nsfw='f' group by tags.name having count(*) > 1 order by c desc LIMIT ?", limit].all
|
|
end
|
|
end
|