1 # This file is part of NIT ( http://www.nitlanguage.org ).
3 # Copyright 2016 Alexandre Terrasa <alexandre@moz-code.org>
5 # Licensed under the Apache License, Version 2.0 (the "License");
6 # you may not use this file except in compliance with the License.
7 # You may obtain a copy of the License at
9 # http://www.apache.org/licenses/LICENSE-2.0
11 # Unless required by applicable law or agreed to in writing, software
12 # distributed under the License is distributed on an "AS IS" BASIS,
13 # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14 # See the License for the specific language governing permissions and
15 # limitations under the License.
20 redef class HttpRequest
21 # Time that request was received by the Popcorn app.
22 var timer
: nullable Clock = null
25 class RequestTimeHandler
28 redef fun all
(req
, res
) do req
.timer
= new Clock
34 redef fun all
(req
, res
) do
37 print
"{req.method} {req.uri} {res.color_status} ({timer.total})"
39 print
"{req.method} {req.uri} {res.color_status}"
47 redef fun get
(req
, res
) do res
.send
"Hello World!"
51 app
.use
("/*", new RequestTimeHandler)
52 app
.use
("/", new HelloHandler)
53 app
.use
("/*", new LogHandler)
54 app
.listen
("localhost", 3000)