Renamed "layout" lib as "app_env" with APPLICATION_ENVIRONMENT interface. applied changed to callers. Added CMS_THEME.has_region (a_name): BOOLEAN to know if a region is declared in a defined theme.
189 lines
5.2 KiB
Plaintext
189 lines
5.2 KiB
Plaintext
note
|
|
description: "Object to log messages for a specific application. "
|
|
date: "$Date$"
|
|
revision: "$Revision$"
|
|
|
|
class
|
|
LOGGER
|
|
|
|
inherit
|
|
ANY
|
|
|
|
LOG_PRIORITY_CONSTANTS
|
|
export
|
|
{NONE} all
|
|
end
|
|
|
|
SHARED_EXECUTION_ENVIRONMENT
|
|
export
|
|
{NONE} all
|
|
end
|
|
|
|
create
|
|
make,
|
|
make_with_environment,
|
|
make_with_layout
|
|
|
|
feature {NONE} -- Initialization
|
|
|
|
make
|
|
-- Initialize a logger object.
|
|
do
|
|
create log.make
|
|
end
|
|
|
|
make_with_environment (app: APPLICATION_ENVIRONMENT)
|
|
-- Initialize a logger object with an application environment `app'.
|
|
do
|
|
make
|
|
apply_environment (app)
|
|
end
|
|
|
|
make_with_layout (app: APPLICATION_ENVIRONMENT)
|
|
-- Initialize a logger object with an application layout `app'.
|
|
obsolete
|
|
"Use make_with_environment"
|
|
do
|
|
make_with_environment (app)
|
|
end
|
|
|
|
feature -- Change
|
|
|
|
apply_environment (app: APPLICATION_ENVIRONMENT)
|
|
do
|
|
initialize_logger (app, log)
|
|
end
|
|
|
|
feature {NONE} -- Internal
|
|
|
|
log: LOGGING_FACILITY
|
|
|
|
feature -- Logging
|
|
|
|
put_information (a_message: separate READABLE_STRING_8)
|
|
-- Put message `a_message' to the log at information level.
|
|
do
|
|
log.write_information (create {STRING}.make_from_separate (a_message))
|
|
end
|
|
|
|
put_error (a_message: separate READABLE_STRING_8)
|
|
-- Put message `a_message' to the log at error level.
|
|
do
|
|
log.write_error (create {STRING}.make_from_separate (a_message))
|
|
end
|
|
|
|
put_warning (a_message: separate READABLE_STRING_8)
|
|
-- Put message `a_message' to the log at warning level.
|
|
do
|
|
log.write_warning (create {STRING}.make_from_separate (a_message))
|
|
end
|
|
|
|
put_critical (a_message: separate READABLE_STRING_8)
|
|
-- Put message `a_message' to the log at critical level.
|
|
do
|
|
log.write_critical (create {STRING}.make_from_separate (a_message))
|
|
end
|
|
|
|
put_alert (a_message: separate READABLE_STRING_8)
|
|
-- Put message `a_message' to the log at alert level.
|
|
do
|
|
log.write_alert (create {STRING}.make_from_separate (a_message))
|
|
end
|
|
|
|
put_debug (a_message: separate READABLE_STRING_8)
|
|
-- Put message `a_message' to the log at debug level.
|
|
do
|
|
log.write_debug (create {STRING}.make_from_separate (a_message))
|
|
end
|
|
|
|
feature {NONE} -- Implementation
|
|
|
|
initialize_logger (app: APPLICATION_ENVIRONMENT; a_log: like log)
|
|
local
|
|
l_log_writer_file: LOG_ROLLING_WRITER_FILE
|
|
l_log_writer: LOG_WRITER
|
|
l_logs_path: detachable PATH
|
|
l_logger_config: LOGGER_CONFIGURATION
|
|
ut: FILE_UTILITIES
|
|
do
|
|
l_logger_config := new_logger_level_configuration (app.application_config_path)
|
|
l_logs_path := l_logger_config.location
|
|
if l_logs_path = Void then
|
|
l_logs_path := app.logs_path
|
|
end
|
|
if ut.directory_path_exists (l_logs_path) then
|
|
create l_log_writer_file.make_at_location (l_logs_path.extended (app.name).appended_with_extension ("log"))
|
|
l_log_writer_file.set_max_file_size ({NATURAL_64} 1024 * 1204)
|
|
l_log_writer_file.set_max_backup_count (l_logger_config.backup_count)
|
|
l_log_writer := l_log_writer_file
|
|
else
|
|
-- Should we create the directory anyway ?
|
|
create {LOG_WRITER_NULL} l_log_writer
|
|
end
|
|
set_logger_level (l_log_writer, l_logger_config.level)
|
|
a_log.register_log_writer (l_log_writer)
|
|
end
|
|
|
|
set_logger_level (a_log_writer: LOG_WRITER; a_priority: INTEGER)
|
|
-- Setup the logger level based on `a_priority'
|
|
do
|
|
if a_priority = log_debug then
|
|
a_log_writer.enable_debug_log_level
|
|
elseif a_priority = Log_emergency then
|
|
a_log_writer.enable_emergency_log_level
|
|
elseif a_priority = Log_alert then
|
|
a_log_writer.enable_alert_log_level
|
|
elseif a_priority = Log_critical then
|
|
a_log_writer.enable_critical_log_level
|
|
elseif a_priority = Log_error then
|
|
a_log_writer.enable_error_log_level
|
|
elseif a_priority = Log_warning then
|
|
a_log_writer.enable_warning_log_level
|
|
elseif a_priority = Log_notice then
|
|
a_log_writer.enable_notice_log_level
|
|
elseif a_priority = Log_information then
|
|
a_log_writer.enable_information_log_level
|
|
else
|
|
a_log_writer.enable_unkno_log_level
|
|
end
|
|
end
|
|
|
|
new_logger_level_configuration (a_path: PATH): LOGGER_CONFIGURATION
|
|
-- Retrieve a new logger level configuration.
|
|
-- By default, level is set to `DEBUG'.
|
|
local
|
|
l_parser: JSON_PARSER
|
|
ut: FILE_UTILITIES
|
|
do
|
|
create Result
|
|
if
|
|
ut.file_path_exists (a_path) and then
|
|
attached (create {JSON_FILE_READER}).read_json_from (a_path.name) as json_file
|
|
then
|
|
create l_parser.make_with_string (json_file)
|
|
l_parser.parse_content
|
|
if
|
|
l_parser.is_valid and then
|
|
attached l_parser.parsed_json_object as jv and then
|
|
attached {JSON_OBJECT} jv.item ("logger") as l_logger
|
|
then
|
|
if attached {JSON_STRING} l_logger.item ("location") as l_location then
|
|
Result.set_location_with_string (l_location.item)
|
|
end
|
|
if attached {JSON_STRING} l_logger.item ("backup_count") as l_count then
|
|
if l_count.item.is_natural then
|
|
Result.set_backup_count (l_count.item.to_natural)
|
|
end
|
|
end
|
|
if attached {JSON_STRING} l_logger.item ("level") as l_level then
|
|
Result.set_level (l_level.item)
|
|
end
|
|
end
|
|
end
|
|
end
|
|
|
|
note
|
|
copyright: "2011-2015, Javier Velilla, Jocelyn Fiat, Eiffel Software and others"
|
|
license: "Eiffel Forum License v2 (see http://www.eiffel.com/licensing/forum.txt)"
|
|
end
|