mirror of https://github.com/grafana/grafana
parent
2c72831be1
commit
201e1d3e6d
Binary file not shown.
@ -0,0 +1,58 @@ |
||||
// Copyright 2013 Martini Authors
|
||||
// Copyright 2014 Unknwon
|
||||
//
|
||||
// Licensed under the Apache License, Version 2.0 (the "License"): you may
|
||||
// not use this file except in compliance with the License. You may obtain
|
||||
// a copy of the License at
|
||||
//
|
||||
// http://www.apache.org/licenses/LICENSE-2.0
|
||||
//
|
||||
// Unless required by applicable law or agreed to in writing, software
|
||||
// distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
|
||||
// WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
|
||||
// License for the specific language governing permissions and limitations
|
||||
// under the License.
|
||||
|
||||
package middleware |
||||
|
||||
import ( |
||||
"fmt" |
||||
"net/http" |
||||
"runtime" |
||||
"time" |
||||
|
||||
"github.com/Unknwon/macaron" |
||||
"github.com/torkelo/grafana-pro/pkg/log" |
||||
) |
||||
|
||||
var isWindows bool |
||||
|
||||
func init() { |
||||
isWindows = runtime.GOOS == "windows" |
||||
} |
||||
|
||||
// Logger returns a middleware handler that logs the request as it goes in and the response as it goes out.
|
||||
func Logger() macaron.Handler { |
||||
return func(res http.ResponseWriter, req *http.Request, c *macaron.Context) { |
||||
start := time.Now() |
||||
|
||||
rw := res.(macaron.ResponseWriter) |
||||
c.Next() |
||||
|
||||
content := fmt.Sprintf("Completed %s %v %s in %v", req.URL.Path, rw.Status(), http.StatusText(rw.Status()), time.Since(start)) |
||||
if !isWindows { |
||||
switch rw.Status() { |
||||
case 200: |
||||
content = fmt.Sprintf("\033[1;32m%s\033[0m", content) |
||||
case 304: |
||||
return |
||||
content = fmt.Sprintf("\033[1;33m%s\033[0m", content) |
||||
case 404: |
||||
content = fmt.Sprintf("\033[1;31m%s\033[0m", content) |
||||
case 500: |
||||
content = fmt.Sprintf("\033[1;36m%s\033[0m", content) |
||||
} |
||||
} |
||||
log.Info(content) |
||||
} |
||||
} |
@ -0,0 +1,52 @@ |
||||
package middleware |
||||
|
||||
import ( |
||||
"time" |
||||
|
||||
"github.com/Unknwon/macaron" |
||||
"github.com/macaron-contrib/session" |
||||
|
||||
"github.com/torkelo/grafana-pro/pkg/log" |
||||
"github.com/torkelo/grafana-pro/pkg/models" |
||||
) |
||||
|
||||
type Context struct { |
||||
*macaron.Context |
||||
Session session.Store |
||||
|
||||
Account *models.Account |
||||
UserAccount *models.Account |
||||
|
||||
IsSigned bool |
||||
} |
||||
|
||||
func GetContextHandler() macaron.Handler { |
||||
return func(c *macaron.Context) { |
||||
ctx := &Context{ |
||||
Context: c, |
||||
} |
||||
|
||||
ctx.Data["PageStartTime"] = time.Now() |
||||
|
||||
c.Map(ctx) |
||||
} |
||||
} |
||||
|
||||
// Handle handles and logs error by given status.
|
||||
func (ctx *Context) Handle(status int, title string, err error) { |
||||
if err != nil { |
||||
log.Error(4, "%s: %v", title, err) |
||||
if macaron.Env != macaron.PROD { |
||||
ctx.Data["ErrorMsg"] = err |
||||
} |
||||
} |
||||
|
||||
switch status { |
||||
case 404: |
||||
ctx.Data["Title"] = "Page Not Found" |
||||
case 500: |
||||
ctx.Data["Title"] = "Internal Server Error" |
||||
} |
||||
|
||||
ctx.HTML(status, "index") |
||||
} |
@ -0,0 +1,12 @@ |
||||
package routes |
||||
|
||||
import "github.com/torkelo/grafana-pro/pkg/middleware" |
||||
|
||||
func Index(ctx *middleware.Context) { |
||||
ctx.HTML(200, "index") |
||||
} |
||||
|
||||
func NotFound(ctx *middleware.Context) { |
||||
ctx.Data["Title"] = "Page Not Found" |
||||
ctx.Handle(404, "index", nil) |
||||
} |
@ -1,7 +0,0 @@ |
||||
package routes |
||||
|
||||
import "github.com/torkelo/grafana-pro/pkg/setting" |
||||
|
||||
func GlobalInit() { |
||||
setting.NewConfigContext() |
||||
} |
Loading…
Reference in new issue