Skip to content

Commit

Permalink
Merge pull request labstack#185 from labstack/context-file
Browse files Browse the repository at this point in the history
Added attachment as option in Context.File function
  • Loading branch information
vishr committed Aug 25, 2015
2 parents 031c14f + 1daa16d commit 2450450
Show file tree
Hide file tree
Showing 3 changed files with 28 additions and 13 deletions.
20 changes: 8 additions & 12 deletions context.go
Original file line number Diff line number Diff line change
Expand Up @@ -3,15 +3,13 @@ package echo
import (
"encoding/json"
"encoding/xml"
"io"
"net/http"
"path"

"fmt"

"net/url"

"os"

"golang.org/x/net/websocket"
)

Expand Down Expand Up @@ -166,16 +164,14 @@ func (c *Context) XML(code int, i interface{}) error {
return xml.NewEncoder(c.response).Encode(i)
}

// File sends a file as attachment.
func (c *Context) File(name string) error {
file, err := os.Open(name)
if err != nil {
return err
// File sends a response with the content of the file. If attachment is true, the
// client is prompted to save the file.
func (c *Context) File(name string, attachment bool) error {
dir, file := path.Split(name)
if attachment {
c.response.Header().Set(ContentDisposition, "attachment; filename="+file)
}
fi, _ := file.Stat()
c.response.Header().Set(ContentDisposition, "attachment; filename="+fi.Name())
_, err = io.Copy(c.response, file)
return err
return serveFile(dir, file, c)
}

// NoContent sends a response with no body and a status code.
Expand Down
12 changes: 11 additions & 1 deletion context_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -141,12 +141,22 @@ func TestContext(t *testing.T) {
// File
rec = httptest.NewRecorder()
c = NewContext(req, NewResponse(rec), New())
err = c.File("test/fixture/walle.png")
err = c.File("test/fixture/walle.png", false)
if assert.NoError(t, err) {
assert.Equal(t, http.StatusOK, rec.Code)
assert.Equal(t, 219885, rec.Body.Len())
}

// File as attachment
rec = httptest.NewRecorder()
c = NewContext(req, NewResponse(rec), New())
err = c.File("test/fixture/walle.png", true)
if assert.NoError(t, err) {
assert.Equal(t, http.StatusOK, rec.Code)
assert.Equal(t, rec.Header().Get(ContentDisposition), "attachment; filename=walle.png")
assert.Equal(t, 219885, rec.Body.Len())
}

// NoContent
rec = httptest.NewRecorder()
c = NewContext(req, NewResponse(rec), New())
Expand Down
9 changes: 9 additions & 0 deletions website/docs/guide.md
Original file line number Diff line number Diff line change
Expand Up @@ -368,6 +368,15 @@ Context.String(code int, s string) error

Sends a text/plain HTTP response with status code.

### File

```go
Context.File(name string, attachment bool) error
```

File sends a response with the content of the file. If attachment is true, the client
is prompted to save the file.

### Static files

`Echo.Static(path, root string)` serves static files. For example, code below serves
Expand Down

0 comments on commit 2450450

Please sign in to comment.