def self.action(action, success=true, description=nil, args={}, detailed_description=nil)
return unless logger
result = success ? "SUCCESS" : "FAILURE"
description = (description || "").strip
detailed_description = (detailed_description || "").strip
time_obj = Time.new
date = time_obj.strftime("%Y-%m-%d")
time = time_obj.strftime("%H:%M:%S")
message = "#{result} DATE=#{date} TIME=#{time} ACTION=#{action} REQ_ID=#{Thread.current[:user_action_log_uuid]}"
auth = " USER_ID=#{Thread.current[:user_action_log_user_id].to_s} LOGIN=#{Thread.current[:user_action_log_identity_id].to_s}"
extra = args.map{|k,v| " #{k}=#{v}"}.join
logger.info("#{message}#{auth}#{extra} #{description}")
unless Rails.env.production?
Rails.logger.add(Logger::DEBUG){ " #{result} ACTION=#{action}#{auth}#{extra} #{description} #{detailed_description}" }
end
end