Module: Cnvrg::Logger
Instance Method Summary collapse
- #info(msg) ⇒ Object
- #jsonify_message(msg: '', success: true) ⇒ Object
- #log_error(e) ⇒ Object
- #log_error_message(msg) ⇒ Object
- #log_handler ⇒ Object
- #log_info(msg) ⇒ Object
- #log_json(json, msg: '') ⇒ Object
- #log_method(bind: nil) ⇒ Object
- #remove_old_log_files ⇒ Object
Instance Method Details
#info(msg) ⇒ Object
61 62 63 |
# File 'lib/cnvrg/logger.rb', line 61 def info(msg) self.log_info(msg) end |
#jsonify_message(msg: '', success: true) ⇒ Object
104 105 106 107 108 109 |
# File 'lib/cnvrg/logger.rb', line 104 def (msg: '', success: true) puts JSON[{ "msg": msg, "success": success.to_s }] end |
#log_error(e) ⇒ Object
76 77 78 79 80 81 82 83 84 |
# File 'lib/cnvrg/logger.rb', line 76 def log_error(e) Cnvrg::Logger.log_handler if $log.blank? return if $log.blank? bc = ActiveSupport::BacktraceCleaner.new bc.add_silencer{|line| line =~ /thor/} $log.error message: "An exception #{e.class} was logged during running", type: "error" backtrace = bc.clean(e.backtrace).slice(0,12).map.with_index{|backtrace,idx| "(#{idx}) - #{backtrace}"}.join("; ") $log.error message: e., type: "error", backtrace: backtrace end |
#log_error_message(msg) ⇒ Object
86 87 88 89 90 |
# File 'lib/cnvrg/logger.rb', line 86 def (msg) Cnvrg::Logger.log_handler if $log.blank? return if $log.blank? $log.error message: msg, type: "error" end |
#log_handler ⇒ Object
4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 |
# File 'lib/cnvrg/logger.rb', line 4 def log_handler begin date = DateTime.now.strftime("%m_%d_%Y") home_dir = File.('~') if !File.directory? home_dir + "/.cnvrg" FileUtils.mkdir_p([home_dir + "/.cnvrg", home_dir + "/.cnvrg/tmp"]) end if !File.exist?(home_dir + "/.cnvrg/config.yml") FileUtils.touch [home_dir + "/.cnvrg/config.yml"] end logfile = File.('~') + "/.cnvrg/log_#{date}.log" if !File.exist? logfile FileUtils.touch([logfile]) yesterday = get_start_day - 86399 date = yesterday.strftime("%m_%d_%Y") logfile_old = File.('~') + "/.cnvrg/log_#{date}.log" count = 0 while not File.exist? logfile_old and count < 60 yesterday = yesterday - 86399 date = yesterday.strftime("%m_%d_%Y") logfile_old = File.('~') + "/.cnvrg/log_#{date}.log" count += 1 end if File.exist? logfile_old @files = Cnvrg::Files.new(Cnvrg::CLI.get_owner, "") @files.upload_log_file(logfile_old, "log_#{date}.log", yesterday) FileUtils.remove logfile_old end end config = LogStashLogger.configure do |config| config.customize_event do |event| event.remove('@version') event.remove('severity') end end $log = LogStashLogger.new(type: :file, path: logfile, sync: true, config: config) self.remove_old_log_files rescue end end |
#log_info(msg) ⇒ Object
92 93 94 95 96 |
# File 'lib/cnvrg/logger.rb', line 92 def log_info(msg) Cnvrg::Logger.log_handler if $log.blank? return if $log.blank? $log.info message: msg, type: "info" end |
#log_json(json, msg: '') ⇒ Object
98 99 100 101 102 |
# File 'lib/cnvrg/logger.rb', line 98 def log_json(json, msg: '') Cnvrg::Logger.log_handler if $log.blank? return if $log.blank? $log.info message: msg, type: "info", data: json end |
#log_method(bind: nil) ⇒ Object
65 66 67 68 69 70 71 72 73 74 |
# File 'lib/cnvrg/logger.rb', line 65 def log_method(bind: nil) return if bind.blank? Cnvrg::Logger.log_handler if $log.blank? arg = {} bind.local_variables.map do |name| arg[name] = bind.local_variable_get(name).try(:to_s) end method = bind.eval('__method__') $log.info method: method, args: arg end |
#remove_old_log_files ⇒ Object
48 49 50 51 52 53 54 55 56 57 58 59 |
# File 'lib/cnvrg/logger.rb', line 48 def remove_old_log_files() begin last_week = (Time.now - (7 * 24 * 60 * 60)).strftime("%Y-%m-%d") home = File.('~') log_files = Dir["#{home}/.cnvrg/tmp/*.log"] log_files.each do |l| if File.mtime(l).strftime("%Y-%m-%d") < last_week FileUtils.rm_rf(l) end end end end |