Display log info about request processing.

Introduced properties

init defaultinit(level: nullable Int, out: nullable OUT, default_formatter: nullable Formatter, no_color: nullable Bool, default_formatter: nullable Formatter)

popcorn :: PopLogger :: defaultinit

fun no_color: Bool

popcorn :: PopLogger :: no_color

Do we want colors in the console output?
protected fun no_color=(no_color: nullable Bool)

popcorn :: PopLogger :: no_color=

Do we want colors in the console output?

Redefined properties

redef type SELF: PopLogger

popcorn $ PopLogger :: SELF

Type of this instance, automatically specialized in every class
redef fun all(req: HttpRequest, res: HttpResponse)

popcorn $ PopLogger :: all

Handler to all kind of HTTP request methods.
redef fun default_formatter: nullable Formatter

popcorn $ PopLogger :: default_formatter

Formatter used to format messages before outputting them
redef fun default_formatter=(default_formatter: nullable Formatter)

popcorn $ PopLogger :: default_formatter=

Formatter used to format messages before outputting them

All properties

fun !=(other: nullable Object): Bool

core :: Object :: !=

Have self and other different values?
fun ==(other: nullable Object): Bool

core :: Object :: ==

Have self and other the same value?
type BODY: Serializable

popcorn :: Handler :: BODY

Kind of objects returned by deserialize_body
type CLASS: Class[SELF]

core :: Object :: CLASS

The type of the class of self.
type OUT: Writer

logger :: Logger :: OUT

Kind of Writer used to output messages
type SELF: Object

core :: Object :: SELF

Type of this instance, automatically specialized in every class
fun add(level: Int, message: Writable, formatter: nullable Formatter): Bool

logger :: Logger :: add

Output a message with level severity
fun add_raw(level: Int, message: Writable): Bool

logger :: Logger :: add_raw

Output a message with level severity without formatting it
fun all(req: HttpRequest, res: HttpResponse)

popcorn :: Handler :: all

Handler to all kind of HTTP request methods.
protected fun class_factory(name: String): CLASS

core :: Object :: class_factory

Implementation used by get_class to create the specific class.
fun class_name: String

core :: Object :: class_name

The class name of the object.
fun debug(message: String, formatter: nullable Formatter): Bool

logger :: Logger :: debug

Output a message with debug severity
fun default_formatter: nullable Formatter

logger :: Logger :: default_formatter

Formatter used to format messages before outputting them
fun default_formatter=(default_formatter: nullable Formatter)

logger :: Logger :: default_formatter=

Formatter used to format messages before outputting them
init defaultinit(level: nullable Int, out: nullable OUT, default_formatter: nullable Formatter, no_color: nullable Bool, default_formatter: nullable Formatter)

popcorn :: PopLogger :: defaultinit

init defaultinit(level: nullable Int, out: nullable OUT, default_formatter: nullable Formatter)

logger :: Logger :: defaultinit

fun delete(req: HttpRequest, res: HttpResponse)

popcorn :: Handler :: delete

DELETE handler.
fun deserialize_body(req: HttpRequest, res: HttpResponse): nullable BODY

popcorn :: Handler :: deserialize_body

Deserialize the request body
fun error(message: String, formatter: nullable Formatter): Bool

logger :: Logger :: error

Output a message with error_level severity
fun fatal(message: String, formatter: nullable Formatter): Bool

logger :: Logger :: fatal

Output a message with fatal_level severity
fun get(req: HttpRequest, res: HttpResponse)

popcorn :: Handler :: get

GET handler.
fun get_class: CLASS

core :: Object :: get_class

The meta-object representing the dynamic type of self.
fun hash: Int

core :: Object :: hash

The hash code of the object.
fun info(message: String, formatter: nullable Formatter): Bool

logger :: Logger :: info

Output a message with info_level severity
init init

core :: Object :: init

fun inspect: String

core :: Object :: inspect

Developer readable representation of self.
protected fun inspect_head: String

core :: Object :: inspect_head

Return "CLASSNAME:#OBJECTID".
intern fun is_same_instance(other: nullable Object): Bool

core :: Object :: is_same_instance

Return true if self and other are the same instance (i.e. same identity).
fun is_same_serialized(other: nullable Object): Bool

core :: Object :: is_same_serialized

Is self the same as other in a serialization context?
intern fun is_same_type(other: Object): Bool

core :: Object :: is_same_type

Return true if self and other have the same dynamic type.
fun level: Int

logger :: Logger :: level

Severity threshold
fun level=(level: nullable Int)

logger :: Logger :: level=

Severity threshold
fun no_color: Bool

popcorn :: PopLogger :: no_color

Do we want colors in the console output?
protected fun no_color=(no_color: nullable Bool)

popcorn :: PopLogger :: no_color=

Do we want colors in the console output?
intern fun object_id: Int

core :: Object :: object_id

An internal hash code for the object based on its identity.
fun out: OUT

logger :: Logger :: out

Writer used to output messages
protected fun out=(out: nullable OUT)

logger :: Logger :: out=

Writer used to output messages
fun output

core :: Object :: output

Display self on stdout (debug only).
intern fun output_class_name

core :: Object :: output_class_name

Display class name on stdout (debug only).
fun post(req: HttpRequest, res: HttpResponse)

popcorn :: Handler :: post

POST handler.
fun put(req: HttpRequest, res: HttpResponse)

popcorn :: Handler :: put

PUT handler.
fun serialization_hash: Int

core :: Object :: serialization_hash

Hash value use for serialization
intern fun sys: Sys

core :: Object :: sys

Return the global sys object, the only instance of the Sys class.
abstract fun to_jvalue(env: JniEnv): JValue

core :: Object :: to_jvalue

fun to_s: String

core :: Object :: to_s

User readable representation of self.
fun unknown(message: String, formatter: nullable Formatter): Bool

logger :: Logger :: unknown

Output a message with unknown_level severity
fun validate_body(req: HttpRequest, res: HttpResponse): nullable String

popcorn :: Handler :: validate_body

Validate body input with validator
fun validator: nullable DocumentValidator

popcorn :: Handler :: validator

Validator used to check body input
protected fun validator=(validator: nullable DocumentValidator)

popcorn :: Handler :: validator=

Validator used to check body input
fun warn(message: String, formatter: nullable Formatter): Bool

logger :: Logger :: warn

Output a message with warn_level severity
package_diagram popcorn::PopLogger PopLogger logger::Logger Logger popcorn::PopLogger->logger::Logger popcorn::Handler Handler popcorn::PopLogger->popcorn::Handler core::Object Object logger::Logger->core::Object popcorn::Handler->core::Object ...core::Object ... ...core::Object->core::Object

Ancestors

interface Object

core :: Object

The root of the class hierarchy.

Parents

abstract class Handler

popcorn :: Handler

Class handler for a route.
class Logger

logger :: Logger

A simple logging utility

Class definitions

popcorn $ PopLogger
# 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
lib/popcorn/pop_logging.nit:32,1--56,3