ニコニコ同期にてニジラー情報自動記載(#276) (#277)

#276

Co-authored-by: miteruzo <miteruzo@naver.com>
Reviewed-on: #277
This commit was merged in pull request #277.
This commit is contained in:
2026-03-05 23:10:37 +09:00
parent e0e7a22c38
commit 98330b00bb
+11 -4
View File
@@ -47,7 +47,6 @@ namespace :nico do
data = JSON.parse(stdout)
data.each do |datum|
code = datum['code']
post =
Post
.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])
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_non_nico_ids = []
datum['tags'].each do |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
unless tag.id.in?(kept_ids)
linked_ids = tag.linked_tags.pluck(:id)
@@ -109,6 +109,13 @@ namespace :nico do
desired_nico_ids.concat(linked_ids)
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_all_ids = kept_non_nico_ids.to_a + desired_nico_ids