Open willkoehler opened 3 years ago
For the time being I'm just doing this:
class LogdnaWithTags < Logdna::Ruby
def log(message = nil, opts = {})
# add ActiveSupport::TaggedLogging log tags to the metadata
if formatter.current_tags.present?
opts[:meta] = (opts[:meta] || {}).merge(tags: formatter.current_tags.join(" "))
end
# Call original LogDNA logger
super
end
end
And then using as before
# This is the default in Rails, but could include more stuff if desired
config.log_tags = [:request_id]
# Send logs to LogDNA
log_dna_logger = LogdnaWithTags.new(
Rails.application.secrets.log_dna_api_key, {
env: "development",
app: "ShayHi",
level: Logger::DEBUG
}
)
# Wrap LogDNA logger in TaggedLogging to add log tags
config.logger = ActiveSupport::TaggedLogging.new(log_dna_logger)
I've made this change locally. But I think it could go in the public gem. I'm using
ActiveSupport::TaggedLogging
in Rails to include log tags like this:I then modified
Logdna::Ruby#log
to include the tags in the metadataLogs now look like this:
This is particularly useful for including the Rails request_id in the log metadata. I can open a PR if this is something you're interested in adding to the gem for everyone.