2019-02-15 15:39:39 +05:30
|
|
|
# frozen_string_literal: true
|
|
|
|
|
|
|
|
module Issues
|
|
|
|
class ImportCsvService
|
|
|
|
def initialize(user, project, csv_io)
|
|
|
|
@user = user
|
|
|
|
@project = project
|
|
|
|
@csv_io = csv_io
|
|
|
|
@results = { success: 0, error_lines: [], parse_error: false }
|
|
|
|
end
|
|
|
|
|
|
|
|
def execute
|
|
|
|
process_csv
|
|
|
|
email_results_to_user
|
|
|
|
|
|
|
|
@results
|
|
|
|
end
|
|
|
|
|
|
|
|
private
|
|
|
|
|
|
|
|
def process_csv
|
|
|
|
csv_data = @csv_io.open(&:read).force_encoding(Encoding::UTF_8)
|
|
|
|
|
2020-04-08 14:13:33 +05:30
|
|
|
csv_parsing_params = {
|
|
|
|
col_sep: detect_col_sep(csv_data.lines.first),
|
|
|
|
headers: true,
|
|
|
|
header_converters: :symbol
|
|
|
|
}
|
|
|
|
|
|
|
|
CSV.new(csv_data, csv_parsing_params).each.with_index(2) do |row, line_no|
|
|
|
|
issue_attributes = {
|
|
|
|
title: row[:title],
|
|
|
|
description: row[:description]
|
|
|
|
}
|
|
|
|
|
|
|
|
issue = Issues::CreateService.new(@project, @user, issue_attributes).execute
|
2019-02-15 15:39:39 +05:30
|
|
|
|
|
|
|
if issue.persisted?
|
|
|
|
@results[:success] += 1
|
|
|
|
else
|
|
|
|
@results[:error_lines].push(line_no)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
rescue ArgumentError, CSV::MalformedCSVError
|
|
|
|
@results[:parse_error] = true
|
|
|
|
end
|
|
|
|
|
|
|
|
def email_results_to_user
|
2020-06-23 00:09:42 +05:30
|
|
|
Notify.import_issues_csv_email(@user.id, @project.id, @results).deliver_later
|
2019-02-15 15:39:39 +05:30
|
|
|
end
|
|
|
|
|
|
|
|
def detect_col_sep(header)
|
|
|
|
if header.include?(",")
|
|
|
|
","
|
|
|
|
elsif header.include?(";")
|
|
|
|
";"
|
|
|
|
elsif header.include?("\t")
|
|
|
|
"\t"
|
|
|
|
else
|
|
|
|
raise CSV::MalformedCSVError
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|