1
0
mirror of https://github.com/labstack/echo.git synced 2025-01-12 01:22:21 +02:00

Now serving static files

Signed-off-by: Vishal Rana <vr@labstack.com>
This commit is contained in:
Vishal Rana 2015-03-06 21:55:51 -08:00
parent 05e8fee3de
commit f8e621248e
4 changed files with 27 additions and 2 deletions

11
bolt.go
View File

@ -3,6 +3,7 @@ package bolt
import ( import (
"log" "log"
"net/http" "net/http"
"strings"
"sync" "sync"
) )
@ -140,6 +141,14 @@ func (b *Bolt) Trace(path string, h ...HandlerFunc) {
b.Handle("TRACE", path, h) b.Handle("TRACE", path, h)
} }
// Static serves static files
func (b *Bolt) Static(path, root string) {
fs := http.StripPrefix(strings.TrimSuffix(path, "*"), http.FileServer(http.Dir(root)))
b.Get(path, func(c *Context) {
fs.ServeHTTP(c.Response, c.Request)
})
}
func (b *Bolt) Handle(method, path string, h []HandlerFunc) { func (b *Bolt) Handle(method, path string, h []HandlerFunc) {
h = append(b.handlers, h...) h = append(b.handlers, h...)
l := len(h) l := len(h)
@ -153,8 +162,8 @@ func (b *Bolt) Handle(method, path string, h []HandlerFunc) {
func (b *Bolt) ServeHTTP(rw http.ResponseWriter, r *http.Request) { func (b *Bolt) ServeHTTP(rw http.ResponseWriter, r *http.Request) {
// Find and execute handler // Find and execute handler
h, c, s := b.Router.Find(r.Method, r.URL.Path) h, c, s := b.Router.Find(r.Method, r.URL.Path)
c.reset(rw, r)
if h != nil { if h != nil {
c.reset(rw, r)
h(c) h(c)
} else { } else {
if s == NotFound { if s == NotFound {

View File

@ -43,5 +43,6 @@ func main() {
b.Post("/users", createUser) b.Post("/users", createUser)
b.Get("/users", getUsers) b.Get("/users", getUsers)
b.Get("/users/:id", getUser) b.Get("/users/:id", getUser)
b.Static("/static/*", "/tmp/")
b.Run(":8080") b.Run(":8080")
} }

View File

@ -32,7 +32,7 @@ type (
const ( const (
snode ntype = iota // Static node snode ntype = iota // Static node
pnode // Param node pnode // Param node
wnode // Wildcard node anode // Catch-all node
) )
const ( const (
@ -79,6 +79,8 @@ func (r *router) Add(method, path string, h HandlerFunc) {
} else { } else {
r.insert(method, path[:i], nil, snode) r.insert(method, path[:i], nil, snode)
} }
} else if path[i] == '*' {
r.insert(method, path[:i], h, anode)
} }
} }
r.insert(method, path, h, snode) r.insert(method, path, h, snode)
@ -206,6 +208,10 @@ func (r *router) Find(method, path string) (handler HandlerFunc, c *Context, s S
// All param read // All param read
continue continue
} }
case anode:
// End search
search = ""
continue
} }
e := cn.findEdge(search[0]) e := cn.findEdge(search[0])
if e == nil { if e == nil {

View File

@ -24,6 +24,15 @@ func TestParam(t *testing.T) {
} }
} }
func TestCatchAll(t *testing.T) {
r := New().Router
r.Add("GET", "/static/*", func(c *Context) {})
h, _, _ := r.Find("GET", "/static/*")
if h == nil {
t.Fatal("handle not found")
}
}
func TestMicroParam(t *testing.T) { func TestMicroParam(t *testing.T) {
r := New().Router r := New().Router
r.Add("GET", "/:a/:b/:c", func(c *Context) {}) r.Add("GET", "/:a/:b/:c", func(c *Context) {})