From 049b7e727fde8c86245060563373f46cb3389dc8 Mon Sep 17 00:00:00 2001 From: George Shammas Date: Tue, 8 Jul 2014 20:15:09 -0400 Subject: [PATCH 1/2] Template loaded, @zellio will write splash page. --- main.go | 13 +++++++------ templates/index.html | 10 ++++++++++ 2 files changed, 17 insertions(+), 6 deletions(-) create mode 100644 templates/index.html diff --git a/main.go b/main.go index 48cad46..15afaf6 100644 --- a/main.go +++ b/main.go @@ -3,12 +3,13 @@ package main import ( "fmt" "net" + "net/http" "os" + "path" "strings" "time" + "github.com/gin-gonic/gin" - "net/http" - "path" ) func Logger() gin.HandlerFunc { @@ -39,7 +40,6 @@ func Logger() gin.HandlerFunc { } } - func mainHandler(c *gin.Context) { fields := strings.Split(c.Params.ByName("field"), ".") ip, err := net.ResolveTCPAddr("tcp", c.Req.RemoteAddr) @@ -53,7 +53,7 @@ func mainHandler(c *gin.Context) { c.Set("encoding", c.Req.Header.Get("Accept-Encoding")) hostnames, err := net.LookupAddr(ip.IP.String()) - if err != nil { + if err != nil { c.Set("host", "") } else { c.Set("host", hostnames[0]) @@ -71,7 +71,7 @@ func mainHandler(c *gin.Context) { if ua[0] == "curl" { c.String(200, fmt.Sprintln(ip.IP)) } else { - c.String(200, "Page Coming Soon") + c.HTML(200, "index.html", c.Keys) } return case "request": @@ -98,7 +98,7 @@ func FileServer(root string) gin.HandlerFunc { return func(c *gin.Context) { file := c.Params.ByName("file") if !strings.HasPrefix(file, "/") { - file = "/"+file + file = "/" + file } http.ServeFile(c.Writer, c.Req, path.Join(root, path.Clean(file))) } @@ -108,6 +108,7 @@ func main() { r := gin.New() r.Use(gin.Recovery()) r.Use(Logger()) + r.LoadHTMLTemplates("templates/*") r.GET("/:field", mainHandler) r.GET("/", mainHandler) diff --git a/templates/index.html b/templates/index.html new file mode 100644 index 0000000..d1e6a5e --- /dev/null +++ b/templates/index.html @@ -0,0 +1,10 @@ + + + + + IFCONFIG.IO + + +{{ .ip }} + + \ No newline at end of file From eab5de5558a9f08811b32d37db5133d3715cc75a Mon Sep 17 00:00:00 2001 From: George Shammas Date: Tue, 8 Jul 2014 20:32:45 -0400 Subject: [PATCH 2/2] Some linting --- main.go | 10 +++++++--- 1 file changed, 7 insertions(+), 3 deletions(-) diff --git a/main.go b/main.go index 15afaf6..8dbbc12 100644 --- a/main.go +++ b/main.go @@ -12,6 +12,9 @@ import ( "github.com/gin-gonic/gin" ) + +// Logger is a simple log handler, out puts in the standard of apache access log common +// http://httpd.apache.org/docs/2.2/logs.html#accesslog func Logger() gin.HandlerFunc { return func(c *gin.Context) { t := time.Now() @@ -24,11 +27,9 @@ func Logger() gin.HandlerFunc { c.Next() // after request - var user string + user := "-" if c.Req.URL.User != nil { user = c.Req.URL.User.Username() - } else { - user = "-" } latency := time.Since(t) @@ -94,6 +95,9 @@ func mainHandler(c *gin.Context) { } + +// FileServer is a basic file serve handler, this is just here as an example. +// gin.Static() should be used instead func FileServer(root string) gin.HandlerFunc { return func(c *gin.Context) { file := c.Params.ByName("file")