Sha256: 325f747026dc39b2c94c992bbb0cf16fdd28aaebf51894b98cbef7c4a693000b

Contents?: true

Size: 1.99 KB

Versions: 7

Compression:

Stored size: 1.99 KB

Contents

module Trinidad
  module Lifecycle
    class Base
      include Trinidad::Tomcat::LifecycleListener
      attr_reader :webapp

      def initialize(webapp)
        @webapp = webapp
        @configured_logger = false
      end

      def lifecycleEvent(event)
        if Trinidad::Tomcat::Lifecycle::BEFORE_START_EVENT == event.type
          context = event.lifecycle
          configure_defaults(context)
        end
      end

      def configure_defaults(context)
        remove_defaults(context)
        configure_logging
      end

      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

      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

        log_handler = jlogging.FileHandler.new(log_path, true)
        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)

        logger.add_handler(log_handler)

        logger.handlers.each do |handler|
          handler.level = level
          handler.formatter = Trinidad::LogFormatter.new
        end

        logger.level = level

        @configured_logger = true
      end
    end
  end
end

Version data entries

7 entries across 7 versions & 1 rubygems

Version Path
trinidad-1.3.4 lib/trinidad/lifecycle/lifecycle_listener_base.rb
trinidad-1.3.3 lib/trinidad/lifecycle/lifecycle_listener_base.rb
trinidad-1.3.2 lib/trinidad/lifecycle/lifecycle_listener_base.rb
trinidad-1.3.1 lib/trinidad/lifecycle/lifecycle_listener_base.rb
trinidad-1.3.0 lib/trinidad/lifecycle/lifecycle_listener_base.rb
trinidad-1.2.3 lib/trinidad/lifecycle/lifecycle_listener_base.rb
trinidad-1.2.2 lib/trinidad/lifecycle/lifecycle_listener_base.rb