String format function allows access to protected attributes, is someone are able to manage the format string can access to sensible information.
CONFIG = {
'SECRET_KEY': 'super secret key'
}
class Event(object):
def __init__(self, id, level, message):
self.id = id
self.level = level
self.message = message
def format_event(format_string, event):
return format_string.format(event=event)
If format_event is executed with format_string = "{event.__init__.__globals__[CONFIG][SECRET_KEY]}", the secret_key will be read