Class: Trinidad::Lifecycle::Base
- Inherits:
-
Object
- Object
- Trinidad::Lifecycle::Base
- Includes:
- Tomcat::LifecycleListener
- Defined in:
- lib/trinidad/lifecycle/lifecycle_listener_base.rb
Instance Attribute Summary collapse
-
#webapp ⇒ Object
readonly
Returns the value of attribute webapp.
Instance Method Summary collapse
- #configure_defaults(context) ⇒ Object
- #configure_logging ⇒ Object
-
#initialize(webapp) ⇒ Base
constructor
A new instance of Base.
- #lifecycleEvent(event) ⇒ Object
- #remove_defaults(context) ⇒ Object
Constructor Details
#initialize(webapp) ⇒ Base
Returns a new instance of Base.
7 8 9 10 |
# File 'lib/trinidad/lifecycle/lifecycle_listener_base.rb', line 7 def initialize(webapp) @webapp = webapp @configured_logger = false end |
Instance Attribute Details
#webapp ⇒ Object (readonly)
Returns the value of attribute webapp.
5 6 7 |
# File 'lib/trinidad/lifecycle/lifecycle_listener_base.rb', line 5 def webapp @webapp end |
Instance Method Details
#configure_defaults(context) ⇒ Object
19 20 21 22 |
# File 'lib/trinidad/lifecycle/lifecycle_listener_base.rb', line 19 def configure_defaults(context) remove_defaults(context) configure_logging end |
#configure_logging ⇒ Object
39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 |
# File 'lib/trinidad/lifecycle/lifecycle_listener_base.rb', line 39 def configure_logging return if @configured_logger log_path = File.join(@webapp.work_dir, 'log', "#{@webapp.environment}.log") log_file = java.io.File.new(log_path) unless log_file.exists log_file.parent_file.mkdirs log_file.create_new_file end jlogging = java.util.logging file_handler = jlogging.FileHandler.new(log_path, true) out_handler = jlogging.ConsoleHandler.new out_handler.set_output_stream JRuby.runtime.out err_handler = jlogging.ConsoleHandler.new err_handler.set_output_stream JRuby.runtime.err logger = jlogging.Logger.get_logger("") log_level = @webapp.log unless %w{ALL CONFIG FINE FINER FINEST INFO OFF SEVERE WARNING}.include?(log_level) puts "Invalid log level #{log_level}, using default: INFO" log_level = 'INFO' end level = jlogging.Level.parse(log_level) console_handler = logger.handlers.first logger.remove_handler(console_handler) logger.add_handler(file_handler) logger.add_handler(out_handler) logger.add_handler(err_handler) logger.handlers.each do |handler| handler.level = level handler.formatter = Trinidad::LogFormatter.new end logger.level = level @configured_logger = true end |
#lifecycleEvent(event) ⇒ Object
12 13 14 15 16 17 |
# File 'lib/trinidad/lifecycle/lifecycle_listener_base.rb', line 12 def lifecycleEvent(event) if Trinidad::Tomcat::Lifecycle::BEFORE_START_EVENT == event.type context = event.lifecycle configure_defaults(context) end end |
#remove_defaults(context) ⇒ Object
24 25 26 27 28 29 30 31 32 33 34 35 36 37 |
# File 'lib/trinidad/lifecycle/lifecycle_listener_base.rb', line 24 def remove_defaults(context) context.remove_welcome_file('index.jsp') context.remove_welcome_file('index.htm') context.remove_welcome_file('index.html') jsp_servlet = context.find_child('jsp') context.remove_child(jsp_servlet) if jsp_servlet context.remove_servlet_mapping('*.jspx') context.remove_servlet_mapping('*.jsp') context.process_tlds = false context.xml_validation = false end |