Class: SemanticLogger::Appender::ElasticsearchHttp

Inherits:
Http show all
Defined in:
lib/semantic_logger/appender/elasticsearch_http.rb

Instance Attribute Summary collapse

Attributes inherited from Http

#compress, #continue_timeout, #header, #http, #open_timeout, #path, #port, #read_timeout, #server, #ssl_options, #url, #username

Attributes inherited from Subscriber

#application, #formatter, #host, #logger, #metrics

Attributes inherited from Base

#filter, #name

Instance Method Summary collapse

Methods inherited from Http

#reopen

Methods inherited from Subscriber

#close, #default_formatter, #flush, #level, #should_log?

Methods inherited from Base

#backtrace, #fast_tag, #level, #level=, #measure, #payload, #pop_tags, #push_tags, #should_log?, #silence, #tagged, #tags, #with_payload

Constructor Details

#initialize(index: 'semantic_logger', type: 'log', url: 'http://localhost:9200', **http_args, &block) ⇒ ElasticsearchHttp

Create Elasticsearch appender over persistent HTTP(S)

Parameters:

index: [String]
  Prefix of the index to store the logs in Elasticsearch.
  The final index appends the date so that indexes are used per day.
    I.e. The final index will look like 'semantic_logger-YYYY.MM.DD'
  Default: 'semantic_logger'

type: [String]
  Document type to associate with logs when they are written.
  Default: 'log'

level: [:trace | :debug | :info | :warn | :error | :fatal]
  Override the log level for this appender.
  Default: SemanticLogger.default_level

formatter: [Object|Proc|Symbol|Hash]
  An instance of a class that implements #call, or a Proc to be used to format
  the output from this appender
  Default: Use the built-in formatter (See: #call)

filter: [Regexp|Proc]
  RegExp: Only include log messages where the class name matches the supplied.
  regular expression. All other messages will be ignored.
  Proc: Only include log messages where the supplied Proc returns true
        The Proc must return true or false.

host: [String]
  Name of this host to appear in log messages.
  Default: SemanticLogger.host

application: [String]
  Name of this application to appear in log messages.
  Default: SemanticLogger.application


53
54
55
56
57
58
59
60
61
62
63
64
65
# File 'lib/semantic_logger/appender/elasticsearch_http.rb', line 53

def initialize(index: 'semantic_logger',
               type: 'log',
               url: 'http://localhost:9200',
               **http_args,
               &block)

  @index = index
  @type  = type
  super(url: url, **http_args, &block)

  @request_path = "#{@path.end_with?('/') ? @path : "#{@path}/"}#{@index}-%Y.%m.%d"
  @logging_path = "#{@request_path}/#{type}"
end

Instance Attribute Details

#indexObject

Returns the value of attribute index.



16
17
18
# File 'lib/semantic_logger/appender/elasticsearch_http.rb', line 16

def index
  @index
end

#typeObject

Returns the value of attribute type.



16
17
18
# File 'lib/semantic_logger/appender/elasticsearch_http.rb', line 16

def type
  @type
end

Instance Method Details

#delete_all(date = Date.today) ⇒ Object

Deletes all log data captured for a day.



73
74
75
# File 'lib/semantic_logger/appender/elasticsearch_http.rb', line 73

def delete_all(date = Date.today)
  delete(date.strftime(@request_path))
end

#log(log) ⇒ Object

Log to the index for today.



68
69
70
# File 'lib/semantic_logger/appender/elasticsearch_http.rb', line 68

def log(log)
  post(formatter.call(log, self), log.time.strftime(@logging_path))
end