aboutsummaryrefslogtreecommitdiff
path: root/server.go
diff options
context:
space:
mode:
authorSimon Ser <contact@emersion.fr>2019-12-03 17:31:53 +0100
committerSimon Ser <contact@emersion.fr>2019-12-03 17:31:53 +0100
commita4729060bedd45481726861c491d5061e90ffefa (patch)
treed9ee85915912c2186162e5ae737f89d3a5751549 /server.go
parent48d6d5d227a4d55d80f9f2a74c1242cafafab7ab (diff)
downloadalps-a4729060bedd45481726861c491d5061e90ffefa.tar.gz
alps-a4729060bedd45481726861c491d5061e90ffefa.zip
Escape mailbox names in URLs
Closes: https://todo.sr.ht/~sircmpwn/koushin/14
Diffstat (limited to 'server.go')
-rw-r--r--server.go12
1 files changed, 10 insertions, 2 deletions
diff --git a/server.go b/server.go
index 6dd7246..3f521e7 100644
--- a/server.go
+++ b/server.go
@@ -142,7 +142,10 @@ func handleLogin(ectx echo.Context) error {
}
func handleGetPart(ctx *context, raw bool) error {
- mboxName := ctx.Param("mbox")
+ mboxName, err := url.PathUnescape(ctx.Param("mbox"))
+ if err != nil {
+ return echo.NewHTTPError(http.StatusBadRequest, err)
+ }
uid, err := parseUid(ctx.Param("uid"))
if err != nil {
return echo.NewHTTPError(http.StatusBadRequest, err)
@@ -312,6 +315,11 @@ func New(imapURL, smtpURL string) *echo.Echo {
e.GET("/mailbox/:mbox", func(ectx echo.Context) error {
ctx := ectx.(*context)
+ mboxName, err := url.PathUnescape(ctx.Param("mbox"))
+ if err != nil {
+ return echo.NewHTTPError(http.StatusBadRequest, err)
+ }
+
var mailboxes []*imap.MailboxInfo
var msgs []imapMessage
var mbox *imap.MailboxStatus
@@ -320,7 +328,7 @@ func New(imapURL, smtpURL string) *echo.Echo {
if mailboxes, err = listMailboxes(c); err != nil {
return err
}
- if msgs, err = listMessages(c, ctx.Param("mbox")); err != nil {
+ if msgs, err = listMessages(c, mboxName); err != nil {
return err
}
mbox = c.Mailbox()