Introduced classes

class PopLogger

popcorn :: PopLogger

Display log info about request processing.
class RequestClock

popcorn :: RequestClock

Initialize a clock for the resquest.

Redefined classes

redef class HttpRequest

popcorn :: pop_logging $ HttpRequest

A request received over HTTP, is build by HttpRequestParser
redef class HttpResponse

popcorn :: pop_logging $ HttpResponse

A response to send over HTTP

All class definitions

redef class HttpRequest

popcorn :: pop_logging $ HttpRequest

A request received over HTTP, is build by HttpRequestParser
redef class HttpResponse

popcorn :: pop_logging $ HttpResponse

A response to send over HTTP
class PopLogger

popcorn $ PopLogger

Display log info about request processing.
class RequestClock

popcorn $ RequestClock

Initialize a clock for the resquest.
package_diagram popcorn::pop_logging pop_logging popcorn::pop_handlers pop_handlers popcorn::pop_logging->popcorn::pop_handlers logger logger popcorn::pop_logging->logger realtime realtime popcorn::pop_logging->realtime popcorn::pop_routes pop_routes popcorn::pop_handlers->popcorn::pop_routes csv csv popcorn::pop_handlers->csv console console logger->console core core realtime->core ...popcorn::pop_routes ... ...popcorn::pop_routes->popcorn::pop_routes ...csv ... ...csv->csv ...console ... ...console->console ...core ... ...core->core github::loader loader github::loader->popcorn::pop_logging popcorn::popcorn popcorn popcorn::popcorn->popcorn::pop_logging a_star-m a_star-m a_star-m->github::loader a_star-m... ... a_star-m...->a_star-m popcorn::popcorn... ... popcorn::popcorn...->popcorn::popcorn

Ancestors

module abstract_collection

core :: abstract_collection

Abstract collection classes and services.
module abstract_text

core :: abstract_text

Abstract class for manipulation of sequences of characters
module array

core :: array

This module introduces the standard array structure.
module base64

base64 :: base64

Offers the base 64 encoding and decoding algorithms
module bitset

core :: bitset

Services to handle BitSet
module bytes

core :: bytes

Services for byte streams and arrays
module caching

serialization :: caching

Services for caching serialization engines
module circular_array

core :: circular_array

Efficient data structure to access both end of the sequence.
module codec_base

core :: codec_base

Base for codecs to use with streams
module codecs

core :: codecs

Group module for all codec-related manipulations
module collection

core :: collection

This module define several collection classes.
module console

console :: console

Defines some ANSI Terminal Control Escape Sequences.
module core

core :: core

Standard classes and methods used by default by Nit programs and libraries.
module csv

csv :: csv

CSV document handling.
module engine_tools

serialization :: engine_tools

Advanced services for serialization engines
module environ

core :: environ

Access to the environment variables of the process
module error

core :: error

Standard error-management infrastructure.
module exec

core :: exec

Invocation and management of operating system sub-processes.
module file

core :: file

File manipulations (create, read, write, etc.)
module file_server

nitcorn :: file_server

Provides the FileServer action, which is a standard and minimal file server
module fixed_ints

core :: fixed_ints

Basic integers of fixed-precision
module fixed_ints_text

core :: fixed_ints_text

Text services to complement fixed_ints
module flat

core :: flat

All the array-based text representations
module gc

core :: gc

Access to the Nit internal garbage collection mechanism
module hash_collection

core :: hash_collection

Introduce HashMap and HashSet.
module http_errors

nitcorn :: http_errors

Offers ErrorTemplate to display error pages
module http_request

nitcorn :: http_request

Provides the HttpRequest class and services to create it
module http_request_buffer

nitcorn :: http_request_buffer

Http request parsing for buffered inputs.
module http_response

nitcorn :: http_response

Provides the HttpResponse class and http_status_codes
module inspect

serialization :: inspect

Refine Serializable::inspect to show more useful information
module iso8859_1

core :: iso8859_1

Codec for ISO8859-1 I/O
module kernel

core :: kernel

Most basic classes and methods.
module libevent

libevent :: libevent

Low-level wrapper around the libevent library to manage events on file descriptors
module list

core :: list

This module handle double linked lists
module math

core :: math

Mathematical operations
module md5

md5 :: md5

Native MD5 digest implementation as Text::md5
module media_types

nitcorn :: media_types

Services to identify Internet media types (or MIME types, Content-types)
module meta

meta :: meta

Simple user-defined meta-level to manipulate types of instances as object.
module more_collections

more_collections :: more_collections

Highly specific, but useful, collections-related classes.
module native

core :: native

Native structures for text and bytes
module nitcorn

nitcorn :: nitcorn

The nitcorn Web server framework creates server-side Web apps in Nit
module numeric

core :: numeric

Advanced services for Numeric types
module pop_routes

popcorn :: pop_routes

Internal routes representation.
module poset

poset :: poset

Pre order sets and partial order set (ie hierarchies)
module protocol

core :: protocol

module queue

core :: queue

Queuing data structures and wrappers
module range

core :: range

Module for range of discrete objects.
module re

core :: re

Regular expression support for all services based on Pattern
module reactor

nitcorn :: reactor

Core of the nitcorn project, provides HttpFactory and Action
module ropes

core :: ropes

Tree-based representation of a String.
module serialization

serialization :: serialization

General serialization services
module serialization_core

serialization :: serialization_core

Abstract services to serialize Nit objects to different formats
module server_config

nitcorn :: server_config

Classes and services to configure the server
module sessions

nitcorn :: sessions

Automated session management
module signal_handler

nitcorn :: signal_handler

Handle SIGINT and SIGTERM to close the server after all active events
module sorter

core :: sorter

This module contains classes used to compare things and sorts arrays.
module stream

core :: stream

Input and output streams of characters
module template

template :: template

Basic template system
module text

core :: text

All the classes and methods related to the manipulation of text entities
module time

core :: time

Management of time and dates
module token

nitcorn :: token

Simple generate_token service, independent of the rest of the nitcorn framework
module union_find

core :: union_find

union–find algorithm using an efficient disjoint-set data structure
module utf8

core :: utf8

Codec for UTF-8 I/O
module vararg_routes

nitcorn :: vararg_routes

Routes with parameters.

Parents

module logger

logger :: logger

A simple logger for Nit
module pop_handlers

popcorn :: pop_handlers

Route handlers.
module realtime

realtime :: realtime

Services to keep time of the wall clock time

Children

module loader

github :: loader

module popcorn

popcorn :: popcorn

Application server abstraction on top of nitcorn.

Descendants

module pop_logging

import pop_handlers
import logger
import realtime

# Initialize a clock for the resquest.
#
# Can be used to compute the time passed to respond that request.
class RequestClock
	super Handler

	redef fun all(req, res) do req.clock = new Clock
end

# Display log info about request processing.
class PopLogger
	super Logger
	super Handler

	# Do we want colors in the console output?
	var no_color = false is optional

	redef var default_formatter = new PopFormatter(no_color) is optional

	redef fun all(req, res) do
		var clock = req.clock
		if clock != null then
			add_raw(info_level, "{req.method} {req.url} {status(res)} ({clock.total}s)")
		else
			add_raw(info_level, "{req.method} {req.url} {status(res)}")
		end
	end

	# Colorize the request status.
	private fun status(res: HttpResponse): String do
		if no_color then return res.status_code.to_s
		return res.color_status
	end
end

class PopFormatter
	super Formatter

	# Do not decorate messages with colors
	var no_color = false is optional, writable

	redef fun format(level, message) do
		var string = message.write_to_string

		if level == fatal_level then
			string = "[FATAL] {string}"
		else if level == error_level then
			string = "[ERROR] {string}"
		else if level == warn_level then
			string = "[WARN] {string}"
		else if level == info_level then
			string = "[INFO] {string}"
		else if level == debug_level then
			string = "[DEBUG] {string}"
		end

		if no_color then return string

		if level == fatal_level then
			return string.red
		else if level == error_level then
			return string.red
		else if level == warn_level then
			return string.yellow
		else if level == info_level then
			return string.blue
		else if level == debug_level then
			return string.gray
		end

		return string
	end
end


redef class HttpRequest
	# Time that request was received by the Popcorn app.
	var clock: nullable Clock = null
end

redef class HttpResponse
	# Return `self` status colored for console.
	fun color_status: String do
		if status_code >= 100 and status_code < 200 then return status_code.to_s.gray
		if status_code >= 200 and status_code < 300 then return status_code.to_s.green
		if status_code >= 300 and status_code < 400 then return status_code.to_s.blue
		if status_code >= 400 and status_code < 500 then return status_code.to_s.yellow
		if status_code >= 500 and status_code < 600 then return status_code.to_s.red
		return status_code.to_s
	end
end
lib/popcorn/pop_logging.nit:17,1--113,3