Merge pull request #812 from Retrospring/fix/export-failures

Prevent exports crashing out if a related object is nil
This commit is contained in:
Karina Kwiatek 2022-11-20 14:52:31 +01:00 committed by GitHub
commit 4c0e92edfd
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
1 changed files with 10 additions and 3 deletions

View File

@ -156,6 +156,8 @@ class Exporter
if opts[:include_answers]
qobj[:answers] = []
question.answers.each do |a|
next if a.nil?
qobj[:answers] << process_answer(a, include_question: false)
end
end
@ -179,17 +181,19 @@ class Exporter
aobj[f] = answer.send f
end
if opts[:include_user]
if opts[:include_user] && answer.user
aobj[:user] = user_stub(answer.user)
end
if opts[:include_question]
if opts[:include_question] && answer.question
aobj[:question] = process_question(answer.question, include_user: true, include_answers: false)
end
if opts[:include_comments]
aobj[:comments] = []
answer.comments.each do |c|
next if c.nil?
aobj[:comments] << process_comment(c, include_user: true, include_answer: false)
end
end
@ -212,7 +216,7 @@ class Exporter
cobj[:user] = user_stub(comment.user)
end
if opts[:include_answer]
if opts[:include_answer] && comment.answer
cobj[:answer] = process_answer(comment.answer, include_comments: false)
end
@ -220,6 +224,8 @@ class Exporter
end
def process_smile(smile)
return unless smile.parent
sobj = {}
%i[id created_at].each do |f|
@ -233,6 +239,7 @@ class Exporter
end
def user_stub(user)
return nil if user.nil?
uobj = {}
%i[answered_count asked_count comment_smiled_count commented_count created_at
id permanently_banned? screen_name smiled_count].each do |f|