From fadddccf8ab37a74b9cb5949d593e0fe73b5863e Mon Sep 17 00:00:00 2001 From: Arpit Jalan Date: Wed, 12 Nov 2014 14:12:50 +0530 Subject: [PATCH] FEATURE: add custom user fields in user csv export --- app/jobs/regular/export_csv_file.rb | 34 ++++++++++++++++++++++++----- 1 file changed, 28 insertions(+), 6 deletions(-) diff --git a/app/jobs/regular/export_csv_file.rb b/app/jobs/regular/export_csv_file.rb index 633dafdd8f4..2bd8a29894f 100644 --- a/app/jobs/regular/export_csv_file.rb +++ b/app/jobs/regular/export_csv_file.rb @@ -4,6 +4,9 @@ require_dependency 'system_message' module Jobs class ExportCsvFile < Jobs::Base + CSV_USER_ATTRS = ['id','name','username','email','title','created_at','trust_level','active','admin','moderator','ip_address'] + CSV_USER_STATS = ['topics_entered','posts_read_count','time_read','topic_count','post_count','likes_given','likes_received'] + sidekiq_options retry: false attr_accessor :current_user @@ -43,7 +46,7 @@ module Jobs private def get_group_names(user) - group_names = [] + group_names = Array.new groups = user.groups groups.each do |group| group_names.push(group.name) @@ -52,21 +55,39 @@ module Jobs end def get_user_fields(user) - csv_user_attrs = ['id','name','username','email','title','created_at'] - csv_user_stats = ['topics_entered','posts_read_count','time_read','topic_count','post_count','likes_given','likes_received'] - user_array = [] + user_array = Array.new - csv_user_attrs.each do |attr| + CSV_USER_ATTRS.each do |attr| user_array.push(user.attributes[attr]) end - csv_user_stats.each do |stat| + CSV_USER_STATS.each do |stat| user_array.push(user.user_stat.attributes[stat]) end + if user.user_fields.present? + user.user_fields.each do |custom_field| + user_array.push(custom_field[1]) + end + end + return user_array end + def get_header + header_array = CSV_USER_ATTRS + CSV_USER_STATS + + user_custom_fields = UserField.all + if user_custom_fields.present? + user_custom_fields.each do |custom_field| + header_array.push("#{custom_field.name} (custom user field)") + end + end + header_array.push("group_names") + + return header_array + end + def set_file_path @file_name = "export_#{SecureRandom.hex(4)}.csv" # ensure directory exists @@ -77,6 +98,7 @@ module Jobs def write_csv_file(data) # write to CSV file CSV.open(File.expand_path("#{ExportCsv.base_directory}/#{@file_name}", __FILE__), "w") do |csv| + csv << get_header data.each do |value| csv << value end