-
-
Notifications
You must be signed in to change notification settings - Fork 128
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Feature Suggestion: Per-logger tags #165
Comments
Yes, setting the logging tags on a per logger instance is a very interesting use case. Rather than override the logger we could also setup the logger instance when the job is instantiated. Both approaches work well. In this case separating class Cart < Entity
include SemanticLogging::Loggable
def initialize
logger.named_tags = {cart_id: self.id}
end
def add_item(item_id, quantity)
InventoryService.reserve_items(item_id: item_id, quantity: quantity, reserved_by: self)
# do more stuff here
logger.debug('added item', item_id: item_id, quantity: quantity)
end
def remove_item(item_id, quantity)
InventoryService.cancel_item_reservation(item_id: item_id, quantity: quantity, reserved_by: self)
# do other stuff here
logger.debug('removed item', item_id: item_id, quantity: quantity)
end
end The hardest part here is remaining backward compatible, with the existing methods that every logger instance already honors: def tagged(*tags, &block)
# Allow named tags to be passed into the logger
if tags.size == 1
tag = tags[0]
return yield if tag.nil? || tag == ""
return tag.is_a?(Hash) ? SemanticLogger.named_tagged(tag, &block) : SemanticLogger.fast_tag(tag.to_s, &block)
end
# Need to flatten and reject empties to support calls from Rails 4
new_tags = tags.flatten.collect(&:to_s).reject(&:empty?)
SemanticLogger.tagged(*new_tags, &block)
end
# :nodoc:
alias with_tags tagged
# :nodoc:
def tags
SemanticLogger.tags
end
def named_tags
SemanticLogger.named_tags
end The above behavior just passes the tags through to the thread specific log tags. Changing Alternatively, we could create a new api to hold tags on a per logger instance basis that does not use the api Something like: def named_tags=(named_tags)
(@named_tags ||= {}).merge(named_tags)
end And then when the named tags are returned def named_tags
SemanticLogger.named_tags.merge(@named_tags)
end The next step is to verify that when the Log event is generated that it uses the named tags from this instance of the logger. Unlike the Feel free to play around with it and look forward to your pull request. |
Wow I was looking for the exact same thing |
Hey @reidmorrison @grncdr 👋 This has been inactive for a while but the solutions discussed here would allow me to tidy up some bits in my use-case. I'm happy to pick this up and get it over the line if you still agree it would be valuable. Please let me know, |
@theocodes definitely open to any efforts to add this capability. If we can figure out a solution that does not break the current behavior would be ideal, otherwise we could make it part of a major version upgrade? I personally do not call these instance methods, but not sure if anyone else does: def tags
SemanticLogger.tags
end
def named_tags
SemanticLogger.named_tags
end |
Thanks @reidmorrison I'll have a play around and report back in the next few days 👍 |
What do you think about allowing individual logger instances to carry their own tags? This would be particularly useful when loggers are owned by an object with an identity (e.g. an ActiveRecord instance).
To clarify what I mean, consider the following example:
As the number of methods grows, repeating
SemanticLogger.tagged(cart_id: self.id)
becomes tedious and leads to a lot of indenting. It also means all logging messages of the InventoryService are tagged with the current cart ID, which isn't always desirable.What would be nice is if I could write this:
And in case I want the current
#tagged
behaviour:The text was updated successfully, but these errors were encountered: