| @@ -47,7 +47,6 @@ namespace :nico do | |||||
| data = JSON.parse(stdout) | data = JSON.parse(stdout) | ||||
| data.each do |datum| | data.each do |datum| | ||||
| code = datum['code'] | code = datum['code'] | ||||
| post = | post = | ||||
| Post | Post | ||||
| .where('url REGEXP ?', "nicovideo\\.jp/watch/#{ Regexp.escape(code) }([^0-9]|$)") | .where('url REGEXP ?', "nicovideo\\.jp/watch/#{ Regexp.escape(code) }([^0-9]|$)") | ||||
| @@ -94,14 +93,15 @@ namespace :nico do | |||||
| sync_post_tags!(post, [Tag.tagme.id, Tag.bot.id, Tag.niconico.id, Tag.video.id]) | sync_post_tags!(post, [Tag.tagme.id, Tag.bot.id, Tag.niconico.id, Tag.video.id]) | ||||
| end | end | ||||
| kept_ids = PostTag.kept.where(post_id: post.id).pluck(:tag_id).to_set | |||||
| kept_non_nico_ids = post.tags.where.not(category: 'nico').pluck(:id).to_set | |||||
| kept_ids = post.tags.pluck(:id).to_set | |||||
| kept_non_nico_ids = post.tags.not_nico.pluck(:id).to_set | |||||
| desired_nico_ids = [] | desired_nico_ids = [] | ||||
| desired_non_nico_ids = [] | desired_non_nico_ids = [] | ||||
| datum['tags'].each do |raw| | datum['tags'].each do |raw| | ||||
| name = "nico:#{ raw }" | name = "nico:#{ raw }" | ||||
| tag = Tag.find_or_create_by_tag_name!(name, category: 'nico') | |||||
| tag = Tag.find_or_create_by_tag_name!(name, category: :nico) | |||||
| desired_nico_ids << tag.id | desired_nico_ids << tag.id | ||||
| unless tag.id.in?(kept_ids) | unless tag.id.in?(kept_ids) | ||||
| linked_ids = tag.linked_tags.pluck(:id) | linked_ids = tag.linked_tags.pluck(:id) | ||||
| @@ -109,6 +109,13 @@ namespace :nico do | |||||
| desired_nico_ids.concat(linked_ids) | desired_nico_ids.concat(linked_ids) | ||||
| end | end | ||||
| end | end | ||||
| deerjikist = Deerjikist.find_by(platform: :nico, code: datum['user']) | |||||
| if deerjikist | |||||
| desired_non_nico_ids << deerjikist.tag_id | |||||
| desired_nico_ids << deerjikist.tag_id | |||||
| end | |||||
| desired_nico_ids.uniq! | desired_nico_ids.uniq! | ||||
| desired_all_ids = kept_non_nico_ids.to_a + desired_nico_ids | desired_all_ids = kept_non_nico_ids.to_a + desired_nico_ids | ||||